bdk_chain::bitcoin::secp256k1::ffi

Trait CPtr

pub trait CPtr {
    type Target;

    // Required methods
    fn as_c_ptr(&self) -> *const Self::Target;
    fn as_mut_c_ptr(&mut self) -> *mut Self::Target;
}
Expand description

A trait for producing pointers that will always be valid in C (assuming NULL pointer is a valid no-op).

Rust does not guarantee pointers to Zero Sized Types (https://doc.rust-lang.org/nomicon/exotic-sizes.html#zero-sized-types-zsts). In case the type is empty this trait will return a NULL pointer, which should be handled in C.

Required Associated Types§

type Target

Required Methods§

fn as_c_ptr(&self) -> *const Self::Target

fn as_mut_c_ptr(&mut self) -> *mut Self::Target

Implementations on Foreign Types§

§

impl CPtr for [u8; 32]

§

type Target = u8

§

fn as_c_ptr(&self) -> *const <[u8; 32] as CPtr>::Target

§

fn as_mut_c_ptr(&mut self) -> *mut <[u8; 32] as CPtr>::Target

§

impl<T> CPtr for &[T]

§

type Target = T

§

fn as_c_ptr(&self) -> *const <&[T] as CPtr>::Target

§

fn as_mut_c_ptr(&mut self) -> *mut <&[T] as CPtr>::Target

§

impl<T> CPtr for Option<T>
where T: CPtr,

§

type Target = <T as CPtr>::Target

§

fn as_mut_c_ptr(&mut self) -> *mut <Option<T> as CPtr>::Target

§

fn as_c_ptr(&self) -> *const <Option<T> as CPtr>::Target

§

impl<T> CPtr for [T]

§

type Target = T

§

fn as_c_ptr(&self) -> *const <[T] as CPtr>::Target

§

fn as_mut_c_ptr(&mut self) -> *mut <[T] as CPtr>::Target

Implementors§

§

impl CPtr for bdk_chain::bitcoin::key::Keypair

§

impl CPtr for bdk_chain::bitcoin::XOnlyPublicKey

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ecdsa::RecoverableSignature

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ecdsa::Signature

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ellswift::ElligatorSwift

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::schnorr::Signature

§

type Target = u8

§

impl CPtr for Message

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::PublicKey

This trait enables interaction with the FFI layer and even though it is part of the public API normal users should never need to directly interact with FFI types.

§

impl CPtr for SecretKey

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::recovery::RecoverableSignature

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::ElligatorSwift

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::Keypair

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::PublicKey

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::Signature

§

type Target = u8

§

impl CPtr for bdk_chain::bitcoin::secp256k1::ffi::XOnlyPublicKey

§

type Target = u8