0.4.21 is a bugfix release that mainly fixes one regression from 0.4.20:
Fall back to UTC in case no timezone is found. Unfortunately this is a regression from the changes we made in 0.4.20 where we now parse the timezone database ourselves. Before 0.4.20, TimeZone::now() fell back to UTC in the case it could not find the current timezone, but the new implementation panicked in that case.
Correctly detect timezone on Android (also #756). Android does have the timezone database installed, but it's in a different path, and it does not use /etc/localtime to keep track of the current timezone. Instead we now use the iana-time-zone crate as a dependency, since it already has quite a bit of logic for finding the current timezone on a host of platforms.
Additionally, there is a documentation fix that reverts an incorrect guarantee:
Document that %Y can have a negative value, both in formatting and in parsing (#760, thanks to @alex)
0.4.20
chrono is a date and time library for Rust and 0.4.20 is the first chrono release since Sep 2020. There has been a long hiatus since the previous maintainer was no longer able to spend much time on the crate; thanks to @quodlibetor for their stewardship of the chrono crate for many years! The new maintainers are @djc and @esheppa. Our first priority has been fixing the soundness issues with calls to localtime_r() as first reported in #499 and the RUSTSEC-2020-0159 advisory. In order to do this we adapted code from the tz-rs crate maintained by @x-hgg-x for use within chrono -- thanks for working on that! With the new implementation, chrono uses safe Rust code to parse the timezone data files on Unix platforms directly instead of relying on libc.
Due to compatibility reasons, this release does not yet remove the time 0.1 dependency, though chrono 0.4.20 does not depend on the vulnerable parts of the time 0.1.x versions. In a future 0.5 release, we will remove the time dependency.
The minimum supported Rust version for 0.4.20 is 1.32.0, which is intentionally still quite conservative. If you are using chrono 0.4 with a Rust version older than 1.52, we'd like to hear from you since we'd like to further modernize the code base to ease maintenance.
Fixes
Fix unsound call to localtime_r() by parsing timezone files in Rust on Unix (#677 and #728)
Allow RFC 2822 parser to deal with comments (#733 then #737, thanks to @Finomnis)
Avoid panicking during parsing (#686, thanks to @botahamec)
Avoid panics when rounding durations (#659, thanks to @ARBaart)
Fix Duration::abs() behavior in case of negative durations with nanoseconds (#734, thanks to @abreis)
Additions
Make ParserErrorKind public and available through ParseError::kind() (#588, thanks to @sbrocket)
Expose associated MIN and MAX const values in favor of free-standing consts (#726)
Chrono obeys the principle of Semantic Versioning, with one caveat: we may
move previously-existing code behind a feature gate and put it behind a new feature. This new
feature will always be placed in the previously-default feature, which you can use to prevent
breakage if you use no-default-features.
There were/are numerous minor versions before 1.0 due to the language changes.
Versions with only mechanical changes will be omitted from the following list.
0.4.20 (unreleased)
Add more formatting documentation and examples.
Add support for microseconds timestamps serde serialization/deserialization (#304)
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
- `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
Bumps chrono from 0.4.19 to 0.4.21.
Release notes
Sourced from chrono's releases.
... (truncated)
Changelog
Sourced from chrono's changelog.
Commits
2d22e57
Bump version number to 0.4.21557bcd5
handle missing /etc/localtime on some unix platforms (#756)5edf4d0
fixes #758 -- correctly document that %Y parses negative years (#760)a185d3b
Remove unnecessary try_opt!() macro0b7feac
Clean up some unreachable_pub warnings65f1f2e
Bump version to 0.4.20bd3b48d
Revise Months APIab688c3
ImplementAdd\<Months>
andSub\<Months>
forNaiveDate
(#731)782f904
Clarify docs forDateTime::with_timezone
27c0558
dont use stub.rs when wasmbind feature is enabledDependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting
@dependabot rebase
.Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)