Struct grafix_toolbox::lib::fmt::DebugMap
1.2.0 · source · pub struct DebugMap<'a, 'b>where
'b: 'a,{ /* private fields */ }Expand description
A struct to help with fmt::Debug implementations.
This is useful when you wish to output a formatted map as a part of your
Debug::fmt implementation.
This can be constructed by the Formatter::debug_map method.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map().entries(self.0.iter().map(|&(ref k, ref v)| (k, v))).finish()
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"A\": 10, \"B\": 11}",
);Implementations§
source§impl<'a, 'b> DebugMap<'a, 'b>where
'b: 'a,
impl<'a, 'b> DebugMap<'a, 'b>where
'b: 'a,
1.2.0 · sourcepub fn entry(
&mut self,
key: &dyn Debug,
value: &dyn Debug,
) -> &mut DebugMap<'a, 'b>
pub fn entry( &mut self, key: &dyn Debug, value: &dyn Debug, ) -> &mut DebugMap<'a, 'b>
Adds a new entry to the map output.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map()
.entry(&"whole", &self.0) // We add the "whole" entry.
.finish()
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"whole\": [(\"A\", 10), (\"B\", 11)]}",
);1.42.0 · sourcepub fn key(&mut self, key: &dyn Debug) -> &mut DebugMap<'a, 'b>
pub fn key(&mut self, key: &dyn Debug) -> &mut DebugMap<'a, 'b>
Adds the key part of a new entry to the map output.
This method, together with value, is an alternative to entry that
can be used when the complete entry isn’t known upfront. Prefer the entry
method when it’s possible to use.
§Panics
key must be called before value and each call to key must be followed
by a corresponding call to value. Otherwise this method will panic.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map()
.key(&"whole").value(&self.0) // We add the "whole" entry.
.finish()
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"whole\": [(\"A\", 10), (\"B\", 11)]}",
);sourcepub fn key_with<F>(&mut self, key_fmt: F) -> &mut DebugMap<'a, 'b>
🔬This is a nightly-only experimental API. (debug_closure_helpers)
pub fn key_with<F>(&mut self, key_fmt: F) -> &mut DebugMap<'a, 'b>
debug_closure_helpers)Adds the key part of a new entry to the map output.
This method is equivalent to DebugMap::key, but formats the
key using a provided closure rather than by calling Debug::fmt.
1.42.0 · sourcepub fn value(&mut self, value: &dyn Debug) -> &mut DebugMap<'a, 'b>
pub fn value(&mut self, value: &dyn Debug) -> &mut DebugMap<'a, 'b>
Adds the value part of a new entry to the map output.
This method, together with key, is an alternative to entry that
can be used when the complete entry isn’t known upfront. Prefer the entry
method when it’s possible to use.
§Panics
key must be called before value and each call to key must be followed
by a corresponding call to value. Otherwise this method will panic.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map()
.key(&"whole").value(&self.0) // We add the "whole" entry.
.finish()
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"whole\": [(\"A\", 10), (\"B\", 11)]}",
);sourcepub fn value_with<F>(&mut self, value_fmt: F) -> &mut DebugMap<'a, 'b>
🔬This is a nightly-only experimental API. (debug_closure_helpers)
pub fn value_with<F>(&mut self, value_fmt: F) -> &mut DebugMap<'a, 'b>
debug_closure_helpers)Adds the value part of a new entry to the map output.
This method is equivalent to DebugMap::value, but formats the
value using a provided closure rather than by calling Debug::fmt.
1.2.0 · sourcepub fn entries<K, V, I>(&mut self, entries: I) -> &mut DebugMap<'a, 'b>
pub fn entries<K, V, I>(&mut self, entries: I) -> &mut DebugMap<'a, 'b>
Adds the contents of an iterator of entries to the map output.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map()
// We map our vec so each entries' first field will become
// the "key".
.entries(self.0.iter().map(|&(ref k, ref v)| (k, v)))
.finish()
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"A\": 10, \"B\": 11}",
);1.2.0 · sourcepub fn finish(&mut self) -> Result<(), Error>
pub fn finish(&mut self) -> Result<(), Error>
Finishes output and returns any error encountered.
§Panics
key must be called before value and each call to key must be followed
by a corresponding call to value. Otherwise this method will panic.
§Examples
use std::fmt;
struct Foo(Vec<(String, i32)>);
impl fmt::Debug for Foo {
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt.debug_map()
.entries(self.0.iter().map(|&(ref k, ref v)| (k, v)))
.finish() // Ends the map formatting.
}
}
assert_eq!(
format!("{:?}", Foo(vec![("A".to_string(), 10), ("B".to_string(), 11)])),
"{\"A\": 10, \"B\": 11}",
);Trait Implementations§
source§impl<'a, 'b> Visit for DebugMap<'a, 'b>
impl<'a, 'b> Visit for DebugMap<'a, 'b>
source§fn record_debug(&mut self, field: &Field, value: &dyn Debug)
fn record_debug(&mut self, field: &Field, value: &dyn Debug)
fmt::Debug.source§fn record_f64(&mut self, field: &Field, value: f64)
fn record_f64(&mut self, field: &Field, value: f64)
source§fn record_i64(&mut self, field: &Field, value: i64)
fn record_i64(&mut self, field: &Field, value: i64)
source§fn record_u64(&mut self, field: &Field, value: u64)
fn record_u64(&mut self, field: &Field, value: u64)
source§fn record_i128(&mut self, field: &Field, value: i128)
fn record_i128(&mut self, field: &Field, value: i128)
source§fn record_u128(&mut self, field: &Field, value: u128)
fn record_u128(&mut self, field: &Field, value: u128)
source§fn record_bool(&mut self, field: &Field, value: bool)
fn record_bool(&mut self, field: &Field, value: bool)
source§fn record_str(&mut self, field: &Field, value: &str)
fn record_str(&mut self, field: &Field, value: &str)
Auto Trait Implementations§
impl<'a, 'b> Freeze for DebugMap<'a, 'b>
impl<'a, 'b> !RefUnwindSafe for DebugMap<'a, 'b>
impl<'a, 'b> !Send for DebugMap<'a, 'b>
impl<'a, 'b> !Sync for DebugMap<'a, 'b>
impl<'a, 'b> Unpin for DebugMap<'a, 'b>
impl<'a, 'b> !UnwindSafe for DebugMap<'a, 'b>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moresource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.