| 
									
										
										
										
											2025-04-12 19:13:33 +00:00
										 |  |  |  | // ReSharper disable MemberCanBePrivate.Global | 
					
						
							| 
									
										
										
										
											2025-04-14 17:29:56 +00:00
										 |  |  |  | namespace SharedTools; | 
					
						
							| 
									
										
										
										
											2025-04-12 19:13:33 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /// <summary> | 
					
						
							|  |  |  |  | /// Implements the Fowler–Noll–Vo hash function for 32-bit and 64-bit hashes. | 
					
						
							|  |  |  |  | /// </summary> | 
					
						
							|  |  |  |  | public static class FNVHash | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     private const uint FNV_OFFSET_BASIS_32_BIT = 2_166_136_261; | 
					
						
							|  |  |  |  |     private const ulong FNV_OFFSET_BASIS_64_BIT = 14_695_981_039_346_656_037; | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     private const uint FNV_PRIME_32_BIT = 16_777_619; | 
					
						
							|  |  |  |  |     private const ulong FNV_PRIME_64_BIT = 1_099_511_628_211; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// <summary> | 
					
						
							|  |  |  |  |     /// Computes the 32bit FNV-1a hash of a string. | 
					
						
							|  |  |  |  |     /// </summary> | 
					
						
							|  |  |  |  |     /// <param name="text">The string to hash.</param> | 
					
						
							|  |  |  |  |     /// <returns>The 32bit FNV-1a hash of the string.</returns> | 
					
						
							|  |  |  |  |     public static uint ToFNV32(this string text) => ToFNV32(text.AsSpan()); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// <summary> | 
					
						
							|  |  |  |  |     /// Computes the 32bit FNV-1a hash of a string. | 
					
						
							|  |  |  |  |     /// </summary> | 
					
						
							|  |  |  |  |     /// <param name="text">The string to hash.</param> | 
					
						
							|  |  |  |  |     /// <returns>The 32bit FNV-1a hash of the string.</returns> | 
					
						
							|  |  |  |  |     public static uint ToFNV32(this ReadOnlySpan<char> text) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         var hash = FNV_OFFSET_BASIS_32_BIT; | 
					
						
							|  |  |  |  |         foreach (var c in text) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             hash ^= c; | 
					
						
							|  |  |  |  |             hash *= FNV_PRIME_32_BIT; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         return hash; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     /// <summary> | 
					
						
							|  |  |  |  |     /// Computes the 64bit FNV-1a hash of a string. | 
					
						
							|  |  |  |  |     /// </summary> | 
					
						
							|  |  |  |  |     /// <param name="text">The string to hash.</param> | 
					
						
							|  |  |  |  |     /// <returns>The 64bit FNV-1a hash of the string.</returns> | 
					
						
							|  |  |  |  |     public static ulong ToFNV64(this string text) => ToFNV64(text.AsSpan()); | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     /// <summary> | 
					
						
							|  |  |  |  |     /// Computes the 64bit FNV-1a hash of a string. | 
					
						
							|  |  |  |  |     /// </summary> | 
					
						
							|  |  |  |  |     /// <param name="text">The string to hash.</param> | 
					
						
							|  |  |  |  |     /// <returns>The 64bit FNV-1a hash of the string.</returns> | 
					
						
							|  |  |  |  |     public static ulong ToFNV64(this ReadOnlySpan<char> text) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         var hash = FNV_OFFSET_BASIS_64_BIT; | 
					
						
							|  |  |  |  |         foreach (var c in text) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             hash ^= c; | 
					
						
							|  |  |  |  |             hash *= FNV_PRIME_64_BIT; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         return hash; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } |