Snap for 11186783 from a15185e48b98c6e0d4f2f681e7b9f613e1adefb0 to 24Q1-release

Change-Id: Iea1aab0151b59b92d4777d6841e327dbd5166d1a
tree: d8b8d12a3816fcc3fdf5f08e859aa5eb539f3270
  1. 1.3.2/
  2. benches/
  3. examples/
  4. patches/
  5. src/
  6. .cargo_vcs_info.json
  7. .gitignore
  8. Android.bp
  9. BUILD
  10. Cargo.toml
  11. Cargo.toml.orig
  12. cargo2rulesmk.json
  13. cargo_embargo.json
  14. CHANGELOG.md
  15. CODE_OF_CONDUCT.md
  16. CONTRIBUTING.md
  17. LICENSE-APACHE
  18. LICENSE-MIT
  19. METADATA
  20. MODULE_LICENSE_APACHE2
  21. OWNERS
  22. README.md
  23. rules.mk
  24. SECURITY.md
  25. TEST_MAPPING
README.md

bitflags

Rust Latest version Documentation License

A Rust macro to generate structures which behave like a set of bitflags

Usage

Add this to your Cargo.toml:

[dependencies]
bitflags = "2.3.2"

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! {
    #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
    struct Flags: u32 {
        const A = 0b00000001;
        const B = 0b00000010;
        const C = 0b00000100;
        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
}

Rust Version Support

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