Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dtolnay/efg

Conditional compilation using boolean expression syntax, rather than any(), all(), not()
https://github.com/dtolnay/efg

Last synced: 5 days ago
JSON representation

Conditional compilation using boolean expression syntax, rather than any(), all(), not()

Awesome Lists containing this project

README

        

Conditional compilation expressions
===================================

[github](https://github.com/dtolnay/efg)
[crates.io](https://crates.io/crates/efg)
[docs.rs](https://docs.rs/efg)
[build status](https://github.com/dtolnay/efg/actions?query=branch%3Amaster)

Conditional compilation using boolean expression syntax, rather than *any()*,
*all()*, *not()*.

```toml
[dependencies]
efg = "0.1"
```


## Summary

Rust's `cfg` and `cfg_attr` conditional compilation attributes use a restrictive
domain-specific language for specifying configuration predicates. The syntax is
described in the *[Conditional compilation]* page of the Rust reference. The
reason for this syntax as opposed to ordinary boolean expressions was to
accommodate restrictions that old versions of rustc used to have on the grammar
of attributes.

However, all restrictions on the attribute grammar were lifted in Rust 1.18.0 by
[rust-lang/rust#40346]. This crate explores implementing conditional compilation
using ordinary boolean expressions
instead: `&&`, `||`, `!` as usual in Rust syntax.

[Conditional compilation]: https://doc.rust-lang.org/1.57.0/reference/conditional-compilation.html
[rust-lang/rust#40346]: https://github.com/rust-lang/rust/pull/40346

built into rustcthis crate
#[cfg(any(thing1, thing2, …))]#[efg(thing1 || thing2 || …)]
#[cfg(all(thing1, thing2, …))]#[efg(thing1 && thing2 && …)]
#[cfg(not(thing))]#[efg(!thing)]


## Examples

A real-world example from the `quote` crate:

```rust
#[efg(feature "proc-macro" && !(target_arch "wasm32" && target_os "unknown"))]
extern crate proc_macro;
```

and from the `proc-macro2` crate:

```rust
#[efg(super_unstable || feature "span-locations")]
pub fn start(&self) -> LineColumn {
```


#### License


Licensed under either of Apache License, Version
2.0
or MIT license at your option.



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