match_cfg

Crates.iomatch_cfg
lib.rsmatch_cfg
version0.1.0
sourcesrc
created_at2019-04-02 10:50:59.802728
updated_at2019-04-02 10:50:59.802728
descriptionA 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.
homepagehttps://github.com/gnzlbg/match_cfg
repositoryhttps://github.com/gnzlbg/match_cfg
max_upload_size
id125332
size20,199
gnzlbg (gnzlbg)

documentation

https://docs.rs/match_cfg

README

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.

Commit count: 4

cargo fmt