Skip to main content

SetWriter

Struct SetWriter 

Source
pub struct SetWriter<'caller, W: Warning> { /* private fields */ }
Expand description

A Display object for writing a set of warnings.

The warnings set is formatted as a tree with element paths on the first level and a list of warning ids on the second.

$path.to.json.[0].field:
  - list_of_warning_ids
  - next_warning_id

$next.path.to.[1].json.field
  - list_of_warning_ids

Implementations§

Source§

impl<'caller, W: Warning> SetWriter<'caller, W>

Source

pub fn new(warnings: &'caller Set<W>) -> Self

Create a new SetWriter with a default warning id indent of " - ".

Examples found in repository?
examples/generate_cdr_from_tariff.rs (line 81)
73fn print_warnings(warnings: &warning::Set<generate::Warning>) {
74    if warnings.is_empty() {
75        return;
76    }
77
78    eprintln!(
79        "WARN: {} warnings from the linting:\n {}",
80        warnings.len_warnings(),
81        warning::SetWriter::new(warnings)
82    );
83}
More examples
Hide additional examples
examples/price_cdr_with_known_version.rs (line 78)
70fn print_pricing_warnings(warnings: &warning::Set<price::Warning>) {
71    if warnings.is_empty() {
72        return;
73    }
74
75    eprintln!(
76        "WARN: {} warnings from the pricing:\n {}",
77        warnings.len_warnings(),
78        warning::SetWriter::new(warnings)
79    );
80}
examples/lint_tariff.rs (line 40)
32fn print_lint_warnings(warnings: &warning::Set<lint::tariff::Warning>) {
33    if warnings.is_empty() {
34        return;
35    }
36
37    eprintln!(
38        "WARN: {} warnings from the linting:\n {}",
39        warnings.len_warnings(),
40        warning::SetWriter::new(warnings)
41    );
42}
examples/price_cdr_with_unknown_version.rs (line 110)
97fn print_timezone_warnings(warnings: &warning::Set<timezone::Warning>) {
98    if warnings.is_empty() {
99        return;
100    }
101
102    eprintln!(
103        "WARN: {} warnings from the timezone search",
104        warnings.len_warnings()
105    );
106
107    eprintln!(
108        "WARN: {} warnings from the timezone search:\n {}",
109        warnings.len_warnings(),
110        warning::SetWriter::new(warnings)
111    );
112}
113
114fn print_pricing_error(error: &warning::Error<price::Warning>) {
115    eprintln!(
116        "ERR: Unable to price CDR due to error at path `{}`: {}",
117        error.element().path,
118        error.warning()
119    );
120}
121
122fn print_pricing_warnings(warnings: &warning::Set<price::Warning>) {
123    if warnings.is_empty() {
124        return;
125    }
126
127    eprintln!(
128        "WARN: {} warnings from the linting:\n {}",
129        warnings.len_warnings(),
130        warning::SetWriter::new(warnings)
131    );
132}
Source

pub fn with_indent(warnings: &'caller Set<W>, indent: &'caller str) -> Self

Create a new SetWriter with a custom warning id indent.

Trait Implementations§

Source§

impl<W: Warning> Debug for SetWriter<'_, W>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<W: Warning> Display for SetWriter<'_, W>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'caller, W> Freeze for SetWriter<'caller, W>

§

impl<'caller, W> RefUnwindSafe for SetWriter<'caller, W>
where W: RefUnwindSafe,

§

impl<'caller, W> Send for SetWriter<'caller, W>

§

impl<'caller, W> Sync for SetWriter<'caller, W>

§

impl<'caller, W> Unpin for SetWriter<'caller, W>

§

impl<'caller, W> UnwindSafe for SetWriter<'caller, W>
where W: RefUnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

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

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more