From: Robert Griesemer Date: Tue, 18 Oct 2011 17:28:30 +0000 (-0700) Subject: godoc: fix ToAbsolute mapping X-Git-Tag: weekly.2011-10-18~19 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=0e4d1c3e2cae6474a0b01a79c37b440817cbfa5f;p=gostls13.git godoc: fix ToAbsolute mapping The implementation of splitFirst was broken; splitFirst("foo/") must be the same as splitFirst("foo"). As a result, ToAbsolute could be simplified, and as a side effect this fixes a long-standing bug. Thanks to Luca Greco for doing the investigation. Fixes #1157. R=rsc CC=golang-dev https://golang.org/cl/5278050 --- diff --git a/src/cmd/godoc/mapping.go b/src/cmd/godoc/mapping.go index 51f23ab985..89e531e2f3 100644 --- a/src/cmd/godoc/mapping.go +++ b/src/cmd/godoc/mapping.go @@ -139,13 +139,18 @@ func (m *Mapping) Fprint(w io.Writer) { } } +// splitFirst splits a path at the first path separator and returns +// the path's head (the top-most directory specified by the path) and +// its tail (the rest of the path). If there is no path separator, +// splitFirst returns path as head, and the the empty string as tail. +// Specifically, splitFirst("foo") == splitFirst("foo/"). +// func splitFirst(path string) (head, tail string) { - i := strings.Index(path, string(filepath.Separator)) - if i > 0 { + if i := strings.Index(path, string(filepath.Separator)); i > 0 { // 0 < i < len(path) return path[0:i], path[i+1:] } - return "", path + return path, "" } // ToAbsolute maps a slash-separated relative path to an absolute filesystem @@ -156,20 +161,14 @@ func (m *Mapping) ToAbsolute(spath string) string { fpath := filepath.FromSlash(spath) prefix, tail := splitFirst(fpath) for _, e := range m.list { - switch { - case e.prefix == prefix: - // use tail - case e.prefix == "": - tail = fpath - default: - continue // no match - } - abspath := filepath.Join(e.path, tail) - if _, err := fs.Stat(abspath); err == nil { - return abspath + if e.prefix == prefix { + // found potential mapping + abspath := filepath.Join(e.path, tail) + if _, err := fs.Stat(abspath); err == nil { + return abspath + } } } - return "" // no match }