pub struct Arguments<'a> {
pieces: &'a [&'static str],
fmt: Option<&'a [Argument]>,
args: &'a [ArgumentV1<'a>],
}
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);
RunFields
pieces: &'a [&'static str]
fmt: Option<&'a [Argument]>
args: &'a [ArgumentV1<'a>]
Implementations
sourceimpl<'a> Arguments<'a>
impl<'a> Arguments<'a>
const: unstable · sourcepub fn new_v1(
pieces: &'a [&'static str],
args: &'a [ArgumentV1<'a>]
) -> Arguments<'a>
🔬 This is a nightly-only experimental API. (fmt_internals
)
pub fn new_v1(
pieces: &'a [&'static str],
args: &'a [ArgumentV1<'a>]
) -> Arguments<'a>
fmt_internals
)When using the format_args!() macro, this function is used to generate the Arguments structure.
const: unstable · sourcepub fn new_v1_formatted(
pieces: &'a [&'static str],
args: &'a [ArgumentV1<'a>],
fmt: &'a [Argument],
_unsafe_arg: UnsafeArg
) -> Arguments<'a>
🔬 This is a nightly-only experimental API. (fmt_internals
)
pub fn new_v1_formatted(
pieces: &'a [&'static str],
args: &'a [ArgumentV1<'a>],
fmt: &'a [Argument],
_unsafe_arg: UnsafeArg
) -> Arguments<'a>
fmt_internals
)This function is used to specify nonstandard formatting parameters.
An UnsafeArg
is required because the following invariants must be held
in order for this function to be safe:
- The
pieces
slice must be at least as long asfmt
. - Every
rt::v1::Argument::position
value withinfmt
must be a valid index ofargs
. - Every [
Count::Param
] withinfmt
must contain a valid index ofargs
.
sourcepub fn estimated_capacity(&self) -> usize
🔬 This is a nightly-only experimental API. (fmt_internals
)
pub fn estimated_capacity(&self) -> usize
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.
sourceimpl<'a> Arguments<'a>
impl<'a> Arguments<'a>
1.52.0 (const: unstable) · sourcepub fn as_str(&self) -> Option<&'static str>
pub fn as_str(&self) -> Option<&'static str>
Get the formatted string, if it has no arguments to be formatted.
This can be used to avoid allocations in the most trivial case.
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());
}
}
Runassert_eq!(format_args!("hello").as_str(), Some("hello"));
assert_eq!(format_args!("").as_str(), Some(""));
assert_eq!(format_args!("{}", 1).as_str(), None);
RunTrait Implementations
impl<'a> Copy for Arguments<'a>
Auto Trait Implementations
impl<'a> Freeze for Arguments<'a>
impl<'a> !RefUnwindSafe for Arguments<'a>
impl<'a> !Send for Arguments<'a>
impl<'a> !Sync for Arguments<'a>
impl<'a> Unpin for Arguments<'a>
impl<'a> !UnwindSafe for Arguments<'a>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more