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 · Sourcefn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>
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§
impl Display for solar::ast::bumpalo::core_alloc::slice::GetDisjointMutError
impl Display for Base
impl Display for ContractKind
impl Display for DataLocation
impl Display for ElementaryType
impl Display for EtherSubDenomination
impl Display for FunctionKind
impl Display for SemverReqComponentKind
impl Display for SemverVersionNumber
impl Display for StateMutability
impl Display for SubDenomination
impl Display for TimeSubDenomination
impl Display for VarMut
impl Display for Visibility
impl Display for BinOpToken
impl Display for TokenDescription
impl Display for TokenKind
impl Display for CompilerOutput
impl Display for CompilerStage
impl Display for DumpKind
impl Display for ErrorFormat
impl Display for EvmVersion
impl Display for HumanEmitterKind
impl Display for Language
impl Display for ResolveError
impl Display for CollectionAllocErr
impl Display for AsciiChar
impl Display for Infallible
impl Display for FromBytesWithNulError
impl Display for IpAddr
impl Display for SocketAddr
impl Display for VarError
impl Display for std::fs::TryLockError
impl Display for std::io::error::ErrorKind
impl Display for RecvTimeoutError
impl Display for TryRecvError
impl Display for InternalType
impl Display for AddressError
impl Display for SignatureError
impl Display for ParseSignedError
impl Display for Sign
impl Display for ParseUnits
impl Display for UnitsError
impl Display for Storage
impl Display for ContextKind
impl Display for ContextValue
impl Display for clap_builder::error::kind::ErrorKind
impl Display for MatchesError
impl Display for ColorChoice
impl Display for FromHexError
impl Display for BinaryError
impl Display for indexmap::GetDisjointMutError
impl Display for log::Level
impl Display for log::LevelFilter
impl Display for StartError
impl Display for Ast
Print a display representation of this Ast.
This does not preserve any of the original whitespace formatting that may have originally been present in the concrete syntax from which this Ast was generated.
This implementation uses constant stack space and heap space proportional
to the size of the Ast.
impl Display for regex_syntax::ast::ErrorKind
impl Display for regex_syntax::error::Error
impl Display for regex_syntax::hir::ErrorKind
impl Display for BaseConvertError
impl Display for ToFieldError
impl Display for ruint::string::ParseError
impl Display for Value
impl Display for StrSimError
impl Display for strum::ParseError
impl Display for StrContext
impl Display for StrContextValue
impl Display for bool
impl Display for char
impl Display for f16
impl Display for f32
impl Display for f64
impl Display for i8
impl Display for i16
impl Display for i32
impl Display for i64
impl Display for i128
impl Display for isize
impl Display for !
impl Display for str
impl Display for u8
impl Display for u16
impl Display for u32
impl Display for u64
impl Display for u128
impl Display for usize
impl Display for AllocError
impl Display for LayoutError
impl Display for ByteStr
impl Display for ByteString
impl Display for UnorderedKeyError
impl Display for solar::ast::bumpalo::core_alloc::collections::TryReserveError
impl Display for FromVecWithNulError
impl Display for IntoStringError
impl Display for NulError
impl Display for ParseBoolError
impl Display for Utf8Error
impl Display for FromUtf8Error
impl Display for FromUtf16Error
impl Display for String
impl Display for AllocErr
impl Display for BinOp
impl Display for Ident
impl Display for Lit<'_>
impl Display for Path
impl Display for PathSlice
impl Display for SemverReq<'_>
impl Display for SemverReqComponent
impl Display for SemverReqCon<'_>
impl Display for SemverVersion
impl Display for Symbol
impl Display for UnOp
impl Display for TokenLit
impl Display for ImportRemapping
impl Display for Threads
impl Display for EmittedDiagnostics
impl Display for FileNameDisplay<'_>
impl Display for OffsetOverflowError
impl Display for EvalError
impl Display for TryFromSliceError
impl Display for core::ascii::EscapeDefault
impl Display for BorrowError
impl Display for BorrowMutError
impl Display for CharTryFromError
impl Display for ParseCharError
impl Display for DecodeUtf16Error
impl Display for core::char::EscapeDebug
impl Display for core::char::EscapeDefault
impl Display for core::char::EscapeUnicode
impl Display for ToLowercase
impl Display for ToUppercase
impl Display for TryFromCharError
impl Display for FromBytesUntilNulError
impl Display for Ipv4Addr
impl Display for Ipv6Addr
Writes an Ipv6Addr, conforming to the canonical style described by RFC 5952.
impl Display for AddrParseError
impl Display for SocketAddrV4
impl Display for SocketAddrV6
impl Display for core::num::dec2flt::ParseFloatError
impl Display for ParseIntError
impl Display for TryFromIntError
impl Display for Location<'_>
impl Display for PanicInfo<'_>
impl Display for PanicMessage<'_>
impl Display for TryFromFloatSecsError
impl Display for Backtrace
impl Display for JoinPathsError
impl Display for std::ffi::os_str::Display<'_>
impl Display for WriterPanicked
impl Display for std::io::error::Error
impl Display for PanicHookInfo<'_>
impl Display for std::path::Display<'_>
impl Display for NormalizeError
impl Display for StripPrefixError
impl Display for ExitStatus
impl Display for ExitStatusError
impl Display for RecvError
impl Display for WouldBlock
impl Display for AccessError
impl Display for SystemTimeError
impl Display for EventParam
impl Display for Param
impl Display for Address
impl Display for AddressChecksumBuffer
impl Display for Bloom
impl Display for Function
impl Display for alloy_primitives::bytes_::Bytes
impl Display for Signature
impl Display for BigIntConversionError
impl Display for Unit
impl Display for alloy_sol_type_parser::error::Error
impl Display for RootType<'_>
impl Display for StrippedStr<'_>
impl Display for Reset
impl Display for Style
impl Display for bitflags::parser::ParseError
impl Display for TryGetError
impl Display for Arg
impl Display for Command
impl Display for ValueRange
impl Display for Str
impl Display for StyledStr
Color-unaware printing. Never uses coloring.
impl Display for Id
impl Display for WrongVariantError
impl Display for UnitError
impl Display for FromStrError
impl Display for indexmap::TryReserveError
impl Display for log::ParseLevelError
impl Display for SetLoggerError
impl Display for Infix
impl Display for Prefix
impl Display for Suffix
impl Display for BigInt
impl Display for BigUint
impl Display for ParseBigIntError
impl Display for ParseRatioError
impl Display for num_traits::ParseFloatError
impl Display for ThreadPoolBuildError
impl Display for regex_automata::dfa::dense::BuildError
impl Display for regex_automata::nfa::thompson::error::BuildError
impl Display for GroupInfoError
impl Display for UnicodeWordBoundaryError
impl Display for PatternIDError
impl Display for SmallIndexError
impl Display for StateIDError
impl Display for MatchError
impl Display for PatternSetInsertError
impl Display for DeserializeError
impl Display for SerializeError
impl Display for regex_syntax::ast::Error
impl Display for regex_syntax::hir::Error
impl Display for Hir
Print a display representation of this Hir.
The result of this is a valid regular expression pattern string.
This implementation uses constant stack space and heap space proportional
to the size of the Hir.
impl Display for CaseFoldError
impl Display for UnicodeWordError
impl Display for semver::parse::Error
impl Display for BuildMetadata
impl Display for Comparator
impl Display for Prerelease
impl Display for Version
impl Display for VersionReq
impl Display for serde_core::de::value::Error
impl Display for serde_json::error::Error
impl Display for Number
impl Display for SetGlobalDefaultError
impl Display for Field
impl Display for FieldSet
impl Display for ValueSet<'_>
impl Display for tracing_core::metadata::Level
impl Display for tracing_core::metadata::LevelFilter
impl Display for tracing_core::metadata::ParseLevelError
impl Display for ParseLevelFilterError
impl Display for tracing_subscriber::filter::directive::ParseError
impl Display for Directive
impl Display for BadName
impl Display for EnvFilter
impl Display for FromEnvError
impl Display for Targets
impl Display for tracing_subscriber::reload::Error
impl Display for TryInitError
impl Display for ContextError
impl Display for EmptyError
impl Display for BStr
impl Display for winnow::stream::bytes::Bytes
impl Display for Range
impl Display for Arguments<'_>
impl Display for solar::data_structures::fmt::Error
impl Display for dyn Expected + '_
impl Display for dyn Value
impl<'a> Display for Unexpected<'a>
impl<'a> Display for EscapeAscii<'a>
impl<'a> Display for solar::ast::bumpalo::core_alloc::str::EscapeDebug<'a>
impl<'a> Display for solar::ast::bumpalo::core_alloc::str::EscapeDefault<'a>
impl<'a> Display for solar::ast::bumpalo::core_alloc::str::EscapeUnicode<'a>
impl<'a> Display for AnsiGenericString<'a, str>
impl<'a> Display for AnsiGenericStrings<'a, str>
impl<'a, I> Display for Format<'a, I>
impl<'a, I, F> Display for FormatWith<'a, I, F>
impl<'a, K, V> Display for std::collections::hash::map::OccupiedError<'a, K, V>
impl<'a, K, V, A> Display for solar::ast::bumpalo::core_alloc::collections::btree_map::OccupiedError<'a, K, V, A>
impl<'a, K, V, S, A> Display for hashbrown::map::OccupiedError<'a, K, V, S, A>
impl<'a, K, V, T> Display for MappedRef<'a, K, V, T>
impl<'a, R, G, T> Display for MappedReentrantMutexGuard<'a, R, G, T>
impl<'a, R, G, T> Display for ReentrantMutexGuard<'a, R, G, T>
impl<'a, R, T> Display for lock_api::mutex::MappedMutexGuard<'a, R, T>
impl<'a, R, T> Display for lock_api::mutex::MutexGuard<'a, R, T>
impl<'a, R, T> Display for lock_api::rwlock::MappedRwLockReadGuard<'a, R, T>
impl<'a, R, T> Display for lock_api::rwlock::MappedRwLockWriteGuard<'a, R, T>
impl<'a, R, T> Display for lock_api::rwlock::RwLockReadGuard<'a, R, T>
impl<'a, R, T> Display for RwLockUpgradableReadGuard<'a, R, T>
impl<'a, R, T> Display for lock_api::rwlock::RwLockWriteGuard<'a, R, T>
impl<'a, T> Display for solar::ast::bumpalo::boxed::Box<'a, T>
impl<B> Display for Cow<'_, B>
impl<E> Display for AllocOrInitError<E>where
E: Display,
impl<E> Display for ErrMode<E>where
E: Debug,
impl<E> Display for Report<E>where
E: Error,
impl<E> Display for FormattedFields<E>where
E: ?Sized,
impl<F> Display for clap_builder::error::Error<F>where
F: ErrorFormatter,
impl<F> Display for FromFn<F>
impl<I> Display for ExactlyOneError<I>where
I: Iterator,
impl<I> Display for InputError<I>
The Display implementation allows the std::error::Error implementation