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 maturity: BlockHeight,
    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/protocol/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§maturity: BlockHeight§predicate: Specification::Predicate§predicate_data: Specification::PredicateData

Implementations§

source§

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

source

pub fn prepare_sign(&mut self)

The “Note” section from the specification: https://github.com/FuelLabs/fuel-specs/blob/master/src/protocol/tx_format/input.md#inputcoin.

source§

impl Coin<Full>

Trait Implementations§

source§

impl<Specification> Clone for Coin<Specification>where Specification: CoinSpecification + Clone, Specification::Witness: 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::Predicate: Default, Specification::PredicateData: Default,

source§

fn default() -> Coin<Specification>

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

impl<Specification> Hash for Coin<Specification>where Specification: CoinSpecification + Hash, Specification::Witness: 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<Coin<Specification>> for Coin<Specification>where Specification: CoinSpecification + PartialEq, Specification::Witness: 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> Read for Coin<Specification>where Specification: CoinSpecification,

source§

fn read(&mut self, full_buf: &mut [u8]) -> Result<usize>

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
1.36.0 · source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · source§

fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>

Read all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Read all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

Read the exact number of bytes required to fill buf. Read more
source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

fn chain<R>(self, next: R) -> Chain<Self, R>where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

fn take(self, limit: u64) -> Take<Self>where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more
source§

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

source§

fn serialized_size(&self) -> usize

Return the expected serialized size for an instance of the type.
source§

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

source§

fn write(&mut self, full_buf: &[u8]) -> Result<usize>

Write a buffer into this writer, returning how many bytes were written. Read more
source§

fn flush(&mut self) -> Result<()>

Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
1.36.0 · source§

fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> Result<usize, Error>

Like write, except that it writes from a slice of buffers. Read more
source§

fn is_write_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Writer has an efficient write_vectored implementation. Read more
1.0.0 · source§

fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>

Attempts to write an entire buffer into this writer. Read more
source§

fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>

🔬This is a nightly-only experimental API. (write_all_vectored)
Attempts to write multiple buffers into this writer. Read more
1.0.0 · source§

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

Writes a formatted string into this writer, returning any error encountered. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Creates a “by reference” adapter for this instance of Write. Read more
source§

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

source§

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

source§

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

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

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

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> Deserializable for Twhere T: Default + Write,

source§

fn from_bytes(bytes: &[u8]) -> Result<T, Error>

Deserialization from variable length slices of bytes.
§

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

§

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

Checks if this value is equivalent to the given key. 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 Twhere 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> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> SerializableVec for Twhere T: SizedBytes + Read,

source§

fn to_bytes(&mut self) -> Vec<u8, Global>

Create a variable size vector of bytes from the instance.
§

impl<T> StorageAsMut for T

§

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

§

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

§

impl<T> StorageAsRef for T

§

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

§

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

source§

impl<T> ToOwned for Twhere 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 Twhere 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 Twhere 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<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<W> Writer for Wwhere W: Write,

§

fn write(&mut self, slice: &[u8]) -> Result<(), Error>

Write the given DER-encoded bytes as output.
§

fn write_byte(&mut self, byte: u8) -> Result<(), Error>

Write a single byte.