rust/tests/target/macro_rules.rs

361 lines
8.1 KiB
Rust
Raw Normal View History

// rustfmt-format_macro_matchers: true
2018-03-18 01:08:02 +09:00
macro_rules! m {
() => {};
2018-03-22 16:09:21 +09:00
($x:ident) => {};
($m1:ident, $m2:ident, $x:ident) => {};
($($beginning:ident),*; $middle:ident; $($end:ident),*) => {};
2018-03-18 01:08:02 +09:00
(
2018-03-22 16:09:21 +09:00
$($beginning:ident),*;
$middle:ident;
$($end:ident),*;
$($beginning:ident),*;
$middle:ident;
$($end:ident),*
2018-03-18 01:08:02 +09:00
) => {};
2018-03-22 16:09:21 +09:00
($name:ident($($dol:tt $var:ident)*) $($body:tt)*) => {};
(
2018-03-22 16:09:21 +09:00
$($i:ident : $ty:ty, $def:expr, $stb:expr, $($dstring:tt),+);+ $(;)*
$($i:ident : $ty:ty, $def:expr, $stb:expr, $($dstring:tt),+);+ $(;)*
) => {};
2018-03-22 16:09:21 +09:00
($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),*) => {};
2018-03-18 01:08:02 +09:00
}
2018-03-18 14:08:24 +09:00
macro_rules! impl_a_method {
2018-03-22 16:09:21 +09:00
($n:ident($a:ident : $ta:ty) -> $ret:ty { $body:expr }) => {
2018-03-18 14:08:24 +09:00
fn $n($a: $ta) -> $ret {
$body
}
macro_rules! $n {
($va: expr) => {
$n($va)
};
}
};
2018-03-22 16:09:21 +09:00
($n:ident($a:ident : $ta:ty, $b:ident : $tb:ty) -> $ret:ty { $body:expr }) => {
2018-03-18 14:08:24 +09:00
fn $n($a: $ta, $b: $tb) -> $ret {
$body
}
macro_rules! $n {
($va: expr,$vb: expr) => {
$n($va, $vb)
};
}
};
(
2018-03-22 16:09:21 +09:00
$n:ident($a:ident : $ta:ty, $b:ident : $tb:ty, $c:ident : $tc:ty) -> $ret:ty { $body:expr }
2018-03-18 14:08:24 +09:00
) => {
fn $n($a: $ta, $b: $tb, $c: $tc) -> $ret {
$body
}
macro_rules! $n {
($va: expr,$vb: expr,$vc: expr) => {
$n($va, $vb, $vc)
};
}
};
(
2018-03-22 16:09:21 +09:00
$n:ident($a:ident : $ta:ty, $b:ident : $tb:ty, $c:ident : $tc:ty, $d:ident : $td:ty) ->
$ret:ty { $body:expr }
2018-03-18 14:08:24 +09:00
) => {
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)
};
}
};
}
2018-01-24 19:09:49 +00:00
macro_rules! m {
2018-01-30 17:05:31 +00:00
// a
2018-03-22 16:09:21 +09:00
($expr:expr, $($func:ident)*) => {{
2018-01-25 14:06:37 +00:00
let x = $expr;
$func(x)
}};
2018-01-24 19:09:49 +00:00
2018-01-30 17:05:31 +00:00
/* b */
() => {
/* c */
};
(@tag) => {};
2018-01-24 19:09:49 +00:00
2018-01-30 17:05:31 +00:00
// d
2018-03-22 16:09:21 +09:00
($item:ident) => {
2018-01-24 19:09:49 +00:00
mod macro_item {
struct $item;
}
};
}
2018-01-30 17:05:31 +00:00
macro m2 {
// a
2018-03-22 16:09:21 +09:00
($expr:expr, $($func:ident)*) => {{
2018-01-30 17:05:31 +00:00
let x = $expr;
$func(x)
}}
/* b */
() => {
/* c */
}
(@tag) => {}
// d
2018-03-22 16:09:21 +09:00
($item:ident) => {
2018-01-30 17:05:31 +00:00
mod macro_item {
struct $item;
}
}
}
2018-02-23 08:10:17 +09:00
// #2438, #2476
macro_rules! m {
() => {
2018-02-23 08:10:17 +09:00
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 {
(
2018-03-22 16:09:21 +09:00
$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
2018-03-22 16:09:21 +09:00
macro foo($type_name:ident, $docs:expr) {
#[allow(non_camel_case_types)]
#[doc=$docs]
#[derive(Debug, Clone, Copy)]
pub struct $type_name;
}
2018-03-17 14:58:56 +09:00
// #2534
macro_rules! foo {
2018-03-22 16:09:21 +09:00
($a:ident : $b:ty) => {};
($a:ident $b:ident $c:ident) => {};
}
2018-03-17 14:58:56 +09:00
// #2538
macro_rules! add_message_to_notes {
2018-03-22 16:09:21 +09:00
($msg:expr) => {{
2018-03-17 14:58:56 +09:00
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,
));
}
}};
}
2018-03-26 20:45:39 +08:00
// #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)()?) => {};
}
2018-05-30 08:09:56 +09:00
// #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)+)*
),
)*
}
) => {};
}
2018-06-07 12:30:14 +09:00
// #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");
};
}
2018-07-01 09:59:45 +09:00
// #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()
}
}
};
}
2018-08-16 07:09:52 +09:00
// #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);
}};
}
}
}
2018-08-31 10:37:22 +09:00
// #2642
macro_rules! template {
($name:expr) => {
format_args!(
r##"
"http://example.com"
# test
"##,
$name
)
};
}
macro_rules! template {
() => {
format_args!(
r"
//
"
)
};
}