Skip to main content

Display

Trait Display 

1.6.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, }),
);

Dyn Compatibility§

This trait is dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety".

Implementors§

Source§

impl Display for !

§

impl Display for Aarch64Architecture

1.26.0 · Source§

impl Display for AccessError

1.4.0 · Source§

impl Display for AddrParseError

Source§

impl Display for AllocError

§

impl Display for Architecture

1.0.0 · Source§

impl Display for Arguments<'_>

§

impl Display for ArmArchitecture

§

impl Display for ArrayType

Source§

impl Display for AsciiChar

1.65.0 · Source§

impl Display for Backtrace

§

impl Display for BinaryFormat

§

impl Display for BinaryReaderError

1.13.0 · Source§

impl Display for BorrowError

1.13.0 · Source§

impl Display for BorrowMutError

Source§

impl Display for BuildMetadata

Source§

impl Display for ByteStr

Source§

impl Display for ByteString

1.34.0 · Source§

impl Display for CharTryFromError

§

impl Display for CleverArchitecture

§

impl Display for CollectionAllocErr

Source§

impl Display for Collector

§

impl Display for ColorChoiceParseError

Source§

impl Display for Comparator

Source§

impl Display for CompileError

§

impl Display for ComponentName

Source§

impl Display for ComponentPC

§

impl Display for CompositeInnerType

§

impl Display for CompositeType

§

impl Display for ContType

§

impl Display for ConvertError

§

impl Display for DecodeError

1.9.0 · Source§

impl Display for DecodeUtf16Error

§

impl Display for DestBufTooSmallError

1.87.0 · Source§

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

1.0.0 · Source§

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

§

impl Display for DwAccess

§

impl Display for DwAddr

§

impl Display for DwAt

§

impl Display for DwAte

§

impl Display for DwCc

§

impl Display for DwCfa

§

impl Display for DwChildren

§

impl Display for DwDefaulted

§

impl Display for DwDs

§

impl Display for DwDsc

§

impl Display for DwEhPe

§

impl Display for DwEnd

§

impl Display for DwForm

§

impl Display for DwId

§

impl Display for DwIdx

§

impl Display for DwInl

§

impl Display for DwLang

§

impl Display for DwLle

§

impl Display for DwLnct

§

impl Display for DwLne

§

impl Display for DwLns

§

impl Display for DwMacinfo

§

impl Display for DwMacro

§

impl Display for DwOp

§

impl Display for DwOrd

§

impl Display for DwRle

§

impl Display for DwSect

§

impl Display for DwSectV2

§

impl Display for DwTag

§

impl Display for DwUt

§

impl Display for DwVirtuality

§

impl Display for DwVis

Source§

impl Display for EngineOrModuleTypeIndex

§

impl Display for Environment

1.0.0 · Source§

impl Display for wasmtime_environ::__core::fmt::Error

1.0.0 · Source§

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

§

impl Display for wasmtime_environ::prelude::Error

Source§

impl Display for serde_core::de::value::Error

Source§

impl Display for anyhow::Error

§

impl Display for Error

Source§

impl Display for semver::parse::Error

§

impl Display for Error

§

impl Display for Error

§

impl Display for Error

§

impl Display for Error

§

impl Display for Error

§

impl Display for Error

§

impl Display for Error

1.60.0 · Source§

impl Display for ErrorKind

1.20.0 · Source§

impl Display for wasmtime_environ::__core::char::EscapeDebug

1.39.0 · Source§

impl Display for wasmtime_environ::__core::ascii::EscapeDefault

1.16.0 · Source§

impl Display for wasmtime_environ::__core::char::EscapeDefault

1.16.0 · Source§

impl Display for wasmtime_environ::__core::char::EscapeUnicode

1.0.0 · Source§

impl Display for ExitStatus

Source§

impl Display for ExitStatusError

§

impl Display for FieldType

Source§

impl Display for FlagValue<'_>

1.69.0 · Source§

impl Display for FromBytesUntilNulError

1.17.0 · Source§

impl Display for FromBytesWithNulError

1.0.0 · Source§

impl Display for FromUtf8Error

1.0.0 · Source§

impl Display for FromUtf16Error

1.58.0 · Source§

impl Display for FromVecWithNulError

§

impl Display for FuncType

1.86.0 · Source§

impl Display for wasmtime_environ::__core::slice::GetDisjointMutError

§

impl Display for GetDisjointMutError

1.34.0 · Source§

impl Display for Infallible

Source§

impl Display for Inlining

1.7.0 · Source§

impl Display for IntoStringError

§

impl Display for InvalidBufferSize

§

impl Display for InvalidLength

§

impl Display for InvalidOutputSize

1.7.0 · Source§

impl Display for IpAddr

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.0.0 · Source§

impl Display for JoinPathsError

§

impl Display for KebabStr

§

impl Display for KebabString

1.28.0 · Source§

impl Display for LayoutError

Source§

impl Display for Level

Source§

impl Display for LevelFilter

1.26.0 · Source§

impl Display for Location<'_>

§

impl Display for MaxRecursionReached

§

impl Display for Mips32Architecture

§

impl Display for Mips64Architecture

Source§

impl Display for ModulePC

Source§

impl Display for NormalizeError

1.0.0 · Source§

impl Display for NulError

Source§

impl Display for ObjectCrateErrorWrapper

§

impl Display for OperatingSystem

§

impl Display for OutOfMemory

§

impl Display for PackedIndex

1.26.0 · Source§

impl Display for PanicHookInfo<'_>

1.26.0 · Source§

impl Display for PanicInfo<'_>

1.81.0 · Source§

impl Display for PanicMessage<'_>

1.0.0 · Source§

impl Display for ParseBoolError

1.20.0 · Source§

impl Display for ParseCharError

§

impl Display for ParseColorError

§

impl Display for ParseError

§

impl Display for ParseError

1.0.0 · Source§

impl Display for ParseFloatError

1.0.0 · Source§

impl Display for ParseIntError

Source§

impl Display for ParseLevelError

Source§

impl Display for Prerelease

§

impl Display for PrimitiveValType

1.0.0 · Source§

impl Display for RecvError

1.15.0 · Source§

impl Display for std::sync::mpsc::RecvTimeoutError

§

impl Display for RefType

§

impl Display for Riscv32Architecture

§

impl Display for Riscv64Architecture

§

impl Display for SectionIndex

Source§

impl Display for SetLoggerError

Source§

impl Display for SizeOverflow

1.0.0 · Source§

impl Display for SocketAddr

1.0.0 · Source§

impl Display for SocketAddrV4

1.0.0 · Source§

impl Display for SocketAddrV6

§

impl Display for StorageType

1.0.0 · Source§

impl Display for String

1.7.0 · Source§

impl Display for StripPrefixError

§

impl Display for StructType

§

impl Display for SubType

§

impl Display for SymbolIndex

1.8.0 · Source§

impl Display for SystemTimeError

1.16.0 · Source§

impl Display for ToLowercase

Source§

impl Display for ToTitlecase

1.16.0 · Source§

impl Display for ToUppercase

§

impl Display for TooFewItemsOrOom

Source§

impl Display for Trap

§

impl Display for Triple

1.59.0 · Source§

impl Display for TryFromCharError

1.66.0 · Source§

impl Display for TryFromFloatSecsError

1.34.0 · Source§

impl Display for TryFromIntError

1.35.0 · Source§

impl Display for TryFromSliceError

1.89.0 · Source§

impl Display for std::fs::TryLockError

1.0.0 · Source§

impl Display for std::sync::mpsc::TryRecvError

1.57.0 · Source§

impl Display for alloc::collections::TryReserveError

§

impl Display for TryReserveError

§

impl Display for TryReserveError

§

impl Display for TryString

Source§

impl Display for UnorderedKeyError

§

impl Display for UnpackedIndex

1.0.0 · Source§

impl Display for Utf8Error

§

impl Display for ValType

1.0.0 · Source§

impl Display for VarError

§

impl Display for Vendor

Source§

impl Display for Version

Source§

impl Display for VersionReq

Source§

impl Display for WasmArrayType

Source§

impl Display for WasmCompositeInnerType

Source§

impl Display for WasmCompositeType

Source§

impl Display for WasmContType

Source§

impl Display for WasmError

Source§

impl Display for WasmExnType

Source§

impl Display for WasmFieldType

Source§

impl Display for WasmFuncType

Source§

impl Display for WasmHeapType

Source§

impl Display for WasmRefType

Source§

impl Display for WasmStorageType

Source§

impl Display for WasmStructType

Source§

impl Display for WasmSubType

Source§

impl Display for WasmValType

Source§

impl Display for WouldBlock

1.56.0 · Source§

impl Display for WriterPanicked

§

impl Display for X86_32Architecture

1.0.0 · Source§

impl Display for bool

1.0.0 · Source§

impl Display for char

Source§

impl Display for dyn Expected + '_

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

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

§

impl<'a> Display for Demangle<'a>

1.60.0 · Source§

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

1.34.0 · Source§

impl<'a> Display for wasmtime_environ::__core::str::EscapeDebug<'a>

1.34.0 · Source§

impl<'a> Display for wasmtime_environ::__core::str::EscapeDefault<'a>

1.34.0 · Source§

impl<'a> Display for wasmtime_environ::__core::str::EscapeUnicode<'a>

Source§

impl<'a> Display for Unexpected<'a>

1.0.0 · Source§

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

§

impl<E> Display for BoxedSliceFromFallibleIterError<E>

§

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

Source§

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

1.93.0 · Source§

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

§

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

§

impl<K, V, S, A> Display for 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, 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,

Source§

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

Source§

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

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 std::sync::nonpoison::mutex::MappedMutexGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::poison::mutex::MappedMutexGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::nonpoison::rwlock::MappedRwLockReadGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::poison::rwlock::MappedRwLockReadGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::nonpoison::rwlock::MappedRwLockWriteGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::poison::rwlock::MappedRwLockWriteGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::nonpoison::mutex::MutexGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for std::sync::poison::mutex::MutexGuard<'_, T>
where T: Display + ?Sized,

1.28.0 · Source§

impl<T> Display for NonZero<T>

1.0.0 · Source§

impl<T> Display for PoisonError<T>

Source§

impl<T> Display for std::sync::oneshot::RecvTimeoutError<T>

Source§

impl<T> Display for ReentrantLockGuard<'_, 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> Display for std::sync::nonpoison::rwlock::RwLockReadGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for std::sync::poison::rwlock::RwLockReadGuard<'_, T>
where T: Display + ?Sized,

Source§

impl<T> Display for std::sync::nonpoison::rwlock::RwLockWriteGuard<'_, T>
where T: Display + ?Sized,

1.20.0 · Source§

impl<T> Display for std::sync::poison::rwlock::RwLockWriteGuard<'_, T>
where T: Display + ?Sized,

1.74.0 · Source§

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

1.0.0 · Source§

impl<T> Display for SendError<T>

Source§

impl<T> Display for SendTimeoutError<T>

Source§

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

1.0.0 · Source§

impl<T> Display for std::sync::poison::TryLockError<T>

Source§

impl<T> Display for std::sync::oneshot::TryRecvError<T>

1.0.0 · Source§

impl<T> Display for TrySendError<T>

1.10.0 · Source§

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

1.0.0 · Source§

impl<W> Display for IntoInnerError<W>