[−][src]Struct miniscript::descriptor::SortedMultiVec
Contents of a "sortedmulti" descriptor
Fields
k: usize
signatures required
pks: Vec<Pk>
public keys inside sorted Multi
Implementations
impl<Pk: MiniscriptKey, Ctx: ScriptContext> SortedMultiVec<Pk, Ctx>
[src]
pub fn new(k: usize, pks: Vec<Pk>) -> Result<Self, Error>
[src]
Create a new instance of SortedMultiVec
given a list of keys and the threshold
Internally checks all the applicable size limits and pubkey types limitations according to the current Ctx
.
impl<Pk: MiniscriptKey, Ctx: ScriptContext> SortedMultiVec<Pk, Ctx>
[src]
pub fn translate_pk<FPk, Q, FuncError>(
&self,
translatefpk: &mut FPk
) -> Result<SortedMultiVec<Q, Ctx>, FuncError> where
FPk: FnMut(&Pk) -> Result<Q, FuncError>,
Q: MiniscriptKey,
[src]
&self,
translatefpk: &mut FPk
) -> Result<SortedMultiVec<Q, Ctx>, FuncError> where
FPk: FnMut(&Pk) -> Result<Q, FuncError>,
Q: MiniscriptKey,
This will panic if translatefpk returns an uncompressed key when converting to a Segwit descriptor. To prevent this panic, ensure translatefpk returns an error in this case instead.
impl<Pk: MiniscriptKey, Ctx: ScriptContext> SortedMultiVec<Pk, Ctx>
[src]
pub fn sorted_node<ToPkCtx: Copy>(
&self,
to_pk_ctx: ToPkCtx
) -> Terminal<Pk, Ctx> where
Pk: ToPublicKey<ToPkCtx>,
[src]
&self,
to_pk_ctx: ToPkCtx
) -> Terminal<Pk, Ctx> where
Pk: ToPublicKey<ToPkCtx>,
Create Terminal::Multi containing sorted pubkeys
pub fn encode<ToPkCtx: Copy>(&self, to_pk_ctx: ToPkCtx) -> Script where
Pk: ToPublicKey<ToPkCtx>,
[src]
Pk: ToPublicKey<ToPkCtx>,
Encode as a Bitcoin script
pub fn satisfy<ToPkCtx, S>(
&self,
satisfier: S,
to_pk_ctx: ToPkCtx
) -> Result<Vec<Vec<u8>>, Error> where
ToPkCtx: Copy,
Pk: ToPublicKey<ToPkCtx>,
S: Satisfier<ToPkCtx, Pk>,
[src]
&self,
satisfier: S,
to_pk_ctx: ToPkCtx
) -> Result<Vec<Vec<u8>>, Error> where
ToPkCtx: Copy,
Pk: ToPublicKey<ToPkCtx>,
S: Satisfier<ToPkCtx, Pk>,
Attempt to produce a satisfying witness for the witness script represented by the parse tree
pub fn script_size<ToPkCtx>(&self, to_pk_ctx: ToPkCtx) -> usize where
ToPkCtx: Copy,
Pk: ToPublicKey<ToPkCtx>,
[src]
ToPkCtx: Copy,
Pk: ToPublicKey<ToPkCtx>,
Size, in bytes of the script-pubkey. If this Miniscript is used outside of segwit (e.g. in a bare or P2SH descriptor), this quantity should be multiplied by 4 to compute the weight.
In general, it is not recommended to use this function directly, but
to instead call the corresponding function on a Descriptor
, which
will handle the segwit/non-segwit technicalities for you.
pub fn max_satisfaction_witness_elements(&self) -> usize
[src]
Maximum number of witness elements used to satisfy the Miniscript
fragment, including the witness script itself. Used to estimate
the weight of the VarInt
that specifies this number in a serialized
transaction.
This function may panic on malformed Miniscript
objects which do
not correspond to semantically sane Scripts. (Such scripts should be
rejected at parse time. Any exceptions are bugs.)
pub fn max_satisfaction_size(&self, _: usize) -> usize
[src]
Maximum size, in bytes, of a satisfying witness. For Segwit outputs
one_cost
should be set to 2, since the number 1
requires two
bytes to encode. For non-segwit outputs one_cost
should be set to
1, since OP_1
is available in scriptSigs.
In general, it is not recommended to use this function directly, but
to instead call the corresponding function on a Descriptor
, which
will handle the segwit/non-segwit technicalities for you.
All signatures are assumed to be 73 bytes in size, including the length prefix (segwit) or push opcode (pre-segwit) and sighash postfix.
This function may panic on malformed Miniscript
objects which do not
correspond to semantically sane Scripts. (Such scripts should be
rejected at parse time. Any exceptions are bugs.)
Trait Implementations
impl<Pk: Clone + MiniscriptKey, Ctx: Clone + ScriptContext> Clone for SortedMultiVec<Pk, Ctx>
[src]
pub fn clone(&self) -> SortedMultiVec<Pk, Ctx>
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<Pk: MiniscriptKey, Ctx: ScriptContext> Debug for SortedMultiVec<Pk, Ctx>
[src]
impl<Pk: MiniscriptKey, Ctx: ScriptContext> Display for SortedMultiVec<Pk, Ctx>
[src]
impl<Pk: Eq + MiniscriptKey, Ctx: Eq + ScriptContext> Eq for SortedMultiVec<Pk, Ctx>
[src]
impl<Pk: MiniscriptKey, Ctx: ScriptContext> Liftable<Pk> for SortedMultiVec<Pk, Ctx>
[src]
impl<Pk: Ord + MiniscriptKey, Ctx: Ord + ScriptContext> Ord for SortedMultiVec<Pk, Ctx>
[src]
pub fn cmp(&self, other: &SortedMultiVec<Pk, Ctx>) -> Ordering
[src]
#[must_use]pub fn max(self, other: Self) -> Self
1.21.0[src]
#[must_use]pub fn min(self, other: Self) -> Self
1.21.0[src]
#[must_use]pub fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]
impl<Pk: PartialEq + MiniscriptKey, Ctx: PartialEq + ScriptContext> PartialEq<SortedMultiVec<Pk, Ctx>> for SortedMultiVec<Pk, Ctx>
[src]
pub fn eq(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
pub fn ne(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
impl<Pk: PartialOrd + MiniscriptKey, Ctx: PartialOrd + ScriptContext> PartialOrd<SortedMultiVec<Pk, Ctx>> for SortedMultiVec<Pk, Ctx>
[src]
pub fn partial_cmp(&self, other: &SortedMultiVec<Pk, Ctx>) -> Option<Ordering>
[src]
pub fn lt(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
pub fn le(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
pub fn gt(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
pub fn ge(&self, other: &SortedMultiVec<Pk, Ctx>) -> bool
[src]
impl<Pk: MiniscriptKey, Ctx: ScriptContext> StructuralEq for SortedMultiVec<Pk, Ctx>
[src]
impl<Pk: MiniscriptKey, Ctx: ScriptContext> StructuralPartialEq for SortedMultiVec<Pk, Ctx>
[src]
Auto Trait Implementations
impl<Pk, Ctx> RefUnwindSafe for SortedMultiVec<Pk, Ctx> where
Ctx: RefUnwindSafe,
Pk: RefUnwindSafe,
Ctx: RefUnwindSafe,
Pk: RefUnwindSafe,
impl<Pk, Ctx> Send for SortedMultiVec<Pk, Ctx> where
Ctx: Send,
Pk: Send,
Ctx: Send,
Pk: Send,
impl<Pk, Ctx> Sync for SortedMultiVec<Pk, Ctx> where
Ctx: Sync,
Pk: Sync,
Ctx: Sync,
Pk: Sync,
impl<Pk, Ctx> Unpin for SortedMultiVec<Pk, Ctx> where
Ctx: Unpin,
Pk: Unpin,
Ctx: Unpin,
Pk: Unpin,
impl<Pk, Ctx> UnwindSafe for SortedMultiVec<Pk, Ctx> where
Ctx: UnwindSafe,
Pk: UnwindSafe,
Ctx: UnwindSafe,
Pk: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,