Skip to main content

CacheKey

Struct CacheKey 

Source
pub struct CacheKey(/* private fields */);
Expand description

The cache-key identity of a task under a given set of inputs (CACHE-001).

Width is 32 bytes: both specification-recognised hash functions (CACHE-002) emit 32-byte digests. A future hash function with a different width would require a chapter revision (CACHE-003) and is out of scope here.

CacheKey is Copy because its only field is a 32-byte array; passing it by value avoids accidental borrow lifetimes in caller code that threads keys through scheduling layers.

Implementations§

Source§

impl CacheKey

Source

pub const fn as_bytes(&self) -> &[u8; 32]

The 32 bytes of this key.

Source

pub const fn from_bytes(bytes: [u8; 32]) -> Self

Wrap bytes directly as a CacheKey. Intended for callers that already obtained 32 bytes from a trusted source (e.g. hex-decoded manifest, network protocol). The cache library’s invariants on a key are byte-level only; no further checking is performed.

Source

pub fn to_hex(&self) -> String

Hexadecimal encoding (lowercase, 64 ASCII characters) used for on-disk paths per CACHE-010 and the manifest’s key field per CACHE-011.

Source

pub fn from_hex(s: &str) -> Result<Self, HexError>

Decode a 64-character hexadecimal string into a CacheKey. Mirror of CacheKey::to_hex.

§Errors

Returns HexError when the input is not 64 hex characters.

Trait Implementations§

Source§

impl Clone for CacheKey

Source§

fn clone(&self) -> CacheKey

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for CacheKey

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Hash for CacheKey

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for CacheKey

Source§

fn eq(&self, other: &CacheKey) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for CacheKey

Source§

impl Eq for CacheKey

Source§

impl StructuralPartialEq for CacheKey

Auto Trait Implementations§

Blanket Implementations§

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<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V