Copyright | Will Thompson and Iñaki García Etxebarria |
---|---|
License | LGPL-2.1 |
Maintainer | Iñaki García Etxebarria |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
Represents a precise time, with seconds and microseconds.
Similar to the struct timeval returned by the gettimeofday()
UNIX system call.
GLib is attempting to unify around the use of 64-bit integers to
represent microsecond-precision time. As such, this type will be
removed from a future version of GLib. A consequence of using glong
for
tv_sec
is that on 32-bit systems GTimeVal
is subject to the year 2038
problem.
Synopsis
- newtype TimeVal = TimeVal (ManagedPtr TimeVal)
- newZeroTimeVal :: MonadIO m => m TimeVal
- timeValAdd :: (HasCallStack, MonadIO m) => TimeVal -> CLong -> m ()
- timeValFromIso8601 :: (HasCallStack, MonadIO m) => Text -> m (Bool, TimeVal)
- timeValToIso8601 :: (HasCallStack, MonadIO m) => TimeVal -> m (Maybe Text)
- getTimeValTvSec :: MonadIO m => TimeVal -> m CLong
- setTimeValTvSec :: MonadIO m => TimeVal -> CLong -> m ()
- getTimeValTvUsec :: MonadIO m => TimeVal -> m CLong
- setTimeValTvUsec :: MonadIO m => TimeVal -> CLong -> m ()
Exported types
Memory-managed wrapper type.
Instances
Eq TimeVal Source # | |
BoxedPtr TimeVal Source # | |
Defined in GI.GLib.Structs.TimeVal boxedPtrCopy :: TimeVal -> IO TimeVal boxedPtrFree :: TimeVal -> IO () | |
CallocPtr TimeVal Source # | |
Defined in GI.GLib.Structs.TimeVal boxedPtrCalloc :: IO (Ptr TimeVal) | |
ManagedPtrNewtype TimeVal Source # | |
Defined in GI.GLib.Structs.TimeVal toManagedPtr :: TimeVal -> ManagedPtr TimeVal | |
tag ~ 'AttrSet => Constructible TimeVal tag Source # | |
Methods
Click to display all available methods, including inherited ones
add
:: (HasCallStack, MonadIO m) | |
=> TimeVal |
|
-> CLong |
|
-> m () |
fromIso8601
:: (HasCallStack, MonadIO m) | |
=> Text |
|
-> m (Bool, TimeVal) | Returns: |
Deprecated: (Since version 2.62)tTimeVal
is not year-2038-safe. Use dateTimeNewFromIso8601
instead.
Converts a string containing an ISO 8601 encoded date and time
to a TimeVal
and puts it into time_
.
isoDate
must include year, month, day, hours, minutes, and
seconds. It can optionally include fractions of a second and a time
zone indicator. (In the absence of any time zone indication, the
timestamp is assumed to be in local time.)
Any leading or trailing space in isoDate
is ignored.
This function was deprecated, along with TimeVal
itself, in GLib 2.62.
Equivalent functionality is available using code like:
>
>GDateTime *dt = g_date_time_new_from_iso8601 (iso8601_string, NULL);
>gint64 time_val = g_date_time_to_unix (dt);
>g_date_time_unref (dt);
Since: 2.12
toIso8601
:: (HasCallStack, MonadIO m) | |
=> TimeVal |
|
-> m (Maybe Text) | Returns: a newly allocated string containing an ISO 8601 date,
or |
Deprecated: (Since version 2.62)tTimeVal
is not year-2038-safe. Use g_date_time_format_iso8601(dt) instead.
Converts time_
into an RFC 3339 encoded string, relative to the
Coordinated Universal Time (UTC). This is one of the many formats
allowed by ISO 8601.
ISO 8601 allows a large number of date/time formats, with or without
punctuation and optional elements. The format returned by this function
is a complete date and time, with optional punctuation included, the
UTC time zone represented as "Z", and the tvUsec
part included if
and only if it is nonzero, i.e. either
"YYYY-MM-DDTHH:MM:SSZ" or "YYYY-MM-DDTHH:MM:SS.fffffZ".
This corresponds to the Internet date/time format defined by RFC 3339, and to either of the two most-precise formats defined by the W3C Note Date and Time Formats. Both of these documents are profiles of ISO 8601.
Use dateTimeFormat
or g_strdup_printf()
if a different
variation of ISO 8601 format is required.
If time_
represents a date which is too large to fit into a struct tm
,
Nothing
will be returned. This is platform dependent. Note also that since
GTimeVal
stores the number of seconds as a glong
, on 32-bit systems it
is subject to the year 2038 problem. Accordingly, since GLib 2.62, this
function has been deprecated. Equivalent functionality is available using:
>
>GDateTime *dt = g_date_time_new_from_unix_utc (time_val);
>iso8601_string = g_date_time_format_iso8601 (dt);
>g_date_time_unref (dt);
The return value of timeValToIso8601
has been nullable since GLib
2.54; before then, GLib would crash under the same conditions.
Since: 2.12
Properties
tvSec
seconds
getTimeValTvSec :: MonadIO m => TimeVal -> m CLong Source #
Get the value of the “tv_sec
” field.
When overloading is enabled, this is equivalent to
get
timeVal #tvSec
setTimeValTvSec :: MonadIO m => TimeVal -> CLong -> m () Source #
Set the value of the “tv_sec
” field.
When overloading is enabled, this is equivalent to
set
timeVal [ #tvSec:=
value ]
tvUsec
microseconds
getTimeValTvUsec :: MonadIO m => TimeVal -> m CLong Source #
Get the value of the “tv_usec
” field.
When overloading is enabled, this is equivalent to
get
timeVal #tvUsec
setTimeValTvUsec :: MonadIO m => TimeVal -> CLong -> m () Source #
Set the value of the “tv_usec
” field.
When overloading is enabled, this is equivalent to
set
timeVal [ #tvUsec:=
value ]