我如何在类型上而不是在类型内部使用自定义名称派生的MACRO属性



我想创建一个使用新名称属性语法的自定义衍生宏: example::attr。我已经能够将其与类型中的属性(例如在struct字段或枚举变体上)一起使用,但是当应用于类型本身时。

src/main.rs

use repro_derive::Example;
#[derive(Example)]
#[example::attr]     // Does not work
struct Demo {
    #[example::attr] // Works
    field: i32,
}
fn main() {}

程序宏本身无济于事,除了声明example::attr是有效的属性。

repro-derive/src/lib.rs

extern crate proc_macro;
use proc_macro::TokenStream;
#[proc_macro_derive(Example, attributes(example::attr))]
pub fn example_derive(_input: TokenStream) -> TokenStream {
    TokenStream::new()
}

编译产量:

error[E0433]: failed to resolve: use of undeclared type or module `example`
 --> src/main.rs:4:3
  |
4 | #[example::attr]
  |   ^^^^^^^ use of undeclared type or module `example`

切换到属性(example_attr)的非命名形式都很好。


我正在使用Rust 1.32.0。项目布局是

$ tree
.
├── Cargo.lock
├── Cargo.toml
├── repro-derive
│   ├── Cargo.toml
│   └── src
│       └── lib.rs
└── src
    └── main.rs

cargo.toml

$ cat Cargo.toml
[package]
name = "repro"
version = "0.1.0"
authors = ["Author"]
edition = "2018"
[dependencies]
repro-derive = { path = "repro-derive" }

repro-derive/cargo.toml

[package]
name = "repro-derive"
version = "0.1.0"
authors = ["Author"]
edition = "2018"
[lib]
proc-macro = true
[dependencies]

proc_macro_derive属性中声明的名称空间完全被忽略,这是一个已知的错误。由于此错误,可以编译以下代码,尽管不应该是。

#[derive(Example)]
#[attr]             // Works (but shouldn't)
struct Demo {
    #[lolwut::attr] // Works (but shouldn't)
    field: i32,
}

直到固定错误,您应该继续使用非命名的表单(example_attr)。

此外,根据此错误报告,从RUST 1.33.0开始, no 通过Proc-Macros实现OP想要的方法,以及如何允许#[example::attr]工作仍在设计中。

最新更新