Macro bitflags
macro_rules! bitflags {
(
$(#[$outer:meta])*
$vis:vis struct $BitFlags:ident: $T:ty {
$(
$(#[$inner:ident $($args:tt)*])*
const $Flag:tt = $value:expr;
)*
}
$($t:tt)*
) => { ... };
(
$(#[$outer:meta])*
impl $BitFlags:ident: $T:ty {
$(
$(#[$inner:ident $($args:tt)*])*
const $Flag:tt = $value:expr;
)*
}
$($t:tt)*
) => { ... };
() => { ... };
}
Expand description
Generate a flags type.
§struct
mode
A declaration that begins with $vis struct
will generate a struct
for a flags type, along with
methods and trait implementations for it. The body of the declaration defines flags as constants,
where each constant is a flags value of the generated flags type.
§Examples
Generate a flags type using u8
as the bits type:
bitflags! {
struct Flags: u8 {
const A = 1;
const B = 1 << 1;
const C = 0b0000_0100;
}
}
Flags types are private by default and accept standard visibility modifiers. Flags themselves are always public:
bitflags! {
pub struct Flags: u8 {
// Constants are always `pub`
const A = 1;
}
}
Flags may refer to other flags using their [Flags::bits
] value:
bitflags! {
struct Flags: u8 {
const A = 1;
const B = 1 << 1;
const AB = Flags::A.bits() | Flags::B.bits();
}
}
A single bitflags
invocation may include zero or more flags type declarations:
bitflags! {}
bitflags! {
struct Flags1: u8 {
const A = 1;
}
struct Flags2: u8 {
const A = 1;
}
}
§impl
mode
A declaration that begins with impl
will only generate methods and trait implementations for the
struct
defined outside of the bitflags
macro.
The struct itself must be a newtype using the bits type as its field.
The syntax for impl
mode is identical to struct
mode besides the starting token.
§Examples
Implement flags methods and traits for a custom flags type using u8
as its underlying bits type:
struct Flags(u8);
bitflags! {
impl Flags: u8 {
const A = 1;
const B = 1 << 1;
const C = 0b0000_0100;
}
}
§Named and unnamed flags
Constants in the body of a declaration are flags. The identifier of the constant is the name of
the flag. If the identifier is _
, then the flag is unnamed. Unnamed flags don’t appear in the
generated API, but affect how bits are truncated.
§Examples
Adding an unnamed flag that makes all bits known:
bitflags! {
struct Flags: u8 {
const A = 1;
const B = 1 << 1;
const _ = !0;
}
}
Flags types may define multiple unnamed flags:
bitflags! {
struct Flags: u8 {
const _ = 1;
const _ = 1 << 1;
}
}