From c7a7ee0ca55f212b4c7697311ae345f2c0e91c90 Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Sun, 7 Apr 2024 16:42:36 +0200 Subject: [PATCH] don't panic in nullhasher misuse --- src/nullhasher.rs | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/nullhasher.rs b/src/nullhasher.rs index afb38c6..f32620d 100644 --- a/src/nullhasher.rs +++ b/src/nullhasher.rs @@ -1,9 +1,10 @@ +use fnv::FnvHasher; use serde::{Deserialize, Serialize}; use std::hash::{BuildHasher, Hasher}; /// A dummy hasher that maps simply returns the hashed u64 /// -/// trying to hash anything but a u64 will result in a panic +/// trying to hash anything but a u64 will result in using fnvhash pub struct NullHasher { data: u64, } @@ -15,8 +16,14 @@ impl Hasher for NullHasher { } #[inline] - fn write(&mut self, _msg: &[u8]) { - panic!("can only hash u64,u32,u16"); + fn write(&mut self, msg: &[u8]) { + let mut hasher = FnvHasher::default(); + hasher.write(msg); + self.data = hasher.finish(); + } + #[inline] + fn write_u8(&mut self, data: u8) { + self.data = data as u64 } #[inline]