diff options
| author | Ondřej Surý <ondrej@sury.org> | 2011-06-03 11:31:24 +0200 | 
|---|---|---|
| committer | Ondřej Surý <ondrej@sury.org> | 2011-06-03 11:38:02 +0200 | 
| commit | 13f4fcd5bf09c70942b6c85a2b919ffa1ca0c6a8 (patch) | |
| tree | 717e1ceeef3a60af29e7897c7629d1502b797838 /src/pkg/exec/lp_unix.go | |
| parent | 6bf52070ef1028f7fcc98fad1e73795a7efd7ce7 (diff) | |
| download | golang-13f4fcd5bf09c70942b6c85a2b919ffa1ca0c6a8.tar.gz | |
Imported Upstream version 2011.06.02
Diffstat (limited to 'src/pkg/exec/lp_unix.go')
| -rw-r--r-- | src/pkg/exec/lp_unix.go | 21 | 
1 files changed, 14 insertions, 7 deletions
| diff --git a/src/pkg/exec/lp_unix.go b/src/pkg/exec/lp_unix.go index 44f84347b..3fc3be832 100644 --- a/src/pkg/exec/lp_unix.go +++ b/src/pkg/exec/lp_unix.go @@ -9,12 +9,18 @@ import (  	"strings"  ) -func canExec(file string) bool { +// ErrNotFound is the error resulting if a path search failed to find an executable file. +var ErrNotFound = os.ErrorString("executable file not found in $PATH") + +func findExecutable(file string) os.Error {  	d, err := os.Stat(file)  	if err != nil { -		return false +		return err +	} +	if d.IsRegular() && d.Permission()&0111 != 0 { +		return nil  	} -	return d.IsRegular() && d.Permission()&0111 != 0 +	return os.EPERM  }  // LookPath searches for an executable binary named file @@ -26,10 +32,11 @@ func LookPath(file string) (string, os.Error) {  	// but that would not match all the Unix shells.  	if strings.Contains(file, "/") { -		if canExec(file) { +		err := findExecutable(file) +		if err == nil {  			return file, nil  		} -		return "", &PathError{file} +		return "", &Error{file, err}  	}  	pathenv := os.Getenv("PATH")  	for _, dir := range strings.Split(pathenv, ":", -1) { @@ -37,9 +44,9 @@ func LookPath(file string) (string, os.Error) {  			// Unix shell semantics: path element "" means "."  			dir = "."  		} -		if canExec(dir + "/" + file) { +		if err := findExecutable(dir + "/" + file); err == nil {  			return dir + "/" + file, nil  		}  	} -	return "", &PathError{file} +	return "", &Error{file, ErrNotFound}  } | 
