A macro to generate structures which behave like bitflags
Find a file
Repository files (latest commit first)
Filename Latest commit message Latest commit date
Balazs Horvath bb88947210
Some checks failed
Rust / Miri (push) Has been cancelled
Rust / Clippy (push) Has been cancelled
Rust / Build (embedded) (push) Has been cancelled
Rust / Tests (push) Has been cancelled
Rust / Tests-1 (push) Has been cancelled
Rust / Tests-2 (push) Has been cancelled
Rust / Check minimal versions (push) Has been cancelled
Rust / Benches (push) Has been cancelled
Rust / UI (push) Has been cancelled
Rust / MSRV (push) Has been cancelled
fix(bitflags): Remove duplicate package key for serde_lib
2026-06-03 22:30:37 +02:00
.github/workflows remove reference to std internal features 2025-08-16 21:00:54 +10:00
benches add some basic parsing and formatting benches 2023-02-08 17:23:16 +10:00
examples depend on serde_core instead of serde 2025-10-19 19:48:57 +10:00
src example_generated.rs: add missing third slash for doc comment 2026-03-13 18:53:49 -07:00
tests chore: sync dependencies (monorepo) 2026-04-06 15:20:57 +02:00
.gitignore commit stderr for compilefail tests 2021-08-05 11:06:04 +10:00
Cargo.toml fix(bitflags): Remove duplicate package key for serde_lib 2026-06-03 22:30:37 +02:00
CHANGELOG.md prepare for 2.11.0 release 2026-02-14 08:11:31 +10:00
CODE_OF_CONDUCT.md add code of conduct (#160) 2018-05-31 15:09:56 +05:30
CONTRIBUTING.md stub out a contributing doc 2022-04-20 21:02:14 +10:00
LICENSE-APACHE Initial commit 2015-01-15 00:32:45 -08:00
LICENSE-MIT Initial commit 2015-01-15 00:32:45 -08:00
README.md prepare for 2.11.0 release 2026-02-14 08:11:31 +10:00
SECURITY.md Create SECURITY.md 2023-04-12 12:56:00 +10:00
spec.md fix difference in the spec 2025-05-17 21:15:52 +10:00

bitflags

Rust Latest version Documentation License

bitflags generates flags enums with well-defined semantics and ergonomic end-user APIs.

You can use bitflags to:

  • provide more user-friendly bindings to C APIs where flags may or may not be fully known in advance.
  • generate efficient options types with string parsing and formatting support.

You can't use bitflags to:

  • guarantee only bits corresponding to defined flags will ever be set. bitflags allows access to the underlying bits type so arbitrary bits may be set.

  • define bitfields. bitflags only generates types where set bits denote the presence of some combination of flags.

  • Documentation

  • Specification

  • Release notes

Usage

Add this to your Cargo.toml:

[dependencies]
bitflags = "2.11.0"

and this to your source code:

use bitflags::bitflags;

Example

Generate a flags structure:

use bitflags::bitflags;

// The `bitflags!` macro generates `struct`s that manage a set of flags.
bitflags! {
    /// Represents a set of flags.
    #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
    struct Flags: u32 {
        /// The value `A`, at bit position `0`.
        const A = 0b00000001;
        /// The value `B`, at bit position `1`.
        const B = 0b00000010;
        /// The value `C`, at bit position `2`.
        const C = 0b00000100;

        /// The combination of `A`, `B`, and `C`.
        const ABC = Self::A.bits() | Self::B.bits() | Self::C.bits();
    }
}

fn main() {
    let e1 = Flags::A | Flags::C;
    let e2 = Flags::B | Flags::C;
    assert_eq!((e1 | e2), Flags::ABC);   // union
    assert_eq!((e1 & e2), Flags::C);     // intersection
    assert_eq!((e1 - e2), Flags::A);     // set difference
    assert_eq!(!e2, Flags::A);           // set complement
}

Cargo features

The bitflags library defines a few Cargo features that you can opt-in to:

  • std: Implement the Error trait on error types used by bitflags.
  • serde: Support deriving serde traits on generated flags types.
  • arbitrary: Support deriving arbitrary traits on generated flags types.
  • bytemuck: Support deriving bytemuck traits on generated flags types.

Also see bitflags_derive for other flags-aware traits.

Rust Version Support

The minimum supported Rust version is documented in the Cargo.toml file. This may be bumped in minor releases as necessary.