// rustfmt-format_macro_matchers: true macro_rules! m { () => {}; ($x:ident) => {}; ($m1:ident, $m2:ident, $x:ident) => {}; ($($beginning:ident),*; $middle:ident; $($end:ident),*) => {}; ( $($beginning:ident),*; $middle:ident; $($end:ident),*; $($beginning:ident),*; $middle:ident; $($end:ident),* ) => {}; ($name:ident($($dol:tt $var:ident)*) $($body:tt)*) => {}; ( $($i:ident : $ty:ty, $def:expr, $stb:expr, $($dstring:tt),+);+ $(;)* $($i:ident : $ty:ty, $def:expr, $stb:expr, $($dstring:tt),+);+ $(;)* ) => {}; ($foo:tt foo[$attr:meta] $name:ident) => {}; ($foo:tt[$attr:meta] $name:ident) => {}; ($foo:tt &'a[$attr:meta] $name:ident) => {}; ($foo:tt foo #[$attr:meta] $name:ident) => {}; ($foo:tt #[$attr:meta] $name:ident) => {}; ($foo:tt &'a #[$attr:meta] $name:ident) => {}; ($x:tt foo bar foo bar foo bar $y:tt => x * y * z $z:tt, $($a:tt),*) => {}; } macro_rules! impl_a_method { ($n:ident($a:ident : $ta:ty) -> $ret:ty { $body:expr }) => { fn $n($a: $ta) -> $ret { $body } macro_rules! $n { ($va: expr) => { $n($va) }; } }; ($n:ident($a:ident : $ta:ty, $b:ident : $tb:ty) -> $ret:ty { $body:expr }) => { fn $n($a: $ta, $b: $tb) -> $ret { $body } macro_rules! $n { ($va: expr,$vb: expr) => { $n($va, $vb) }; } }; ( $n:ident($a:ident : $ta:ty, $b:ident : $tb:ty, $c:ident : $tc:ty) -> $ret:ty { $body:expr } ) => { fn $n($a: $ta, $b: $tb, $c: $tc) -> $ret { $body } macro_rules! $n { ($va: expr,$vb: expr,$vc: expr) => { $n($va, $vb, $vc) }; } }; ( $n:ident($a:ident : $ta:ty, $b:ident : $tb:ty, $c:ident : $tc:ty, $d:ident : $td:ty) -> $ret:ty { $body:expr } ) => { fn $n($a: $ta, $b: $tb, $c: $tc, $d: $td) -> $ret { $body } macro_rules! $n { ($va: expr,$vb: expr,$vc: expr,$vd: expr) => { $n($va, $vb, $vc, $vd) }; } }; } macro_rules! m { // a ($expr:expr, $($func:ident)*) => {{ let x = $expr; $func(x) }}; /* b */ () => { /* c */ }; (@tag) => {}; // d ($item:ident) => { mod macro_item { struct $item; } }; } macro m2 { // a ($expr:expr, $($func:ident)*) => {{ let x = $expr; $func(x) }} /* b */ () => { /* c */ } (@tag) => {} // d ($item:ident) => { mod macro_item { struct $item; } } } // #2438, #2476 macro_rules! m { () => { fn foo() { this_line_is_98_characters_long_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx(); } }; } macro_rules! m { () => { fn foo() { this_line_is_99_characters_long_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx( ); } }; } macro_rules! m { () => { fn foo() { this_line_is_100_characters_long_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx( ); } }; } macro_rules! m { () => { fn foo() { this_line_is_101_characters_long_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx( ); } }; } // #2439 macro_rules! m { ( $line0_xxxxxxxxxxxxxxxxx:expr, $line1_xxxxxxxxxxxxxxxxx:expr, $line2_xxxxxxxxxxxxxxxxx:expr, $line3_xxxxxxxxxxxxxxxxx:expr, ) => {}; } // #2466 // Skip formatting `macro_rules!` that are not using `{}`. macro_rules! m ( () => () ); macro_rules! m [ () => () ]; // #2470 macro foo($type_name: ident, $docs: expr) { #[allow(non_camel_case_types)] #[doc=$docs] #[derive(Debug, Clone, Copy)] pub struct $type_name; } // #2534 macro_rules! foo { ($a:ident : $b:ty) => {}; ($a:ident $b:ident $c:ident) => {}; } // #2538 macro_rules! add_message_to_notes { ($msg:expr) => {{ let mut lines = message.lines(); notes.push_str(&format!("\n{}: {}", level, lines.next().unwrap())); for line in lines { notes.push_str(&format!( "\n{:indent$}{line}", "", indent = level.len() + 2, line = line, )); } }}; } // #2560 macro_rules! binary { ($_self:ident, $expr:expr, $lhs:expr, $func:ident) => { while $_self.matched($expr) { let op = $_self.get_binary_op()?; let rhs = Box::new($_self.$func()?); $lhs = Spanned { span: $lhs.get_span().to(rhs.get_span()), value: Expression::Binary { lhs: Box::new($lhs), op, rhs, }, } } }; } // #2558 macro_rules! m { ($x:) => {}; ($($foo:expr)()?) => {}; } // #2749 macro_rules! foo { ($(x)* {}) => {}; ($(x)*()) => {}; ($(x)*[]) => {}; } macro_rules! __wundergraph_expand_sqlite_mutation { ( $mutation_name:ident $((context = $($context:tt)*))* { $( $entity_name:ident( $(insert = $insert:ident,)* $(update = $update:ident,)* $(delete = $($delete:tt)+)* ), )* } ) => {}; } // #2607 macro_rules! bench { ($ty:ident) => { criterion_group!( name = benches; config = ::common_bench::reduced_samples(); targets = call, map; ); }; } // #2770 macro_rules! save_regs { () => { asm!("push rax push rcx push rdx push rsi push rdi push r8 push r9 push r10 push r11" :::: "intel", "volatile"); }; } // #2721 macro_rules! impl_as_byte_slice_arrays { ($n:expr,) => {}; ($n:expr, $N:ident, $($NN:ident,)*) => { impl_as_byte_slice_arrays!($n - 1, $($NN,)*); impl AsByteSliceMut for [T; $n] where [T]: AsByteSliceMut { fn as_byte_slice_mut(&mut self) -> &mut [u8] { self[..].as_byte_slice_mut() } fn to_le(&mut self) { self[..].to_le() } } }; (!div $n:expr,) => {}; (!div $n:expr, $N:ident, $($NN:ident,)*) => { impl_as_byte_slice_arrays!(!div $n / 2, $($NN,)*); impl AsByteSliceMut for [T; $n] where [T]: AsByteSliceMut { fn as_byte_slice_mut(&mut self) -> &mut [u8] { self[..].as_byte_slice_mut() } fn to_le(&mut self) { self[..].to_le() } } }; } // #2919 fn foo() { { macro_rules! touch_value { ($func:ident, $value:expr) => {{ let result = API::get_cached().$func( self, key.as_ptr(), $value, ffi::VSPropAppendMode::paTouch, ); let result = API::get_cached().$func(self, key.as_ptr(), $value, ffi::VSPropAppend); let result = API::get_cached().$func(self, key.as_ptr(), $value, ffi::VSPropAppendM); let result = APIIIIIIIII::get_cached().$func(self, key.as_ptr(), $value, ffi::VSPropAppendM); let result = API::get_cached().$func( self, key.as_ptr(), $value, ffi::VSPropAppendMMMMMMMMMM, ); debug_assert!(result == 0); }}; } } } // #2642 macro_rules! template { ($name:expr) => { format_args!( r##" "http://example.com" # test "##, $name ) }; } macro_rules! template { () => { format_args!( r" // " ) }; }