Minor optimization in StringKey, making it from an Arc<String> into an Arc<str>
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				continuous-integration/drone/push Build is passing
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	continuous-integration/drone/push Build is passing
				
			This commit is contained in:
		| @@ -8,12 +8,12 @@ use std::sync::{Arc, Mutex, Weak}; | |||||||
| /// `charmander` == `Charmander`. | /// `charmander` == `Charmander`. | ||||||
| #[derive(Clone, Debug)] | #[derive(Clone, Debug)] | ||||||
| pub struct StringKey { | pub struct StringKey { | ||||||
|     str: Arc<String>, |     str: Arc<str>, | ||||||
|     hash: u32, |     hash: u32, | ||||||
| } | } | ||||||
|  |  | ||||||
| lazy_static::lazy_static! { | lazy_static::lazy_static! { | ||||||
|     static ref STRING_CACHE: Mutex<HashMap<u32, Weak<String>>> = Mutex::new(HashMap::new()); |     static ref STRING_CACHE: Mutex<HashMap<u32, Weak<str>>> = Mutex::new(HashMap::new()); | ||||||
| } | } | ||||||
|  |  | ||||||
| impl StringKey { | impl StringKey { | ||||||
| @@ -49,7 +49,7 @@ impl StringKey { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         let v = Self { |         let v = Self { | ||||||
|             str: Arc::new(s.to_string()), |             str: s.into(), | ||||||
|             hash, |             hash, | ||||||
|         }; |         }; | ||||||
|         cache.insert(hash, Arc::downgrade(&v.str)); |         cache.insert(hash, Arc::downgrade(&v.str)); | ||||||
| @@ -57,7 +57,7 @@ impl StringKey { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn str(&self) -> &str { |     pub fn str(&self) -> &str { | ||||||
|         self.str.as_str() |         &self.str | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn hash(&self) -> u32 { |     pub fn hash(&self) -> u32 { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user