All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
Expose main trace events at Info level for increased visibility, log-directives can be used by dependencies to filter out tokio-graceful info events if not desired.
Expose a signal that can be awaited on without awaiting the configured
delay first. If no delay is used this API is equivalent to the already
existing cancelled
function.
This can be used for scenarios where you do not need a graceful buffer and would like to cancel as soon as a signal is received.
This is usability wise not a breaking release, however it does make changes to the API which might break subtle edge cases and it also increases the MSRV to 1.75.
New Features:
- add a delay (Duration) that can be used to trigger the cancel notification to ongoing jobs once the shutdown trigger (signal) has been received;
- add a second signal factory that can be used to create an overwrite signal to be created and triggered once the main signal has been triggered, as an alternative to the jobs being complete or max delay has been reached.
Both features can be configured using the newly introduced ShutdownBuilder
,
which can be made directly or via Shutdown::builder
.
- Upgrade hyper examples to adapt to dev dependency hyper v1.0 (was hyper v0.14);
- Support and use Loom for testing;
- Fixes a bug in the private trigger code where a race condition could cause a deadlock (found using loom);
- Signal / Project support for the Windows platform;
- affected code:
crate::default_signal
andcrate::Shutdown::default
;- Unix and Windows are supported and have this code enabled;
- Other platforms won't have this code;
- When using Loom this code is also not there;
- This fixes build errors for platforms that we do not support for the default signal;
- affected code:
- Add example regarding ensuring you do catch exits and document it;
- Support and add Waitgroup example;
- Fix mistake in docs (thank you Mike Cronce);
- Update 0.1.2 changelog to highlight the library is no longer 100% Rust Safe Code;
- Fix typos in README (thank you @hds);
- Performance improvements (thank you awake readers on Reddit);
- add more docs to README and internal code;
- library is no longer 100% safe Rust code, due to usage of https://doc.rust-lang.org/stable/std/mem/struct.ManuallyDrop.html in an internal struct;
- Improved documentation and add FAQ to readme;
- Optimization to the
into_spawn*
methods (don't clone first); - add CI semver check;
- Initial release.