From 1fc393ce86ffbc38921430ec68de749b8c502c01 Mon Sep 17 00:00:00 2001 From: mxsm Date: Thu, 7 Nov 2024 03:45:57 +0000 Subject: [PATCH] [ISSUE #21]Optimize CheetahString display --- src/cheetah_string.rs | 62 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 61 insertions(+), 1 deletion(-) diff --git a/src/cheetah_string.rs b/src/cheetah_string.rs index 2377862..6b28de2 100644 --- a/src/cheetah_string.rs +++ b/src/cheetah_string.rs @@ -1,7 +1,11 @@ use std::cmp::Ordering; +use std::fmt::Display; +use std::hash::Hash; use std::ops::Deref; use std::sync::Arc; +const EMPTY_STRING: &str = ""; + #[derive(Clone)] #[repr(transparent)] pub struct CheetahString { @@ -89,6 +93,13 @@ impl AsRef<[u8]> for CheetahString { } impl CheetahString { + #[inline] + pub fn empty() -> Self { + CheetahString { + inner: InnerString::Empty, + } + } + #[inline] pub fn new() -> Self { CheetahString::default() @@ -136,7 +147,7 @@ impl CheetahString { InnerString::StaticStr(s) => s, #[cfg(feature = "bytes")] InnerString::Bytes(b) => std::str::from_utf8(b.as_ref()).unwrap(), - InnerString::Empty => "", + InnerString::Empty => EMPTY_STRING, } } @@ -162,6 +173,7 @@ impl CheetahString { } } + #[inline] pub fn is_empty(&self) -> bool { match &self.inner { InnerString::ArcString(s) => s.is_empty(), @@ -179,6 +191,42 @@ impl PartialEq for CheetahString { } } +impl PartialEq for CheetahString { + fn eq(&self, other: &str) -> bool { + self.as_str() == other + } +} + +impl PartialEq for CheetahString { + fn eq(&self, other: &String) -> bool { + self.as_str() == other.as_str() + } +} + +impl<'a> PartialEq<&'a str> for CheetahString { + fn eq(&self, other: &&'a str) -> bool { + self.as_str() == *other + } +} + +impl PartialEq for str { + fn eq(&self, other: &CheetahString) -> bool { + self == other.as_str() + } +} + +impl PartialEq for String { + fn eq(&self, other: &CheetahString) -> bool { + self.as_str() == other.as_str() + } +} + +impl PartialEq for &str { + fn eq(&self, other: &CheetahString) -> bool { + *self == other.as_str() + } +} + impl Eq for CheetahString {} impl PartialOrd for CheetahString { @@ -193,6 +241,18 @@ impl Ord for CheetahString { } } +impl Hash for CheetahString { + fn hash(&self, state: &mut H) { + self.as_str().hash(state); + } +} + +impl Display for CheetahString { + fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result { + self.as_str().fmt(f) + } +} + /// The `InnerString` enum represents different types of string storage. /// /// Variants: