Struct fuel_tx::input::coin::Coin

source ·
pub struct Coin<Specification>
where Specification: CoinSpecification,
{ pub utxo_id: UtxoId, pub owner: Address, pub amount: Word, pub asset_id: AssetId, pub tx_pointer: TxPointer, pub witness_index: Specification::Witness, pub predicate_gas_used: Specification::PredicateGasUsed, pub predicate: Specification::Predicate, pub predicate_data: Specification::PredicateData, }
Expand description

It is a full representation of the coin from the specification: https://github.com/FuelLabs/fuel-specs/blob/master/src/tx-format/input.md#inputcoin.

The specification defines the layout of the Coin in the serialized form for the fuel-vm. But on the business logic level, we don’t use all fields at the same time. It is why in the super::Input the coin is represented by several forms based on the usage context. Leaving some fields empty reduces the memory consumption by the structure and erases the empty useless fields.

The CoinSpecification trait specifies the sub-coin for the corresponding usage context. It allows us to write the common logic of all sub-coins without the overhead and duplication.

Sub-coin:

  • Signed - means that the coin should be signed by the owner, and the signature(witness) should be stored under the witness_index index in the witnesses vector of the crate::Transaction.
  • Predicate - means that the coin is not signed, and the owner is a predicate bytecode. The merkle root from the predicate should be equal to the owner.
  • Full - is used during the deserialization of the coin. It should be transformed into Signed or Predicate sub-coin. If the predicate is empty, it is Signed, else Predicate.

Fields§

§utxo_id: UtxoId§owner: Address§amount: Word§asset_id: AssetId§tx_pointer: TxPointer§witness_index: Specification::Witness§predicate_gas_used: Specification::PredicateGasUsed§predicate: Specification::Predicate§predicate_data: Specification::PredicateData

Implementations§

source§

impl<Specification> Coin<Specification>
where Specification: CoinSpecification,

source§

impl Coin<Full>

source§

impl Coin<Signed>

source

pub fn into_full(self) -> Coin<Full>

source§

impl Coin<Predicate>

source

pub fn into_full(self) -> Coin<Full>

Trait Implementations§

source§

impl<Specification> Clone for Coin<Specification>
where Specification: CoinSpecification + Clone, Specification::Witness: Clone, Specification::PredicateGasUsed: Clone, Specification::Predicate: Clone, Specification::PredicateData: Clone,

source§

fn clone(&self) -> Coin<Specification>

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<Specification> Debug for Coin<Specification>
where Specification: CoinSpecification,

source§

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

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

impl<Specification> Default for Coin<Specification>
where Specification: CoinSpecification + Default, Specification::Witness: Default, Specification::PredicateGasUsed: Default, Specification::Predicate: Default, Specification::PredicateData: Default,

source§

fn default() -> Coin<Specification>

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

impl<Specification> Deserialize for Coin<Specification>
where Specification: CoinSpecification, Specification::Witness: Deserialize, Specification::PredicateGasUsed: Deserialize, Specification::Predicate: Deserialize, Specification::PredicateData: Deserialize,

source§

fn decode_static<I: Input + ?Sized>(buffer: &mut I) -> Result<Self, Error>

Decodes static part of Self from the buffer.
source§

fn decode_dynamic<I: Input + ?Sized>( &mut self, buffer: &mut I, ) -> Result<(), Error>

Decodes dynamic part of the information from the buffer to fill Self. The default implementation does nothing. Dynamically-sized contains should override this.
source§

fn decode<I>(buffer: &mut I) -> Result<Self, Error>
where I: Input + ?Sized,

Decodes Self from the buffer. Read more
source§

fn from_bytes(buffer: &[u8]) -> Result<Self, Error>

Helper method for deserializing Self from bytes.
source§

impl<Specification> Hash for Coin<Specification>
where Specification: CoinSpecification + Hash, Specification::Witness: Hash, Specification::PredicateGasUsed: Hash, Specification::Predicate: Hash, Specification::PredicateData: Hash,

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<Specification> PartialEq for Coin<Specification>
where Specification: CoinSpecification + PartialEq, Specification::Witness: PartialEq, Specification::PredicateGasUsed: PartialEq, Specification::Predicate: PartialEq, Specification::PredicateData: PartialEq,

source§

fn eq(&self, other: &Coin<Specification>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<Specification> Serialize for Coin<Specification>
where Specification: CoinSpecification, Specification::Witness: Serialize, Specification::PredicateGasUsed: Serialize, Specification::Predicate: Serialize, Specification::PredicateData: Serialize,

source§

fn size_static(&self) -> usize

Size of the static part of the serialized object, in bytes. Saturates to usize::MAX on overflow.
source§

fn size_dynamic(&self) -> usize

Size of the dynamic part, in bytes. Saturates to usize::MAX on overflow.
source§

fn encode_static<O: Output + ?Sized>(&self, buffer: &mut O) -> Result<(), Error>

Encodes staticly-sized part of Self.
source§

fn encode_dynamic<O: Output + ?Sized>( &self, buffer: &mut O, ) -> Result<(), Error>

Encodes dynamically-sized part of Self. The default implementation does nothing. Dynamically-sized contains should override this.
source§

fn size(&self) -> usize

Total size of the serialized object, in bytes. Saturates to usize::MAX on overflow.
source§

fn encode<O>(&self, buffer: &mut O) -> Result<(), Error>
where O: Output + ?Sized,

Encodes Self into the buffer. Read more
source§

fn to_bytes(&self) -> Vec<u8>

Encodes Self into bytes vector. Required known size.
source§

impl<Specification> Eq for Coin<Specification>
where Specification: CoinSpecification + Eq, Specification::Witness: Eq, Specification::PredicateGasUsed: Eq, Specification::Predicate: Eq, Specification::PredicateData: Eq,

source§

impl<Specification> StructuralPartialEq for Coin<Specification>
where Specification: CoinSpecification,

Auto Trait Implementations§

§

impl<Specification> Freeze for Coin<Specification>
where <Specification as CoinSpecification>::Witness: Freeze, <Specification as CoinSpecification>::PredicateGasUsed: Freeze, <Specification as CoinSpecification>::Predicate: Freeze, <Specification as CoinSpecification>::PredicateData: Freeze,

§

impl<Specification> RefUnwindSafe for Coin<Specification>

§

impl<Specification> Send for Coin<Specification>
where <Specification as CoinSpecification>::Witness: Send, <Specification as CoinSpecification>::PredicateGasUsed: Send, <Specification as CoinSpecification>::Predicate: Send, <Specification as CoinSpecification>::PredicateData: Send,

§

impl<Specification> Sync for Coin<Specification>
where <Specification as CoinSpecification>::Witness: Sync, <Specification as CoinSpecification>::PredicateGasUsed: Sync, <Specification as CoinSpecification>::Predicate: Sync, <Specification as CoinSpecification>::PredicateData: Sync,

§

impl<Specification> Unpin for Coin<Specification>
where <Specification as CoinSpecification>::Witness: Unpin, <Specification as CoinSpecification>::PredicateGasUsed: Unpin, <Specification as CoinSpecification>::Predicate: Unpin, <Specification as CoinSpecification>::PredicateData: Unpin,

§

impl<Specification> UnwindSafe for Coin<Specification>
where <Specification as CoinSpecification>::Witness: UnwindSafe, <Specification as CoinSpecification>::PredicateGasUsed: UnwindSafe, <Specification as CoinSpecification>::Predicate: UnwindSafe, <Specification as CoinSpecification>::PredicateData: 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> 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<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, 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> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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> Same for T

§

type Output = T

Should always be Self
source§

impl<T> StorageAsMut for T

source§

fn storage<Type>(&mut self) -> StorageMut<'_, Self, Type>
where Type: Mappable,

source§

fn storage_as_mut<Type>(&mut self) -> StorageMut<'_, Self, Type>
where Type: Mappable,

source§

impl<T> StorageAsRef for T

source§

fn storage<Type>(&self) -> StorageRef<'_, Self, Type>
where Type: Mappable,

source§

fn storage_as_ref<Type>(&self) -> StorageRef<'_, Self, Type>
where Type: Mappable,

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,

§

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

§

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

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V