serde::__private::fmt

Struct Arguments

1.0.0 · source
pub struct Arguments<'a> { /* private fields */ }
Expand description

This structure represents a safely precompiled version of a format string and its arguments. This cannot be generated at runtime because it cannot safely be done, so no constructors are given and the fields are private to prevent modification.

The format_args! macro will safely create an instance of this structure. The macro validates the format string at compile-time so usage of the write() and format() functions can be safely performed.

You can use the Arguments<'a> that format_args! returns in Debug and Display contexts as seen below. The example also shows that Debug and Display format to the same thing: the interpolated format string in format_args!.

let debug = format!("{:?}", format_args!("{} foo {:?}", 1, 2));
let display = format!("{}", format_args!("{} foo {:?}", 1, 2));
assert_eq!("1 foo 2", display);
assert_eq!(display, debug);

Implementations§

source§

impl<'a> Arguments<'a>

Used by the format_args!() macro to create a fmt::Arguments object.

source

pub const fn new_const<const N: usize>( pieces: &'a [&'static str; N], ) -> Arguments<'a>

🔬This is a nightly-only experimental API. (fmt_internals)
source

pub fn new_v1<const P: usize, const A: usize>( pieces: &'a [&'static str; P], args: &'a [Argument<'a>; A], ) -> Arguments<'a>

🔬This is a nightly-only experimental API. (fmt_internals)

When using the format_args!() macro, this function is used to generate the Arguments structure.

source

pub fn new_v1_formatted( pieces: &'a [&'static str], args: &'a [Argument<'a>], fmt: &'a [Placeholder], _unsafe_arg: UnsafeArg, ) -> Arguments<'a>

🔬This is a nightly-only experimental API. (fmt_internals)

Specifies nonstandard formatting parameters.

An rt::UnsafeArg is required because the following invariants must be held in order for this function to be safe:

  1. The pieces slice must be at least as long as fmt.
  2. Every rt::Placeholder::position value within fmt must be a valid index of args.
  3. Every rt::Count::Param within fmt must contain a valid index of args.
source

pub fn estimated_capacity(&self) -> usize

🔬This is a nightly-only experimental API. (fmt_internals)

Estimates the length of the formatted text.

This is intended to be used for setting initial String capacity when using format!. Note: this is neither the lower nor upper bound.

source§

impl<'a> Arguments<'a>

1.52.0 (const: unstable) · source

pub fn as_str(&self) -> Option<&'static str>

Gets the formatted string, if it has no arguments to be formatted at runtime.

This can be used to avoid allocations in some cases.

§Guarantees

For format_args!("just a literal"), this function is guaranteed to return Some("just a literal").

For most cases with placeholders, this function will return None.

However, the compiler may perform optimizations that can cause this function to return Some(_) even if the format string contains placeholders. For example, format_args!("Hello, {}!", "world") may be optimized to format_args!("Hello, world!"), such that as_str() returns Some("Hello, world!").

The behavior for anything but the trivial case (without placeholders) is not guaranteed, and should not be relied upon for anything other than optimization.

§Examples
use std::fmt::Arguments;

fn write_str(_: &str) { /* ... */ }

fn write_fmt(args: &Arguments<'_>) {
    if let Some(s) = args.as_str() {
        write_str(s)
    } else {
        write_str(&args.to_string());
    }
}
assert_eq!(format_args!("hello").as_str(), Some("hello"));
assert_eq!(format_args!("").as_str(), Some(""));
assert_eq!(format_args!("{:?}", std::env::current_dir()).as_str(), None);

Trait Implementations§

1.0.0 · source§

impl<'a> Clone for Arguments<'a>

source§

fn clone(&self) -> Arguments<'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
1.0.0 · source§

impl Debug for Arguments<'_>

source§

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

Formats the value using the given formatter. Read more
1.0.0 · source§

impl Display for Arguments<'_>

source§

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

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

impl<'a> Serialize for Arguments<'a>

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
1.71.0 · source§

impl ToString for Arguments<'_>

source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
1.0.0 · source§

impl<'a> Copy for Arguments<'a>

1.0.0 · source§

impl !Send for Arguments<'_>

1.0.0 · source§

impl !Sync for Arguments<'_>

Auto Trait Implementations§

§

impl<'a> Freeze for Arguments<'a>

§

impl<'a> RefUnwindSafe for Arguments<'a>

§

impl<'a> Unpin for Arguments<'a>

§

impl<'a> UnwindSafe for Arguments<'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> SizedTypeProperties for T

source§

#[doc(hidden)] const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
source§

#[doc(hidden)] const LAYOUT: Layout = _

🔬This is a nightly-only experimental API. (sized_type_properties)
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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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> Printable for T
where T: Copy + Debug,

source§

impl<T> TyCompat<Maybe> for T
where T: ?Sized,

source§

impl<T> TyCompat<T> for T
where T: ?Sized,