[−][src]Struct lightning_invoice::PositiveTimestamp
A timestamp that refers to a date after 1 January 1970 which means its representation as UNIX timestamp is positive.
Invariants
The UNIX timestamp representing the stored time has to be positive and small enough so that
a EpiryTime
can be added to it without an overflow.
Implementations
impl PositiveTimestamp
[src]
pub fn from_unix_timestamp(unix_seconds: u64) -> Result<Self, CreationError>
[src]
Create a new PositiveTimestamp
from a unix timestamp in the Range
0...SYSTEM_TIME_MAX_UNIX_TIMESTAMP - MAX_EXPIRY_TIME
, otherwise return a
CreationError::TimestampOutOfBounds
.
pub fn from_system_time(time: SystemTime) -> Result<Self, CreationError>
[src]
Create a new PositiveTimestamp
from a SystemTime
with a corresponding unix timestamp in
the Range 0...SYSTEM_TIME_MAX_UNIX_TIMESTAMP - MAX_EXPIRY_TIME
, otherwise return a
CreationError::TimestampOutOfBounds
.
pub fn as_unix_timestamp(&self) -> u64
[src]
Returns the UNIX timestamp representing the stored time
pub fn as_time(&self) -> &SystemTime
[src]
Returns a reference to the internal SystemTime
time representation
Methods from Deref<Target = SystemTime>
pub const UNIX_EPOCH: SystemTime
1.28.0[src]
pub fn duration_since(
&self,
earlier: SystemTime
) -> Result<Duration, SystemTimeError>
1.8.0[src]
&self,
earlier: SystemTime
) -> Result<Duration, SystemTimeError>
Returns the amount of time elapsed from an earlier point in time.
This function may fail because measurements taken earlier are not
guaranteed to always be before later measurements (due to anomalies such
as the system clock being adjusted either forwards or backwards).
Instant
can be used to measure elapsed time without this risk of failure.
If successful, Ok
(
Duration
)
is returned where the duration represents
the amount of time elapsed from the specified measurement to this one.
Returns an Err
if earlier
is later than self
, and the error
contains how far from self
the time is.
Examples
use std::time::SystemTime; let sys_time = SystemTime::now(); let new_sys_time = SystemTime::now(); let difference = new_sys_time.duration_since(sys_time) .expect("Clock may have gone backwards"); println!("{:?}", difference);
pub fn elapsed(&self) -> Result<Duration, SystemTimeError>
1.8.0[src]
Returns the difference between the clock time when this system time was created, and the current clock time.
This function may fail as the underlying system clock is susceptible to
drift and updates (e.g., the system clock could go backwards), so this
function may not always succeed. If successful, Ok
(
Duration
)
is
returned where the duration represents the amount of time elapsed from
this time measurement to the current time.
To measure elapsed time reliably, use Instant
instead.
Returns an Err
if self
is later than the current system time, and
the error contains how far from the current system time self
is.
Examples
use std::thread::sleep; use std::time::{Duration, SystemTime}; let sys_time = SystemTime::now(); let one_sec = Duration::from_secs(1); sleep(one_sec); assert!(sys_time.elapsed().unwrap() >= one_sec);
pub fn checked_add(&self, duration: Duration) -> Option<SystemTime>
1.34.0[src]
Returns Some(t)
where t
is the time self + duration
if t
can be represented as
SystemTime
(which means it's inside the bounds of the underlying data structure), None
otherwise.
pub fn checked_sub(&self, duration: Duration) -> Option<SystemTime>
1.34.0[src]
Returns Some(t)
where t
is the time self - duration
if t
can be represented as
SystemTime
(which means it's inside the bounds of the underlying data structure), None
otherwise.
Trait Implementations
impl Clone for PositiveTimestamp
[src]
pub fn clone(&self) -> PositiveTimestamp
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Debug for PositiveTimestamp
[src]
impl Deref for PositiveTimestamp
[src]
type Target = SystemTime
The resulting type after dereferencing.
pub fn deref(&self) -> &Self::Target
[src]
impl Eq for PositiveTimestamp
[src]
impl FromBase32 for PositiveTimestamp
[src]
type Err = ParseError
The associated error which can be returned from parsing (e.g. because of bad padding).
pub fn from_base32(b32: &[u5]) -> Result<Self, Self::Err>
[src]
impl Into<SystemTime> for PositiveTimestamp
[src]
pub fn into(self) -> SystemTime
[src]
impl PartialEq<PositiveTimestamp> for PositiveTimestamp
[src]
pub fn eq(&self, other: &PositiveTimestamp) -> bool
[src]
pub fn ne(&self, other: &PositiveTimestamp) -> bool
[src]
impl StructuralEq for PositiveTimestamp
[src]
impl StructuralPartialEq for PositiveTimestamp
[src]
impl ToBase32 for PositiveTimestamp
[src]
Auto Trait Implementations
impl RefUnwindSafe for PositiveTimestamp
[src]
impl Send for PositiveTimestamp
[src]
impl Sync for PositiveTimestamp
[src]
impl Unpin for PositiveTimestamp
[src]
impl UnwindSafe for PositiveTimestamp
[src]
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, 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>,