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.
§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 geng_core::prelude::bincode::ErrorKind
impl Display for BernoulliError
impl Display for WeightedError
impl Display for geng_core::prelude::futures::io::ErrorKind
impl Display for AsciiChar
impl Display for Infallible
impl Display for FromBytesWithNulError
impl Display for core::net::ip_addr::IpAddr
impl Display for SocketAddr
impl Display for GetDisjointMutError
impl Display for VarError
impl Display for std::fs::TryLockError
impl Display for RecvTimeoutError
impl Display for std::sync::mpsc::TryRecvError
impl Display for DecodeError
impl Display for CheckedCastError
impl Display for PodCastError
impl Display for RoundingError
impl Display for Weekday
impl Display for claxon::error::Error
impl Display for BuildStreamError
impl Display for DefaultFormatError
impl Display for DeviceNameError
impl Display for DevicesError
impl Display for PauseStreamError
impl Display for PlayStreamError
impl Display for StreamError
impl Display for SupportedFormatsError
impl Display for MatchingType
impl Display for gif::encoder::EncodingError
impl Display for gif::reader::decoder::DecodingError
impl Display for gimli::read::Error
impl Display for ContextError
impl Display for CreationError
impl Display for hound::Error
impl Display for GetTimezoneError
impl Display for ImageError
impl Display for ImageFormatHint
impl Display for image::flat::Error
impl Display for jpeg_decoder::error::Error
impl Display for AudioReadError
impl Display for VorbisError
impl Display for HeaderReadError
impl Display for libloading::error::Error
impl Display for minimp3::error::Error
impl Display for nix::Error
impl Display for Errno
impl Display for Signal
impl Display for InetAddr
impl Display for nix::sys::socket::addr::IpAddr
impl Display for SockAddr
impl Display for OggReadError
impl Display for BlendOp
impl Display for DisposeOp
impl Display for png::decoder::stream::DecodingError
impl Display for png::encoder::EncodingError
impl Display for DecoderError
impl Display for ErrorCode
impl Display for rusttype::Error
impl Display for CacheReadErr
impl Display for CacheWriteErr
impl Display for CollectionAllocErr
impl Display for TiffError
impl Display for TiffFormatError
impl Display for TiffUnsupportedError
impl Display for FaceParsingError
impl Display for Void
impl Display for ConnectError
impl Display for GlobalError
impl Display for MessageParseError
impl Display for MessageWriteError
impl Display for LzwError
impl Display for ExternalError
impl Display for BadIcon
impl Display for XNotSupported
impl Display for XmlVersion
impl Display for Encoding
impl Display for EmitterError
impl Display for BigEndian
impl Display for LittleEndian
impl Display for Level
impl Display for LevelFilter
impl Display for Value
impl Display for Shell
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 geng_core::prelude::anyhow::Error
impl Display for geng_core::prelude::futures::channel::mpsc::SendError
impl Display for geng_core::prelude::futures::channel::mpsc::TryRecvError
impl Display for Canceled
impl Display for EnterError
impl Display for Aborted
impl Display for geng_core::prelude::futures::io::Error
impl Display for SpawnError
impl Display for ByteString
impl Display for UnorderedKeyError
impl Display for TryReserveError
impl Display for FromVecWithNulError
impl Display for IntoStringError
impl Display for NulError
impl Display for FromUtf8Error
impl Display for FromUtf16Error
impl Display for String
impl Display for LayoutError
impl Display for AllocError
impl Display for core::array::TryFromSliceError
impl Display for core::ascii::EscapeDefault
impl Display for ByteStr
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 Arguments<'_>
impl Display for core::fmt::Error
impl Display for core::net::ip_addr::Ipv4Addr
impl Display for core::net::ip_addr::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 ParseBoolError
impl Display for Utf8Error
impl Display for TryFromFloatSecsError
impl Display for std::backtrace::Backtrace
impl Display for JoinPathsError
impl Display for std::ffi::os_str::Display<'_>
impl Display for WriterPanicked
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 AccessError
impl Display for SystemTimeError
impl Display for Infix
impl Display for Prefix
impl Display for Suffix
impl Display for ParseError
impl Display for ParseMonthError
impl Display for NaiveDate
The Display
output of the naive date d
is the same as
d.format("%Y-%m-%d")
.
The string printed can be readily parsed via the parse
method on str
.
§Example
use chrono::NaiveDate;
assert_eq!(format!("{}", NaiveDate::from_ymd_opt(2015, 9, 5).unwrap()), "2015-09-05");
assert_eq!(format!("{}", NaiveDate::from_ymd_opt(0, 1, 1).unwrap()), "0000-01-01");
assert_eq!(format!("{}", NaiveDate::from_ymd_opt(9999, 12, 31).unwrap()), "9999-12-31");
ISO 8601 requires an explicit sign for years before 1 BCE or after 9999 CE.
assert_eq!(format!("{}", NaiveDate::from_ymd_opt(-1, 1, 1).unwrap()), "-0001-01-01");
assert_eq!(format!("{}", NaiveDate::from_ymd_opt(10000, 12, 31).unwrap()), "+10000-12-31");
impl Display for NaiveDateTime
The Display
output of the naive date and time dt
is the same as
dt.format("%Y-%m-%d %H:%M:%S%.f")
.
It should be noted that, for leap seconds not on the minute boundary, it may print a representation not distinguishable from non-leap seconds. This doesn’t matter in practice, since such leap seconds never happened. (By the time of the first leap second on 1972-06-30, every time zone offset around the world has standardized to the 5-minute alignment.)
§Example
use chrono::NaiveDate;
let dt = NaiveDate::from_ymd_opt(2016, 11, 15).unwrap().and_hms_opt(7, 39, 24).unwrap();
assert_eq!(format!("{}", dt), "2016-11-15 07:39:24");
Leap seconds may also be used.
let dt =
NaiveDate::from_ymd_opt(2015, 6, 30).unwrap().and_hms_milli_opt(23, 59, 59, 1_500).unwrap();
assert_eq!(format!("{}", dt), "2015-06-30 23:59:60.500");
impl Display for NaiveTime
The Display
output of the naive time t
is the same as
t.format("%H:%M:%S%.f")
.
The string printed can be readily parsed via the parse
method on str
.
It should be noted that, for leap seconds not on the minute boundary, it may print a representation not distinguishable from non-leap seconds. This doesn’t matter in practice, since such leap seconds never happened. (By the time of the first leap second on 1972-06-30, every time zone offset around the world has standardized to the 5-minute alignment.)
§Example
use chrono::NaiveTime;
assert_eq!(format!("{}", NaiveTime::from_hms_opt(23, 56, 4).unwrap()), "23:56:04");
assert_eq!(
format!("{}", NaiveTime::from_hms_milli_opt(23, 56, 4, 12).unwrap()),
"23:56:04.012"
);
assert_eq!(
format!("{}", NaiveTime::from_hms_micro_opt(23, 56, 4, 1234).unwrap()),
"23:56:04.001234"
);
assert_eq!(
format!("{}", NaiveTime::from_hms_nano_opt(23, 56, 4, 123456).unwrap()),
"23:56:04.000123456"
);
Leap seconds may also be used.
assert_eq!(
format!("{}", NaiveTime::from_hms_milli_opt(6, 59, 59, 1_500).unwrap()),
"06:59:60.500"
);
impl Display for FixedOffset
impl Display for Utc
impl Display for OutOfRange
impl Display for OutOfRangeError
impl Display for TimeDelta
impl Display for ParseWeekdayError
impl Display for WeekdaySet
Print the collection as a slice-like list of weekdays.
§Example
use chrono::Weekday::*;
assert_eq!("[]", WeekdaySet::EMPTY.to_string());
assert_eq!("[Mon]", WeekdaySet::single(Mon).to_string());
assert_eq!("[Mon, Fri, Sun]", WeekdaySet::from_array([Mon, Fri, Sun]).to_string());
impl Display for BackendSpecificError
impl Display for failure::backtrace::Backtrace
impl Display for getrandom::error::Error
impl Display for DecodingFormatError
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 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
impl Display for image::error::DecodingError
impl Display for image::error::EncodingError
impl Display for LimitError
impl Display for ParameterError
impl Display for UnsupportedError
impl Display for AlgAddr
impl Display for LinkAddr
impl Display for NetlinkAddr
impl Display for nix::sys::socket::addr::Ipv4Addr
impl Display for nix::sys::socket::addr::Ipv6Addr
impl Display for UnixAddr
impl Display for TimeSpec
impl Display for TimeVal
impl Display for Gid
impl Display for Pid
impl Display for Uid
impl Display for ParseRatioError
impl Display for num_traits::ParseFloatError
impl Display for object::read::Error
impl Display for SectionIndex
impl Display for SymbolIndex
impl Display for FloatIsNan
impl Display for ThreadPoolBuildError
impl Display for ron::error::Error
impl Display for Position
impl Display for ColorChoiceParseError
impl Display for ParseColorError
impl Display for tinyvec::arrayvec::TryFromSliceError
impl Display for Tag
impl Display for ProgramLinkError
impl Display for ShaderCompilationError
impl Display for walkdir::error::Error
impl Display for ProtocolError
impl Display for NotSupportedError
impl Display for OsError
impl Display for VideoMode
impl Display for XError
impl Display for OpenError
impl Display for xdg::base_directories::Error
impl Display for Attribute<'_>
impl Display for OwnedAttribute
impl Display for TextPosition
impl Display for Name<'_>
impl Display for OwnedName
impl Display for xml::reader::error::Error
impl Display for ParseLevelError
impl Display for SetLoggerError
impl Display for ReadError
impl Display for geng_core::prelude::rand::Error
impl Display for geng_core::prelude::serde::de::value::Error
impl Display for geng_core::prelude::serde_json::Error
impl Display for Number
impl Display for geng_core::prelude::Error
impl Display for geng_core::prelude::structopt::clap::Error
impl Display for dyn Expected + '_
impl<'a> Display for BytesOrWideString<'a>
impl<'a> Display for Unexpected<'a>
impl<'a> Display for EscapeAscii<'a>
impl<'a> Display for core::str::iter::EscapeDebug<'a>
impl<'a> Display for core::str::iter::EscapeDefault<'a>
impl<'a> Display for core::str::iter::EscapeUnicode<'a>
impl<'a> Display for ANSIGenericString<'a, str>
impl<'a> Display for ANSIGenericStrings<'a, str>
impl<'a> Display for SymbolName<'a>
impl<'a> Display for Base64Display<'a>
impl<'a> Display for PercentEncode<'a>
impl<'a> Display for Demangle<'a>
impl<'a, 'b> Display for ReprDisplay<'a, 'b>where
'b: 'a,
impl<'a, I, B> Display for DelayedFormat<I>
impl<'a, K, V> Display for std::collections::hash::map::OccupiedError<'a, K, V>
impl<'a, K, V, A> Display for alloc::collections::btree::map::entry::OccupiedError<'a, K, V, A>
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<'n, 'e> Display for App<'n, 'e>
impl<'s, T> Display for SliceVec<'s, T>where
T: Display,
impl<A> Display for TinyVec<A>
impl<A> Display for ArrayVec<A>
impl<A, S, V> Display for ConvertError<A, S, V>
Produces a human-readable error message.
The message differs between debug and release builds. When
debug_assertions
are enabled, this message is verbose and includes
potentially sensitive information.
impl<B> Display for Cow<'_, B>
impl<D> Display for Context<D>
impl<E> Display for ParseNotNanError<E>where
E: Debug,
impl<E> Display for Report<E>where
E: Error,
impl<E> Display for Compat<E>where
E: Display,
impl<Enum> Display for TryFromPrimitiveError<Enum>where
Enum: TryFromPrimitive,
impl<F> Display for FromFn<F>
impl<L, R> Display for Either<L, R>
impl<O> Display for F32<O>where
O: ByteOrder,
impl<O> Display for F64<O>where
O: ByteOrder,
impl<O> Display for I16<O>where
O: ByteOrder,
impl<O> Display for I32<O>where
O: ByteOrder,
impl<O> Display for I64<O>where
O: ByteOrder,
impl<O> Display for I128<O>where
O: ByteOrder,
impl<O> Display for Isize<O>where
O: ByteOrder,
impl<O> Display for U16<O>where
O: ByteOrder,
impl<O> Display for U32<O>where
O: ByteOrder,
impl<O> Display for U64<O>where
O: ByteOrder,
impl<O> Display for U128<O>where
O: ByteOrder,
impl<O> Display for Usize<O>where
O: ByteOrder,
impl<Ptr> Display for Pin<Ptr>where
Ptr: Display,
impl<Src, Dst> Display for AlignmentError<Src, Dst>
Produces a human-readable error message.
The message differs between debug and release builds. When
debug_assertions
are enabled, this message is verbose and includes
potentially sensitive information.
impl<Src, Dst> Display for SizeError<Src, Dst>
Produces a human-readable error message.
The message differs between debug and release builds. When
debug_assertions
are enabled, this message is verbose and includes
potentially sensitive information.
impl<Src, Dst> Display for ValidityError<Src, Dst>
Produces a human-readable error message.
The message differs between debug and release builds. When
debug_assertions
are enabled, this message is verbose and includes
potentially sensitive information.