#macro #cfg #numbers #match #depending #statement #libcore

match_cfg

A convenience macro to ergonomically define an item depending on a large number of #[cfg] parameters. Structured like match statement, the first matching branch is the item that gets emitted.

1 unstable release

Uses old Rust 2015

0.1.0 Apr 2, 2019

#1097 in Rust patterns

Download history 409947/week @ 2024-03-14 408753/week @ 2024-03-21 406140/week @ 2024-03-28 412255/week @ 2024-04-04 410607/week @ 2024-04-11 409040/week @ 2024-04-18 388228/week @ 2024-04-25 381094/week @ 2024-05-02 377550/week @ 2024-05-09 401312/week @ 2024-05-16 395575/week @ 2024-05-23 412038/week @ 2024-05-30 397873/week @ 2024-06-06 404700/week @ 2024-06-13 394089/week @ 2024-06-20 336963/week @ 2024-06-27

1,618,782 downloads per month

MIT/Apache

8KB
129 lines

match_cfg

Build Status

Documentation

Minimum Supported Rust Version: 1.13.0.

A convenience macro to ergonomically define an item depending on a large number of #[cfg] parameters. Structured like match statement, the first matching branch is the item that gets emitted.

[dependencies]
match_cfg = "0.1"

The use_core feature is enabled by default and builds the crate with libcore as a dependency by using the #![no_std] attribute. When this feature is disabled, this crate is built without libcore support by using the #![no_core] attribute - this makes use of the #![feature(no_core)] and requires a nightly version of Rust.

Example

#[macro_use(match_cfg)]
extern crate match_cfg;

match_cfg! {
    #[cfg(unix)] => {
         fn foo() { /* unix specific functionality */ }
     }
     #[cfg(target_pointer_width = "32")] => {
         fn foo() { /* non-unix, 32-bit functionality */ }
     }
     _ => {
         fn foo() { /* fallback implementation */ }
     }
}

fn main() {
    foo();
}

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Serde by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps

Features