Skip to main content

SmallDecimal

Struct SmallDecimal 

Source
pub struct SmallDecimal {
    pub value: i64,
    pub scale: i16,
    pub negative: bool,
}
Expand description

Small decimal structure for parsing/formatting without floats This avoids floating-point precision issues for financial data

Fields§

§value: i64

The integer value (unscaled)

§scale: i16

The scale (number of decimal places)

§negative: bool

Whether the value is negative

Implementations§

Source§

impl SmallDecimal

Source

pub fn new(value: i64, scale: i16, negative: bool) -> Self

Create a new SmallDecimal.

Source

pub fn zero(scale: i16) -> Self

Create a zero value with the given scale

Source

pub fn normalize(&mut self)

Normalize -0 to 0 (NORMATIVE)

Source

pub fn to_string(&self) -> String

Format as string with fixed scale (NORMATIVE)

Always render with exactly scale digits after decimal point.

Source

pub fn from_str(s: &str, expected_scale: i16) -> Result<Self>

Parse a decimal string into a SmallDecimal using the expected scale.

§Errors

Returns an error when the text violates the expected numeric format.

Source

pub fn to_fixed_scale_string(&self, scale: i16) -> String

Format as string with the given fixed scale.

Always renders with exactly scale digits after the decimal point, independent of the SmallDecimal’s own scale. Used for lossless JSON output.

Source

pub fn format_to_scratch_buffer(&self, scale: i16, scratch_buffer: &mut String)

Format the decimal into a caller-owned string buffer to avoid allocation.

This is the hot-path formatter used in COMP-3 JSON conversion. The buffer is cleared before writing.

Source

pub fn scale(&self) -> i16

Get the scale of this decimal

Source

pub fn is_negative(&self) -> bool

Check if this decimal is negative

Source

pub fn total_digits(&self) -> u16

Get the total number of digits in this decimal

Trait Implementations§

Source§

impl Clone for SmallDecimal

Source§

fn clone(&self) -> SmallDecimal

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 SmallDecimal

Source§

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

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

impl PartialEq for SmallDecimal

Source§

fn eq(&self, other: &SmallDecimal) -> 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 SmallDecimal

Source§

impl StructuralPartialEq for SmallDecimal

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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