#byte-slice #string-search #string #ascii #byte #simd #character-set

jetscii

A tiny library to efficiently search strings and byte slices for sets of ASCII characters or bytes

13 releases

Uses old Rust 2015

0.5.3 Jul 7, 2022
0.5.1 Sep 18, 2021
0.5.0 May 6, 2021
0.4.4 Jun 10, 2019
0.3.1 Jul 29, 2015

#193 in Text processing

Download history 4357/week @ 2024-07-19 3584/week @ 2024-07-26 4447/week @ 2024-08-02 4080/week @ 2024-08-09 3423/week @ 2024-08-16 3090/week @ 2024-08-23 3558/week @ 2024-08-30 3688/week @ 2024-09-06 3548/week @ 2024-09-13 4190/week @ 2024-09-20 4269/week @ 2024-09-27 4729/week @ 2024-10-04 4075/week @ 2024-10-11 4149/week @ 2024-10-18 4561/week @ 2024-10-25 3721/week @ 2024-11-01

17,024 downloads per month
Used in 53 crates (14 directly)

MIT/Apache

57KB
1.5K SLoC

Jetscii

A tiny library to efficiently search strings for sets of ASCII characters or byte slices for sets of bytes.

Current Version Documentation

Examples

Searching for a set of ASCII characters

#[macro_use]
extern crate jetscii;

fn main() {
    let part_number = "86-J52:rev1";
    let first = ascii_chars!('-', ':').find(part_number);
    assert_eq!(first, Some(2));
}

Searching for a set of bytes

#[macro_use]
extern crate jetscii;

fn main() {
    let raw_data = [0x00, 0x01, 0x10, 0xFF, 0x42];
    let first = bytes!(0x01, 0x10).find(&raw_data);
    assert_eq!(first, Some(1));
}

Check out the documentation for information about feature flags and benchmarks.

Contributing

  1. Fork it (https://github.com/shepmaster/jetscii/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Add a failing test.
  4. Add code to pass the test.
  5. Commit your changes (git commit -am 'Add some feature')
  6. Ensure tests pass.
  7. Push to the branch (git push origin my-new-feature)
  8. Create a new Pull Request

No runtime deps