summaryrefslogtreecommitdiffstats
path: root/tests/ui/parser/macro
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:59:35 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:59:35 +0000
commitd1b2d29528b7794b41e66fc2136e395a02f8529b (patch)
treea4a17504b260206dec3cf55b2dca82929a348ac2 /tests/ui/parser/macro
parentReleasing progress-linux version 1.72.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-d1b2d29528b7794b41e66fc2136e395a02f8529b.tar.xz
rustc-d1b2d29528b7794b41e66fc2136e395a02f8529b.zip
Merging upstream version 1.73.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/parser/macro')
-rw-r--r--tests/ui/parser/macro/macro-expand-to-field.rs70
-rw-r--r--tests/ui/parser/macro/macro-expand-to-field.stderr74
-rw-r--r--tests/ui/parser/macro/macro-expand-to-match-arm.rs18
-rw-r--r--tests/ui/parser/macro/macro-expand-to-match-arm.stderr10
4 files changed, 172 insertions, 0 deletions
diff --git a/tests/ui/parser/macro/macro-expand-to-field.rs b/tests/ui/parser/macro/macro-expand-to-field.rs
new file mode 100644
index 000000000..155872f7a
--- /dev/null
+++ b/tests/ui/parser/macro/macro-expand-to-field.rs
@@ -0,0 +1,70 @@
+// compile-flags: --crate-type=lib
+
+macro_rules! field {
+ ($name:ident:$type:ty) => {
+ $name:$type
+ };
+}
+
+macro_rules! variant {
+ ($name:ident) => {
+ $name
+ }
+}
+
+struct Struct {
+ field!(bar:u128),
+ //~^ NOTE macros cannot expand to struct fields
+ //~| ERROR unexpected token: `!`
+ //~| NOTE unexpected token after this
+ a: u32,
+ b: u32,
+ field!(recovers:()), //~ NOTE macros cannot expand to struct fields
+ //~^ ERROR unexpected token: `!`
+ //~^^ NOTE unexpected token after this
+}
+
+enum EnumVariant {
+ variant!(whoops),
+ //~^ NOTE macros cannot expand to enum variants
+ //~| ERROR unexpected token: `!`
+ //~| NOTE unexpected token after this
+ U32,
+ F64,
+ variant!(recovers),
+ //~^ NOTE macros cannot expand to enum variants
+ //~| ERROR unexpected token: `!`
+ //~| NOTE unexpected token after this
+ Data {
+ field!(x:u32),
+ //~^ NOTE macros cannot expand to struct fields
+ //~| ERROR unexpected token: `!`
+ //~| NOTE unexpected token after this
+ }
+}
+
+enum EnumVariantField {
+ Named {
+ field!(oopsies:()),
+ //~^ NOTE macros cannot expand to struct fields
+ //~| ERROR unexpected token: `!`
+ //~| unexpected token after this
+ field!(oopsies2:()),
+ //~^ NOTE macros cannot expand to struct fields
+ //~| ERROR unexpected token: `!`
+ //~| unexpected token after this
+ },
+}
+
+union Union {
+ A: u32,
+ field!(oopsies:()),
+ //~^ NOTE macros cannot expand to union fields
+ //~| ERROR unexpected token: `!`
+ //~| unexpected token after this
+ B: u32,
+ field!(recovers:()),
+ //~^ NOTE macros cannot expand to union fields
+ //~| ERROR unexpected token: `!`
+ //~| unexpected token after this
+}
diff --git a/tests/ui/parser/macro/macro-expand-to-field.stderr b/tests/ui/parser/macro/macro-expand-to-field.stderr
new file mode 100644
index 000000000..adcd032f5
--- /dev/null
+++ b/tests/ui/parser/macro/macro-expand-to-field.stderr
@@ -0,0 +1,74 @@
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:16:10
+ |
+LL | field!(bar:u128),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to struct fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:22:10
+ |
+LL | field!(recovers:()),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to struct fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:28:12
+ |
+LL | variant!(whoops),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to enum variants
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:34:12
+ |
+LL | variant!(recovers),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to enum variants
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:39:14
+ |
+LL | field!(x:u32),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to struct fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:48:14
+ |
+LL | field!(oopsies:()),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to struct fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:52:14
+ |
+LL | field!(oopsies2:()),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to struct fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:61:10
+ |
+LL | field!(oopsies:()),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to union fields
+
+error: unexpected token: `!`
+ --> $DIR/macro-expand-to-field.rs:66:10
+ |
+LL | field!(recovers:()),
+ | ^ unexpected token after this
+ |
+ = note: macros cannot expand to union fields
+
+error: aborting due to 9 previous errors
+
diff --git a/tests/ui/parser/macro/macro-expand-to-match-arm.rs b/tests/ui/parser/macro/macro-expand-to-match-arm.rs
new file mode 100644
index 000000000..39d1d065e
--- /dev/null
+++ b/tests/ui/parser/macro/macro-expand-to-match-arm.rs
@@ -0,0 +1,18 @@
+macro_rules! arm {
+ ($pattern:pat => $block:block) => {
+ $pattern => $block
+ };
+}
+
+fn main() {
+ let x = Some(1);
+ match x {
+ Some(1) => {},
+ arm!(None => {}),
+ //~^ NOTE macros cannot expand to match arms
+ //~| ERROR unexpected `,` in pattern
+ // doesn't recover
+ Some(2) => {},
+ _ => {},
+ };
+}
diff --git a/tests/ui/parser/macro/macro-expand-to-match-arm.stderr b/tests/ui/parser/macro/macro-expand-to-match-arm.stderr
new file mode 100644
index 000000000..1a5f46968
--- /dev/null
+++ b/tests/ui/parser/macro/macro-expand-to-match-arm.stderr
@@ -0,0 +1,10 @@
+error: unexpected `,` in pattern
+ --> $DIR/macro-expand-to-match-arm.rs:11:25
+ |
+LL | arm!(None => {}),
+ | ^
+ |
+ = note: macros cannot expand to match arms
+
+error: aborting due to previous error
+