#const #attributes #compiler-version #macro #static #proc-macro #no-alloc

macro no-std const_fn

A lightweight attribute for easy generation of const functions with conditional compilations

23 releases

new 0.4.11 Jan 6, 2025
0.4.10 Apr 21, 2024
0.4.9 Jan 3, 2022
0.4.8 May 19, 2021
0.1.2 Dec 27, 2018

#800 in Rust patterns

Download history 148891/week @ 2024-09-21 163543/week @ 2024-09-28 150451/week @ 2024-10-05 159470/week @ 2024-10-12 161920/week @ 2024-10-19 140918/week @ 2024-10-26 137454/week @ 2024-11-02 149310/week @ 2024-11-09 158334/week @ 2024-11-16 116723/week @ 2024-11-23 165627/week @ 2024-11-30 168768/week @ 2024-12-07 154267/week @ 2024-12-14 68969/week @ 2024-12-21 87312/week @ 2024-12-28 123864/week @ 2025-01-04

462,001 downloads per month
Used in 1,084 crates (7 directly)

Apache-2.0 OR MIT

32KB
503 lines

#[const_fn]

crates.io docs.rs license msrv github actions

A lightweight attribute for easy generation of const functions with conditional compilations.

Usage

Add this to your Cargo.toml:

[dependencies]
const_fn = "0.4"

Examples

use const_fn::const_fn;

// function is `const` on specified version and later compiler (including beta, nightly, and dev build)
#[const_fn("1.36")]
pub const fn version() {
    /* ... */
}

// function is `const` on nightly compiler (including dev build)
#[const_fn(nightly)]
pub const fn nightly() {
    /* ... */
}

// function is `const` if `cfg(...)` is true
#[const_fn(cfg(...))]
pub const fn cfg() {
    /* ... */
}

// function is `const` if `cfg(feature = "...")` is true
#[const_fn(feature = "...")]
pub const fn feature() {
    /* ... */
}

Use this crate as an optional dependency

If no arguments are passed, const_fn will always make the function const.

Therefore, you can use const_fn as an optional dependency by combination with cfg_attr.

// function is `const` if `cfg(feature = "...")` is true
#[cfg_attr(feature = "...", const_fn::const_fn)]
pub fn optional() {
    /* ... */
}

Alternatives

This crate is proc-macro, but is very lightweight, and has no dependencies.

You can manually define declarative macros with similar functionality (see if_rust_version), or you can define the same function twice with different cfg. (Note: the former approach requires more macros to be defined depending on the number of version requirements, the latter approach requires more functions to be maintained manually)

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 the work 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