Struct tyche::dice::Builder

source ·
pub struct Builder(/* private fields */);
Expand description

Builds Dice with a fluent interface.

§Examples

§Basic dice

use tyche::Dice;

let dice = Dice::builder().count(2).sides(6).build();
assert_eq!(dice, Dice::new(2, 6));

§Single modifier

use tyche::dice::{Dice, Modifier};

let dice = Dice::builder().count(6).sides(8).explode(None, true).build();
assert_eq!(
	dice,
	Dice {
		count: 6,
		sides: 8,
		modifiers: vec![Modifier::Explode {
			cond: None,
			recurse: true,
		}],
	},
);

§Multiple modifiers

use tyche::dice::{modifier::{Condition, Modifier}, Dice};

let dice = Dice::builder()
	.count(6)
	.sides(8)
	.reroll(Condition::Eq(1), false)
	.keep_high(4)
	.build();
assert_eq!(
	dice,
	Dice {
		count: 6,
		sides: 8,
		modifiers: vec![
			Modifier::Reroll {
				cond: Condition::Eq(1),
				recurse: false
			},
			Modifier::KeepHigh(4),
		],
	},
);

Implementations§

source§

impl Builder

source

pub const fn count(self, count: u8) -> Self

Sets the number of dice to roll.

source

pub const fn sides(self, sides: u8) -> Self

Sets the number of sides per die.

source

pub fn reroll(self, cond: Condition, recurse: bool) -> Self

Adds a reroll modifier to the dice.

source

pub fn explode(self, cond: Option<Condition>, recurse: bool) -> Self

Adds an exploding modifier to the dice.

source

pub fn keep_high(self, count: u8) -> Self

Adds a keep highest modifier to the dice.

source

pub fn keep_low(self, count: u8) -> Self

Adds a keep lowest modifier to the dice.

source

pub fn min(self, min: u8) -> Self

Adds a minimum modifier to the dice.

source

pub fn max(self, max: u8) -> Self

Adds a maximum modifier to the dice.

source

pub fn build(self) -> Dice

Finalizes the dice.

Trait Implementations§

source§

impl Clone for Builder

source§

fn clone(&self) -> Builder

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 Debug for Builder

source§

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

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

impl Default for Builder

source§

fn default() -> Builder

Returns the “default value” for a type. Read more

Auto Trait Implementations§

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, 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.

§

impl<'p, T> Seq<'p, T> for T
where T: Clone,

§

type Item<'a> = &'a T where T: 'a

The item yielded by the iterator.
§

type Iter<'a> = Once<&'a T> where T: 'a

An iterator over the items within this container, by reference.
§

fn seq_iter(&self) -> <T as Seq<'p, T>>::Iter<'_>

Iterate over the elements of the container.
§

fn contains(&self, val: &T) -> bool
where T: PartialEq,

Check whether an item is contained within this sequence.
§

fn to_maybe_ref<'b>(item: <T as Seq<'p, T>>::Item<'b>) -> Maybe<T, &'p T>
where 'p: 'b,

Convert an item of the sequence into a [MaybeRef].
source§

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

§

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>,

§

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>,

§

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.
§

impl<T> MaybeSync for T

§

impl<'p, T> OrderedSeq<'p, T> for T
where T: Clone,