Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dcbaker/toml-describe
Crate for describing common checks from build.rs in Cargo.toml instead
https://github.com/dcbaker/toml-describe
Last synced: about 1 month ago
JSON representation
Crate for describing common checks from build.rs in Cargo.toml instead
- Host: GitHub
- URL: https://github.com/dcbaker/toml-describe
- Owner: dcbaker
- License: mit
- Created: 2023-11-02T20:30:01.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-07T17:43:24.000Z (3 months ago)
- Last Synced: 2024-10-14T16:56:45.456Z (3 months ago)
- Language: Rust
- Size: 43 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Toml Describe
Toml-describe is a rust crate to allow describing feature checks in toml, instead of open coding them in build.rs. It achieves this by providing a simple entry point to add to your build.rs, and then you describe the environment in your Cargo.toml.
## Usage
Add this snippet to your build.rs:
```rs
extern crate toml_describe;fn main() {
toml_describe::evaluate();
}
```### Compiler checked CFGs
These are added to Toml in the format
```toml
[package.metadata.toml_describe.compiler_checks.CFG_NAME]
version = "1.75"
nightly_version = "1.60"
```Using `version` will set the cfg if the compiler is at least the given version, `nightly_version` will return tru if the compiler is `nightly` and the compiler has at least that version. If both `version` and `nightly_version` are set, then the condition is true if either check succeeds.
```toml
[package.metadata.toml_describe.compiler_checks]
CFG_NAME = { can_compile = "fn function() -> bool { false }" }
```Will cause the compiler to be invoked to compile the given code snippet. If it can be compiled then the cfg will be enabled, otherwise it wont.
If both versions and compiler checks are provided, then both must be true for the cfg to be emitted.
### Allowed CFGS
These are sent to cargo for use with the `-Z cfg-check` option. options are in the form `cfg = [...]`. If the CFG does not have allowed values, it should be an empty list
```toml
[package.metadata.toml_describe.allowed_cfgs]
use_foo = []
foo_backend = ["unix", "windows"]
```With the correct flags, rustc will then warn about CFGS that are not defined, or values to those cfgs that are not in the allowed value set.