go/src
Benjamin Prosnitz a106defdda hex: fix panic in Decode when len(src) > 2*len(dst)
hex.Decode never checks the length of dst and triggers a panic
if there are insufficient bytes in the slice.

There isn't document on what the behavior *should* be in this case.
Two possibilities:
1. Error dst has insufficient space (as done in this change)
2. Reduce the length of the decode to min(dst, src)

Option 1 was chosen because it seems the least surprising or
subtle.

Change-Id: I3bf029e3d928202de716830434285e3c165f26dd
Reviewed-on: https://go-review.googlesource.com/c/go/+/461958
Reviewed-by: Ian Lance Taylor <iant@google.com>
Auto-Submit: Ian Lance Taylor <iant@google.com>
Reviewed-by: Bryan Mills <bcmills@google.com>
Run-TryBot: Ian Lance Taylor <iant@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Benjamin Prosnitz <bprosnitz@gmail.com>
Run-TryBot: Ian Lance Taylor <iant@golang.org>
2023-01-27 15:28:30 +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 go/types, types2: move tparamIndex from unify.go into infer.go 2023-01-27 14:34:03 +00:00
compress all: add missing periods in comments 2022-11-18 17:59:44 +00:00
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 database/sql: add a missing period to end of sentence in Rows.Scan docs 2022-11-14 18:35:41 +00:00
debug all: fix typos in go file comments 2023-01-20 03:27:26 +00:00
embed
encoding hex: fix panic in Decode when len(src) > 2*len(dst) 2023-01-27 15:28:30 +00:00
errors errors: move example functions into example_test file 2023-01-20 21:55:10 +00:00
expvar expvar: convert f to atomic type 2022-11-10 05:17:55 +00:00
flag
fmt fmt: add uintptr test case 2022-11-23 22:49:51 +00:00
go go/types, types2: move tparamIndex from unify.go into infer.go 2023-01-27 14:34:03 +00:00
hash runtime,hash/maphash: eliminate maphash torture test for -race 2022-12-01 19:24:55 +00:00
html all: add missing periods in comments 2022-11-18 17:59:44 +00:00
image all: fix a few function names on comments 2022-11-03 15:17:11 +00:00
index/suffixarray
internal internal/syscall/unix: use atomic.Bool for getrandomUnsupported 2023-01-26 21:54:02 +00:00
io io/fs: clean up test helper functions 2022-11-18 15:21:18 +00:00
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: fix missing word in ServeMux doc 2023-01-27 00:42:16 +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 plugin: add warning 2022-11-23 03:37:22 +00:00
reflect internal/abi,runtime: refactor map constants into one place 2023-01-23 15:51:32 +00:00
regexp all: add missing periods in comments 2022-11-18 17:59:44 +00:00
runtime runtime/debug: expand fuzz corpus for FuzzParseBuildInfoRoundTrip 2023-01-26 23:37:45 +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 all: fix typos in go file comments 2023-01-09 15:34:31 +00:00
text all: fix function names in comments 2022-11-04 22:36:12 +00:00
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 unsafe: add docs for SliceData, String, and StringData 2022-11-09 22:11:13 +00:00
vendor all: update vendored golang.org/x/net 2022-12-07 00:51:44 +00:00
Make.dist
README.vendor README.vendor: minor updates 2023-01-03 20:31:59 +00:00
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 all: update vendored golang.org/x/net 2022-12-07 00:51:44 +00:00
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'.