23 releases

0.1.25 Jun 18, 2024
0.1.24 Aug 4, 2023
0.1.23 Feb 13, 2023
0.1.18 Jun 13, 2022
0.1.5 Mar 20, 2021

#114 in Algorithms

Download history 77/week @ 2024-09-21 74/week @ 2024-09-28 56/week @ 2024-10-05 76/week @ 2024-10-12 114/week @ 2024-10-19 42/week @ 2024-10-26 26/week @ 2024-11-02 2/week @ 2024-11-09 4/week @ 2024-11-16 19/week @ 2024-11-23 22/week @ 2024-11-30 54/week @ 2024-12-07 46/week @ 2024-12-14 3/week @ 2024-12-21 3/week @ 2024-12-28 3/week @ 2025-01-04

74 downloads per month
Used in 5 crates (3 directly)

MIT/Apache

63KB
1K SLoC

naive_opt

crate Docs Rust Version Apache2/MIT licensed Test ubu Test mac Test win

The optimized naive string-search algorithm.

Features

  • The naive string-searching algorithm
  • Enhanced with 1-byte search like the libc++ and the libstd++ string::find
  • Specializing in UTF-8 strings, which is a feature of rust
  • The ASCII Stochastics search
  • Support the zero overhead trait.
  • Support ignore ascii case match.
  • minimum support rustc 1.56.1 (59eed8a2a 2021-11-01)

Compatibility

This crate is implemented to replace the rust std library. However, the method names are different, so please rewrite your code. It shouldn't be too difficult.

compatibility:

rust std::str this crate
std::str::find() naive_opt::Search::search()
std::str::rfind() naive_opt::Search::rsearch()
std::str::contains() naive_opt::Search::includes()
std::str::match_indices() naive_opt::Search::search_indices()
std::str::rmatch_indices() naive_opt::Search::rsearch_indices()

Ignore ascii case match

This crate supports an ASCII case-insensitive match with each function.

this crate
naive_opt::Search::search_ignore_ascii_case()
naive_opt::Search::rsearch_ignore_ascii_case()
naive_opt::Search::includes_ignore_ascii_case()
naive_opt::Search::search_indices_ignore_ascii_case()
naive_opt::Search::rsearch_indices_ignore_ascii_case()

Examples

Example function:

use naive_opt::{string_search, string_rsearch};
use naive_opt::{string_search_indices, string_rsearch_indices};

let haystack = "111 a 111b";
let needle = "a";
let r = string_search(haystack, needle);
assert_eq!(r, Some(4));

assert_eq!(string_search(haystack, "1"), Some(0));
assert_eq!(string_rsearch(haystack, "1"), Some(8));

let v: Vec<_> = string_search_indices("abc345abc901abc", "abc").collect();
assert_eq!(v, [(0, "abc"), (6, "abc"), (12, "abc")]);
let v: Vec<_> = string_rsearch_indices("abc345abc901abc", "abc").collect();
assert_eq!(v, [(12, "abc"), (6, "abc"), (0, "abc")]);
use naive_opt::Search;

let haystack = "111 a 111b";
let needle = "a";
let r = haystack.search(needle);
assert_eq!(r, Some(4));

assert_eq!(haystack.search("1"), Some(0));
assert_eq!(haystack.rsearch("1"), Some(8));

let v: Vec<_> = "abc345abc901abc".search_indices("abc").collect();
assert_eq!(v, [(0, "abc"), (6, "abc"), (12, "abc")]);
let v: Vec<_> = "abc345abc901abc".rsearch_indices("abc").collect();
assert_eq!(v, [(12, "abc"), (6, "abc"), (0, "abc")]);

Example trait: SearchIn

use naive_opt::SearchIn;

let haystack = "111 a 111b";
let needle = "a";
let r = needle.search_in(haystack);
assert_eq!(r, Some(4));

assert_eq!("1".search_in(haystack), Some(0));
assert_eq!("1".rsearch_in(haystack), Some(8));

Example Ignore ascii case match

use naive_opt::Search;

let haystack = "111 a 111b";
let needle = "A";
let r = haystack.search_ignore_ascii_case(needle);
assert_eq!(r, Some(4));
assert_eq!(haystack.rsearch_ignore_ascii_case("A"), Some(4));

let v: Vec<_> = "abc345aBc901abc".search_indices_ignore_ascii_case("abc").collect();
assert_eq!(v, [(0, "abc"), (6, "aBc"), (12, "abc")]);
let v: Vec<_> = "abc345aBc901abc".rsearch_indices_ignore_ascii_case("abc").collect();
assert_eq!(v, [(12, "abc"), (6, "aBc"), (0, "abc")]);

assert_eq!("<A HREF=http://".includes_ignore_ascii_case("href"), true);

Benchmark results

  • compile by rustc 1.66.0 (69f9c33d7 2022-12-12)
name bench:en bench:ja musl:en musl:ja
std_str_str 757.800 μc 521.920 μc 728.020 μc 520.580 μc
std_string_string 760.410 μc 525.830 μc 733.070 μc 536.770 μc
func_str_str 102.100 μc 121.790 μc 122.460 μc 122.300 μc
func_string_string 101.720 μc 123.290 μc 102.760 μc 121.960 μc
trait_str_str 98.238 μc 120.290 μc 116.560 μc 117.960 μc
trait_string_string 98.459 μc 120.490 μc 98.106 μc 118.940 μc
std_indices 470.700 μc 370.070 μc 468.480 μc 392.680 μc
func_indices 100.840 μc 118.750 μc 101.620 μc 146.220 μc
trait_indices 100.920 μc 118.810 μc 101.070 μc 145.120 μc
  • std is std::str::find()
  • us is micro seconds
  • :en is english haystack.
  • :ja is japanese haystack.
  • musl is x86_64-unknown-linux-musl
  • bench on intel Q6600 @ 2.40GHz

Changelogs

This crate's changelog here.

References

License

This project is licensed under either of

at your option.

Dependencies

~1MB
~22K SLoC