Struct bpstd::CompressedPk 
source · pub struct CompressedPk(/* private fields */);Implementations§
source§impl CompressedPk
 
impl CompressedPk
pub fn from_byte_array( data: [u8; 33], ) -> Result<CompressedPk, InvalidPubkey<33>>
pub fn to_byte_array(&self) -> [u8; 33]
pub fn from_bytes( bytes: impl AsRef<[u8]>, ) -> Result<CompressedPk, InvalidPubkey<33>>
Methods from Deref<Target = PublicKey>§
sourcepub fn cmp_fast_unstable(&self, other: &PublicKey) -> Ordering
 
pub fn cmp_fast_unstable(&self, other: &PublicKey) -> Ordering
Like cmp::Cmp but faster and with no guarantees across library versions.
The Cmp implementation for FFI types is stable but slow because it first
serializes self and other before comparing them. This function provides a faster
comparison if you know that your types come from the same library version.
sourcepub fn eq_fast_unstable(&self, other: &PublicKey) -> bool
 
pub fn eq_fast_unstable(&self, other: &PublicKey) -> bool
Like cmp::Eq but faster and with no guarantees across library versions.
The Eq implementation for FFI types is stable but slow because it first serializes
self and other before comparing them. This function provides a faster equality
check if you know that your types come from the same library version.
sourcepub fn as_ptr(&self) -> *const PublicKey
 👎Deprecated since 0.25.0: Use Self::as_c_ptr if you need to access the FFI layer
pub fn as_ptr(&self) -> *const PublicKey
Obtains a raw const pointer suitable for use with FFI functions.
sourcepub fn as_mut_ptr(&mut self) -> *mut PublicKey
 👎Deprecated since 0.25.0: Use Self::as_mut_c_ptr if you need to access the FFI layer
pub fn as_mut_ptr(&mut self) -> *mut PublicKey
Obtains a raw mutable pointer suitable for use with FFI functions.
sourcepub fn serialize(&self) -> [u8; 33]
 
pub fn serialize(&self) -> [u8; 33]
Serializes the key as a byte-encoded pair of values. In compressed form the y-coordinate is represented by only a single bit, as x determines it up to one bit.
sourcepub fn serialize_uncompressed(&self) -> [u8; 65]
 
pub fn serialize_uncompressed(&self) -> [u8; 65]
Serializes the key as a byte-encoded pair of values, in uncompressed form.
sourcepub fn combine(&self, other: &PublicKey) -> Result<PublicKey, Error>
 
pub fn combine(&self, other: &PublicKey) -> Result<PublicKey, Error>
Adds a second key to this one, returning the sum.
§Errors
If the result would be the point at infinity, i.e. adding this point to its own negation.
§Examples
use secp256k1::{rand, Secp256k1};
let secp = Secp256k1::new();
let mut rng = rand::thread_rng();
let (_, pk1) = secp.generate_keypair(&mut rng);
let (_, pk2) = secp.generate_keypair(&mut rng);
let sum = pk1.combine(&pk2).expect("It's improbable to fail for 2 random public keys");sourcepub fn x_only_public_key(&self) -> (XOnlyPublicKey, Parity)
 
pub fn x_only_public_key(&self) -> (XOnlyPublicKey, Parity)
Returns the XOnlyPublicKey (and it’s Parity) for this PublicKey.
Trait Implementations§
source§impl AsMut<<CompressedPk as Wrapper>::Inner> for CompressedPk
 
impl AsMut<<CompressedPk as Wrapper>::Inner> for CompressedPk
source§impl AsRef<PublicKey> for CompressedPk
 
impl AsRef<PublicKey> for CompressedPk
source§impl Borrow<PublicKey> for CompressedPk
 
impl Borrow<PublicKey> for CompressedPk
source§impl BorrowMut<<CompressedPk as Wrapper>::Inner> for CompressedPk
 
impl BorrowMut<<CompressedPk as Wrapper>::Inner> for CompressedPk
source§fn borrow_mut(&mut self) -> &mut <CompressedPk as Wrapper>::Inner
 
fn borrow_mut(&mut self) -> &mut <CompressedPk as Wrapper>::Inner
source§impl Clone for CompressedPk
 
impl Clone for CompressedPk
source§fn clone(&self) -> CompressedPk
 
fn clone(&self) -> CompressedPk
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for CompressedPk
 
impl Debug for CompressedPk
source§impl Decode for CompressedPk
 
impl Decode for CompressedPk
fn decode(reader: &mut impl Read) -> Result<CompressedPk, DecodeError>
fn deserialize(bytes: impl AsRef<[u8]>) -> Result<Self, PsbtError>
source§impl Deref for CompressedPk
 
impl Deref for CompressedPk
source§impl DerefMut for CompressedPk
 
impl DerefMut for CompressedPk
source§impl Derive<CompressedPk> for XpubDerivable
 
impl Derive<CompressedPk> for XpubDerivable
fn default_keychain(&self) -> Keychain
fn keychains(&self) -> BTreeSet<Keychain>
fn derive( &self, keychain: impl Into<Keychain>, index: impl Into<NormalIndex>, ) -> CompressedPk
fn derive_batch( &self, keychain: impl Into<Keychain>, from: impl Into<NormalIndex>, max_count: u8, ) -> Vec<D>
source§impl DeriveKey<CompressedPk> for XpubDerivable
 
impl DeriveKey<CompressedPk> for XpubDerivable
source§impl Display for CompressedPk
 
impl Display for CompressedPk
source§impl Encode for CompressedPk
 
impl Encode for CompressedPk
source§impl From<CompressedPk> for LegacyPk
 
impl From<CompressedPk> for LegacyPk
source§fn from(pk: CompressedPk) -> LegacyPk
 
fn from(pk: CompressedPk) -> LegacyPk
source§impl From<CompressedPk> for PubkeyHash
 
impl From<CompressedPk> for PubkeyHash
source§fn from(pk: CompressedPk) -> PubkeyHash
 
fn from(pk: CompressedPk) -> PubkeyHash
source§impl From<CompressedPk> for PublicKey
 
impl From<CompressedPk> for PublicKey
source§fn from(wrapped: CompressedPk) -> PublicKey
 
fn from(wrapped: CompressedPk) -> PublicKey
source§impl From<CompressedPk> for WPubkeyHash
 
impl From<CompressedPk> for WPubkeyHash
source§fn from(pk: CompressedPk) -> WPubkeyHash
 
fn from(pk: CompressedPk) -> WPubkeyHash
source§impl From<CompressedPk> for XOnlyPk
 
impl From<CompressedPk> for XOnlyPk
source§fn from(pubkey: CompressedPk) -> XOnlyPk
 
fn from(pubkey: CompressedPk) -> XOnlyPk
source§impl From<PublicKey> for CompressedPk
 
impl From<PublicKey> for CompressedPk
source§fn from(v: PublicKey) -> CompressedPk
 
fn from(v: PublicKey) -> CompressedPk
source§impl FromStr for CompressedPk
 
impl FromStr for CompressedPk
§type Err = PubkeyParseError<33>
 
type Err = PubkeyParseError<33>
source§fn from_str(s: &str) -> Result<CompressedPk, <CompressedPk as FromStr>::Err>
 
fn from_str(s: &str) -> Result<CompressedPk, <CompressedPk as FromStr>::Err>
s to return a value of this type. Read moresource§impl Hash for CompressedPk
 
impl Hash for CompressedPk
source§impl LowerHex for CompressedPk
 
impl LowerHex for CompressedPk
source§impl Ord for CompressedPk
 
impl Ord for CompressedPk
source§fn cmp(&self, other: &CompressedPk) -> Ordering
 
fn cmp(&self, other: &CompressedPk) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
    Self: Sized,
 
fn max(self, other: Self) -> Selfwhere
    Self: Sized,
source§impl PartialEq for CompressedPk
 
impl PartialEq for CompressedPk
source§fn eq(&self, other: &CompressedPk) -> bool
 
fn eq(&self, other: &CompressedPk) -> bool
self and other values to be equal, and is used
by ==.source§impl PartialOrd for CompressedPk
 
impl PartialOrd for CompressedPk
source§fn partial_cmp(&self, other: &CompressedPk) -> Option<Ordering>
 
fn partial_cmp(&self, other: &CompressedPk) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
 
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read moresource§impl StrictDecode for CompressedPk
 
impl StrictDecode for CompressedPk
fn strict_decode( reader: &mut impl TypedRead, ) -> Result<CompressedPk, DecodeError>
fn strict_read(reader: impl ReadRaw) -> Result<Self, DecodeError>
source§impl StrictDumb for CompressedPk
 
impl StrictDumb for CompressedPk
fn strict_dumb() -> CompressedPk
source§impl StrictEncode for CompressedPk
 
impl StrictEncode for CompressedPk
fn strict_encode<W>(&self, writer: W) -> Result<W, Error>where
    W: TypedWrite,
fn strict_write(&self, writer: impl WriteRaw) -> Result<(), Error>
source§impl StrictTuple for CompressedPk
 
impl StrictTuple for CompressedPk
const FIELD_COUNT: u8 = 1u8
fn strict_check_fields()
fn strict_type_info() -> TypeInfo<Self>
source§impl StrictType for CompressedPk
 
impl StrictType for CompressedPk
const STRICT_LIB_NAME: &'static str = LIB_NAME_BITCOIN
fn strict_name() -> Option<TypeName>
source§impl Wrapper for CompressedPk
 
impl Wrapper for CompressedPk
source§fn from_inner(inner: <CompressedPk as Wrapper>::Inner) -> CompressedPk
 
fn from_inner(inner: <CompressedPk as Wrapper>::Inner) -> CompressedPk
source§fn as_inner(&self) -> &<CompressedPk as Wrapper>::Inner
 
fn as_inner(&self) -> &<CompressedPk as Wrapper>::Inner
source§fn into_inner(self) -> <CompressedPk as Wrapper>::Inner
 
fn into_inner(self) -> <CompressedPk as Wrapper>::Inner
source§impl WrapperMut for CompressedPk
 
impl WrapperMut for CompressedPk
source§fn as_inner_mut(&mut self) -> &mut <CompressedPk as Wrapper>::Inner
 
fn as_inner_mut(&mut self) -> &mut <CompressedPk as Wrapper>::Inner
impl Copy for CompressedPk
impl Eq for CompressedPk
impl StrictProduct for CompressedPk
impl StructuralPartialEq for CompressedPk
Auto Trait Implementations§
impl Freeze for CompressedPk
impl RefUnwindSafe for CompressedPk
impl Send for CompressedPk
impl Sync for CompressedPk
impl Unpin for CompressedPk
impl UnwindSafe for CompressedPk
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<Q, K> Comparable<K> for Q
 
impl<Q, K> Comparable<K> for Q
source§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.