Skip to main content

KeyDigestComputer

Struct KeyDigestComputer 

Source
pub struct KeyDigestComputer { /* private fields */ }
Expand description

Cassandra-compatible key digest computer

This struct provides the exact key digest computation algorithm used by Cassandra for partition key hashing in Index.db files.

Implementations§

Source§

impl KeyDigestComputer

Source

pub fn new() -> Self

Create a new key digest computer

Source

pub fn compute_partition_key_digest( &mut self, partition_key_bytes: &[u8], parsing_context: &ParsingContext, ) -> Result<Vec<u8>>

Compute the partition key digest for Index.db lookup

This method implements the exact Cassandra algorithm:

  1. Parse the partition key bytes according to schema comparators
  2. Create byte-comparable encoding for each component
  3. Combine components into a single byte-comparable key
  4. Compute Murmur3 hash with seed 0 (Cassandra default)
  5. Return the hash as little-endian bytes
Source

pub fn compute_simple_digest(&self, partition_key: &[u8]) -> Result<Vec<u8>>

Compute a simple hash-based digest (fallback for when schema is unavailable)

This method provides compatibility with the existing implementation when full schema information is not available.

Trait Implementations§

Source§

impl Default for KeyDigestComputer

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.