go/src
Sameer Ajmani 5b42f89e39 context: add APIs for writing and reading cancelation cause
Extend the context package to allow users to specify why a context was
canceled in the form of an error, the "cause". Users write the cause
by calling WithCancelCause to construct a derived context, then
calling cancel(cause) to cancel the context with the provided cause.
Users retrieve the cause by calling context.Cause(ctx), which returns
the cause of the first cancelation for ctx or any of its parents.

The cause is implemented as a field of cancelCtx, since only cancelCtx
can be canceled. Calling cancel copies the cause to all derived (child)
cancelCtxs. Calling Cause(ctx) finds the nearest parent cancelCtx by
looking up the context value keyed by cancelCtxKey.

API changes:
+pkg context, func Cause(Context) error
+pkg context, func WithCancelCause(Context) (Context, CancelCauseFunc)
+pkg context, type CancelCauseFunc func(error)

Fixes #26356
Fixes #51365

Change-Id: I15b62bd454c014db3f4f1498b35204451509e641
Reviewed-on: https://go-review.googlesource.com/c/go/+/375977
Reviewed-by: Damien Neil <dneil@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Run-TryBot: Sameer Ajmani <sameer@golang.org>
Auto-Submit: Sameer Ajmani <sameer@golang.org>
2022-11-08 13:51:16 +00:00
..
archive
arena
bufio
builtin
bytes
cmd cmd/asm: optimize if statement to return directly 2022-11-08 08:14:37 +00:00
compress
container
context context: add APIs for writing and reading cancelation cause 2022-11-08 13:51:16 +00:00
crypto crypto/tls: use certificate cache in client 2022-11-07 19:47:10 +00:00
database/sql
debug all: fix comment typos 2022-11-05 21:02:45 +00:00
embed
encoding all: fix comment typos 2022-11-05 21:02:45 +00:00
errors errors: add test for Join 2022-10-17 21:48:12 +00:00
expvar
flag flag: clarify that the main func at pkg.go.dev is part of a testing suite 2022-10-26 18:59:00 +00:00
fmt
go all: fix comment typos 2022-11-05 21:02:45 +00:00
hash hash/crc64: use slicing by 8 when the size is greater or equal than 2k 2022-10-27 16:52:41 +00:00
html
image all: fix a few function names on comments 2022-11-03 15:17:11 +00:00
index/suffixarray
internal internal/bytealg: add PCALIGN to indexbodyp9 function on ppc64x 2022-11-07 19:27:43 +00:00
io
log
math math/big: remove underscores from Binomial docs 2022-11-08 05:24:43 +00:00
mime
net net/http: remove redundant code 2022-11-08 03:06:55 +00:00
os all: fix function names in comments 2022-11-04 22:36:12 +00:00
path
plugin
reflect reflect: rewrite value.Equal to avoid allocations 2022-11-04 23:20:35 +00:00
regexp regexp: add ErrLarge error 2022-11-02 18:15:21 +00:00
runtime runtime: fix a few function names on comments 2022-11-07 19:48:30 +00:00
sort
strconv all: remove uses of rand.Seed 2022-10-26 16:24:57 +00:00
strings internal/bytealg: fix bug in index function for ppc64le/power9 2022-10-31 12:52:07 +00:00
sync sync/atomic: disallow type conversions of atomic.Pointer[T] 2022-11-07 21:25:12 +00:00
syscall syscall, os/exec: reject environment variables containing NULs 2022-11-01 16:40:37 +00:00
testdata
testing testing: Document RunParallel ns/op behavior 2022-11-07 10:44:33 +00:00
text all: fix function names in comments 2022-11-04 22:36:12 +00:00
time time: optimize appendInt and appendNanos 2022-10-24 19:23:32 +00:00
unicode
unsafe
vendor all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash
buildall.bash
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
go.sum all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
make.bash all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
make.bat all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
make.rc all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
race.bash
race.bat
run.bash
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.

In GOPATH mode, imports of vendored packages are resolved to these
directories following normal vendor directory logic
(see golang.org/s/go15vendor).

In module mode, std and cmd are modules (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 GO111MODULE=off is not set ('on' or 'auto' should work).

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 -d 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'.