1
0
mirror of https://github.com/golang/go synced 2024-11-19 10:04:56 -07:00
go/src/os/executable_solaris.go
Shenghou Ma 2fc67e71af os: add Executable() (string, error)
// Executable returns the path name for the executable that started
// the current process. There is no guarantee that the path is still
// pointing to the correct executable. If a symlink was used to start
// the process, depending on the operating system, the result might
// be the symlink or the path it pointed to. If a stable result is
// needed, path/filepath.EvalSymlinks might help.
//
// Executable returns an absolute path unless an error occurred.
//
// The main use case is finding resources located relative to an
// executable.
//
// Executable is not supported on nacl or OpenBSD (unless procfs is
// mounted.)
func Executable() (string, error) {
	return executable()
}

Fixes #12773.

Change-Id: I469738d905b12f0b633ea4d88954f8859227a88c
Reviewed-on: https://go-review.googlesource.com/16551
Run-TryBot: Minux Ma <minux@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
2016-11-07 22:34:48 +00:00

28 lines
569 B
Go

// Copyright 2016 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package os
import "syscall"
var initCwd, initCwdErr = Getwd()
func executable() (string, error) {
path, err := syscall.Getexecname()
if err != nil {
return path, err
}
if len(path) > 0 && path[0] != '/' {
if initCwdErr != nil {
return path, initCwdErr
}
if len(path) > 2 && path[0:2] == "./" {
// skip "./"
path = path[2:]
}
return initCwd + "/" + path, nil
}
return path, nil
}