Skip to main content

SummaryRegistry

Struct SummaryRegistry 

Source
pub struct SummaryRegistry {
    user_specs: BTreeMap<FunctionId, FunctionSummary>,
    computed: BTreeMap<FunctionId, FunctionSummary>,
    defaults: BTreeMap<FunctionId, FunctionSummary>,
}
Expand description

Unified registry for function summaries with three-tier priority lookup.

When looking up a function, the registry checks each tier in order: user specs > computed > defaults. The first match wins.

Fields§

§user_specs: BTreeMap<FunctionId, FunctionSummary>

User-edited YAML specs converted to summaries (highest priority).

§computed: BTreeMap<FunctionId, FunctionSummary>

Analysis-computed summaries.

§defaults: BTreeMap<FunctionId, FunctionSummary>

Default shipped specs converted to summaries (lowest priority).

Implementations§

Source§

impl SummaryRegistry

Source

pub fn new() -> Self

Create an empty registry.

Source

pub fn get(&self, id: &FunctionId) -> Option<&FunctionSummary>

Look up a summary with priority: user > computed > default.

Returns the highest-priority summary for the given function, or None if no summary exists in any tier.

Source

pub fn insert_computed(&mut self, summary: FunctionSummary)

Insert an analysis-computed summary into the computed tier.

If a computed summary already exists for this function, it is replaced.

Source

pub fn insert_user(&mut self, summary: FunctionSummary)

Insert a user-spec summary into the user tier (highest priority).

If a user summary already exists for this function, it is replaced.

Source

pub fn insert_default(&mut self, summary: FunctionSummary)

Insert a default summary into the defaults tier (lowest priority).

If a default summary already exists for this function, it is replaced.

Source

pub fn load_specs(&mut self, registry: &SpecRegistry)

Load all exact-match specs from a SpecRegistry and convert them to summaries in the defaults tier.

Each spec is converted via FunctionSummary::from_spec with a FunctionId derived from the spec’s name. Pattern-based specs are skipped (they require runtime name resolution at call sites).

Source

pub fn load_user_specs(&mut self, registry: &SpecRegistry)

Load all exact-match specs from a SpecRegistry into the user tier.

Same as load_specs but inserts into the highest-priority user tier.

Source

pub fn total_count(&self) -> usize

Get the total number of summaries across all tiers.

Note: if the same function appears in multiple tiers, it is counted multiple times. Use unique_count for deduplicated count.

Source

pub fn unique_count(&self) -> usize

Get the number of unique functions with at least one summary.

Source

pub fn is_empty(&self) -> bool

Check if the registry is empty (no summaries in any tier).

Source

pub fn iter(&self) -> impl Iterator<Item = (&FunctionId, &FunctionSummary)>

Iterate over all unique function IDs, yielding the highest-priority summary for each.

Source

pub fn computed_count(&self) -> usize

Get the number of summaries in the computed tier.

Source

pub fn user_count(&self) -> usize

Get the number of summaries in the user tier.

Source

pub fn defaults_count(&self) -> usize

Get the number of summaries in the defaults tier.

Trait Implementations§

Source§

impl Clone for SummaryRegistry

Source§

fn clone(&self) -> SummaryRegistry

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for SummaryRegistry

Source§

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

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

impl Default for SummaryRegistry

Source§

fn default() -> SummaryRegistry

Returns the “default value” for a type. 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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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> 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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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