Skip to content

Commit

Permalink
add hyperlinks to documentation and clarify derive macros (#355)
Browse files Browse the repository at this point in the history
this makes it easier to navigate the documentation.

one comment seemed to suggest that the reexport of the derive
macros was depricated, however that has been ignored for several
reasons:

1. exposing macros through a derive feature flag is common practice,
   see the serde crate for an example.
2. using a feature flag means you can't accidentally have a version
   mismatch.
3. the reexport is used in several examples
4. the only evidence of deprication is a private comment,
   which would never be seen by normal users of the crate.

Co-authored-by: binarycat <binarycat@envs.net>
  • Loading branch information
lolbinarycat and lolbinarycat authored May 12, 2024
1 parent 186d29f commit 9689d7b
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 2 deletions.
2 changes: 1 addition & 1 deletion strum/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ impl std::error::Error for ParseError {
}

/// This trait designates that an `Enum` can be iterated over. It can
/// be auto generated using `strum_macros` on your behalf.
/// be auto generated using the [`EnumIter`](derive.EnumIter.html) derive macro.
///
/// # Example
///
Expand Down
6 changes: 5 additions & 1 deletion strum_macros/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,10 @@
//! Strum is a set of macros and traits for working with
//! enums and strings easier in Rust.
//!
//! This crate only contains derive macros for use with the
//! [`strum`](https://docs.rs/strum)
//! crate. The macros provied by this crate are also available by
//! enabling the `derive` feature in aforementioned `strum` crate.
#![recursion_limit = "128"]

Expand Down Expand Up @@ -428,7 +432,7 @@ pub fn display(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
/// Creates a new type that iterates of the variants of an enum.
///
/// Iterate over the variants of an Enum. Any additional data on your variants will be set to `Default::default()`.
/// The macro implements `strum::IntoEnumIterator` on your enum and creates a new type called `YourEnumIter` that is the iterator object.
/// The macro implements [`strum::IntoEnumIterator`](https://docs.rs/strum/latest/strum/trait.IntoEnumIterator.html) on your enum and creates a new type called `YourEnumIter` that is the iterator object.
/// You cannot derive `EnumIter` on any type with a lifetime bound (`<'a>`) because the iterator would surely
/// create [unbounded lifetimes](https://doc.rust-lang.org/nightly/nomicon/unbounded-lifetimes.html).
///
Expand Down

0 comments on commit 9689d7b

Please sign in to comment.