13 releases (breaking)

0.10.0 Apr 16, 2024
0.9.0 Feb 26, 2024
0.8.0 Jan 16, 2024
0.7.1 Dec 11, 2023
0.3.0 May 9, 2023

#2021 in Procedural macros

Download history 96/week @ 2024-05-06 6/week @ 2024-05-13 5/week @ 2024-05-20 15/week @ 2024-05-27 10/week @ 2024-06-03 7/week @ 2024-06-10 8/week @ 2024-06-17 14/week @ 2024-06-24 4/week @ 2024-07-01 4/week @ 2024-07-08 15/week @ 2024-07-15 113/week @ 2024-07-29 173/week @ 2024-08-05 9/week @ 2024-08-12 17/week @ 2024-08-19

312 downloads per month
Used in 12 crates (via devela)

MIT/Apache

30KB
419 lines

devela_macros

Crate API MSRV: 1.72.1

Procedural macros for devela.

See the documentation for more information.

Status

This is currently in an experimental stage of development.

License

This project is dual licensed under either MIT or Apache-2.0 at your option.

Contributing

Contributions are welcomed to help refine and improve this library over time. If you notice a bug, have an idea for a new feature, or simply want to suggest improvements to the existing codebase, please get in touch.


lib.rs:

Conditional compilation

Each form of conditional compilation takes a compilation predicate that evaluates to true or false.

These are the [#[compile]][compile()] and [#[compile_attr]][compile_attr()] attributes and the [cif!][cif()] macro.

They are similar to the #[cfg] and #[cfg_attr] attributes and the cfg! macro, except they use compilation predicates.

There is also the [#[compile_doc]][compile_doc()] macro to conditionally compile documentation blocks depending on predicates.

Panics

Compilation macros will panic if they encounter an unrecognized predicate. As opposed to configuration macros (cfg!) that return false for unrecognized predicates without signaling an error.

Compilation predicates

The following compilation predicates are supported:

  • unary:

    • A bare predicate returns true only if it is the true literal.
    • A bare predicate returns false if it's the false literal or it's empty.
    • not(): returns true only if the predicate does not evaluate to true.
  • binary:

    • equal(): returns true if both predicates are evaluated as equal.

    • xor(): returns true if only one predicate is true, but not both.

    • eq(): returns true if both predicates are number literals and Left == Right.

    • ne(): returns true if both predicates are number literals and Left != Right.

    • ge(): returns true if both predicates are number literals and Left >= Right.

    • gt(): returns true if both predicates are number literals and Left > Right.

    • le(): returns true if both predicates are number literals and Left <= Right.

    • lt(): returns true if both predicates are number literals and Left < Right.

  • non-binary:

    • any(): returns true if any predicate is true.
    • all(): returns true if all predicates are true.
    • none(): returns true if there is no given predicate.
    • some(): returns true if there is some given predicate.
    • diff(): returns true if any predicate has a different text.
    • same(): returns true if all the predicates have the same text.
    • xany(): returns true if there are any true predicates, but not all.
    • xodd(): returns true if there is an odd number of true predicates.
    • xone(): returns true if there is just one true predicate, but no more.
  • pointer width:

    • pointer_width_eq(width): returns true if current pointer width == the given width.
    • pointer_width_ne(width): returns true if current pointer width != the given width.
    • pointer_width_ge(width): returns true if current pointer width >= the given width.
    • pointer_width_gt(width): returns true if current pointer width > the given width.
    • pointer_width_le(width): returns true if current pointer width <= the given width.
    • pointer_width_lt(width): returns true if current pointer width < the given width.
  • endianness:

    • little_endian(): returns true if current architecture is little-endian.
    • big_endian(): returns true if current architecture is big-endian.

When more than 1 predicate is supported, they are separated by commas.

No runtime deps

Features