#pattern-matching #bit-manipulation #bit

macro bitpattern

bitwise pattern matching and extracting

1 unstable release

0.1.0 Jul 17, 2020

#79 in #bit-manipulation

Download history 749/week @ 2026-02-18 542/week @ 2026-02-25 888/week @ 2026-03-04 748/week @ 2026-03-11 701/week @ 2026-03-18 484/week @ 2026-03-25 618/week @ 2026-04-01 568/week @ 2026-04-08 1162/week @ 2026-04-15 2279/week @ 2026-04-22 924/week @ 2026-04-29 825/week @ 2026-05-06 3442/week @ 2026-05-13 3155/week @ 2026-05-20 2503/week @ 2026-05-27 1179/week @ 2026-06-03

10,524 downloads per month
Used in 3 crates (via h264-profile-level-id)

MIT/Apache

10KB
126 lines

bitpattern

bitwise pattern matching and extracting

Actions Status Crates.io Docs.rs

Usage

[dependencies]
bitpattern = "0.1.0"

Example

    let x = 0xacu8; // 10101100

    // '0' means the bit must be 0.
    // '1' means the bit must be 1.
    // '_' can be uses as separator.
    assert_eq!(bitpattern!("1010_1100", x), Some(()));
    assert_eq!(bitpattern!("1010_0100", x), None);

    // '?' means the bit can be 0 or 1.
    assert_eq!(bitpattern!("1?10_1?00", x), Some(()));

    // Other charactors can be used for extracting.
    // 'a' extracts a single bit.
    assert_eq!(bitpattern!("1a10_1100", x), Some(0));
    assert_eq!(bitpattern!("10a0_1100", x), Some(1));

    // Multi-bit extracting by continuous charactors.
    assert_eq!(bitpattern!("1aaa_a100", x), Some(5));

    // Multiple extracting.
    assert_eq!(bitpattern!("1aa0_aa00", x), Some((1, 3)));

    // If the extracting fields are adjacent, the different charactors can be used.
    assert_eq!(bitpattern!("1aab_bccc", x), Some((1, 1, 4)));

License

Licensed under either of

at your option.

Contribution

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.

Dependencies

~67KB