macro_rules! make_macro { ($macro_name:ident $($matcher:tt)*) => { #[macro_export] macro_rules! $macro_name { (<= $($matcher)* =>) => {}; } } } // @has macro_generated_macro/macro.interpolations.html //pre 'macro_rules! interpolations {' // @has - //pre '(<= type $($i:ident)::* + $e:expr =>) => { ... };' make_macro!(interpolations type $($i:ident)::* + $e:expr); interpolations!(<= type foo::bar + x.sort() =>); // @has macro_generated_macro/macro.attributes.html //pre 'macro_rules! attributes {' // @has - //pre '(<= #![no_std] #[cfg(feature = "alloc")] =>) => { ... };' make_macro!(attributes #![no_std] #[cfg(feature = "alloc")]); // @has macro_generated_macro/macro.groups.html //pre 'macro_rules! groups {' // @has - //pre '(<= fn {} () { foo[0] } =>) => { ... };' make_macro!(groups fn {}() {foo[0]}); // @snapshot macro_linebreak_pre macro_generated_macro/macro.linebreak.html //pre/text() make_macro!(linebreak 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28); // @snapshot macro_morestuff_pre macro_generated_macro/macro.morestuff.html //pre/text() make_macro!(morestuff "space between most kinds of tokens": 1 $x + @ :: >>= 'static "no space inside paren or bracket": (2 a) [2 a] $(2 $a:tt)* "space inside curly brace": { 2 a } "no space inside empty delimiters": () [] {} "no space before comma or semicolon": a, (a), { a }, a; [T; 0]; "the three repetition specifiers": $(@)*, $(@)+, $(@)? "repetition separators": $(@)|*, $(@)|+, $(@)==*, $(@)static* "plus or star cannot be a repetition separator": $(@)+ * $(@)* + "no space between ident and paren": let _ = f(0) + f[0] + Struct {}; "space between keyword and paren": return (a,) & for x in (..) "some special case keywords": pub(crate), fn() -> u8, Self(0, 0) );