1 // This file is part of ICU4X. For terms of use, please see the file
2 // called LICENSE at the top level of the ICU4X source tree
3 // (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).
5 //! `tinystr` is a utility crate of the [`ICU4X`] project.
7 //! It includes [`TinyAsciiStr`], a core API for representing small ASCII-only bounded length strings.
9 //! It is optimized for operations on strings of size 8 or smaller. When use cases involve comparison
10 //! and conversion of strings for lowercase/uppercase/titlecase, or checking
11 //! numeric/alphabetic/alphanumeric, `TinyAsciiStr` is the edge performance library.
16 //! use tinystr::TinyAsciiStr;
18 //! let s1: TinyAsciiStr<4> = "tEsT".parse().expect("Failed to parse.");
20 //! assert_eq!(s1, "tEsT");
21 //! assert_eq!(s1.to_ascii_uppercase(), "TEST");
22 //! assert_eq!(s1.to_ascii_lowercase(), "test");
23 //! assert_eq!(s1.to_ascii_titlecase(), "Test");
24 //! assert_eq!(s1.is_ascii_alphanumeric(), true);
25 //! assert_eq!(s1.is_ascii_numeric(), false);
27 //! let s2 = TinyAsciiStr::<8>::try_from_raw(*b"New York")
28 //! .expect("Failed to parse.");
30 //! assert_eq!(s2, "New York");
31 //! assert_eq!(s2.to_ascii_uppercase(), "NEW YORK");
32 //! assert_eq!(s2.to_ascii_lowercase(), "new york");
33 //! assert_eq!(s2.to_ascii_titlecase(), "New york");
34 //! assert_eq!(s2.is_ascii_alphanumeric(), false);
39 //! When strings are of size 8 or smaller, the struct transforms the strings as `u32`/`u64` and uses
40 //! bitmasking to provide basic string manipulation operations:
41 //! * `is_ascii_numeric`
42 //! * `is_ascii_alphabetic`
43 //! * `is_ascii_alphanumeric`
44 //! * `to_ascii_lowercase`
45 //! * `to_ascii_uppercase`
46 //! * `to_ascii_titlecase`
49 //! `TinyAsciiStr` will fall back to `u8` character manipulation for strings of length greater than 8.
52 //! [`ICU4X`]: ../icu/index.html
54 // https://github.com/unicode-org/icu4x/blob/main/docs/process/boilerplate.md#library-annotations
55 #![cfg_attr(not(test), no_std)]
59 clippy
::indexing_slicing
,
63 clippy
::exhaustive_structs
,
64 clippy
::exhaustive_enums
,
65 missing_debug_implementations
,
76 #[cfg(feature = "serde")]
79 #[cfg(feature = "databake")]
82 #[cfg(feature = "zerovec")]
85 #[cfg(any(feature = "serde", feature = "alloc"))]
88 pub use ascii
::TinyAsciiStr
;
89 pub use error
::TinyStrError
;
91 /// These are temporary compatability reexports that will be removed
92 /// in a future version.
93 pub type TinyStr4
= TinyAsciiStr
<4>;
94 /// These are temporary compatability reexports that will be removed
95 /// in a future version.
96 pub type TinyStr8
= TinyAsciiStr
<8>;
97 /// These are temporary compatability reexports that will be removed
98 /// in a future version.
99 pub type TinyStr16
= TinyAsciiStr
<16>;
104 core
::mem
::size_of
::<TinyStr4
>(),
105 core
::mem
::size_of
::<Option
<TinyStr4
>>()
108 core
::mem
::size_of
::<TinyStr8
>(),
109 core
::mem
::size_of
::<Option
<TinyStr8
>>()
112 // /// Allows unit tests to use the macro
115 // pub use super::{TinyAsciiStr, TinyStrError};