Skip to main content

MedianTimePast

Struct MedianTimePast 

Source
pub struct MedianTimePast(/* private fields */);
Expand description

The median timestamp of 11 consecutive blocks, representing “the timestamp” of the final block for locktime-checking purposes.

Time-based locktimes are not measured against the timestamps in individual block headers, since these are not monotone and may be subject to miner manipulation. Instead, locktimes use the “median-time-past” (MTP) of the most recent 11 blocks, a quantity which is required by consensus to be monotone and which is difficult for any individual miner to manipulate.

Implementations§

Source§

impl MedianTimePast

Source

pub const MIN: MedianTimePast

The minimum MTP allowable in a locktime (Tue Nov 05 1985 00:53:20 GMT+0000).

Source

pub const MAX: MedianTimePast

The maximum MTP allowable in a locktime (Sun Feb 07 2106 06:28:15 GMT+0000).

Source

pub fn new( timestamps: [BlockTime; 11], ) -> Result<MedianTimePast, ConversionError>

Constructs an MedianTimePast by computing the median-time-past from the last 11 block timestamps.

Because block timestamps are not monotonic, this function internally sorts them; it is therefore not important what order they appear in the array; use whatever is most convenient.

§Errors

If the median block timestamp is not in the allowable range of MTPs in a locktime: [500_000_000, 2^32 - 1]. Because there is a consensus rule that MTP be monotonically increasing, and the MTP of the first 11 blocks exceeds 500_000_000 for every real-life chain, this error typically cannot be hit in practice.

Source

pub fn from_hex(s: &str) -> Result<MedianTimePast, ParseTimeError>

Constructs a new MedianTimePast from a big-endian hex-encoded u32.

The input string may or may not contain a typical hex prefix e.g., 0x.

§Errors

If the input string is not a valid hex representation of a block time.

Source

pub const fn from_u32(n: u32) -> Result<MedianTimePast, ConversionError>

Constructs a new MTP directly from a u32 value.

This function, with MedianTimePast::to_u32, is used to obtain a raw MTP value. It is not used to convert to or from a block timestamp, which is not a MTP.

§Errors

If n is not in the allowable range of MTPs in a locktime: [500_000_000, 2^32 - 1].

§Examples
use bitcoin_units::locktime::absolute;

let t: u32 = 1653195600; // May 22nd, 5am UTC.
let time = absolute::MedianTimePast::from_u32(t)?;
assert_eq!(time.to_u32(), t);
Source

pub const fn to_u32(self) -> u32

Converts this MedianTimePast to a raw u32 value.

§Examples
use bitcoin_units::locktime::absolute;

assert_eq!(absolute::MedianTimePast::MIN.to_u32(), 500_000_000);
Source

pub fn is_satisfied_by(self, time: MedianTimePast) -> bool

Returns true if a transaction with this locktime can be included in the next block.

self is the value of the LockTime and if time is the median time past of the block at the chain tip then a transaction with this lock can be broadcast for inclusion in the next block.

Trait Implementations§

Source§

impl<'a> Arbitrary<'a> for MedianTimePast

Available on crate feature arbitrary only.
Source§

fn arbitrary(u: &mut Unstructured<'a>) -> Result<MedianTimePast, Error>

Generate an arbitrary value of Self from the given unstructured data. Read more
Source§

fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>

Generate an arbitrary value of Self from the entirety of the given unstructured data. Read more
Source§

fn size_hint(depth: usize) -> (usize, Option<usize>)

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

fn try_size_hint( depth: usize, ) -> Result<(usize, Option<usize>), MaxRecursionReached>

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

impl Binary for MedianTimePast

Source§

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

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

impl Clone for MedianTimePast

Source§

fn clone(&self) -> MedianTimePast

Returns a duplicate 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 MedianTimePast

Source§

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

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

impl Display for MedianTimePast

Source§

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

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

impl From<MedianTimePast> for BlockMtp

Source§

fn from(h: MedianTimePast) -> BlockMtp

Converts a [locktime::absolute::MedianTimePast] to a BlockMtp.

An absolute locktime MTP has a minimum value of absolute::LOCK_TIME_THRESHOLD, while BlockMtp may take the full range of u32.

Source§

impl From<MedianTimePast> for LockTime

Source§

fn from(t: MedianTimePast) -> LockTime

Converts to this type from the input type.
Source§

impl FromStr for MedianTimePast

Source§

type Err = ParseTimeError

The associated error which can be returned from parsing.
Source§

fn from_str(s: &str) -> Result<MedianTimePast, <MedianTimePast as FromStr>::Err>

Parses a string s to return a value of this type. Read more
Source§

impl Hash for MedianTimePast

Source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl LowerHex for MedianTimePast

Source§

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

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

impl Octal for MedianTimePast

Source§

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

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

impl Ord for MedianTimePast

Source§

fn cmp(&self, other: &MedianTimePast) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for MedianTimePast

Source§

fn eq(&self, other: &MedianTimePast) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for MedianTimePast

Source§

fn partial_cmp(&self, other: &MedianTimePast) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl TryFrom<&str> for MedianTimePast

Source§

type Error = ParseTimeError

The type returned in the event of a conversion error.
Source§

fn try_from( s: &str, ) -> Result<MedianTimePast, <MedianTimePast as TryFrom<&str>>::Error>

Performs the conversion.
Source§

impl TryFrom<BlockMtp> for MedianTimePast

Source§

fn try_from( h: BlockMtp, ) -> Result<MedianTimePast, <MedianTimePast as TryFrom<BlockMtp>>::Error>

Converts a BlockHeight to a [locktime::absolute::Height].

An absolute locktime MTP has a minimum value of absolute::LOCK_TIME_THRESHOLD, while BlockMtp may take the full range of u32.

Source§

type Error = ConversionError

The type returned in the event of a conversion error.
Source§

impl TryFrom<Box<str>> for MedianTimePast

Source§

type Error = ParseTimeError

The type returned in the event of a conversion error.
Source§

fn try_from( s: Box<str>, ) -> Result<MedianTimePast, <MedianTimePast as TryFrom<Box<str>>>::Error>

Performs the conversion.
Source§

impl TryFrom<String> for MedianTimePast

Source§

type Error = ParseTimeError

The type returned in the event of a conversion error.
Source§

fn try_from( s: String, ) -> Result<MedianTimePast, <MedianTimePast as TryFrom<String>>::Error>

Performs the conversion.
Source§

impl UpperHex for MedianTimePast

Source§

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

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

impl Copy for MedianTimePast

Source§

impl Eq for MedianTimePast

Source§

impl StructuralPartialEq for MedianTimePast

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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 T
where 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 T
where T: Clone,

Source§

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 T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.