| // 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<T> 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<T> 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" |
| // |
| |
| " |
| ) |
| }; |
| } |