在macro_rules中使用另一个宏而不需要生锈的“extern crate”

问题描述 投票:2回答:1

有没有办法“重新导出”#[macro_use] extern crate类似于pub use,以便使用宏的宏的用户不必手动添加这些依赖的extern crates?

问题的其余部分是一个例子来说明。

src/lib.rs,请注意id宏正在使用lazy_static宏:

#[macro_export]
macro_rules! id {
    () => {
        lazy_static! {
            static ref NUMBER : std::sync::atomic::AtomicUsize =
                std::sync::atomic::AtomicUsize::new(0);
        }
        return NUMBER.fetch_add(1, std::sync::atomic::Ordering::SeqCst);
    }
}

examples/example.rs,我们需要每个宏的extern crate线,即使我们只是直接使用id宏:

#[macro_use]
extern crate id_macro;
#[macro_use]
extern crate lazy_static;

fn new_id() -> usize {
    id!();
}

fn main() {
    println!("id {}", new_id()); // prints "id 0"
    println!("id {}", new_id()); // prints "id 1"
}

在这个例子中,如果id_macro的用户可以在不知道id!的情况下使用lazy_static,那就太棒了。有没有办法像extern crate那样“再出口”pub use,以使以下几行脱离示例?

#[macro_use]
extern crate lazy_static;
macros rust
1个回答
3
投票

有一个不稳定的macro_reexport属性。

但是,Rust正在努力使宏(2.0)表现得像支持pub use的普通项一样,所以这个属性将不稳定并且将变得过时。

© www.soinside.com 2019 - 2024. All rights reserved.