From 4741338ad21afe24e53fd0b545ea1d6781c20599 Mon Sep 17 00:00:00 2001 From: Paul Dicker Date: Sun, 31 Mar 2024 13:46:34 +0200 Subject: [PATCH] Update documentation of crate features --- README.md | 13 ++++++------- src/lib.rs | 14 ++++++++------ 2 files changed, 14 insertions(+), 13 deletions(-) diff --git a/README.md b/README.md index 87e085519b..76ef22541e 100644 --- a/README.md +++ b/README.md @@ -50,12 +50,10 @@ See [docs.rs](https://docs.rs/chrono/latest/chrono/) for the API reference. Default features: +* `std`: Implements `TryFrom` and `std::error::Error` for error types, implies `alloc`. * `alloc`: Enable features that depend on allocation (primarily string formatting). -* `std`: Enables functionality that depends on the standard library. This is a superset of `alloc` - and adds interoperation with standard library types and traits. -* `clock`: Enables reading the local timezone (`Local`). This is a superset of `now`. -* `now`: Enables reading the system time (`now`). -* `wasmbind`: Interface with the JS Date API for the `wasm32` target. +* `clock`: Enables reading the local timezone (`Local`), implies `now`. +* `now`: Enables reading the system time (`now()`), on most platforms using the standard library. Optional features: @@ -64,15 +62,16 @@ Optional features: * `rkyv-32`: Enable serialization/deserialization via [rkyv], using 32-bit integers for integral `*size` types. * `rkyv-64`: Enable serialization/deserialization via [rkyv], using 64-bit integers for integral `*size` types. * `rkyv-validation`: Enable rkyv validation support using `bytecheck`. -* `arbitrary`: Construct arbitrary instances of a type with the Arbitrary crate. +* `arbitrary`: Construct arbitrary instances of a type with the [arbitrary] crate. +* `wasmbind`: Interface with the JS Date API for the `wasm32` target. * `unstable-locales`: Enable localization. This adds various methods with a `_localized` suffix. The implementation and API may change or even be removed in a patch release. Feedback welcome. -* `oldtime`: This feature no longer has any effect; it used to offer compatibility with the `time` 0.1 crate. Note: The `rkyv-{16,32,64}` features are mutually exclusive. [serde]: https://github.com/serde-rs/serde [rkyv]: https://github.com/rkyv/rkyv +[arbitrary]: https://github.com/rust-fuzz/arbitrary/ ## Rust version requirements diff --git a/src/lib.rs b/src/lib.rs index e95948dff1..fb2f6ef432 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -25,12 +25,12 @@ //! //! Default features: //! +//! - `std`: Implements `TryFrom` and `std::error::Error` for error types, +//! implies `alloc`. //! - `alloc`: Enable features that depend on allocation (primarily string formatting). -//! - `std`: Enables functionality that depends on the standard library. This is a superset of -//! `alloc` and adds interoperation with standard library types and traits. -//! - `clock`: Enables reading the local timezone (`Local`). This is a superset of `now`. -//! - `now`: Enables reading the system time (`now`). -//! - `wasmbind`: Interface with the JS Date API for the `wasm32` target. +//! - `clock`: Enables reading the local timezone (`Local`), implies `now`. +//! - `now`: Enables reading the system time (`now()`), on most platforms using the standard +//! library. //! //! Optional features: //! @@ -42,7 +42,8 @@ //! - `rkyv-64`: Enable serialization/deserialization via [rkyv], //! using 64-bit integers for integral `*size` types. //! - `rkyv-validation`: Enable rkyv validation support using `bytecheck`. -//! - `arbitrary`: Construct arbitrary instances of a type with the Arbitrary crate. +//! - `arbitrary`: Construct arbitrary instances of a type with the [arbitrary] crate. +//! - `wasmbind`: Interface with the JS Date API for the `wasm32` target. //! - `unstable-locales`: Enable localization. This adds various methods with a `_localized` suffix. //! The implementation and API may change or even be removed in a patch release. Feedback welcome. //! @@ -52,6 +53,7 @@ //! //! [serde]: https://github.com/serde-rs/serde //! [rkyv]: https://github.com/rkyv/rkyv +//! [arbitrary]: https://github.com/rust-fuzz/arbitrary/ //! [cargo docs]: https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#choosing-features //! //! ## Overview