slog: change nopc variant from build tag to internal global

During benchmarking, we want to skip the call to runtime.Callers so we
can measure the speedup without it.

Previously we used the build tag `nopc` for this. But build tags are,
in a sense, exported API: anyone can rebuild with a particular tag. In
fact, at least one user believed that `nopc` was a supported feature
of slog.

This CL switches to using a global boolean variable. (The extra time
involved in checking the global is negligible.) To hide the variable
while letting both the slog and benchmarks packages access it,
we put it in an internal package.

Change-Id: I48c133e53c63cd36cc802bbd5f858b74cc19b9e8
Reviewed-on: https://go-review.googlesource.com/c/exp/+/473335
TryBot-Result: Gopher Robot <gobot@golang.org>
Run-TryBot: Jonathan Amsterdam <jba@google.com>
Reviewed-by: Alan Donovan <adonovan@google.com>
9 files changed
tree: e7373688bab2cbf5ab12a0e9548fc6bc20ac967d
  1. apidiff/
  2. cmd/
  3. constraints/
  4. devtools/
  5. ebnf/
  6. ebnflint/
  7. errors/
  8. event/
  9. inotify/
  10. io/
  11. jsonrpc2/
  12. maps/
  13. mmap/
  14. rand/
  15. shiny/
  16. shootout/
  17. slices/
  18. slog/
  19. sumdb/
  20. typeparams/
  21. utf8string/
  22. .gitattributes
  23. .gitignore
  24. codereview.cfg
  25. CONTRIBUTING.md
  26. go.mod
  27. go.sum
  28. LICENSE
  29. PATENTS
  30. README.md
README.md

exp

PkgGoDev

This subrepository holds experimental and deprecated (in the old directory) packages.

The idea for this subrepository originated as the pkg/exp directory of the main repository, but its presence there made it unavailable to users of the binary downloads of the Go installation. The subrepository has therefore been created to make it possible to go get these packages.

Warning: Packages here are experimental and unreliable. Some may one day be promoted to the main repository or other subrepository, or they may be modified arbitrarily or even disappear altogether.

In short, code in this subrepository is not subject to the Go 1 compatibility promise. (No subrepo is, but the promise is even more likely to be violated by go.exp than the others.)

Caveat emptor.