mirror of
https://github.com/golang/go
synced 2024-11-21 19:14:44 -07:00
go/build: fixes for windows paths
R=golang-dev, mattn.jp, adg CC=golang-dev https://golang.org/cl/4746047
This commit is contained in:
parent
98f5fc5e86
commit
42effdf096
@ -10,7 +10,6 @@ import (
|
||||
"os"
|
||||
"path/filepath"
|
||||
"runtime"
|
||||
"strings"
|
||||
)
|
||||
|
||||
// Path is a validated list of Trees derived from $GOROOT and $GOPATH at init.
|
||||
@ -96,7 +95,7 @@ func FindTree(path string) (tree *Tree, pkg string, err os.Error) {
|
||||
}
|
||||
for _, t := range Path {
|
||||
tpath := t.SrcDir() + string(filepath.Separator)
|
||||
if !strings.HasPrefix(path, tpath) {
|
||||
if !filepath.HasPrefix(path, tpath) {
|
||||
continue
|
||||
}
|
||||
tree = t
|
||||
@ -123,9 +122,13 @@ func FindTree(path string) (tree *Tree, pkg string, err os.Error) {
|
||||
}
|
||||
|
||||
// isLocalPath returns whether the given path is local (/foo ./foo ../foo . ..)
|
||||
// Windows paths that starts with drive letter (c:\foo c:foo) are considered local.
|
||||
func isLocalPath(s string) bool {
|
||||
const sep = string(filepath.Separator)
|
||||
return strings.HasPrefix(s, sep) || strings.HasPrefix(s, "."+sep) || strings.HasPrefix(s, ".."+sep) || s == "." || s == ".."
|
||||
return s == "." || s == ".." ||
|
||||
filepath.HasPrefix(s, sep) ||
|
||||
filepath.HasPrefix(s, "."+sep) || filepath.HasPrefix(s, ".."+sep) ||
|
||||
filepath.VolumeName(s) != ""
|
||||
}
|
||||
|
||||
var (
|
||||
|
@ -38,7 +38,7 @@ const (
|
||||
// Getting Dot-Dot right,''
|
||||
// http://plan9.bell-labs.com/sys/doc/lexnames.html
|
||||
func Clean(path string) string {
|
||||
vol := volumeName(path)
|
||||
vol := VolumeName(path)
|
||||
path = path[len(vol):]
|
||||
if path == "" {
|
||||
return vol + "."
|
||||
|
@ -11,8 +11,13 @@ func IsAbs(path string) bool {
|
||||
return strings.HasPrefix(path, "/") || strings.HasPrefix(path, "#")
|
||||
}
|
||||
|
||||
// volumeName returns the leading volume name on Windows.
|
||||
// VolumeName returns the leading volume name on Windows.
|
||||
// It returns "" elsewhere
|
||||
func volumeName(path string) string {
|
||||
func VolumeName(path string) string {
|
||||
return ""
|
||||
}
|
||||
|
||||
// HasPrefix tests whether the path p begins with prefix.
|
||||
func HasPrefix(p, prefix string) bool {
|
||||
return strings.HasPrefix(p, prefix)
|
||||
}
|
||||
|
@ -11,8 +11,13 @@ func IsAbs(path string) bool {
|
||||
return strings.HasPrefix(path, "/")
|
||||
}
|
||||
|
||||
// volumeName returns the leading volume name on Windows.
|
||||
// VolumeName returns the leading volume name on Windows.
|
||||
// It returns "" elsewhere.
|
||||
func volumeName(path string) string {
|
||||
func VolumeName(path string) string {
|
||||
return ""
|
||||
}
|
||||
|
||||
// HasPrefix tests whether the path p begins with prefix.
|
||||
func HasPrefix(p, prefix string) bool {
|
||||
return strings.HasPrefix(p, prefix)
|
||||
}
|
||||
|
@ -4,9 +4,11 @@
|
||||
|
||||
package filepath
|
||||
|
||||
import "strings"
|
||||
|
||||
// IsAbs returns true if the path is absolute.
|
||||
func IsAbs(path string) (b bool) {
|
||||
v := volumeName(path)
|
||||
v := VolumeName(path)
|
||||
if v == "" {
|
||||
return false
|
||||
}
|
||||
@ -17,9 +19,10 @@ func IsAbs(path string) (b bool) {
|
||||
return path[0] == '/' || path[0] == '\\'
|
||||
}
|
||||
|
||||
// volumeName return leading volume name.
|
||||
// If given "C:\foo\bar", return "C:" on windows.
|
||||
func volumeName(path string) (v string) {
|
||||
// VolumeName returns leading volume name.
|
||||
// Given "C:\foo\bar" it returns "C:" under windows.
|
||||
// On other platforms it returns "".
|
||||
func VolumeName(path string) (v string) {
|
||||
if len(path) < 2 {
|
||||
return ""
|
||||
}
|
||||
@ -32,3 +35,12 @@ func volumeName(path string) (v string) {
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
// HasPrefix tests whether the path p begins with prefix.
|
||||
// It ignores case while comparing.
|
||||
func HasPrefix(p, prefix string) bool {
|
||||
if strings.HasPrefix(p, prefix) {
|
||||
return true
|
||||
}
|
||||
return strings.HasPrefix(strings.ToLower(p), strings.ToLower(prefix))
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user