Skip to content

Commit 1a91bb9

Browse files
rscgopherbot
authored andcommitted
[release-branch.go1.20] cmd/go: do not index std as a module in modcache
We do not index std as a whole module ever. When working in the main Go repo, files in package change often, so we don't want to pay the cost of reindexing all of std when what we really need is just to reindex strings. Per-package indexing works better for that case. When using a released Go toolchain, we don't have to worry about the whole module changing, but if we switch to whole-module indexing at that point, we have the potential for bugs that only happen in released toolchains. Probably not worth the risk. For similar reasons, we don't index the current work module as a whole module (individual packages are changing), so we use the heuristic that we only do whole-module indexing in the module cache. The new toolchain modules live in the module cache, though, and our heuristic was causing whole-module indexing for them. As predicted, enabling whole-module indexing for std when it's completely untested does in fact lead to bugs (a very minor one). This CL turns off whole-module indexing for std even when it is in the module cache, to bring toolchain module behavior back in line with the other ways to run toolchains. Updates #57001. For #61873. Change-Id: I5012dc713f566846eb4b2848facc7f75bc956eb9 Reviewed-on: https://go-review.googlesource.com/c/go/+/504119 TryBot-Result: Gopher Robot <[email protected]> Reviewed-by: Bryan Mills <[email protected]> Auto-Submit: Russ Cox <[email protected]> Run-TryBot: Russ Cox <[email protected]> (cherry picked from commit a7b1793) Reviewed-on: https://go-review.googlesource.com/c/go/+/518415 Reviewed-by: Russ Cox <[email protected]> Run-TryBot: Bryan Mills <[email protected]> Auto-Submit: Dmitri Shuralyov <[email protected]>
1 parent ede3e27 commit 1a91bb9

File tree

1 file changed

+1
-1
lines changed
  • src/cmd/go/internal/modindex

1 file changed

+1
-1
lines changed

src/cmd/go/internal/modindex/read.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -162,7 +162,7 @@ func GetModule(modroot string) (*Module, error) {
162162
return nil, errNotFromModuleCache
163163
}
164164
modroot = filepath.Clean(modroot)
165-
if !str.HasFilePathPrefix(modroot, cfg.GOMODCACHE) {
165+
if str.HasFilePathPrefix(modroot, cfg.GOROOTsrc) || !str.HasFilePathPrefix(modroot, cfg.GOMODCACHE) {
166166
return nil, errNotFromModuleCache
167167
}
168168
return openIndexModule(modroot, true)

0 commit comments

Comments
 (0)