#macro-derive #macro-helpers #enums #proc-macro #macro #derive

derive_utils

A procedural macro helper for easily writing derive macros for enums

28 releases

0.14.1 Jan 27, 2024
0.13.2 Jul 27, 2023
0.13.0 Mar 26, 2023
0.12.0 Jan 10, 2022
0.5.3 Dec 27, 2018

#14 in Procedural macros

Download history 45600/week @ 2024-01-03 42062/week @ 2024-01-10 43332/week @ 2024-01-17 41461/week @ 2024-01-24 43394/week @ 2024-01-31 38821/week @ 2024-02-07 38808/week @ 2024-02-14 43064/week @ 2024-02-21 43575/week @ 2024-02-28 45552/week @ 2024-03-06 53616/week @ 2024-03-13 52922/week @ 2024-03-20 44924/week @ 2024-03-27 50772/week @ 2024-04-03 49208/week @ 2024-04-10 39105/week @ 2024-04-17

192,973 downloads per month
Used in 302 crates (9 directly)

Apache-2.0 OR MIT

36KB
475 lines

derive_utils

crates.io docs.rs license rust version github actions

A procedural macro helper for easily writing derives macros for enums.

Usage

Add this to your Cargo.toml:

[dependencies]
derive_utils = "0.14"

Compiler support: requires rustc 1.56+

Examples

quick_derive! macro make easy to write proc_macro_derive like deriving trait to enum so long as all variants are implemented that trait.

use derive_utils::quick_derive;
use proc_macro::TokenStream;

#[proc_macro_derive(Iterator)]
pub fn derive_iterator(input: TokenStream) -> TokenStream {
    quick_derive! {
        input,
        // trait path
        std::iter::Iterator,
        // trait definition
        trait Iterator {
            type Item;
            fn next(&mut self) -> Option<Self::Item>;
            fn size_hint(&self) -> (usize, Option<usize>);
        }
    }
}

#[proc_macro_derive(ExactSizeIterator)]
pub fn derive_exact_size_iterator(input: TokenStream) -> TokenStream {
    quick_derive! {
        input,
        // trait path
        std::iter::ExactSizeIterator,
        // super trait's associated types
        <Item>,
        // trait definition
        trait ExactSizeIterator: Iterator {
            fn len(&self) -> usize;
        }
    }
}

Generated code

When deriving for enum like the following:

#[derive(Iterator, ExactSizeIterator, Future)]
enum Enum<A, B> {
    A(A),
    B(B),
}

Code like this will be generated:

enum Enum<A, B> {
    A(A),
    B(B),
}

impl<A, B> std::iter::Iterator for Enum<A, B>
where
    A: std::iter::Iterator,
    B: std::iter::Iterator<Item = <A as std::iter::Iterator>::Item>,
{
    type Item = <A as std::iter::Iterator>::Item;
    fn next(&mut self) -> Option<Self::Item> {
        match self {
            Enum::A(x) => x.next(),
            Enum::B(x) => x.next(),
        }
    }
    fn size_hint(&self) -> (usize, Option<usize>) {
        match self {
            Enum::A(x) => x.size_hint(),
            Enum::B(x) => x.size_hint(),
        }
    }
}

impl<A, B> std::iter::ExactSizeIterator for Enum<A, B>
where
    A: std::iter::ExactSizeIterator,
    B: std::iter::ExactSizeIterator<Item = <A as Iterator>::Item>,
{
    fn len(&self) -> usize {
        match self {
            Enum::A(x) => x.len(),
            Enum::B(x) => x.len(),
        }
    }
}
  • auto_enums: A library for to allow multiple return types by automatically generated enum.
  • io-enum: #[derive(Read, Write, Seek, BufRead)] for enums.
  • iter-enum: #[derive(Iterator, DoubleEndedIterator, ExactSizeIterator, FusedIterator, Extend)] for enums.

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~310–760KB
~18K SLoC