go/src
Bryan C. Mills c611ef2860 cmd/dist: restore the original GOCACHE before building std and cmd
The user is likely to run other commands that need these libraries
immediately after they are built.

For #57734.
Updates #56889.

Change-Id: I2a1a234e6031d85f017ee692ea1ace8c6e0e7355
Reviewed-on: https://go-review.googlesource.com/c/go/+/452679
Run-TryBot: Bryan Mills <bcmills@google.com>
Auto-Submit: Bryan Mills <bcmills@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Russ Cox <rsc@golang.org>
2023-01-26 23:32:05 +00:00
..
archive archive/zip: use base offset 0 if it has a valid entry 2023-01-20 01:04:11 +00:00
arena
bufio
builtin runtime: replace panic(nil) with panic(new(runtime.PanicNilError)) 2023-01-19 22:21:50 +00:00
bytes bytes, strings: add ContainsFunc 2023-01-24 22:06:45 +00:00
cmd cmd/dist: restore the original GOCACHE before building std and cmd 2023-01-26 23:32:05 +00:00
compress
container
context context: eliminate arbitrary timeouts in examples 2023-01-25 21:12:45 +00:00
crypto crypto/rand, internal/syscall/unix: add support for getrandom on NetBSD ≥ 10.0 2023-01-26 10:15:35 +00:00
database/sql
debug all: fix typos in go file comments 2023-01-20 03:27:26 +00:00
embed
encoding encoding/gob: slightly simplify init code 2023-01-24 20:07:49 +00:00
errors errors: move example functions into example_test file 2023-01-20 21:55:10 +00:00
expvar
flag
fmt
go go/types, types2: remove misleading example from comment 2023-01-26 19:45:22 +00:00
hash
html
image
index/suffixarray
internal internal/syscall/unix: use atomic.Bool for getrandomUnsupported 2023-01-26 21:54:02 +00:00
io
log
math math: handle int64 overflows for odd integer exponents in Pow(-0, y) 2023-01-24 19:10:58 +00:00
mime
net net/http: keep sensitive headers on redirects to the same host 2023-01-26 00:52:05 +00:00
os os: eliminate arbitrary timeout in testClosewithBlockingRead 2023-01-25 20:45:53 +00:00
path os: make Lstat for symlinks on Windows consistent with POSIX 2023-01-25 16:38:21 +00:00
plugin
reflect internal/abi,runtime: refactor map constants into one place 2023-01-23 15:51:32 +00:00
regexp
runtime Revert "runtime: use explicit NOFRAME on darwin/amd64" 2023-01-26 15:41:28 +00:00
sort
strconv
strings bytes, strings: add ContainsFunc 2023-01-24 22:06:45 +00:00
sync sync: document memory model for Swap/CompareAnd{Swap,Delete} in Map 2023-01-20 19:38:29 +00:00
syscall syscall: clean up variable declarations in forkAndExecInChild 2023-01-25 03:23:11 +00:00
testdata
testing
text
time time: no need to wrap error with errors.New 2023-01-20 01:07:08 +00:00
unicode utf16: reduce utf16.Decode allocations 2023-01-23 20:59:01 +00:00
unsafe
vendor
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash cmd/dist: add map of broken ports and -force flag 2023-01-20 17:52:26 +00:00
buildall.bash
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod src: update go.mod files to go 1.21 2023-01-17 23:10:41 +00:00
go.sum
make.bash make.bash, make.rc: fix GOROOT detection when GOEXPERIMENT is set 2023-01-17 22:30:56 +00:00
make.bat make.bat: support existing toolchain paths with spaces 2023-01-19 20:43:23 +00:00
make.rc make.bash, make.rc: fix GOROOT detection when GOEXPERIMENT is set 2023-01-17 22:30:56 +00:00
race.bash
race.bat
run.bash cmd/dist: remove hardcoded timeout scale for arm and mips{,le,64,64le} 2023-01-20 17:47:35 +00:00
run.bat
run.rc

README.vendor

Vendoring in std and cmd
========================

The Go command maintains copies of external packages needed by the
standard library in the src/vendor and src/cmd/vendor directories.

There are two modules, std and cmd, defined in src/go.mod and
src/cmd/go.mod. When a package outside std or cmd is imported
by a package inside std or cmd, the import path is interpreted
as if it had a "vendor/" prefix. For example, within "crypto/tls",
an import of "golang.org/x/crypto/cryptobyte" resolves to
"vendor/golang.org/x/crypto/cryptobyte". When a package with the
same path is imported from a package outside std or cmd, it will
be resolved normally. Consequently, a binary may be built with two
copies of a package at different versions if the package is
imported normally and vendored by the standard library.

Vendored packages are internally renamed with a "vendor/" prefix
to preserve the invariant that all packages have distinct paths.
This is necessary to avoid compiler and linker conflicts. Adding
a "vendor/" prefix also maintains the invariant that standard
library packages begin with a dotless path element.

The module requirements of std and cmd do not influence version
selection in other modules. They are only considered when running
module commands like 'go get' and 'go mod vendor' from a directory
in GOROOT/src.

Maintaining vendor directories
==============================

Before updating vendor directories, ensure that module mode is enabled.
Make sure that GO111MODULE is not set in the environment, or that it is
set to 'on' or 'auto'.

Requirements may be added, updated, and removed with 'go get'.
The vendor directory may be updated with 'go mod vendor'.
A typical sequence might be:

    cd src
    go get golang.org/x/net@latest
    go mod tidy
    go mod vendor

Use caution when passing '-u' to 'go get'. The '-u' flag updates
modules providing all transitively imported packages, not only
the module providing the target package.

Note that 'go mod vendor' only copies packages that are transitively
imported by packages in the current module. If a new package is needed,
it should be imported before running 'go mod vendor'.