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

An Object which can be used to construct a script piece by piece.

Implementations§

source§

impl Builder

source

pub const fn new() -> Self

Creates a new empty script.

source

pub fn len(&self) -> usize

Returns the length in bytes of the script.

source

pub fn is_empty(&self) -> bool

Checks whether the script is the empty script.

source

pub fn push_int(self, data: i64) -> Builder

Adds instructions to push an integer onto the stack.

Integers are encoded as little-endian signed-magnitude numbers, but there are dedicated opcodes to push some small integers.

source

pub fn push_slice<T: AsRef<PushBytes>>(self, data: T) -> Builder

Adds instructions to push some arbitrary data onto the stack.

source

pub fn push_key(self, key: &PublicKey) -> Builder

Adds instructions to push a public key onto the stack.

source

pub fn push_x_only_key(self, x_only_key: &XOnlyPublicKey) -> Builder

Adds instructions to push an XOnly public key onto the stack.

source

pub fn push_opcode(self, data: Opcode) -> Builder

Adds a single opcode to the script.

source

pub fn push_verify(self) -> Builder

Adds an OP_VERIFY to the script or replaces the last opcode with VERIFY form.

Some opcodes such as OP_CHECKSIG have a verify variant that works as if VERIFY was in the script right after. To save space this function appends VERIFY only if the most-recently-added opcode does not have an alternate VERIFY form. If it does the last opcode is replaced. E.g., OP_CHECKSIG will become OP_CHECKSIGVERIFY.

Note that existing OP_*VERIFY opcodes do not lead to the instruction being ignored because OP_VERIFY consumes an item from the stack so ignoring them would change the semantics.

source

pub fn push_lock_time(self, lock_time: LockTime) -> Builder

Adds instructions to push an absolute lock time onto the stack.

source

pub fn push_sequence(self, sequence: Sequence) -> Builder

Adds instructions to push a sequence number onto the stack.

source

pub fn into_script(self) -> ScriptBuf

Converts the Builder into ScriptBuf.

source

pub fn into_bytes(self) -> Vec<u8>

Converts the Builder into script bytes

source

pub fn as_script(&self) -> &Script

Returns the internal script

source

pub fn as_bytes(&self) -> &[u8]

Returns script bytes

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<(), Error>

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

impl Display for Builder

source§

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

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

impl From<Vec<u8, Global>> for Builder

Creates a new builder from an existing vector.

source§

fn from(v: Vec<u8>) -> Builder

Converts to this type from the input type.
source§

impl PartialEq<Builder> for Builder

source§

fn eq(&self, other: &Builder) -> 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 Eq for Builder

source§

impl StructuralEq for Builder

source§

impl StructuralPartialEq for Builder

Auto Trait Implementations§

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> 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> 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> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.