Enum Conditional

Source
pub enum Conditional<T> {
    Always(T),
    OnlyBroken(T),
    OnlyUnbroken(T),
}
Expand description

A wrapper which decides whether or not to render its contents based on the breaking mode of the environment.

§Examples

Adding a trailing comma only when broken:

use pretty_trait::{JoinExt, Sep, Conditional, to_string};

let max_line = Some(10);
let tab_size = 4;

let to_render = "lorem,"
    .join(Sep(1))
    .join("ipsum,")
    .join(Sep(1))
    .join("dolor,")
    .join(Sep(1))
    .join("sit,")
    .join(Sep(1))
    .join("amet")
    .join(Conditional::OnlyBroken(","));

// Trailing comma when broken across multiple lines:

let expected_broken = "\
lorem,
ipsum,
dolor,
sit,
amet,";

assert_eq!(to_string(&to_render, max_line, tab_size), expected_broken);

// No trailing comma when rendered on a single line:

assert_eq!(
    to_string(&to_render, None, tab_size),
    "lorem, ipsum, dolor, sit, amet"
);

Variants§

§

Always(T)

Render the wrapped value under all circumstances

§

OnlyBroken(T)

Render the wrapped value only when it appears in a multi-line context

§

OnlyUnbroken(T)

Render the wrapped value only when it appears in a single-line context

Trait Implementations§

Source§

impl<T: Clone> Clone for Conditional<T>

Source§

fn clone(&self) -> Conditional<T>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug> Debug for Conditional<T>

Source§

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

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

impl<T: Pretty> Pretty for Conditional<T>

Source§

fn size(&self) -> Size

Calculate the intrinsic size of this value, if it were to be displayed on a single line.
Source§

fn pretty_write(&self, context: Context<'_>) -> Result<()>

Render this value in a given context.
Source§

impl<T: Copy> Copy for Conditional<T>

Auto Trait Implementations§

§

impl<T> Freeze for Conditional<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Conditional<T>
where T: RefUnwindSafe,

§

impl<T> Send for Conditional<T>
where T: Send,

§

impl<T> Sync for Conditional<T>
where T: Sync,

§

impl<T> Unpin for Conditional<T>
where T: Unpin,

§

impl<T> UnwindSafe for Conditional<T>
where T: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> JoinExt for T
where T: Pretty,

Source§

fn join<U>(self, other: U) -> Join<T, U>

Concatenate two pretty-printable values. This directly displays one after the other, with no separation or line breaks. For separation, use the Sep type. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.