mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-18 16:44:09 -05:00
402 lines
14 KiB
Markdown
402 lines
14 KiB
Markdown
|
# Changelog
|
||
|
|
||
|
## 1.15.0 (23 Apr 2020)
|
||
|
|
||
|
Bugfixes:
|
||
|
* [#804][]: Fix handling of `Time` values out of `UnixNano` range.
|
||
|
* [#812][]: Fix `IncreaseLevel` being reset after a call to `With`.
|
||
|
|
||
|
Enhancements:
|
||
|
* [#806][]: Add `WithCaller` option to supersede the `AddCaller` option. This
|
||
|
allows disabling annotation of log entries with caller information if
|
||
|
previously enabled with `AddCaller`.
|
||
|
* [#813][]: Deprecate `NewSampler` constructor in favor of
|
||
|
`NewSamplerWithOptions` which supports a `SamplerHook` option. This option
|
||
|
adds support for monitoring sampling decisions through a hook.
|
||
|
|
||
|
Thanks to @danielbprice for their contributions to this release.
|
||
|
|
||
|
## 1.14.1 (14 Mar 2020)
|
||
|
|
||
|
Bugfixes:
|
||
|
* [#791][]: Fix panic on attempting to build a logger with an invalid Config.
|
||
|
* [#795][]: Vendoring Zap with `go mod vendor` no longer includes Zap's
|
||
|
development-time dependencies.
|
||
|
* [#799][]: Fix issue introduced in 1.14.0 that caused invalid JSON output to
|
||
|
be generated for arrays of `time.Time` objects when using string-based time
|
||
|
formats.
|
||
|
|
||
|
Thanks to @YashishDua for their contributions to this release.
|
||
|
|
||
|
## 1.14.0 (20 Feb 2020)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#771][]: Optimize calls for disabled log levels.
|
||
|
* [#773][]: Add millisecond duration encoder.
|
||
|
* [#775][]: Add option to increase the level of a logger.
|
||
|
* [#786][]: Optimize time formatters using `Time.AppendFormat` where possible.
|
||
|
|
||
|
Thanks to @caibirdme for their contributions to this release.
|
||
|
|
||
|
## 1.13.0 (13 Nov 2019)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#758][]: Add `Intp`, `Stringp`, and other similar `*p` field constructors
|
||
|
to log pointers to primitives with support for `nil` values.
|
||
|
|
||
|
Thanks to @jbizzle for their contributions to this release.
|
||
|
|
||
|
## 1.12.0 (29 Oct 2019)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#751][]: Migrate to Go modules.
|
||
|
|
||
|
## 1.11.0 (21 Oct 2019)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#725][]: Add `zapcore.OmitKey` to omit keys in an `EncoderConfig`.
|
||
|
* [#736][]: Add `RFC3339` and `RFC3339Nano` time encoders.
|
||
|
|
||
|
Thanks to @juicemia, @uhthomas for their contributions to this release.
|
||
|
|
||
|
## 1.10.0 (29 Apr 2019)
|
||
|
|
||
|
Bugfixes:
|
||
|
* [#657][]: Fix `MapObjectEncoder.AppendByteString` not adding value as a
|
||
|
string.
|
||
|
* [#706][]: Fix incorrect call depth to determine caller in Go 1.12.
|
||
|
|
||
|
Enhancements:
|
||
|
* [#610][]: Add `zaptest.WrapOptions` to wrap `zap.Option` for creating test
|
||
|
loggers.
|
||
|
* [#675][]: Don't panic when encoding a String field.
|
||
|
* [#704][]: Disable HTML escaping for JSON objects encoded using the
|
||
|
reflect-based encoder.
|
||
|
|
||
|
Thanks to @iaroslav-ciupin, @lelenanam, @joa, @NWilson for their contributions
|
||
|
to this release.
|
||
|
|
||
|
## v1.9.1 (06 Aug 2018)
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#614][]: MapObjectEncoder should not ignore empty slices.
|
||
|
|
||
|
## v1.9.0 (19 Jul 2018)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#602][]: Reduce number of allocations when logging with reflection.
|
||
|
* [#572][], [#606][]: Expose a registry for third-party logging sinks.
|
||
|
|
||
|
Thanks to @nfarah86, @AlekSi, @JeanMertz, @philippgille, @etsangsplk, and
|
||
|
@dimroc for their contributions to this release.
|
||
|
|
||
|
## v1.8.0 (13 Apr 2018)
|
||
|
|
||
|
Enhancements:
|
||
|
* [#508][]: Make log level configurable when redirecting the standard
|
||
|
library's logger.
|
||
|
* [#518][]: Add a logger that writes to a `*testing.TB`.
|
||
|
* [#577][]: Add a top-level alias for `zapcore.Field` to clean up GoDoc.
|
||
|
|
||
|
Bugfixes:
|
||
|
* [#574][]: Add a missing import comment to `go.uber.org/zap/buffer`.
|
||
|
|
||
|
Thanks to @DiSiqueira and @djui for their contributions to this release.
|
||
|
|
||
|
## v1.7.1 (25 Sep 2017)
|
||
|
|
||
|
Bugfixes:
|
||
|
* [#504][]: Store strings when using AddByteString with the map encoder.
|
||
|
|
||
|
## v1.7.0 (21 Sep 2017)
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#487][]: Add `NewStdLogAt`, which extends `NewStdLog` by allowing the user
|
||
|
to specify the level of the logged messages.
|
||
|
|
||
|
## v1.6.0 (30 Aug 2017)
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#491][]: Omit zap stack frames from stacktraces.
|
||
|
* [#490][]: Add a `ContextMap` method to observer logs for simpler
|
||
|
field validation in tests.
|
||
|
|
||
|
## v1.5.0 (22 Jul 2017)
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#460][] and [#470][]: Support errors produced by `go.uber.org/multierr`.
|
||
|
* [#465][]: Support user-supplied encoders for logger names.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#477][]: Fix a bug that incorrectly truncated deep stacktraces.
|
||
|
|
||
|
Thanks to @richard-tunein and @pavius for their contributions to this release.
|
||
|
|
||
|
## v1.4.1 (08 Jun 2017)
|
||
|
|
||
|
This release fixes two bugs.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#435][]: Support a variety of case conventions when unmarshaling levels.
|
||
|
* [#444][]: Fix a panic in the observer.
|
||
|
|
||
|
## v1.4.0 (12 May 2017)
|
||
|
|
||
|
This release adds a few small features and is fully backward-compatible.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#424][]: Add a `LineEnding` field to `EncoderConfig`, allowing users to
|
||
|
override the Unix-style default.
|
||
|
* [#425][]: Preserve time zones when logging times.
|
||
|
* [#431][]: Make `zap.AtomicLevel` implement `fmt.Stringer`, which makes a
|
||
|
variety of operations a bit simpler.
|
||
|
|
||
|
## v1.3.0 (25 Apr 2017)
|
||
|
|
||
|
This release adds an enhancement to zap's testing helpers as well as the
|
||
|
ability to marshal an AtomicLevel. It is fully backward-compatible.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#415][]: Add a substring-filtering helper to zap's observer. This is
|
||
|
particularly useful when testing the `SugaredLogger`.
|
||
|
* [#416][]: Make `AtomicLevel` implement `encoding.TextMarshaler`.
|
||
|
|
||
|
## v1.2.0 (13 Apr 2017)
|
||
|
|
||
|
This release adds a gRPC compatibility wrapper. It is fully backward-compatible.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#402][]: Add a `zapgrpc` package that wraps zap's Logger and implements
|
||
|
`grpclog.Logger`.
|
||
|
|
||
|
## v1.1.0 (31 Mar 2017)
|
||
|
|
||
|
This release fixes two bugs and adds some enhancements to zap's testing helpers.
|
||
|
It is fully backward-compatible.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#385][]: Fix caller path trimming on Windows.
|
||
|
* [#396][]: Fix a panic when attempting to use non-existent directories with
|
||
|
zap's configuration struct.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#386][]: Add filtering helpers to zaptest's observing logger.
|
||
|
|
||
|
Thanks to @moitias for contributing to this release.
|
||
|
|
||
|
## v1.0.0 (14 Mar 2017)
|
||
|
|
||
|
This is zap's first stable release. All exported APIs are now final, and no
|
||
|
further breaking changes will be made in the 1.x release series. Anyone using a
|
||
|
semver-aware dependency manager should now pin to `^1`.
|
||
|
|
||
|
Breaking changes:
|
||
|
|
||
|
* [#366][]: Add byte-oriented APIs to encoders to log UTF-8 encoded text without
|
||
|
casting from `[]byte` to `string`.
|
||
|
* [#364][]: To support buffering outputs, add `Sync` methods to `zapcore.Core`,
|
||
|
`zap.Logger`, and `zap.SugaredLogger`.
|
||
|
* [#371][]: Rename the `testutils` package to `zaptest`, which is less likely to
|
||
|
clash with other testing helpers.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#362][]: Make the ISO8601 time formatters fixed-width, which is friendlier
|
||
|
for tab-separated console output.
|
||
|
* [#369][]: Remove the automatic locks in `zapcore.NewCore`, which allows zap to
|
||
|
work with concurrency-safe `WriteSyncer` implementations.
|
||
|
* [#347][]: Stop reporting errors when trying to `fsync` standard out on Linux
|
||
|
systems.
|
||
|
* [#373][]: Report the correct caller from zap's standard library
|
||
|
interoperability wrappers.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#348][]: Add a registry allowing third-party encodings to work with zap's
|
||
|
built-in `Config`.
|
||
|
* [#327][]: Make the representation of logger callers configurable (like times,
|
||
|
levels, and durations).
|
||
|
* [#376][]: Allow third-party encoders to use their own buffer pools, which
|
||
|
removes the last performance advantage that zap's encoders have over plugins.
|
||
|
* [#346][]: Add `CombineWriteSyncers`, a convenience function to tee multiple
|
||
|
`WriteSyncer`s and lock the result.
|
||
|
* [#365][]: Make zap's stacktraces compatible with mid-stack inlining (coming in
|
||
|
Go 1.9).
|
||
|
* [#372][]: Export zap's observing logger as `zaptest/observer`. This makes it
|
||
|
easier for particularly punctilious users to unit test their application's
|
||
|
logging.
|
||
|
|
||
|
Thanks to @suyash, @htrendev, @flisky, @Ulexus, and @skipor for their
|
||
|
contributions to this release.
|
||
|
|
||
|
## v1.0.0-rc.3 (7 Mar 2017)
|
||
|
|
||
|
This is the third release candidate for zap's stable release. There are no
|
||
|
breaking changes.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#339][]: Byte slices passed to `zap.Any` are now correctly treated as binary blobs
|
||
|
rather than `[]uint8`.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#307][]: Users can opt into colored output for log levels.
|
||
|
* [#353][]: In addition to hijacking the output of the standard library's
|
||
|
package-global logging functions, users can now construct a zap-backed
|
||
|
`log.Logger` instance.
|
||
|
* [#311][]: Frames from common runtime functions and some of zap's internal
|
||
|
machinery are now omitted from stacktraces.
|
||
|
|
||
|
Thanks to @ansel1 and @suyash for their contributions to this release.
|
||
|
|
||
|
## v1.0.0-rc.2 (21 Feb 2017)
|
||
|
|
||
|
This is the second release candidate for zap's stable release. It includes two
|
||
|
breaking changes.
|
||
|
|
||
|
Breaking changes:
|
||
|
|
||
|
* [#316][]: Zap's global loggers are now fully concurrency-safe
|
||
|
(previously, users had to ensure that `ReplaceGlobals` was called before the
|
||
|
loggers were in use). However, they must now be accessed via the `L()` and
|
||
|
`S()` functions. Users can update their projects with
|
||
|
|
||
|
```
|
||
|
gofmt -r "zap.L -> zap.L()" -w .
|
||
|
gofmt -r "zap.S -> zap.S()" -w .
|
||
|
```
|
||
|
* [#309][] and [#317][]: RC1 was mistakenly shipped with invalid
|
||
|
JSON and YAML struct tags on all config structs. This release fixes the tags
|
||
|
and adds static analysis to prevent similar bugs in the future.
|
||
|
|
||
|
Bugfixes:
|
||
|
|
||
|
* [#321][]: Redirecting the standard library's `log` output now
|
||
|
correctly reports the logger's caller.
|
||
|
|
||
|
Enhancements:
|
||
|
|
||
|
* [#325][] and [#333][]: Zap now transparently supports non-standard, rich
|
||
|
errors like those produced by `github.com/pkg/errors`.
|
||
|
* [#326][]: Though `New(nil)` continues to return a no-op logger, `NewNop()` is
|
||
|
now preferred. Users can update their projects with `gofmt -r 'zap.New(nil) ->
|
||
|
zap.NewNop()' -w .`.
|
||
|
* [#300][]: Incorrectly importing zap as `github.com/uber-go/zap` now returns a
|
||
|
more informative error.
|
||
|
|
||
|
Thanks to @skipor and @chapsuk for their contributions to this release.
|
||
|
|
||
|
## v1.0.0-rc.1 (14 Feb 2017)
|
||
|
|
||
|
This is the first release candidate for zap's stable release. There are multiple
|
||
|
breaking changes and improvements from the pre-release version. Most notably:
|
||
|
|
||
|
* **Zap's import path is now "go.uber.org/zap"** — all users will
|
||
|
need to update their code.
|
||
|
* User-facing types and functions remain in the `zap` package. Code relevant
|
||
|
largely to extension authors is now in the `zapcore` package.
|
||
|
* The `zapcore.Core` type makes it easy for third-party packages to use zap's
|
||
|
internals but provide a different user-facing API.
|
||
|
* `Logger` is now a concrete type instead of an interface.
|
||
|
* A less verbose (though slower) logging API is included by default.
|
||
|
* Package-global loggers `L` and `S` are included.
|
||
|
* A human-friendly console encoder is included.
|
||
|
* A declarative config struct allows common logger configurations to be managed
|
||
|
as configuration instead of code.
|
||
|
* Sampling is more accurate, and doesn't depend on the standard library's shared
|
||
|
timer heap.
|
||
|
|
||
|
## v0.1.0-beta.1 (6 Feb 2017)
|
||
|
|
||
|
This is a minor version, tagged to allow users to pin to the pre-1.0 APIs and
|
||
|
upgrade at their leisure. Since this is the first tagged release, there are no
|
||
|
backward compatibility concerns and all functionality is new.
|
||
|
|
||
|
Early zap adopters should pin to the 0.1.x minor version until they're ready to
|
||
|
upgrade to the upcoming stable release.
|
||
|
|
||
|
[#316]: https://github.com/uber-go/zap/pull/316
|
||
|
[#309]: https://github.com/uber-go/zap/pull/309
|
||
|
[#317]: https://github.com/uber-go/zap/pull/317
|
||
|
[#321]: https://github.com/uber-go/zap/pull/321
|
||
|
[#325]: https://github.com/uber-go/zap/pull/325
|
||
|
[#333]: https://github.com/uber-go/zap/pull/333
|
||
|
[#326]: https://github.com/uber-go/zap/pull/326
|
||
|
[#300]: https://github.com/uber-go/zap/pull/300
|
||
|
[#339]: https://github.com/uber-go/zap/pull/339
|
||
|
[#307]: https://github.com/uber-go/zap/pull/307
|
||
|
[#353]: https://github.com/uber-go/zap/pull/353
|
||
|
[#311]: https://github.com/uber-go/zap/pull/311
|
||
|
[#366]: https://github.com/uber-go/zap/pull/366
|
||
|
[#364]: https://github.com/uber-go/zap/pull/364
|
||
|
[#371]: https://github.com/uber-go/zap/pull/371
|
||
|
[#362]: https://github.com/uber-go/zap/pull/362
|
||
|
[#369]: https://github.com/uber-go/zap/pull/369
|
||
|
[#347]: https://github.com/uber-go/zap/pull/347
|
||
|
[#373]: https://github.com/uber-go/zap/pull/373
|
||
|
[#348]: https://github.com/uber-go/zap/pull/348
|
||
|
[#327]: https://github.com/uber-go/zap/pull/327
|
||
|
[#376]: https://github.com/uber-go/zap/pull/376
|
||
|
[#346]: https://github.com/uber-go/zap/pull/346
|
||
|
[#365]: https://github.com/uber-go/zap/pull/365
|
||
|
[#372]: https://github.com/uber-go/zap/pull/372
|
||
|
[#385]: https://github.com/uber-go/zap/pull/385
|
||
|
[#396]: https://github.com/uber-go/zap/pull/396
|
||
|
[#386]: https://github.com/uber-go/zap/pull/386
|
||
|
[#402]: https://github.com/uber-go/zap/pull/402
|
||
|
[#415]: https://github.com/uber-go/zap/pull/415
|
||
|
[#416]: https://github.com/uber-go/zap/pull/416
|
||
|
[#424]: https://github.com/uber-go/zap/pull/424
|
||
|
[#425]: https://github.com/uber-go/zap/pull/425
|
||
|
[#431]: https://github.com/uber-go/zap/pull/431
|
||
|
[#435]: https://github.com/uber-go/zap/pull/435
|
||
|
[#444]: https://github.com/uber-go/zap/pull/444
|
||
|
[#477]: https://github.com/uber-go/zap/pull/477
|
||
|
[#465]: https://github.com/uber-go/zap/pull/465
|
||
|
[#460]: https://github.com/uber-go/zap/pull/460
|
||
|
[#470]: https://github.com/uber-go/zap/pull/470
|
||
|
[#487]: https://github.com/uber-go/zap/pull/487
|
||
|
[#490]: https://github.com/uber-go/zap/pull/490
|
||
|
[#491]: https://github.com/uber-go/zap/pull/491
|
||
|
[#504]: https://github.com/uber-go/zap/pull/504
|
||
|
[#508]: https://github.com/uber-go/zap/pull/508
|
||
|
[#518]: https://github.com/uber-go/zap/pull/518
|
||
|
[#577]: https://github.com/uber-go/zap/pull/577
|
||
|
[#574]: https://github.com/uber-go/zap/pull/574
|
||
|
[#602]: https://github.com/uber-go/zap/pull/602
|
||
|
[#572]: https://github.com/uber-go/zap/pull/572
|
||
|
[#606]: https://github.com/uber-go/zap/pull/606
|
||
|
[#614]: https://github.com/uber-go/zap/pull/614
|
||
|
[#657]: https://github.com/uber-go/zap/pull/657
|
||
|
[#706]: https://github.com/uber-go/zap/pull/706
|
||
|
[#610]: https://github.com/uber-go/zap/pull/610
|
||
|
[#675]: https://github.com/uber-go/zap/pull/675
|
||
|
[#704]: https://github.com/uber-go/zap/pull/704
|
||
|
[#725]: https://github.com/uber-go/zap/pull/725
|
||
|
[#736]: https://github.com/uber-go/zap/pull/736
|
||
|
[#751]: https://github.com/uber-go/zap/pull/751
|
||
|
[#758]: https://github.com/uber-go/zap/pull/758
|
||
|
[#771]: https://github.com/uber-go/zap/pull/771
|
||
|
[#773]: https://github.com/uber-go/zap/pull/773
|
||
|
[#775]: https://github.com/uber-go/zap/pull/775
|
||
|
[#786]: https://github.com/uber-go/zap/pull/786
|
||
|
[#791]: https://github.com/uber-go/zap/pull/791
|
||
|
[#795]: https://github.com/uber-go/zap/pull/795
|
||
|
[#799]: https://github.com/uber-go/zap/pull/799
|
||
|
[#804]: https://github.com/uber-go/zap/pull/804
|
||
|
[#812]: https://github.com/uber-go/zap/pull/812
|
||
|
[#806]: https://github.com/uber-go/zap/pull/806
|
||
|
[#813]: https://github.com/uber-go/zap/pull/813
|