Rust Macro_rules 嵌套重复

Sol*_*cko 6 macros repeat rust

在宏规则中!转录器,嵌套重复处理不正确。这工作正常:

macro_rules! demo_macro {
    ($op:tt; $($arg:tt),*) {
        ($($op * $arg),*)
    }
}

fn main() {
    println!("{?:}", demo_macro!(2; 1,2,3));
}
Run Code Online (Sandbox Code Playgroud)

和输出(2, 4, 6),但这不会编译:

macro_rules! demo_macro {
    ([$($op:tt)*] $($arg:tt),*) {
        ($($($op)* $arg),*)
    }
}

fn main() {
    println!("{?:}", demo_macro!([2*] 1,2,3));
}
Run Code Online (Sandbox Code Playgroud)

并导致此错误消息:

error: meta-variable `op` repeats 2 times, but `arg` repeats 3 times
 --> src/main.rs:3:11
  |
3 |         ($($($op)* $arg),*)
  |           ^^^^^^^^^^^^^^
Run Code Online (Sandbox Code Playgroud)

如果我更改1,2,31,2使重复计数匹配,我会收到以下错误消息:

error: attempted to repeat an expression containing no syntax variables matched as repeating at this depth
 --> src/main.rs:3:13
  |
3 |         ($($($op)* $arg),*)
  |             ^^^^^
Run Code Online (Sandbox Code Playgroud)

知道如何产生demo_macro!([2*] 1,2,3)结果(2, 4, 6)吗?

Sol*_*cko 6

是的,这有效!

macro_rules! unbracket {
    (_ [$($tt1:tt)*]) => { $($tt1)* };
    (() [$($tt1:tt)*]) => { ($($tt1)*) };
    ([] [$($tt1:tt)*]) => { [$($tt1)*] };
    ({} [$($tt1:tt)*]) => { {$($tt1)*} };
    ($tt0:tt [$($tt1:tt)*] @unbracket ($($tt2:tt)*) $($tt3:tt)*) => { unbracket!{ $tt0 [$($tt1)* $($tt2)*] $($tt3)*} };
    ($tt0:tt [$($tt1:tt)*] @unbracket [$($tt2:tt)*] $($tt3:tt)*) => { unbracket!{ $tt0 [$($tt1)* $($tt2)*] $($tt3)*} };
    ($tt0:tt [$($tt1:tt)*] @unbracket {$($tt2:tt)*} $($tt3:tt)*) => { unbracket!{ $tt0 [$($tt1)* $($tt2)*] $($tt3)*} };
    ($tt0:tt [$($tt1:tt)*] $tt2:tt $($tt3:tt)*) => { unbracket!{$tt0 [$($tt1)* $tt2] $($tt3)*} };
}

macro_rules! demo_macro {
    ($op:tt $($arg:tt),*) => {
        unbracket!(() [] $(@unbracket $op $arg),*)
    }
}

fn main() {
    println!("{:?}", demo_macro!([2*] 1,2,3));
}
Run Code Online (Sandbox Code Playgroud)