Skip to main content

time_macros/format_description/public/
modifier.rs

1use std::num::NonZero;
2
3use proc_macro::{Delimiter, Group, Ident, Span, TokenStream, TokenTree};
4
5use crate::to_tokens::{ToTokenStream, ToTokenTree};
6
7macro_rules! to_tokens {
8    (
9        $(#[$struct_attr:meta])*
10        $struct_vis:vis struct $struct_name:ident {$(
11            $(#[$field_attr:meta])*
12            $field_vis:vis $field_name:ident : $field_ty:ty = $default:pat
13        ),* $(,)?}
14    ) => {
15        $(#[$struct_attr])*
16        #[derive(Clone, Copy)]
17        $struct_vis struct $struct_name {$(
18            $(#[$field_attr])*
19            $field_vis $field_name: $field_ty
20        ),*}
21
22        impl ToTokenTree for $struct_name {
23            fn into_token_tree(self) -> TokenTree {
24                let Self {$($field_name),*} = self;
25
26                #[allow(clippy::redundant_pattern_matching)]
27                if matches!(($(&$field_name,)*), ($($default,)*)) {
28                    return TokenTree::Group(Group::new(
29                        Delimiter::None,
30                        quote_! { $struct_name::default() }
31                    ));
32                }
33
34                let mut tokens = quote_! {
35                    $struct_name::default()
36                };
37                $(
38                    #[allow(clippy::redundant_pattern_matching)]
39                    if !matches!($field_name, $default) {
40                        let method_name = Ident::new(concat!("with_", stringify!($field_name)), Span::mixed_site());
41                        quote_append!(tokens .#(method_name)(#S($field_name)));
42                    }
43                )*
44
45                TokenTree::Group(Group::new(
46                    Delimiter::Brace,
47                    tokens,
48                ))
49            }
50        }
51    };
52
53    (
54        $(#[$enum_attr:meta])*
55        $enum_vis:vis enum $enum_name:ident {$(
56            $(#[$variant_attr:meta])*
57            $variant_name:ident
58        ),+ $(,)?}
59    ) => {
60        $(#[$enum_attr])*
61        #[derive(Clone, Copy)]
62        $enum_vis enum $enum_name {$(
63            $(#[$variant_attr])*
64            $variant_name
65        ),+}
66
67        impl ToTokenStream for $enum_name {
68            fn append_to(self, ts: &mut TokenStream) {
69                quote_append! { ts
70                    $enum_name::
71                };
72                let name = match self {
73                    $(Self::$variant_name => stringify!($variant_name)),+
74                };
75                ts.extend([TokenTree::Ident(Ident::new(name, Span::mixed_site()))]);
76            }
77        }
78    }
79}
80
81#[automatically_derived]
impl ::core::clone::Clone for Day {
    #[inline]
    fn clone(&self) -> Day {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Day { }
impl ToTokenTree for Day {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Day",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Day",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
82    pub(crate) struct Day {
83        pub(crate) padding: Padding = Padding::Zero,
84    }
85}
86
87#[automatically_derived]
impl ::core::clone::Clone for MonthShort {
    #[inline]
    fn clone(&self) -> MonthShort {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for MonthShort { }
impl ToTokenTree for MonthShort {
    fn into_token_tree(self) -> TokenTree {
        let Self { case_sensitive } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&case_sensitive,)
                {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"MonthShort",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"MonthShort",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match case_sensitive {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_case_sensitive", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(case_sensitive,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
88    pub(crate) struct MonthShort {
89        pub(crate) case_sensitive: bool = true,
90    }
91}
92
93#[automatically_derived]
impl ::core::clone::Clone for MonthLong {
    #[inline]
    fn clone(&self) -> MonthLong {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for MonthLong { }
impl ToTokenTree for MonthLong {
    fn into_token_tree(self) -> TokenTree {
        let Self { case_sensitive } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&case_sensitive,)
                {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"MonthLong",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"MonthLong",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match case_sensitive {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_case_sensitive", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(case_sensitive,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
94    pub(crate) struct MonthLong {
95        pub(crate) case_sensitive: bool = true,
96    }
97}
98
99#[automatically_derived]
impl ::core::clone::Clone for MonthNumerical {
    #[inline]
    fn clone(&self) -> MonthNumerical {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for MonthNumerical { }
impl ToTokenTree for MonthNumerical {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"MonthNumerical",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"MonthNumerical",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
100    pub(crate) struct MonthNumerical {
101        pub(crate) padding: Padding = Padding::Zero,
102    }
103}
104
105#[automatically_derived]
impl ::core::clone::Clone for Ordinal {
    #[inline]
    fn clone(&self) -> Ordinal {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Ordinal { }
impl ToTokenTree for Ordinal {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Ordinal",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Ordinal",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
106    pub(crate) struct Ordinal {
107        pub(crate) padding: Padding = Padding::Zero,
108    }
109}
110
111#[automatically_derived]
impl ::core::clone::Clone for WeekdayShort {
    #[inline]
    fn clone(&self) -> WeekdayShort {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekdayShort { }
impl ToTokenTree for WeekdayShort {
    fn into_token_tree(self) -> TokenTree {
        let Self { case_sensitive } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&case_sensitive,)
                {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayShort",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayShort",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match case_sensitive {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_case_sensitive", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(case_sensitive,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
112    pub(crate) struct WeekdayShort {
113        pub(crate) case_sensitive: bool = true,
114    }
115}
116
117#[automatically_derived]
impl ::core::clone::Clone for WeekdayLong {
    #[inline]
    fn clone(&self) -> WeekdayLong {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekdayLong { }
impl ToTokenTree for WeekdayLong {
    fn into_token_tree(self) -> TokenTree {
        let Self { case_sensitive } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&case_sensitive,)
                {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayLong",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayLong",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match case_sensitive {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_case_sensitive", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(case_sensitive,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
118    pub(crate) struct WeekdayLong {
119        pub(crate) case_sensitive: bool = true,
120    }
121}
122
123#[automatically_derived]
impl ::core::clone::Clone for WeekdaySunday {
    #[inline]
    fn clone(&self) -> WeekdaySunday {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekdaySunday { }
impl ToTokenTree for WeekdaySunday {
    fn into_token_tree(self) -> TokenTree {
        let Self { one_indexed } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&one_indexed,) {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekdaySunday",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekdaySunday",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match one_indexed {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_one_indexed", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(one_indexed,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
124    pub(crate) struct WeekdaySunday {
125        pub(crate) one_indexed: bool = true,
126    }
127}
128
129#[automatically_derived]
impl ::core::clone::Clone for WeekdayMonday {
    #[inline]
    fn clone(&self) -> WeekdayMonday {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekdayMonday { }
impl ToTokenTree for WeekdayMonday {
    fn into_token_tree(self) -> TokenTree {
        let Self { one_indexed } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&one_indexed,) {
                (true,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayMonday",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekdayMonday",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match one_indexed {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_one_indexed", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(one_indexed,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
130    pub(crate) struct WeekdayMonday {
131        pub(crate) one_indexed: bool = true,
132    }
133}
134
135#[automatically_derived]
impl ::core::clone::Clone for WeekNumberIso {
    #[inline]
    fn clone(&self) -> WeekNumberIso {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekNumberIso { }
impl ToTokenTree for WeekNumberIso {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberIso",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberIso",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
136    pub(crate) struct WeekNumberIso {
137        pub(crate) padding: Padding = Padding::Zero,
138    }
139}
140
141#[automatically_derived]
impl ::core::clone::Clone for WeekNumberSunday {
    #[inline]
    fn clone(&self) -> WeekNumberSunday {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekNumberSunday { }
impl ToTokenTree for WeekNumberSunday {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberSunday",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberSunday",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
142    pub(crate) struct WeekNumberSunday {
143        pub(crate) padding: Padding = Padding::Zero,
144    }
145}
146
147#[automatically_derived]
impl ::core::clone::Clone for WeekNumberMonday {
    #[inline]
    fn clone(&self) -> WeekNumberMonday {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for WeekNumberMonday { }
impl ToTokenTree for WeekNumberMonday {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberMonday",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"WeekNumberMonday",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
148    pub(crate) struct WeekNumberMonday {
149        pub(crate) padding: Padding = Padding::Zero,
150    }
151}
152
153#[automatically_derived]
impl ::core::clone::Clone for CalendarYearFullStandardRange {
    #[inline]
    fn clone(&self) -> CalendarYearFullStandardRange {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for CalendarYearFullStandardRange { }
impl ToTokenTree for CalendarYearFullStandardRange {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding, sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,
                    &sign_is_mandatory) {
                (Padding::Zero, false) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearFullStandardRange",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearFullStandardRange",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
154    pub(crate) struct CalendarYearFullStandardRange {
155        pub(crate) padding: Padding = Padding::Zero,
156        pub(crate) sign_is_mandatory: bool = false,
157    }
158}
159
160#[cfg(feature = "large-dates")]
161to_tokens! {
162    pub(crate) struct CalendarYearFullExtendedRange {
163        pub(crate) padding: Padding = Padding::Zero,
164        pub(crate) sign_is_mandatory: bool = false,
165    }
166}
167
168#[automatically_derived]
impl ::core::clone::Clone for CalendarYearCenturyStandardRange {
    #[inline]
    fn clone(&self) -> CalendarYearCenturyStandardRange {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for CalendarYearCenturyStandardRange { }
impl ToTokenTree for CalendarYearCenturyStandardRange {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding, sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,
                    &sign_is_mandatory) {
                (Padding::Zero, false) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearCenturyStandardRange",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearCenturyStandardRange",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
169    pub(crate) struct CalendarYearCenturyStandardRange {
170        pub(crate) padding: Padding = Padding::Zero,
171        pub(crate) sign_is_mandatory: bool = false,
172    }
173}
174
175#[cfg(feature = "large-dates")]
176to_tokens! {
177    pub(crate) struct CalendarYearCenturyExtendedRange {
178        pub(crate) padding: Padding = Padding::Zero,
179        pub(crate) sign_is_mandatory: bool = false,
180    }
181}
182
183#[automatically_derived]
impl ::core::clone::Clone for IsoYearFullStandardRange {
    #[inline]
    fn clone(&self) -> IsoYearFullStandardRange {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for IsoYearFullStandardRange { }
impl ToTokenTree for IsoYearFullStandardRange {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding, sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,
                    &sign_is_mandatory) {
                (Padding::Zero, false) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearFullStandardRange",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearFullStandardRange",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
184    pub(crate) struct IsoYearFullStandardRange {
185        pub(crate) padding: Padding = Padding::Zero,
186        pub(crate) sign_is_mandatory: bool = false,
187    }
188}
189
190#[cfg(feature = "large-dates")]
191to_tokens! {
192    pub(crate) struct IsoYearFullExtendedRange {
193        pub(crate) padding: Padding = Padding::Zero,
194        pub(crate) sign_is_mandatory: bool = false,
195    }
196}
197
198#[automatically_derived]
impl ::core::clone::Clone for IsoYearCenturyStandardRange {
    #[inline]
    fn clone(&self) -> IsoYearCenturyStandardRange {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for IsoYearCenturyStandardRange { }
impl ToTokenTree for IsoYearCenturyStandardRange {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding, sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,
                    &sign_is_mandatory) {
                (Padding::Zero, false) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearCenturyStandardRange",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearCenturyStandardRange",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
199    pub(crate) struct IsoYearCenturyStandardRange {
200        pub(crate) padding: Padding = Padding::Zero,
201        pub(crate) sign_is_mandatory: bool = false,
202    }
203}
204
205#[cfg(feature = "large-dates")]
206to_tokens! {
207    pub(crate) struct IsoYearCenturyExtendedRange {
208        pub(crate) padding: Padding = Padding::Zero,
209        pub(crate) sign_is_mandatory: bool = false,
210    }
211}
212
213#[automatically_derived]
impl ::core::clone::Clone for CalendarYearLastTwo {
    #[inline]
    fn clone(&self) -> CalendarYearLastTwo {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for CalendarYearLastTwo { }
impl ToTokenTree for CalendarYearLastTwo {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearLastTwo",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"CalendarYearLastTwo",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
214    pub(crate) struct CalendarYearLastTwo {
215        pub(crate) padding: Padding = Padding::Zero,
216    }
217}
218
219#[automatically_derived]
impl ::core::clone::Clone for IsoYearLastTwo {
    #[inline]
    fn clone(&self) -> IsoYearLastTwo {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for IsoYearLastTwo { }
impl ToTokenTree for IsoYearLastTwo {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearLastTwo",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"IsoYearLastTwo",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
220    pub(crate) struct IsoYearLastTwo {
221        pub(crate) padding: Padding = Padding::Zero,
222    }
223}
224
225#[automatically_derived]
impl ::core::clone::Clone for Hour12 {
    #[inline]
    fn clone(&self) -> Hour12 {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Hour12 { }
impl ToTokenTree for Hour12 {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Hour12",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Hour12",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
226    pub(crate) struct Hour12 {
227        pub(crate) padding: Padding = Padding::Zero,
228    }
229}
230
231#[automatically_derived]
impl ::core::clone::Clone for Hour24 {
    #[inline]
    fn clone(&self) -> Hour24 {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Hour24 { }
impl ToTokenTree for Hour24 {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Hour24",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Hour24",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
232    pub(crate) struct Hour24 {
233        pub(crate) padding: Padding = Padding::Zero,
234    }
235}
236
237#[automatically_derived]
impl ::core::clone::Clone for Minute {
    #[inline]
    fn clone(&self) -> Minute {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Minute { }
impl ToTokenTree for Minute {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Minute",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Minute",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
238    pub(crate) struct Minute {
239        pub(crate) padding: Padding = Padding::Zero,
240    }
241}
242
243#[automatically_derived]
impl ::core::clone::Clone for Period {
    #[inline]
    fn clone(&self) -> Period {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Period { }
impl ToTokenTree for Period {
    fn into_token_tree(self) -> TokenTree {
        let Self { is_uppercase, case_sensitive } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&is_uppercase,
                    &case_sensitive) {
                (true, true) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Period",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Period",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match is_uppercase {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_is_uppercase", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(is_uppercase,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match case_sensitive {
                    true => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_case_sensitive", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(case_sensitive,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
244    pub(crate) struct Period {
245        pub(crate) is_uppercase: bool = true,
246        pub(crate) case_sensitive: bool = true,
247    }
248}
249
250#[automatically_derived]
impl ::core::clone::Clone for Second {
    #[inline]
    fn clone(&self) -> Second {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Second { }
impl ToTokenTree for Second {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Second",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Second",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
251    pub(crate) struct Second {
252        pub(crate) padding: Padding = Padding::Zero,
253    }
254}
255
256#[automatically_derived]
impl ::core::clone::Clone for SubsecondDigits {
    #[inline]
    fn clone(&self) -> SubsecondDigits { *self }
}
#[automatically_derived]
impl ::core::marker::Copy for SubsecondDigits { }
impl ToTokenStream for SubsecondDigits {
    fn append_to(self, ts: &mut TokenStream) {
        {
            use proc_macro::*;
            ts.extend([TokenTree::from(Ident::new(&"SubsecondDigits",
                                Span::mixed_site()))]);
            ts.extend([TokenTree::from(Punct::new(':', Spacing::Joint)),
                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
            ;
            ;
        };
        let name =
            match self {
                Self::One => "One",
                Self::Two => "Two",
                Self::Three => "Three",
                Self::Four => "Four",
                Self::Five => "Five",
                Self::Six => "Six",
                Self::Seven => "Seven",
                Self::Eight => "Eight",
                Self::Nine => "Nine",
                Self::OneOrMore => "OneOrMore",
            };
        ts.extend([TokenTree::Ident(Ident::new(name, Span::mixed_site()))]);
    }
}to_tokens! {
257    pub(crate) enum SubsecondDigits {
258        One,
259        Two,
260        Three,
261        Four,
262        Five,
263        Six,
264        Seven,
265        Eight,
266        Nine,
267        OneOrMore,
268    }
269}
270
271#[automatically_derived]
impl ::core::clone::Clone for Subsecond {
    #[inline]
    fn clone(&self) -> Subsecond {
        let _: ::core::clone::AssertParamIsClone<SubsecondDigits>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for Subsecond { }
impl ToTokenTree for Subsecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { digits } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&digits,) {
                (SubsecondDigits::OneOrMore,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"Subsecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Subsecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match digits {
                    SubsecondDigits::OneOrMore => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_digits", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(digits, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
272    pub(crate) struct Subsecond {
273        pub(crate) digits: SubsecondDigits = SubsecondDigits::OneOrMore,
274    }
275}
276
277#[automatically_derived]
impl ::core::clone::Clone for OffsetHour {
    #[inline]
    fn clone(&self) -> OffsetHour {
        let _: ::core::clone::AssertParamIsClone<bool>;
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for OffsetHour { }
impl ToTokenTree for OffsetHour {
    fn into_token_tree(self) -> TokenTree {
        let Self { sign_is_mandatory, padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&sign_is_mandatory,
                    &padding) {
                (false, Padding::Zero) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"OffsetHour",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"OffsetHour",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
278    pub(crate) struct OffsetHour {
279        pub(crate) sign_is_mandatory: bool = false,
280        pub(crate) padding: Padding = Padding::Zero,
281    }
282}
283
284#[automatically_derived]
impl ::core::clone::Clone for OffsetMinute {
    #[inline]
    fn clone(&self) -> OffsetMinute {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for OffsetMinute { }
impl ToTokenTree for OffsetMinute {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"OffsetMinute",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"OffsetMinute",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
285    pub(crate) struct OffsetMinute {
286        pub(crate) padding: Padding = Padding::Zero,
287    }
288}
289
290#[automatically_derived]
impl ::core::clone::Clone for OffsetSecond {
    #[inline]
    fn clone(&self) -> OffsetSecond {
        let _: ::core::clone::AssertParamIsClone<Padding>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for OffsetSecond { }
impl ToTokenTree for OffsetSecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { padding } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&padding,) {
                (Padding::Zero,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"OffsetSecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"OffsetSecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match padding {
                    Padding::Zero => true,
                    _ => false,
                } {
            let method_name = Ident::new("with_padding", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(padding, ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
291    pub(crate) struct OffsetSecond {
292        pub(crate) padding: Padding = Padding::Zero,
293    }
294}
295
296#[automatically_derived]
impl ::core::clone::Clone for Padding {
    #[inline]
    fn clone(&self) -> Padding { *self }
}
#[automatically_derived]
impl ::core::marker::Copy for Padding { }
impl ToTokenStream for Padding {
    fn append_to(self, ts: &mut TokenStream) {
        {
            use proc_macro::*;
            ts.extend([TokenTree::from(Ident::new(&"Padding",
                                Span::mixed_site()))]);
            ts.extend([TokenTree::from(Punct::new(':', Spacing::Joint)),
                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
            ;
            ;
        };
        let name =
            match self {
                Self::Space => "Space",
                Self::Zero => "Zero",
                Self::None => "None",
            };
        ts.extend([TokenTree::Ident(Ident::new(name, Span::mixed_site()))]);
    }
}to_tokens! {
297    pub(crate) enum Padding {
298        Space,
299        Zero,
300        None,
301    }
302}
303
304#[derive(#[automatically_derived]
impl ::core::clone::Clone for Ignore {
    #[inline]
    fn clone(&self) -> Ignore {
        let _: ::core::clone::AssertParamIsClone<NonZero<u16>>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for Ignore { }Copy)]
305pub(crate) struct Ignore {
306    pub(crate) count: NonZero<u16>,
307}
308
309impl ToTokenTree for Ignore {
310    fn into_token_tree(self) -> TokenTree {
311        {
    use proc_macro::*;
    TokenTree::Group(Group::new(Delimiter::Brace,
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"Ignore",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"count",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        ts_mut.extend([crate::to_tokens::ToTokenTree::into_token_tree(self.count)]);
                                        ;
                                        ts
                                    }))]);
                ;
                ts
            }))
}quote_group! {{
312            Ignore::count(#(self.count))
313        }}
314    }
315}
316
317#[automatically_derived]
impl ::core::clone::Clone for UnixTimestampSecond {
    #[inline]
    fn clone(&self) -> UnixTimestampSecond {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for UnixTimestampSecond { }
impl ToTokenTree for UnixTimestampSecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&sign_is_mandatory,)
                {
                (false,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampSecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampSecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
318    pub(crate) struct UnixTimestampSecond {
319        pub(crate) sign_is_mandatory: bool = false,
320    }
321}
322
323#[automatically_derived]
impl ::core::clone::Clone for UnixTimestampMillisecond {
    #[inline]
    fn clone(&self) -> UnixTimestampMillisecond {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for UnixTimestampMillisecond { }
impl ToTokenTree for UnixTimestampMillisecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&sign_is_mandatory,)
                {
                (false,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampMillisecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampMillisecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
324    pub(crate) struct UnixTimestampMillisecond {
325        pub(crate) sign_is_mandatory: bool = false,
326    }
327}
328
329#[automatically_derived]
impl ::core::clone::Clone for UnixTimestampMicrosecond {
    #[inline]
    fn clone(&self) -> UnixTimestampMicrosecond {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for UnixTimestampMicrosecond { }
impl ToTokenTree for UnixTimestampMicrosecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&sign_is_mandatory,)
                {
                (false,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampMicrosecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampMicrosecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
330    pub(crate) struct UnixTimestampMicrosecond {
331        pub(crate) sign_is_mandatory: bool = false,
332    }
333}
334
335#[automatically_derived]
impl ::core::clone::Clone for UnixTimestampNanosecond {
    #[inline]
    fn clone(&self) -> UnixTimestampNanosecond {
        let _: ::core::clone::AssertParamIsClone<bool>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for UnixTimestampNanosecond { }
impl ToTokenTree for UnixTimestampNanosecond {
    fn into_token_tree(self) -> TokenTree {
        let Self { sign_is_mandatory } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&sign_is_mandatory,)
                {
                (false,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampNanosecond",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"UnixTimestampNanosecond",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match sign_is_mandatory
                    {
                    false => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_sign_is_mandatory", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(sign_is_mandatory,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
336    pub(crate) struct UnixTimestampNanosecond {
337        pub(crate) sign_is_mandatory: bool = false,
338    }
339}
340
341#[automatically_derived]
impl ::core::clone::Clone for TrailingInput {
    #[inline]
    fn clone(&self) -> TrailingInput { *self }
}
#[automatically_derived]
impl ::core::marker::Copy for TrailingInput { }
impl ToTokenStream for TrailingInput {
    fn append_to(self, ts: &mut TokenStream) {
        {
            use proc_macro::*;
            ts.extend([TokenTree::from(Ident::new(&"TrailingInput",
                                Span::mixed_site()))]);
            ts.extend([TokenTree::from(Punct::new(':', Spacing::Joint)),
                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
            ;
            ;
        };
        let name =
            match self {
                Self::Prohibit => "Prohibit",
                Self::Discard => "Discard",
            };
        ts.extend([TokenTree::Ident(Ident::new(name, Span::mixed_site()))]);
    }
}to_tokens! {
342    pub(crate) enum TrailingInput {
343        Prohibit,
344        Discard,
345    }
346}
347
348#[automatically_derived]
impl ::core::clone::Clone for End {
    #[inline]
    fn clone(&self) -> End {
        let _: ::core::clone::AssertParamIsClone<TrailingInput>;
        *self
    }
}
#[automatically_derived]
impl ::core::marker::Copy for End { }
impl ToTokenTree for End {
    fn into_token_tree(self) -> TokenTree {
        let Self { trailing_input } = self;

        #[allow(clippy :: redundant_pattern_matching)]
        if #[allow(non_exhaustive_omitted_patterns)] match (&trailing_input,)
                {
                (TrailingInput::Prohibit,) => true,
                _ => false,
            } {
            return TokenTree::Group(Group::new(Delimiter::None,
                        {
                            use proc_macro::*;
                            let mut ts = TokenStream::new();
                            let ts_mut = &mut ts;
                            ts_mut.extend([TokenTree::from(Ident::new(&"End",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::from(Punct::new(':',
                                                Spacing::Joint)),
                                        TokenTree::from(Punct::new(':', Spacing::Alone))]);
                            ;
                            ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                                Span::mixed_site()))]);
                            ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                                proc_macro::TokenStream::new()))]);
                            ;
                            ts
                        }));
        }
        let mut tokens =
            {
                use proc_macro::*;
                let mut ts = TokenStream::new();
                let ts_mut = &mut ts;
                ts_mut.extend([TokenTree::from(Ident::new(&"End",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::from(Punct::new(':',
                                    Spacing::Joint)),
                            TokenTree::from(Punct::new(':', Spacing::Alone))]);
                ;
                ts_mut.extend([TokenTree::from(Ident::new(&"default",
                                    Span::mixed_site()))]);
                ts_mut.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    proc_macro::TokenStream::new()))]);
                ;
                ts
            };

        #[allow(clippy :: redundant_pattern_matching)]
        if !#[allow(non_exhaustive_omitted_patterns)] match trailing_input {
                    TrailingInput::Prohibit => true,
                    _ => false,
                } {
            let method_name =
                Ident::new("with_trailing_input", Span::mixed_site());
            {
                use proc_macro::*;
                tokens.extend([TokenTree::from(Punct::new('.',
                                    Spacing::Alone))]);
                ;
                tokens.extend([crate::to_tokens::ToTokenTree::into_token_tree(method_name)]);
                tokens.extend([TokenTree::Group(Group::new(Delimiter::Parenthesis,
                                    {
                                        use proc_macro::*;
                                        let mut ts = TokenStream::new();
                                        let ts_mut = &mut ts;
                                        crate::to_tokens::ToTokenStream::append_to(trailing_input,
                                            ts_mut);
                                        ;
                                        ts
                                    }))]);
                ;
            };
        }
        TokenTree::Group(Group::new(Delimiter::Brace, tokens))
    }
}to_tokens! {
349    pub(crate) struct End {
350        pub(crate) trailing_input: TrailingInput = TrailingInput::Prohibit,
351    }
352}