Struct TimeWithTimeZone

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

A safe wrapper around Postgres TIME WITH TIME ZONE type, backed by a pg_sys::TimeTzADT integer value.

Implementations§

Source§

impl TimeWithTimeZone

Source

pub fn new( hour: u8, minute: u8, second: f64, ) -> Result<TimeWithTimeZone, DateTimeConversionError>

Construct a new TimeWithTimeZone from its constituent parts.

§Notes

This function uses Postgres’ “current time zone”

§Errors

Returns a DateTimeConversionError if any part is outside the bounds for that part

Source

pub fn new_unchecked(hour: u8, minute: u8, second: f64) -> TimeWithTimeZone

Construct a new TimeWithTimeZone from its constituent parts.

Elides the overhead of trapping errors for out-of-bounds parts

§Notes

This function uses Postgres’ “current time zone”

§Panics

This function panics if any part is out-of-bounds

Source

pub fn with_timezone<Tz>( hour: u8, minute: u8, second: f64, timezone: Tz, ) -> Result<TimeWithTimeZone, DateTimeConversionError>

Construct a new TimeWithTimeZone from its constituent parts at a specific time zone

§Errors

Returns a DateTimeConversionError if any part is outside the bounds for that part

Source

pub fn with_timezone_offset( hour: u8, minute: u8, second: f64, timezone_offset: Interval, ) -> Result<TimeWithTimeZone, DateTimeConversionError>

Construct a new TimeWithTimeZone from its constituent parts at a specific time zone Interval

§Errors

Returns a DateTimeConversionError if any part is outside the bounds for that part

Source

pub fn hour(&self) -> u8

Extract the hour

Source

pub fn minute(&self) -> u8

Extract the minute

Source

pub fn second(&self) -> f64

Extract the second

Source

pub fn microseconds(&self) -> u32

Return the microseconds part. This is not the time counted in microseconds, but the fractional seconds

Source

pub fn timezone_offset(&self) -> i32

Extract the timezone, measured in seconds past GMT

Source

pub fn timezone_hour(&self) -> i32

Extract the timezone_hour, measured in hours past GMT

Source

pub fn timezone_minute(&self) -> i32

Extract the timezone_minute, measured in hours past GMT

Source

pub fn to_hms_micro(&self) -> (u8, u8, u8, u32)

Return the hour, minute, second, and microseconds as a Rust tuple

Source

pub fn to_utc(&self) -> Time

Shift this TimeWithTimeZone to UTC

Source

pub fn at_timezone<Tz>( &self, timezone: Tz, ) -> Result<TimeWithTimeZone, DateTimeConversionError>

Shift the TimeWithTimeZone to the specified time zone

§Errors

Returns a DateTimeConversionError if the specified time zone is invalid or if for some other reason the underlying time cannot be represented in the specified time zone

Source

pub fn into_inner(self) -> TimeTzADT

Return the backing pg_sys::TimeTzADT value.

Trait Implementations§

Source§

impl Add<Date> for TimeWithTimeZone

Source§

type Output = TimestampWithTimeZone

The resulting type after applying the + operator.
Source§

fn add(self, rhs: Date) -> <TimeWithTimeZone as Add<Date>>::Output

Performs the + operation. Read more
Source§

impl Add<Interval> for TimeWithTimeZone

Source§

type Output = TimeWithTimeZone

The resulting type after applying the + operator.
Source§

fn add(self, rhs: Interval) -> <TimeWithTimeZone as Add<Interval>>::Output

Performs the + operation. Read more
Source§

impl Add<TimeWithTimeZone> for Date

Source§

type Output = TimestampWithTimeZone

The resulting type after applying the + operator.
Source§

fn add(self, rhs: TimeWithTimeZone) -> <Date as Add<TimeWithTimeZone>>::Output

Performs the + operation. Read more
Source§

impl Add<TimeWithTimeZone> for Interval

Source§

type Output = TimeWithTimeZone

The resulting type after applying the + operator.
Source§

fn add( self, rhs: TimeWithTimeZone, ) -> <Interval as Add<TimeWithTimeZone>>::Output

Performs the + operation. Read more
Source§

impl Clone for TimeWithTimeZone

Source§

fn clone(&self) -> TimeWithTimeZone

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 TimeWithTimeZone

Source§

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

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

impl<'de> Deserialize<'de> for TimeWithTimeZone

Source§

fn deserialize<D>( deserializer: D, ) -> Result<TimeWithTimeZone, <D as Deserializer<'de>>::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for TimeWithTimeZone

Source§

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

Uses the underlying “output” function to convert this type to a String

Source§

impl From<(i64, i32)> for TimeWithTimeZone

Source§

fn from(value: (i64, i32)) -> TimeWithTimeZone

Converts to this type from the input type.
Source§

impl From<Time> for TimeWithTimeZone

Source§

fn from(t: Time) -> TimeWithTimeZone

Converts to this type from the input type.
Source§

impl From<TimeTzADT> for TimeWithTimeZone

This impl currently allows creating a TimeWithTimeZone that cannot be constructed by SQL, such as at the time 37:42 in the time zone UTC+25:00, which may yield logic bugs if used.

Source§

fn from(value: TimeTzADT) -> TimeWithTimeZone

Converts to this type from the input type.
Source§

impl From<TimeWithTimeZone> for Time

Source§

fn from(value: TimeWithTimeZone) -> Time

Converts to this type from the input type.
Source§

impl From<TimestampWithTimeZone> for TimeWithTimeZone

Source§

fn from(value: TimestampWithTimeZone) -> TimeWithTimeZone

Converts to this type from the input type.
Source§

impl FromDatum for TimeWithTimeZone

Source§

unsafe fn from_polymorphic_datum( datum: Datum, is_null: bool, _typoid: Oid, ) -> Option<TimeWithTimeZone>

Like from_datum for instantiating polymorphic types which require preserving the dynamic type metadata. Read more
Source§

const GET_TYPOID: bool = false

Should a type OID be fetched when calling from_datum?
Source§

unsafe fn from_datum(datum: Datum, is_null: bool) -> Option<Self>
where Self: Sized,

Safety Read more
Source§

unsafe fn from_datum_in_memory_context( memory_context: PgMemoryContexts, datum: Datum, is_null: bool, typoid: Oid, ) -> Option<Self>
where Self: Sized,

Default implementation switched to the specified memory context and then simply calls FromDatum::from_datum(...) from within that context. Read more
Source§

unsafe fn try_from_datum( datum: Datum, is_null: bool, type_oid: Oid, ) -> Result<Option<Self>, TryFromDatumError>
where Self: Sized + IntoDatum,

try_from_datum is a convenience wrapper around FromDatum::from_datum that returns a a Result around an Option, as a Datum can be null. It’s intended to be used in situations where the caller needs to know whether the type conversion succeeded or failed. Read more
Source§

unsafe fn try_from_datum_in_memory_context( memory_context: PgMemoryContexts, datum: Datum, is_null: bool, type_oid: Oid, ) -> Result<Option<Self>, TryFromDatumError>
where Self: Sized + IntoDatum,

A version of try_from_datum that switches to the given context to convert from Datum
Source§

impl FromStr for TimeWithTimeZone

Source§

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

Create this type from a string.

Source§

type Err = DateTimeConversionError

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

impl HasExtractableParts for TimeWithTimeZone

Source§

const EXTRACT_FUNCTION: unsafe fn(*mut FunctionCallInfoBaseData) -> Datum = {pgrx::pg_sys::extract_timetz as unsafe fn(*mut pgrx::pg_sys::FunctionCallInfoBaseData) -> pgrx::pg_sys::Datum}

Source§

fn extract_part(&self, field: DateTimeParts) -> Option<AnyNumeric>

Extract a DateTimeParts part from a date/time-like type
Source§

impl Hash for TimeWithTimeZone

Source§

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

Uses the underlying Postgres “hash” function for this type

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 IntoDatum for TimeWithTimeZone

Source§

fn into_datum(self) -> Option<Datum>

Source§

fn type_oid() -> Oid

Source§

fn composite_type_oid(&self) -> Option<Oid>

Source§

fn array_type_oid() -> Oid

Source§

fn is_compatible_with(other: Oid) -> bool

Is a Datum of this type compatible with another Postgres type? Read more
Source§

impl Ord for TimeWithTimeZone

Source§

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

Uses the underlying Postgres “_cmp()” function for this type

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 TimeWithTimeZone

Source§

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

Uses the underlying Postgres “_eq()” function for this type

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 TimeWithTimeZone

Source§

fn partial_cmp(&self, other: &TimeWithTimeZone) -> 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 Serialize for TimeWithTimeZone

Source§

fn serialize<S>( &self, serializer: S, ) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>
where S: Serializer,

Serialize this TimeWithTimeZone in ISO form, compatible with most JSON parsers

Source§

impl SqlTranslatable for TimeWithTimeZone

Source§

impl Sub<Interval> for TimeWithTimeZone

Source§

type Output = TimeWithTimeZone

The resulting type after applying the - operator.
Source§

fn sub(self, rhs: Interval) -> <TimeWithTimeZone as Sub<Interval>>::Output

Performs the - operation. Read more
Source§

impl ToIsoString for TimeWithTimeZone

Source§

fn to_iso_string(self) -> String

Encode of this date/time-like type into JSON string in ISO format using optionally preallocated buffer ‘buf’. Read more
Source§

fn to_iso_string_with_timezone<Tz>( self, timezone: Tz, ) -> Result<String, DateTimeConversionError>
where Tz: AsRef<str>,

Encode of this date/time-like type into JSON string in ISO format using optionally preallocated buffer ‘buf’. Read more
Source§

impl Copy for TimeWithTimeZone

Source§

impl Eq for TimeWithTimeZone

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<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. 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> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
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> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.
Source§

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

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<N> NodeTrait for N
where N: Copy + Ord + Hash,