Skip to main content

UsageDimensions

Struct UsageDimensions 

Source
#[non_exhaustive]
pub struct UsageDimensions { pub input_tokens: u64, pub output_tokens: u64, pub wall_ms: Option<u64>, pub custom: BTreeMap<String, u64>, pub dedup_key: Option<String>, }
Expand description

Usage report for report_usage. Mirrors today’s ff_report_usage_and_check ARGV: token-counts, wall-time, custom dimensions.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§input_tokens: u64

Input tokens consumed (LLM-shaped usage). 0 if not applicable.

§output_tokens: u64

Output tokens produced (LLM-shaped usage).

§wall_ms: Option<u64>

Wall-clock duration, in milliseconds, attributable to this report. None for pure token-count reports.

§custom: BTreeMap<String, u64>

Arbitrary caller-defined dimensions. Use BTreeMap for stable iteration order (important for dedup-key derivation on some budget schemes).

§dedup_key: Option<String>

Optional caller-supplied idempotency key. When set, the backend rejects a repeat application of the same key with ReportUsageResult::AlreadyApplied rather than double-counting (RFC-012 §R7.4; Lua ff_report_usage_and_check threads this as the trailing ARGV). None / empty string disables dedup.

Implementations§

Source§

impl UsageDimensions

Source

pub fn new() -> Self

Create an empty usage report (all dimensions zero / None).

Provided for external-crate consumers: UsageDimensions is #[non_exhaustive], so struct-literal and functional-update construction are unavailable across crate boundaries. Start from new() and chain with_* setters to build a report.

Source

pub fn with_input_tokens(self, tokens: u64) -> Self

Set the input-token count dimension. Consumes and returns self for chaining.

Source

pub fn with_output_tokens(self, tokens: u64) -> Self

Set the output-token count dimension. Consumes and returns self for chaining.

Source

pub fn with_wall_ms(self, ms: u64) -> Self

Set the wall-clock duration dimension, in milliseconds. Consumes and returns self for chaining.

Source

pub fn with_dedup_key(self, key: impl Into<String>) -> Self

Set the optional caller-supplied idempotency key. When set, the backend rejects a repeat application of the same key with ReportUsageResult::AlreadyApplied rather than double-counting (RFC-012 §R7.4). Consumes and returns self for chaining.

Trait Implementations§

Source§

impl Clone for UsageDimensions

Source§

fn clone(&self) -> UsageDimensions

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 UsageDimensions

Source§

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

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

impl Default for UsageDimensions

Source§

fn default() -> UsageDimensions

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

impl PartialEq for UsageDimensions

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 Eq for UsageDimensions

Source§

impl StructuralPartialEq for UsageDimensions

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