15 releases (4 stable)
| 1.0.4 | Oct 15, 2025 |
|---|---|
| 1.0.1 | Jun 9, 2025 |
| 1.0.0 | Oct 6, 2020 |
| 0.1.10 | Sep 24, 2019 |
| 0.1.0 | Jul 8, 2015 |
#41 in Rust patterns
54,084,140 downloads per month
Used in 126,288 crates
(2,545 directly)
10KB
143 lines
cfg-if
A macro to ergonomically define an item depending on a large number of #[cfg] parameters. Structured like an if-else chain, the first matching branch is the item that gets emitted.
[dependencies]
cfg-if = "1.0"
Example
cfg_if::cfg_if! {
if #[cfg(unix)] {
fn foo() { /* unix specific functionality */ }
} else if #[cfg(target_pointer_width = "32")] {
fn foo() { /* non-unix, 32-bit functionality */ }
} else {
fn foo() { /* fallback implementation */ }
}
}
fn main() {
foo();
}
The cfg_if! block above is expanded to:
#[cfg(unix)]
fn foo() { /* unix specific functionality */ }
#[cfg(all(target_pointer_width = "32", not(unix)))]
fn foo() { /* non-unix, 32-bit functionality */ }
#[cfg(not(any(unix, target_pointer_width = "32")))]
fn foo() { /* fallback implementation */ }
License
This project is licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in cfg-if by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.