thousands::policies

Struct SeparatorPolicy

Source
pub struct SeparatorPolicy<'a> {
    pub separator: &'a str,
    pub groups: &'a [u8],
    pub digits: &'a [char],
}
Expand description

A policy for inserting separators into numbers.

The configurable aspects are:

  • The separator character to insert.

  • How to group the separators.

  • What characters are considered digits (for skipping non-digits such as a minus sign).

Fields§

§separator: &'a str

The separator to insert.

§groups: &'a [u8]

The grouping. The numbers in this array give the size of the groups, from right to left, with the last number in the array giving the size of all subsequent groups.

So to group by threes, as is typical in many places, this array should be &[3]. However, to get a grouping like 1,23,45,678, where the last group has size three and the others size two, you would use &[3, 2].

§digits: &'a [char]

The characters that are considered digits. If there are multiple groups of digits separated by non-digits, we only add separators to the first group. This means, for example, that the number -12345.67 will only have separators inserted into the 12345 portion.

Trait Implementations§

Source§

impl<'a> Clone for SeparatorPolicy<'a>

Source§

fn clone(&self) -> SeparatorPolicy<'a>

Returns a copy 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<'a> Debug for SeparatorPolicy<'a>

Source§

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

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

impl<'a> Copy for SeparatorPolicy<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for SeparatorPolicy<'a>

§

impl<'a> RefUnwindSafe for SeparatorPolicy<'a>

§

impl<'a> Send for SeparatorPolicy<'a>

§

impl<'a> Sync for SeparatorPolicy<'a>

§

impl<'a> Unpin for SeparatorPolicy<'a>

§

impl<'a> UnwindSafe for SeparatorPolicy<'a>

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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.