Skip to main content

Conditions

Struct Conditions 

Source
pub struct Conditions<T = NodePtr> { /* private fields */ }
Expand description

A grow-only list of conditions which can be used when building spend bundles.

Implementations§

Source§

impl Conditions

Source

pub fn new() -> Conditions

Create a new empty list of conditions. To make inference easier for the compiler, the generic type defaults to NodePtr, since that’s the most general choice and common when building spend bundles.

If you need to create an instance with a different generic type, use Conditions::default instead.

Source§

impl<T> Conditions<T>

Source

pub fn len(&self) -> usize

Gets the number of conditions.

Source

pub fn is_empty(&self) -> bool

Checks if there are no conditions.

Source

pub fn iter(&self) -> impl Iterator<Item = &Condition<T>>

Gets an iterator over the conditions.

Source

pub fn into_vec(self) -> Vec<Condition<T>>

Converts the list of conditions into a vector.

Source

pub fn with(self, condition: impl Into<Condition<T>>) -> Conditions<T>

Adds a condition and returns the updated list.

Source

pub fn extend( self, conditions: impl IntoIterator<Item = impl Into<Condition<T>>>, ) -> Conditions<T>

Appends a list of conditions to the end from an iterator.

Source

pub fn extend_from_slice(self, conditions: &[Condition<T>]) -> Conditions<T>
where T: Clone,

Appends a list of conditions to the end from a slice.

Source

pub fn push(&mut self, condition: impl Into<Condition<T>>)

Adds a condition to the end of the list.

Source§

impl<T> Conditions<T>

Source

pub fn remark(self, rest: T) -> Conditions<T>

Source

pub fn agg_sig_parent( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_puzzle( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_amount( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_puzzle_amount( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_parent_amount( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_parent_puzzle( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_unsafe( self, public_key: PublicKey, message: Bytes, ) -> Conditions<T>

Source

pub fn agg_sig_me(self, public_key: PublicKey, message: Bytes) -> Conditions<T>

Source

pub fn create_coin( self, puzzle_hash: BytesImpl<32>, amount: u64, memos: Memos<T>, ) -> Conditions<T>

Source

pub fn reserve_fee(self, amount: u64) -> Conditions<T>

Source

pub fn create_coin_announcement(self, message: Bytes) -> Conditions<T>

Source

pub fn assert_coin_announcement( self, announcement_id: BytesImpl<32>, ) -> Conditions<T>

Source

pub fn create_puzzle_announcement(self, message: Bytes) -> Conditions<T>

Source

pub fn assert_puzzle_announcement( self, announcement_id: BytesImpl<32>, ) -> Conditions<T>

Source

pub fn assert_concurrent_spend(self, coin_id: BytesImpl<32>) -> Conditions<T>

Source

pub fn assert_concurrent_puzzle( self, puzzle_hash: BytesImpl<32>, ) -> Conditions<T>

Source

pub fn send_message( self, mode: u8, message: Bytes, data: Vec<T>, ) -> Conditions<T>

Source

pub fn receive_message( self, mode: u8, message: Bytes, data: Vec<T>, ) -> Conditions<T>

Source

pub fn assert_my_coin_id(self, coin_id: BytesImpl<32>) -> Conditions<T>

Source

pub fn assert_my_parent_id(self, parent_id: BytesImpl<32>) -> Conditions<T>

Source

pub fn assert_my_puzzle_hash(self, puzzle_hash: BytesImpl<32>) -> Conditions<T>

Source

pub fn assert_my_amount(self, amount: u64) -> Conditions<T>

Source

pub fn assert_my_birth_seconds(self, seconds: u64) -> Conditions<T>

Source

pub fn assert_my_birth_height(self, height: u32) -> Conditions<T>

Source

pub fn assert_ephemeral(self) -> Conditions<T>

Source

pub fn assert_seconds_relative(self, seconds: u64) -> Conditions<T>

Source

pub fn assert_seconds_absolute(self, seconds: u64) -> Conditions<T>

Source

pub fn assert_height_relative(self, height: u32) -> Conditions<T>

Source

pub fn assert_height_absolute(self, height: u32) -> Conditions<T>

Source

pub fn assert_before_seconds_relative(self, seconds: u64) -> Conditions<T>

Source

pub fn assert_before_seconds_absolute(self, seconds: u64) -> Conditions<T>

Source

pub fn assert_before_height_relative(self, height: u32) -> Conditions<T>

Source

pub fn assert_before_height_absolute(self, height: u32) -> Conditions<T>

Source

pub fn softfork(self, cost: u64, rest: T) -> Conditions<T>

Source

pub fn transfer_nft( self, launcher_id: Option<BytesImpl<32>>, trade_prices: Vec<TradePrice>, singleton_inner_puzzle_hash: Option<BytesImpl<32>>, ) -> Conditions<T>

Source

pub fn run_cat_tail(self, program: T, solution: T) -> Conditions<T>

Source

pub fn melt_singleton(self) -> Conditions<T>

Source

pub fn update_nft_metadata( self, updater_puzzle_reveal: T, updater_solution: T, ) -> Conditions<T>

Source

pub fn update_data_store_merkle_root( self, new_merkle_root: BytesImpl<32>, memos: Vec<Bytes>, ) -> Conditions<T>

Trait Implementations§

Source§

impl<T> AsRef<[Condition<T>]> for Conditions<T>

Source§

fn as_ref(&self) -> &[Condition<T>]

Converts this type into a shared reference of the (usually inferred) input type.
Source§

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

Source§

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

Returns a duplicate 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 for Conditions<T>
where T: Debug,

Source§

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

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

impl<T> Default for Conditions<T>

Source§

fn default() -> Conditions<T>

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

impl<T> From<Vec<Condition<T>>> for Conditions<T>

Source§

fn from(conditions: Vec<Condition<T>>) -> Conditions<T>

Converts to this type from the input type.
Source§

impl<T, Node, D> FromClvm<D> for Conditions<T>
where T: FromClvm<D>, D: ClvmDecoder<Node = Node>,

Source§

fn from_clvm(decoder: &D, node: Node) -> Result<Conditions<T>, FromClvmError>

Source§

impl<T> Index<usize> for Conditions<T>

Source§

type Output = Condition<T>

The returned type after indexing.
Source§

fn index(&self, index: usize) -> &<Conditions<T> as Index<usize>>::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl<'a, T> IntoIterator for &'a Conditions<T>

Source§

type Item = &'a Condition<T>

The type of the elements being iterated over.
Source§

type IntoIter = Iter<'a, Condition<T>>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> <&'a Conditions<T> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
Source§

impl<T> IntoIterator for Conditions<T>

Source§

type Item = Condition<T>

The type of the elements being iterated over.
Source§

type IntoIter = IntoIter<Condition<T>>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> <Conditions<T> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
Source§

impl<T> PartialEq for Conditions<T>
where T: PartialEq,

Source§

fn eq(&self, other: &Conditions<T>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T, Node, E> ToClvm<E> for Conditions<T>
where T: ToClvm<E>, E: ClvmEncoder<Node = Node>,

Source§

fn to_clvm(&self, encoder: &mut E) -> Result<Node, ToClvmError>

Source§

impl<T> Eq for Conditions<T>
where T: Eq,

Source§

impl<T> StructuralPartialEq for Conditions<T>

Auto Trait Implementations§

§

impl<T> Freeze for Conditions<T>

§

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

§

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

§

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

§

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

§

impl<T> UnsafeUnpin for Conditions<T>

§

impl<T> UnwindSafe for Conditions<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<A, T> AsBits<T> for A
where A: AsRef<[T]>, T: BitStore,

Source§

fn as_bits<O>(&self) -> &BitSlice<T, O>
where O: BitOrder,

Views self as an immutable bit-slice region with the O ordering.
Source§

fn try_as_bits<O>(&self) -> Result<&BitSlice<T, O>, BitSpanError<T>>
where O: BitOrder,

Attempts to view self as an immutable bit-slice region with the O ordering. 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> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. 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> Layer for T

Source§

type Solution = NodePtr

Most of the time, this is an actual CLVM type representing the solution. However, you can also use a helper struct and customize Layer::construct_solution and Layer::parse_solution.
Source§

fn parse_puzzle( allocator: &Allocator, puzzle: Puzzle, ) -> Result<Option<T>, DriverError>

Parses this layer from the given puzzle, returning None if the puzzle doesn’t match. An error is returned if the puzzle should have matched but couldn’t be parsed.
Source§

fn parse_solution( _allocator: &Allocator, solution: NodePtr, ) -> Result<<T as Layer>::Solution, DriverError>

Parses the Layer::Solution type from a CLVM solution pointer.
Source§

fn construct_puzzle( &self, ctx: &mut SpendContext, ) -> Result<NodePtr, DriverError>

Constructs the full curried puzzle for this layer. Ideally, the puzzle itself should be cached in the SpendContext.
Source§

fn construct_solution( &self, _ctx: &mut SpendContext, solution: <T as Layer>::Solution, ) -> Result<NodePtr, DriverError>

Constructs the full solution for this layer. Can be used to construct the solution from a helper struct, if it’s not directly a CLVM type. It’s also possible to influence the solution based on the puzzle, if needed.
Source§

fn construct_spend( &self, ctx: &mut SpendContext, solution: Self::Solution, ) -> Result<Spend, DriverError>

Creates a spend for this layer.
Source§

fn construct_coin_spend( &self, ctx: &mut SpendContext, coin: Coin, solution: Self::Solution, ) -> Result<CoinSpend, DriverError>

Creates a coin spend for this layer.
Source§

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

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
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> ToTreeHash for T
where T: ToClvm<TreeHasher>,

Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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