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}