Skip to main content

Record

Struct Record 

Source
pub struct Record {
Show 18 fields pub key: String, pub value: String, pub category: Category, pub priority: Priority, pub tags: Vec<String>, pub created_at: u64, pub updated_at: u64, pub ref_url: Option<String>, pub staleness: StalenessScore, pub lifecycle: RecordLifecycle, pub version: RecordVersion, pub quality: QualityScore, pub access_count: u32, pub last_accessed: u64, pub source: RecordSource, pub confidence: ConfidenceScore, pub gap_analysis_score: f32, pub payload: Option<Value>,
}
Expand description

The universal store entry. All categories (gotcha, file, decision, …) share this struct. Category-specific detail is in value (human-readable) and in the typed FileRecord / GotchaRecord for Layer 0/1 fast paths.

Does not derive PartialEq — see module-level float equality note.

Key namespacing:

gotcha:<slug>     file:<path>     decision:<slug>
stage:current     dep:<ecosystem>:<name> dev_note:<slug>

Fields§

§key: String

Namespaced key — primary storage identifier and graph node key.

§value: String

Human-readable content: purpose (file), rule (gotcha), body (decision). Indexed by tantivy for full-text search.

§category: Category§priority: Priority§tags: Vec<String>

Free-form tags for search and filtering.

§created_at: u64

Unix timestamp (seconds) when this record was first created.

§updated_at: u64

Unix timestamp (seconds) of the last write.

§ref_url: Option<String>

URL to a PR, issue, doc, or incident that explains this record.

§staleness: StalenessScore§lifecycle: RecordLifecycle§version: RecordVersion

Versioning for Lamport-clock conflict resolution (see RecordVersion). Use record.version.device_id to identify the authoring device.

§quality: QualityScore§access_count: u32

How many times this record has been read via mem_get or hooks.

§last_accessed: u64

Unix timestamp (seconds) of the last access.

§source: RecordSource§confidence: ConfidenceScore§gap_analysis_score: f32

Pre-computed gap risk score: change_frequency × (1 - coverage_score).

§payload: Option<Value>

Structured per-category payload — typed data in JSON form.

  • file:*FileRecord
  • gotcha:*GotchaRecord
  • decision:* → serialized decision body (TBD Layer 1)
  • analytics:*, session:* → arbitrary JSON blob (DailyAgg, StaleReviewPayload, …)

value is always the human-readable text: rule, purpose, body. payload carries all structured fields so read sites never parse value as JSON. Stored as-is in MessagePack (serde_json::Value → msgpack map).

Implementations§

Source§

impl Record

Source

pub fn device_id(&self) -> DeviceId

The device that last wrote this record.

Convenience accessor — delegates to self.version.device_id.

Source

pub fn payload_as<T: DeserializeOwned>(&self) -> Option<T>

Deserialize the structured payload into a typed value.

Returns None when payload is absent or the JSON shape does not match T. Always prefer this over serde_json::from_str(&self.value).

Source

pub fn layer0_file_stub( key: impl Into<String>, device_id: DeviceId, logical_clock: u64, wall_clock: u64, ) -> Self

Construct a layer-0 file stub for file:<path>.

This is the persisted companion to FileRecord::layer0_stub. Layer 0 file records start empty on purpose/value, but still get the suppressed quality default so they never surface in Claude-facing injection paths until enrichment raises them.

Trait Implementations§

Source§

impl Clone for Record

Source§

fn clone(&self) -> Record

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 Record

Source§

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

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

impl<'de> Deserialize<'de> for Record

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for Record

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSend for T
where T: Any + Send,

Source§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Send + Sync>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

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

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Fruit for T
where T: Send + Downcast,

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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> 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

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more