From 6f2c7ccabd94e78f4bbf585085b54e21eb6e99fe Mon Sep 17 00:00:00 2001 From: Paul Dicker Date: Thu, 21 Mar 2024 19:04:00 +0100 Subject: [PATCH] Use different method to run feature-dependent doctests --- src/datetime/mod.rs | 10 ++++++---- src/format/mod.rs | 5 +++-- src/format/parsed.rs | 10 ++++++---- src/format/strftime.rs | 4 ++-- src/lib.rs | 15 +++++++++------ src/naive/time/mod.rs | 10 ++++++---- src/offset/fixed.rs | 10 ++++++---- src/weekday.rs | 5 +++-- 8 files changed, 41 insertions(+), 28 deletions(-) diff --git a/src/datetime/mod.rs b/src/datetime/mod.rs index 8a8234ae84..3271835442 100644 --- a/src/datetime/mod.rs +++ b/src/datetime/mod.rs @@ -79,8 +79,8 @@ impl DateTime { /// /// # Example /// - #[cfg_attr(not(feature = "clock"), doc = "```ignore")] - #[cfg_attr(feature = "clock", doc = "```rust")] + /// ``` + /// # #[cfg(feature = "clock")] { /// use chrono::{DateTime, Local}; /// /// let dt = Local::now(); @@ -90,6 +90,7 @@ impl DateTime { /// // Serialize, pass through FFI... and recreate the `DateTime`: /// let dt_new = DateTime::::from_naive_utc_and_offset(naive_utc, offset); /// assert_eq!(dt, dt_new); + /// # } /// ``` #[inline] #[must_use] @@ -691,8 +692,8 @@ impl DateTime { /// /// # Example /// - #[cfg_attr(not(feature = "clock"), doc = "```ignore")] - #[cfg_attr(feature = "clock", doc = "```rust")] + /// ``` + /// # #[cfg(feature = "clock")] { /// use chrono::{Local, NaiveTime}; /// /// let noon = NaiveTime::from_hms_opt(12, 0, 0).unwrap(); @@ -701,6 +702,7 @@ impl DateTime { /// /// assert_eq!(today_noon.single().unwrap().time(), noon); /// assert_eq!(today_midnight.single().unwrap().time(), NaiveTime::MIN); + /// # } /// ``` #[must_use] pub fn with_time(&self, time: NaiveTime) -> LocalResult { diff --git a/src/format/mod.rs b/src/format/mod.rs index c2401a7fc1..d67a20177c 100644 --- a/src/format/mod.rs +++ b/src/format/mod.rs @@ -16,8 +16,8 @@ //! C's `strftime` format. The available options can be found [here](./strftime/index.html). //! //! # Example -#![cfg_attr(not(feature = "std"), doc = "```ignore")] -#![cfg_attr(feature = "std", doc = "```rust")] +//! ``` +//! # #[cfg(feature = "std")] { //! use chrono::{NaiveDateTime, TimeZone, Utc}; //! //! let date_time = Utc.with_ymd_and_hms(2020, 11, 10, 0, 1, 32).unwrap(); @@ -27,6 +27,7 @@ //! //! let parsed = NaiveDateTime::parse_from_str(&formatted, "%Y-%m-%d %H:%M:%S")?.and_utc(); //! assert_eq!(parsed, date_time); +//! # } //! # Ok::<(), chrono::ParseError>(()) //! ``` diff --git a/src/format/parsed.rs b/src/format/parsed.rs index 4f74b85224..8d1cde2d5a 100644 --- a/src/format/parsed.rs +++ b/src/format/parsed.rs @@ -57,8 +57,8 @@ use crate::{DateTime, Datelike, TimeDelta, Timelike, Weekday}; /// /// Let's see how `Parsed` correctly detects the second RFC 2822 string from before is inconsistent. /// -#[cfg_attr(not(feature = "alloc"), doc = "```ignore")] -#[cfg_attr(feature = "alloc", doc = "```rust")] +/// ``` +/// # #[cfg(feature = "alloc")] { /// use chrono::format::{ParseErrorKind, Parsed}; /// use chrono::Weekday; /// @@ -89,6 +89,7 @@ use crate::{DateTime, Datelike, TimeDelta, Timelike, Weekday}; /// if let Err(error) = result { /// assert_eq!(error.kind(), ParseErrorKind::Impossible); /// } +/// # } /// # Ok::<(), chrono::ParseError>(()) /// ``` /// @@ -98,8 +99,8 @@ use crate::{DateTime, Datelike, TimeDelta, Timelike, Weekday}; /// [RFC2822 formatting item]: crate::format::Fixed::RFC2822 /// [`format::parse()`]: crate::format::parse() /// -#[cfg_attr(not(feature = "alloc"), doc = "```ignore")] -#[cfg_attr(feature = "alloc", doc = "```rust")] +/// ``` +/// # #[cfg(feature = "alloc")] { /// use chrono::format::{parse, Fixed, Item, Parsed}; /// use chrono::Weekday; /// @@ -120,6 +121,7 @@ use crate::{DateTime, Datelike, TimeDelta, Timelike, Weekday}; /// // What is the weekday? /// assert_eq!(parsed.weekday(), Some(Weekday::Thu)); /// } +/// # } /// # Ok::<(), chrono::ParseError>(()) /// ``` #[allow(clippy::manual_non_exhaustive)] diff --git a/src/format/strftime.rs b/src/format/strftime.rs index 724e9ee421..555e36f9c0 100644 --- a/src/format/strftime.rs +++ b/src/format/strftime.rs @@ -258,8 +258,8 @@ impl<'a> StrftimeItems<'a> { /// /// # Example /// - #[cfg_attr(not(any(feature = "alloc", feature = "std")), doc = "```ignore")] - #[cfg_attr(any(feature = "alloc", feature = "std"), doc = "```rust")] + /// ``` + /// # #[cfg(feature = "alloc")] { /// use chrono::format::{Locale, StrftimeItems}; /// use chrono::{FixedOffset, TimeZone}; /// diff --git a/src/lib.rs b/src/lib.rs index bc7c05b81d..ef9794ffed 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -108,20 +108,22 @@ //! or in the local time zone //! ([`Local::now()`](./offset/struct.Local.html#method.now)). //! -#![cfg_attr(not(feature = "now"), doc = "```ignore")] -#![cfg_attr(feature = "now", doc = "```rust")] +//! ``` +//! # #[cfg(feature = "now")] { //! use chrono::prelude::*; //! //! let utc: DateTime = Utc::now(); // e.g. `2014-11-28T12:45:59.324310806Z` //! # let _ = utc; +//! # } //! ``` //! -#![cfg_attr(not(feature = "clock"), doc = "```ignore")] -#![cfg_attr(feature = "clock", doc = "```rust")] +//! ``` +//! # #[cfg(feature = "clock")] { //! use chrono::prelude::*; //! //! let local: DateTime = Local::now(); // e.g. `2014-11-28T21:45:59.324310806+09:00` //! # let _ = local; +//! # } //! ``` //! //! Alternatively, you can create your own date and time. @@ -382,8 +384,8 @@ //! [`DateTime.timestamp_subsec_nanos`](DateTime::timestamp_subsec_nanos) //! to get the number of additional number of nanoseconds. //! -#![cfg_attr(not(feature = "std"), doc = "```ignore")] -#![cfg_attr(feature = "std", doc = "```rust")] +//! ``` +//! # #[cfg(feature = "std")] { //! // We need the trait in scope to use Utc::timestamp(). //! use chrono::{DateTime, Utc}; //! @@ -394,6 +396,7 @@ //! // Get epoch value from a datetime: //! let dt = DateTime::parse_from_rfc2822("Fri, 14 Jul 2017 02:40:00 +0000").unwrap(); //! assert_eq!(dt.timestamp(), 1_500_000_000); +//! # } //! ``` //! //! ### Naive date and time diff --git a/src/naive/time/mod.rs b/src/naive/time/mod.rs index 56dc5cd891..7fe26a3615 100644 --- a/src/naive/time/mod.rs +++ b/src/naive/time/mod.rs @@ -948,12 +948,13 @@ impl Timelike for NaiveTime { /// ([Why?](#leap-second-handling)) /// Use the proper [formatting method](#method.format) to get a human-readable representation. /// - #[cfg_attr(not(feature = "std"), doc = "```ignore")] - #[cfg_attr(feature = "std", doc = "```")] + /// ``` + /// # #[cfg(feature = "std")] { /// # use chrono::{NaiveTime, Timelike}; /// let leap = NaiveTime::from_hms_milli_opt(23, 59, 59, 1_000).unwrap(); /// assert_eq!(leap.second(), 59); /// assert_eq!(leap.format("%H:%M:%S").to_string(), "23:59:60"); + /// # } /// ``` #[inline] fn second(&self) -> u32 { @@ -980,12 +981,13 @@ impl Timelike for NaiveTime { /// You can reduce the range with `time.nanosecond() % 1_000_000_000`, or /// use the proper [formatting method](#method.format) to get a human-readable representation. /// - #[cfg_attr(not(feature = "std"), doc = "```ignore")] - #[cfg_attr(feature = "std", doc = "```")] + /// ``` + /// # #[cfg(feature = "std")] { /// # use chrono::{NaiveTime, Timelike}; /// let leap = NaiveTime::from_hms_milli_opt(23, 59, 59, 1_000).unwrap(); /// assert_eq!(leap.nanosecond(), 1_000_000_000); /// assert_eq!(leap.format("%H:%M:%S%.9f").to_string(), "23:59:60.000000000"); + /// # } /// ``` #[inline] fn nanosecond(&self) -> u32 { diff --git a/src/offset/fixed.rs b/src/offset/fixed.rs index 24cd983766..59c6aeec3a 100644 --- a/src/offset/fixed.rs +++ b/src/offset/fixed.rs @@ -49,13 +49,14 @@ impl FixedOffset { /// /// # Example /// - #[cfg_attr(not(feature = "std"), doc = "```ignore")] - #[cfg_attr(feature = "std", doc = "```")] + /// ``` + /// # #[cfg(feature = "std")] { /// use chrono::{FixedOffset, TimeZone}; /// let hour = 3600; /// let datetime = /// FixedOffset::east_opt(5 * hour).unwrap().with_ymd_and_hms(2016, 11, 08, 0, 0, 0).unwrap(); /// assert_eq!(&datetime.to_rfc3339(), "2016-11-08T00:00:00+05:00") + /// # } /// ``` #[must_use] pub const fn east_opt(secs: i32) -> Option { @@ -83,13 +84,14 @@ impl FixedOffset { /// /// # Example /// - #[cfg_attr(not(feature = "std"), doc = "```ignore")] - #[cfg_attr(feature = "std", doc = "```")] + /// ``` + /// # #[cfg(feature = "std")] { /// use chrono::{FixedOffset, TimeZone}; /// let hour = 3600; /// let datetime = /// FixedOffset::west_opt(5 * hour).unwrap().with_ymd_and_hms(2016, 11, 08, 0, 0, 0).unwrap(); /// assert_eq!(&datetime.to_rfc3339(), "2016-11-08T00:00:00-05:00") + /// # } /// ``` #[must_use] pub const fn west_opt(secs: i32) -> Option { diff --git a/src/weekday.rs b/src/weekday.rs index 618d5355d6..72ce34084a 100644 --- a/src/weekday.rs +++ b/src/weekday.rs @@ -123,8 +123,8 @@ impl Weekday { /// /// # Example /// - #[cfg_attr(not(feature = "clock"), doc = "```ignore")] - #[cfg_attr(feature = "clock", doc = "```rust")] + /// ``` + /// # #[cfg(feature = "clock")] { /// # use chrono::{Local, Datelike}; /// // MTWRFSU is occasionally used as a single-letter abbreviation of the weekdays. /// // Use `num_days_from_monday` to index into the array. @@ -132,6 +132,7 @@ impl Weekday { /// /// let today = Local::now().weekday(); /// println!("{}", MTWRFSU[today.num_days_from_monday() as usize]); + /// # } /// ``` #[inline] pub const fn num_days_from_monday(&self) -> u32 {