#[macro_export]
#[doc(alias = "tuple")]
#[doc(alias = "preceded")]
#[doc(alias = "terminated")]
#[doc(alias = "delimited")]
#[doc(alias = "pair")]
#[doc(alias = "separated_pair")]
#[doc(alias = "struct_parser")]
macro_rules! seq {
($name: ident { $($fields: tt)* }) => {
$crate::combinator::trace(stringify!($name), move |input: &mut _| {
use $crate::Parser;
$crate::seq_parse_struct_fields!(input; $($fields)*);
#[allow(clippy::redundant_field_names)]
Ok($crate::seq_init_struct_fields!( ($($fields)*); $name;))
})
};
($name: ident ( $($elements: tt)* )) => {
$crate::combinator::trace(stringify!($name), move |input: &mut _| {
use $crate::Parser;
$crate::seq_parse_tuple_fields!( ($($elements)*) ; ).map(|t| {
$crate::seq_init_tuple_fields!(
($($elements)*);
(t.0, t.1, t.2, t.3, t.4, t.5, t.6, t.7, t.8, t.9, t.10, t.11, t.12, t.13, t.14, t.15, t.16, t.17, t.18, t.19, t.20);
$name;
)
}).parse_next(input)
})
};
(( $($elements: tt)* )) => {
$crate::combinator::trace("tuple", move |input: &mut _| {
use $crate::Parser;
$crate::seq_parse_tuple_fields!( ($($elements)*) ; ).map(|t| {
$crate::seq_init_tuple_fields!(
($($elements)*);
(t.0, t.1, t.2, t.3, t.4, t.5, t.6, t.7, t.8, t.9, t.10, t.11, t.12, t.13, t.14, t.15, t.16, t.17, t.18, t.19, t.20);
;
)
}).parse_next(input)
})
};
($($elements: tt)*) => {
$crate::seq!(($($elements)*))
};
}
#[macro_export]
#[doc(hidden)]
macro_rules! seq_parse_struct_fields {
(
$input: ident;
_ : $head_parser: expr, $($fields: tt)*
) => {
let _ = $head_parser.parse_next($input)?;
$crate::seq_parse_struct_fields!($input; $($fields)*)
};
(
$input: ident;
_ : $head_parser: expr
) => {
let _ = $head_parser.parse_next($input)?;
};
(
$input: ident;
$head_field: ident : $head_parser: expr, $($fields: tt)*
) => {
let $head_field = $head_parser.parse_next($input)?;
$crate::seq_parse_struct_fields!($input; $($fields)*)
};
(
$input: ident;
$head_field: ident : $head_parser: expr
) => {
let $head_field = $head_parser.parse_next($input)?;
};
(
$input: expr;
.. $update: expr
) => {};
(
$input: expr;
$(,)?
) => {};
}
#[macro_export]
#[doc(hidden)]
macro_rules! seq_parse_tuple_fields {
(
(_ : $head_parser: expr, $($fields: tt)* );
$($sequenced: tt)*
) => {
$crate::seq_parse_tuple_fields!( ( $($fields)* ) ; $($sequenced)* $head_parser.void(), )
};
(
(_ : $head_parser: expr);
$($sequenced: tt)*
) => {
$crate::seq_parse_tuple_fields!((); $($sequenced)* $head_parser.void(), )
};
(
($head_parser: expr, $($fields: tt)*);
$($sequenced: tt)*
) => {
$crate::seq_parse_tuple_fields!( ( $($fields)* ) ; $($sequenced)* $head_parser, )
};
(
($head_parser: expr);
$($sequenced: tt)*
)=> {
$crate::seq_parse_tuple_fields!((); $($sequenced)* $head_parser, )
};
(
();
$($sequenced: tt)*
) => {
($($sequenced)*)
};
}
#[macro_export]
#[doc(hidden)]
macro_rules! seq_init_struct_fields {
(
(_ : $head_parser: expr, $($fields: tt)*);
$name: ident;
$($inits: tt)*
) => {
$crate::seq_init_struct_fields!( ( $($fields)* ) ; $name ; $($inits)* )
};
(
(_ : $head_parser: expr);
$name: ident;
$($inits: tt)*
) => {
$crate::seq_init_struct_fields!( (); $name ; $($inits)* )
};
(
($head_field: ident : $head_parser: expr, $($fields: tt)*);
$name: ident;
$($inits: tt)*
) =>
{
$crate::seq_init_struct_fields!( ( $($fields)* ) ; $name ; $($inits)* $head_field: $head_field, )
};
(
($head_field: ident : $head_parser: expr);
$name: ident;
$($inits: tt)*
) => {
$crate::seq_init_struct_fields!( (); $name ; $($inits)* $head_field: $head_field,)
};
(
(.. $update: expr);
$name: ident;
$($inits: tt)*
) => {
$name { $($inits)* ..$update }
};
(
($(,)?);
$name: ident;
$($inits: tt)*
) => {
$name { $($inits)* }
};
}
#[macro_export]
#[doc(hidden)]
macro_rules! seq_init_tuple_fields {
(
(_ : $head_parser: expr, $($fields: tt)*);
($head_arg: expr, $($args: expr),*);
$($name: ident)?;
$($inits: tt)*
) => {
$crate::seq_init_tuple_fields!( ( $($fields)* ); ( $($args),* ) ; $($name)? ; $($inits)* )
};
(
(_ : $head_parser: expr);
($head_arg: expr, $($args: expr),*);
$($name: ident)?;
$($inits: tt)*
) => {
$crate::seq_init_tuple_fields!((); ( $($args),* ); $($name)? ; $($inits)*)
};
(
($head_parser: expr, $($fields: tt)*);
($head_arg: expr, $($args: expr),*);
$($name: ident)?;
$($inits: tt)*
) => {
$crate::seq_init_tuple_fields!( ( $($fields)* ) ; ( $($args),* ) ; $($name)? ; $($inits)* $head_arg, )
};
(
($head_parser: expr);
($head_arg: expr, $($args: expr),*);
$($name: ident)?;
$($inits: tt)*
) => {
$crate::seq_init_tuple_fields!((); ( $($args),* ); $($name)? ; $($inits)* $head_arg)
};
(
();
($($args: expr),*);
$($name: ident)?;
$($inits: expr),* $(,)?
) => {
$($name)?( $($inits,)* )
};
}