Trait Display

1.0.0 · Source
pub trait Display {
    // Required method
    fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>;
}
Expand description

Format trait for an empty format, {}.

Implementing this trait for a type will automatically implement the ToString trait for the type, allowing the usage of the .to_string() method. Prefer implementing the Display trait for a type, rather than ToString.

Display is similar to Debug, but Display is for user-facing output, and so cannot be derived.

For more information on formatters, see the module-level documentation.

§Completeness and parseability

Display for a type might not necessarily be a lossless or complete representation of the type. It may omit internal state, precision, or other information the type does not consider important for user-facing output, as determined by the type. As such, the output of Display might not be possible to parse, and even if it is, the result of parsing might not exactly match the original value.

However, if a type has a lossless Display implementation whose output is meant to be conveniently machine-parseable and not just meant for human consumption, then the type may wish to accept the same format in FromStr, and document that usage. Having both Display and FromStr implementations where the result of Display cannot be parsed with FromStr may surprise users.

§Internationalization

Because a type can only have one Display implementation, it is often preferable to only implement Display when there is a single most “obvious” way that values can be formatted as text. This could mean formatting according to the “invariant” culture and “undefined” locale, or it could mean that the type display is designed for a specific culture/locale, such as developer logs.

If not all values have a justifiably canonical textual format or if you want to support alternative formats not covered by the standard set of possible formatting traits, the most flexible approach is display adapters: methods like str::escape_default or Path::display which create a wrapper implementing Display to output the specific display format.

§Examples

Implementing Display on a type:

use std::fmt;

struct Point {
    x: i32,
    y: i32,
}

impl fmt::Display for Point {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "({}, {})", self.x, self.y)
    }
}

let origin = Point { x: 0, y: 0 };

assert_eq!(format!("The origin is: {origin}"), "The origin is: (0, 0)");

Required Methods§

1.0.0 · Source

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

Formats the value using the given formatter.

§Errors

This function should return Err if, and only if, the provided Formatter returns Err. String formatting is considered an infallible operation; this function only returns a Result because writing to the underlying stream might fail and it must provide a way to propagate the fact that an error has occurred back up the stack.

§Examples
use std::fmt;

struct Position {
    longitude: f32,
    latitude: f32,
}

impl fmt::Display for Position {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "({}, {})", self.longitude, self.latitude)
    }
}

assert_eq!(
    "(1.987, 2.983)",
    format!("{}", Position { longitude: 1.987, latitude: 2.983, }),
);

Implementors§

Source§

impl Display for AddressBech32DecodeError

Source§

impl Display for AddressBech32EncodeError

Source§

impl Display for ParseBlsPublicKeyError

Source§

impl Display for ParseBlsSignatureError

Source§

impl Display for ParseEd25519PublicKeyError

Source§

impl Display for ParseEd25519SignatureError

Source§

impl Display for ParseHashError

Source§

impl Display for ParseSecp256k1PublicKeyError

Source§

impl Display for ParseSecp256k1SignatureError

Source§

impl Display for ParseManifestAddressReservationError

Source§

impl Display for ParseManifestBlobRefError

Source§

impl Display for ParseManifestBucketError

Source§

impl Display for ParseManifestDecimalError

Source§

impl Display for ParseManifestExpressionError

Source§

impl Display for ParseManifestPreciseDecimalError

Source§

impl Display for ParseManifestProofError

Source§

impl Display for NonFungibleLocalId

Source§

impl Display for ParseNonFungibleLocalIdError

Source§

impl Display for ParseOwnError

Source§

impl Display for ParseReferenceError

Source§

impl Display for ParseI192Error

Source§

impl Display for ParseI256Error

Source§

impl Display for ParseI320Error

Source§

impl Display for ParseI384Error

Source§

impl Display for ParseI448Error

Source§

impl Display for ParseI512Error

Source§

impl Display for ParseI768Error

Source§

impl Display for ParseU192Error

Source§

impl Display for ParseU256Error

Source§

impl Display for ParseU320Error

Source§

impl Display for ParseU384Error

Source§

impl Display for ParseU448Error

Source§

impl Display for ParseU512Error

Source§

impl Display for ParseU768Error

Source§

impl Display for ParseDecimalError

Source§

impl Display for ParsePreciseDecimalError

Source§

impl Display for DateTimeError

Source§

impl Display for ParseUtcDateTimeError

Source§

impl Display for ParseComponentAddressError

Source§

impl Display for ParseGlobalAddressError

Source§

impl Display for ParseInternalAddressError

Source§

impl Display for ParseNonFungibleGlobalIdError

Source§

impl Display for ParsePackageAddressError

Source§

impl Display for ParseResourceAddressError

Source§

impl Display for AsciiChar

1.17.0 · Source§

impl Display for FromBytesWithNulError

1.7.0 · Source§

impl Display for IpAddr

1.0.0 · Source§

impl Display for SocketAddr

1.0.0 · Source§

impl Display for VarError

Source§

impl Display for std::fs::TryLockError

1.60.0 · Source§

impl Display for ErrorKind

Source§

impl Display for bech32::Error

Source§

impl Display for FromHexError

Source§

impl Display for radix_common::prelude::indexmap::GetDisjointMutError

1.34.0 · Source§

impl Display for Infallible

1.86.0 · Source§

impl Display for radix_common::prelude::rust::slice::GetDisjointMutError

1.15.0 · Source§

impl Display for RecvTimeoutError

1.0.0 · Source§

impl Display for TryRecvError

1.0.0 · Source§

impl Display for bool

1.0.0 · Source§

impl Display for char

1.0.0 · Source§

impl Display for f16

1.0.0 · Source§

impl Display for f32

1.0.0 · Source§

impl Display for f64

1.0.0 · Source§

impl Display for i8

1.0.0 · Source§

impl Display for i16

1.0.0 · Source§

impl Display for i32

1.0.0 · Source§

impl Display for i64

1.0.0 · Source§

impl Display for i128

1.0.0 · Source§

impl Display for isize

Source§

impl Display for !

1.0.0 · Source§

impl Display for str

1.0.0 · Source§

impl Display for u8

1.0.0 · Source§

impl Display for u16

1.0.0 · Source§

impl Display for u32

1.0.0 · Source§

impl Display for u64

1.0.0 · Source§

impl Display for u128

1.0.0 · Source§

impl Display for usize

Source§

impl Display for Bls12381G1PublicKey

Source§

impl Display for Bls12381G2Signature

Source§

impl Display for Ed25519PublicKey

Source§

impl Display for Ed25519Signature

Source§

impl Display for Hash

Source§

impl Display for Secp256k1PublicKey

Source§

impl Display for Secp256k1Signature

Source§

impl Display for I192

Source§

impl Display for I256

Source§

impl Display for I320

Source§

impl Display for I384

Source§

impl Display for I448

Source§

impl Display for I512

Source§

impl Display for I768

Source§

impl Display for U192

Source§

impl Display for U256

Source§

impl Display for U320

Source§

impl Display for U384

Source§

impl Display for U448

Source§

impl Display for U512

Source§

impl Display for U768

Source§

impl Display for Decimal

Source§

impl Display for PreciseDecimal

Source§

impl Display for UtcDateTime

Source§

impl Display for UnorderedKeyError

1.0.0 · Source§

impl Display for Arguments<'_>

1.0.0 · Source§

impl Display for radix_common::prelude::fmt::Error

Source§

impl Display for ByteString

1.57.0 · Source§

impl Display for alloc::collections::TryReserveError

1.58.0 · Source§

impl Display for FromVecWithNulError

1.7.0 · Source§

impl Display for IntoStringError

1.0.0 · Source§

impl Display for NulError

1.35.0 · Source§

impl Display for TryFromSliceError

1.39.0 · Source§

impl Display for core::ascii::EscapeDefault

Source§

impl Display for ByteStr

1.34.0 · Source§

impl Display for CharTryFromError

1.20.0 · Source§

impl Display for ParseCharError

1.9.0 · Source§

impl Display for DecodeUtf16Error

1.20.0 · Source§

impl Display for core::char::EscapeDebug

1.16.0 · Source§

impl Display for core::char::EscapeDefault

1.16.0 · Source§

impl Display for core::char::EscapeUnicode

1.16.0 · Source§

impl Display for ToLowercase

1.16.0 · Source§

impl Display for ToUppercase

1.59.0 · Source§

impl Display for TryFromCharError

1.69.0 · Source§

impl Display for FromBytesUntilNulError

1.0.0 · Source§

impl Display for Ipv4Addr

1.0.0 · Source§

impl Display for Ipv6Addr

Writes an Ipv6Addr, conforming to the canonical style described by RFC 5952.

1.4.0 · Source§

impl Display for AddrParseError

1.0.0 · Source§

impl Display for SocketAddrV4

1.0.0 · Source§

impl Display for SocketAddrV6

1.26.0 · Source§

impl Display for Location<'_>

1.26.0 · Source§

impl Display for PanicInfo<'_>

1.81.0 · Source§

impl Display for PanicMessage<'_>

1.66.0 · Source§

impl Display for TryFromFloatSecsError

1.65.0 · Source§

impl Display for Backtrace

1.0.0 · Source§

impl Display for JoinPathsError

1.87.0 · Source§

impl Display for std::ffi::os_str::Display<'_>

1.56.0 · Source§

impl Display for WriterPanicked

1.0.0 · Source§

impl Display for std::io::error::Error

1.26.0 · Source§

impl Display for PanicHookInfo<'_>

1.0.0 · Source§

impl Display for std::path::Display<'_>

Source§

impl Display for NormalizeError

1.7.0 · Source§

impl Display for StripPrefixError

1.0.0 · Source§

impl Display for ExitStatus

Source§

impl Display for ExitStatusError

1.26.0 · Source§

impl Display for AccessError

1.8.0 · Source§

impl Display for SystemTimeError

Source§

impl Display for block_buffer::Error

Source§

impl Display for bnum::errors::parseint::ParseIntError

Source§

impl Display for bnum::errors::tryfrom::TryFromIntError

Source§

impl Display for Digest

Source§

impl Display for InvalidLength

Source§

impl Display for MacError

Source§

impl Display for InvalidBufferSize

Source§

impl Display for InvalidOutputSize

Source§

impl Display for Signature

Source§

impl Display for BigInt

Source§

impl Display for BigUint

Source§

impl Display for ParseBigIntError

Source§

impl Display for num_traits::ParseFloatError

Source§

impl Display for signature::error::Error

Source§

impl Display for radix_common::prelude::indexmap::TryReserveError

Source§

impl Display for AllocError

1.28.0 · Source§

impl Display for LayoutError

1.0.0 · Source§

impl Display for radix_common::prelude::rust::num::ParseFloatError

1.0.0 · Source§

impl Display for radix_common::prelude::rust::num::ParseIntError

1.34.0 · Source§

impl Display for radix_common::prelude::rust::num::TryFromIntError

1.0.0 · Source§

impl Display for ParseBoolError

1.0.0 · Source§

impl Display for Utf8Error

1.0.0 · Source§

impl Display for FromUtf8Error

1.0.0 · Source§

impl Display for FromUtf16Error

1.0.0 · Source§

impl Display for RecvError

1.13.0 · Source§

impl Display for BorrowError

1.13.0 · Source§

impl Display for BorrowMutError

1.0.0 · Source§

impl Display for String

1.60.0 · Source§

impl<'a> Display for EscapeAscii<'a>

1.34.0 · Source§

impl<'a> Display for radix_common::prelude::rust::str::EscapeDebug<'a>

1.34.0 · Source§

impl<'a> Display for radix_common::prelude::rust::str::EscapeDefault<'a>

1.34.0 · Source§

impl<'a> Display for radix_common::prelude::rust::str::EscapeUnicode<'a>

Source§

impl<'a, 'b, TValue, TContext> Display for ContextDisplayable<'a, TValue, TContext>
where TValue: ContextualDisplay<TContext> + ?Sized,

Source§

impl<'a, K, V> Display for radix_common::prelude::hash_map::OccupiedError<'a, K, V>
where K: Debug, V: Debug,

Source§

impl<'a, K, V, A> Display for radix_common::prelude::btree_map::OccupiedError<'a, K, V, A>
where K: Debug + Ord, V: Debug, A: Allocator + Clone,

1.0.0 · Source§

impl<B> Display for Cow<'_, B>
where B: Display + ToOwned + ?Sized, <B as ToOwned>::Owned: Display,

Source§

impl<E> Display for PayloadValidationError<E>
where E: CustomExtension,

Source§

impl<E> Display for TypedTraversalError<E>
where E: CustomExtension,

Source§

impl<E> Display for Report<E>
where E: Error,

Source§

impl<F> Display for FromFn<F>
where F: Fn(&mut Formatter<'_>) -> Result<(), Error>,

Source§

impl<K, V, S, A> Display for hashbrown::map::OccupiedError<'_, K, V, S, A>
where K: Debug, V: Debug, A: Allocator,

1.33.0 · Source§

impl<Ptr> Display for Pin<Ptr>
where Ptr: Display,

1.0.0 · Source§

impl<T> Display for radix_common::prelude::rust::sync::TryLockError<T>

Source§

impl<T> Display for SendTimeoutError<T>

1.0.0 · Source§

impl<T> Display for TrySendError<T>

1.0.0 · Source§

impl<T> Display for &T
where T: Display + ?Sized,

1.0.0 · Source§

impl<T> Display for &mut T
where T: Display + ?Sized,

Source§

impl<T> Display for TryFromBigIntError<T>

Source§

impl<T> Display for ThinBox<T>
where T: Display + ?Sized,

1.28.0 · Source§

impl<T> Display for NonZero<T>

1.74.0 · Source§

impl<T> Display for Saturating<T>
where T: Display,

1.10.0 · Source§

impl<T> Display for Wrapping<T>
where T: Display,

1.0.0 · Source§

impl<T> Display for SendError<T>

Source§

impl<T> Display for MappedMutexGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for MappedRwLockReadGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for MappedRwLockWriteGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for MutexGuard<'_, T>
where T: Display + ?Sized,

1.0.0 · Source§

impl<T> Display for PoisonError<T>

Source§

impl<T> Display for ReentrantLockGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for RwLockReadGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for RwLockWriteGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for Ref<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for RefMut<'_, T>
where T: Display + ?Sized,

Source§

impl<T, A> Display for UniqueRc<T, A>
where T: Display + ?Sized, A: Allocator,

Source§

impl<T, A> Display for UniqueArc<T, A>
where T: Display + ?Sized, A: Allocator,

1.0.0 · Source§

impl<T, A> Display for Arc<T, A>
where T: Display + ?Sized, A: Allocator,

1.0.0 · Source§

impl<T, A> Display for Box<T, A>
where T: Display + ?Sized, A: Allocator,

1.0.0 · Source§

impl<T, A> Display for Rc<T, A>
where T: Display + ?Sized, A: Allocator,

1.0.0 · Source§

impl<W> Display for IntoInnerError<W>

Source§

impl<X> Display for ValueKind<X>
where X: CustomValueKind,

Source§

impl<const N: usize> Display for BInt<N>

Source§

impl<const N: usize> Display for BIntD8<N>

Source§

impl<const N: usize> Display for BIntD16<N>

Source§

impl<const N: usize> Display for BIntD32<N>

Source§

impl<const N: usize> Display for BUint<N>

Source§

impl<const N: usize> Display for BUintD8<N>

Source§

impl<const N: usize> Display for BUintD16<N>

Source§

impl<const N: usize> Display for BUintD32<N>