aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorliushuyu <liushuyu011@gmail.com>2022-09-26 22:30:33 -0600
committerliushuyu <liushuyu011@gmail.com>2022-09-26 22:30:33 -0600
commit1c19256b70634ab62eeddefed58556bfc4912a90 (patch)
tree533af670fe654b937bece6d89ef28694e0defecd
parentca3a03dd74c0f0300597bca257f7e0f6250fc57b (diff)
downloadgcc-1c19256b70634ab62eeddefed58556bfc4912a90.zip
gcc-1c19256b70634ab62eeddefed58556bfc4912a90.tar.gz
gcc-1c19256b70634ab62eeddefed58556bfc4912a90.tar.bz2
testsuite/rust: add a testcase for testing ...
... builtin macro and decl macro mixed expansion
-rw-r--r--gcc/testsuite/rust/compile/builtin_macro_recurse.rs21
1 files changed, 21 insertions, 0 deletions
diff --git a/gcc/testsuite/rust/compile/builtin_macro_recurse.rs b/gcc/testsuite/rust/compile/builtin_macro_recurse.rs
new file mode 100644
index 0000000..0b516fd
--- /dev/null
+++ b/gcc/testsuite/rust/compile/builtin_macro_recurse.rs
@@ -0,0 +1,21 @@
+// { dg-additional-options "-fdump-tree-gimple" }
+
+#[rustc_builtin_macro]
+macro_rules! concat {
+ () => {{}};
+}
+
+macro_rules! a {
+ () => { "test" };
+}
+
+macro_rules! b {
+ () => { "canary" };
+}
+
+fn main() {
+ // { dg-final { scan-tree-dump-times {"test1canary"} 1 gimple } }
+ let _ = concat!(a!(), 1, b!());
+ // should not error
+ concat!(a!(), true, b!(),);
+}