Commit fef54b22 authored by Russ Cox's avatar Russ Cox

cmd/go: revise disallowInternal

This fixes two problems: x/internal/y/z was using parent = x/internal/y instead of x,
and hasPathPrefix only looks at /, not \ for Windows.

LGTM=bradfitz
R=bradfitz
CC=golang-codereviews
https://golang.org/cl/121280045
parent 7bcaff70
...@@ -330,16 +330,18 @@ func disallowInternal(srcDir string, p *Package, stk *importStack) *Package { ...@@ -330,16 +330,18 @@ func disallowInternal(srcDir string, p *Package, stk *importStack) *Package {
} }
// Check for "internal" element: four cases depending on begin of string and/or end of string. // Check for "internal" element: four cases depending on begin of string and/or end of string.
if p.ImportPath != "internal" && i, ok := findInternal(p.ImportPath)
!strings.HasPrefix(p.ImportPath, "internal/") && if !ok {
!strings.HasSuffix(p.ImportPath, "/internal") &&
!strings.Contains(p.ImportPath, "/internal/") {
return p return p
} }
// Internal is present. Check directory. // Internal is present.
parent := filepath.Dir(p.Dir) // Map import path back to directory corresponding to parent of internal.
if hasPathPrefix(srcDir, parent) { if i > 0 {
i-- // rewind over slash in ".../internal"
}
parent := p.Dir[:i+len(p.Dir)-len(p.ImportPath)]
if hasPathPrefix(filepath.ToSlash(srcDir), filepath.ToSlash(parent)) {
return p return p
} }
...@@ -353,6 +355,25 @@ func disallowInternal(srcDir string, p *Package, stk *importStack) *Package { ...@@ -353,6 +355,25 @@ func disallowInternal(srcDir string, p *Package, stk *importStack) *Package {
return &perr return &perr
} }
// findInternal looks for the final "internal" path element in the given import path.
// If there isn't one, findInternal returns ok=false.
// Otherwise, findInternal returns ok=true and the index of the "internal".
func findInternal(path string) (index int, ok bool) {
// Four cases, depending on internal at start/end of string or not.
// The order matters: we must return the index of the final element,
// because the final one produces the most restrictive requirement
// on the importer.
switch {
case strings.HasSuffix(path, "/internal"):
return len(path) - len("internal"), true
case strings.Contains(path, "/internal/"):
return strings.LastIndex(path, "/internal/") + 1, true
case path == "internal", strings.HasPrefix(path, "internal/"):
return 0, true
}
return 0, false
}
type targetDir int type targetDir int
const ( const (
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment