pub struct LegacyPk {
    pub compressed: bool,
    pub pubkey: PublicKey,
}Fields§
§compressed: bool§pubkey: PublicKeyImplementations§
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 Derive<LegacyPk> for XpubDerivable
 
impl Derive<LegacyPk> for XpubDerivable
fn default_keychain(&self) -> Keychain
fn keychains(&self) -> BTreeSet<Keychain>
fn derive( &self, keychain: impl Into<Keychain>, index: impl Into<NormalIndex>, ) -> LegacyPk
fn derive_batch( &self, keychain: impl Into<Keychain>, from: impl Into<NormalIndex>, max_count: u8, ) -> Vec<D>
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<LegacyPk> for PubkeyHash
 
impl From<LegacyPk> for PubkeyHash
source§fn from(pk: LegacyPk) -> PubkeyHash
 
fn from(pk: LegacyPk) -> PubkeyHash
source§impl From<UncompressedPk> for LegacyPk
 
impl From<UncompressedPk> for LegacyPk
source§fn from(pk: UncompressedPk) -> LegacyPk
 
fn from(pk: UncompressedPk) -> LegacyPk
source§impl Ord for LegacyPk
 
impl Ord for LegacyPk
source§impl PartialEq for LegacyPk
 
impl PartialEq for LegacyPk
source§impl PartialOrd for LegacyPk
 
impl PartialOrd for LegacyPk
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 LegacyPk
 
impl StrictDecode for LegacyPk
fn strict_decode(reader: &mut impl TypedRead) -> Result<LegacyPk, DecodeError>
fn strict_read(reader: impl ReadRaw) -> Result<Self, DecodeError>
source§impl StrictDumb for LegacyPk
 
impl StrictDumb for LegacyPk
fn strict_dumb() -> LegacyPk
source§impl StrictEncode for LegacyPk
 
impl StrictEncode for LegacyPk
fn strict_encode<W>(&self, writer: W) -> Result<W, Error>where
    W: TypedWrite,
fn strict_write(&self, writer: impl WriteRaw) -> Result<(), Error>
source§impl StrictStruct for LegacyPk
 
impl StrictStruct for LegacyPk
const ALL_FIELDS: &'static [&'static str] = _
fn strict_check_fields()
fn strict_type_info() -> TypeInfo<Self>
source§impl StrictType for LegacyPk
 
impl StrictType for LegacyPk
const STRICT_LIB_NAME: &'static str = LIB_NAME_BITCOIN
fn strict_name() -> Option<TypeName>
source§impl Wrapper for LegacyPk
 
impl Wrapper for LegacyPk
source§fn from_inner(inner: <LegacyPk as Wrapper>::Inner) -> LegacyPk
 
fn from_inner(inner: <LegacyPk as Wrapper>::Inner) -> LegacyPk
source§fn as_inner(&self) -> &<LegacyPk as Wrapper>::Inner
 
fn as_inner(&self) -> &<LegacyPk as Wrapper>::Inner
source§fn into_inner(self) -> <LegacyPk as Wrapper>::Inner
 
fn into_inner(self) -> <LegacyPk as Wrapper>::Inner
source§impl WrapperMut for LegacyPk
 
impl WrapperMut for LegacyPk
impl Copy for LegacyPk
impl Eq for LegacyPk
impl StrictProduct for LegacyPk
impl StructuralPartialEq for LegacyPk
Auto Trait Implementations§
impl Freeze for LegacyPk
impl RefUnwindSafe for LegacyPk
impl Send for LegacyPk
impl Sync for LegacyPk
impl Unpin for LegacyPk
impl UnwindSafe for LegacyPk
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.