diff options
author | Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com> | 2023-07-21 14:18:12 +0200 |
---|---|---|
committer | Arthur Cohen <arthur.cohen@embecosm.com> | 2024-01-16 18:56:00 +0100 |
commit | e58650e6df390e71e7ce880c6bc895a4c4930e25 (patch) | |
tree | 6c8a5f120466d6ff2b18c5f80b1e7afdc133e7e9 | |
parent | 3c1cc1190a23f6dc9c5028e1b92e7bbb85651ac3 (diff) | |
download | gcc-e58650e6df390e71e7ce880c6bc895a4c4930e25.zip gcc-e58650e6df390e71e7ce880c6bc895a4c4930e25.tar.gz gcc-e58650e6df390e71e7ce880c6bc895a4c4930e25.tar.bz2 |
gccrs: Add tests for non function proc_macro_derive
Add a bunch of test cases to avoid regressions on proc_macro_derive
attribute errors when placed on any non function item.
gcc/testsuite/ChangeLog:
* rust/compile/proc_macro_derive_non_function.rs: New test.
Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
-rw-r--r-- | gcc/testsuite/rust/compile/proc_macro_derive_non_function.rs | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/gcc/testsuite/rust/compile/proc_macro_derive_non_function.rs b/gcc/testsuite/rust/compile/proc_macro_derive_non_function.rs new file mode 100644 index 0000000..7cb4c0b --- /dev/null +++ b/gcc/testsuite/rust/compile/proc_macro_derive_non_function.rs @@ -0,0 +1,60 @@ +// { dg-additional-options "-frust-crate-type=proc-macro" } + +trait ToDerive {} + +mod inner { + struct InnerStruct; +} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +type AliasedType = inner::InnerStruct; + +// { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" "" { target *-*-* } .+1 } +#[proc_macro_derive(ToDerive)] +use inner::InnerStruct; + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +struct MyStruct; + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +struct MyCurlyStruct { + member: usize, +} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +struct MyTupleStruct(usize); + +#[proc_macro_derive(ToDerive)] +// { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" "" { target *-*-* } .-1 } +extern crate my_extern_crate; // { dg-error "unknown crate .my_extern_crate." } + // { dg-error "failed to locate crate .my_extern_crate." "" { target *-*-* } .-1 } + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +mod my_module {} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +enum MyEnum {} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +union MyUnion { + f1: u32, + f2: f32, +} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +const MY_CONST_STR: &str = "my_string"; + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +static MY_STATIC_USIZE: usize = 10; + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +trait MyTrait {} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +impl MyStruct {} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +impl MyTrait for MyStruct {} + +#[proc_macro_derive(ToDerive)] // { dg-error "the .#.proc_macro_derive.. attribute may only be used on bare functions" } +extern "C" {} |