Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
High-resolution, realtime clock and timer functions for Posix systems. This module is being developed according to IEEE Std 1003.1-2008: http://www.opengroup.org/onlinepubs/9699919799/, http://www.opengroup.org/onlinepubs/9699919799/functions/clock_getres.html#
Documentation
Clock types. A clock may be system-wide (that is, visible to all processes)
or per-process (measuring time that is meaningful only within a process).
All implementations shall support Realtime
.
Monotonic | The identifier for the system-wide monotonic clock, which is defined as
a clock measuring real time, whose value cannot be set via
|
Realtime | The identifier of the system-wide clock measuring real time. For this
clock, the value returned by |
ProcessCPUTime | The identifier of the CPU-time clock associated with the calling
process. For this clock, the value returned by |
ThreadCPUTime | The identifier of the CPU-time clock associated with the calling OS
thread. For this clock, the value returned by |
MonotonicRaw | (since Linux 2.6.28, macOS 10.12)
Similar to |
Boottime | (since Linux 2.6.39; Linux-specific)
Identical to |
MonotonicCoarse | (since Linux 2.6.32; Linux-specific)
A faster but less precise version of |
RealtimeCoarse | (since Linux 2.6.32; Linux-specific)
A faster but less precise version of |
Instances
Enum Clock Source # | |
Eq Clock Source # | |
Read Clock Source # | |
Show Clock Source # | |
Generic Clock Source # | |
type Rep Clock Source # | |
Defined in System.Clock type Rep Clock = D1 ('MetaData "Clock" "System.Clock" "clock-0.8.2-Gn00uvh2IWgKr3x8wn0zeC" 'False) (((C1 ('MetaCons "Monotonic" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "Realtime" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "ProcessCPUTime" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "ThreadCPUTime" 'PrefixI 'False) (U1 :: Type -> Type))) :+: ((C1 ('MetaCons "MonotonicRaw" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "Boottime" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "MonotonicCoarse" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "RealtimeCoarse" 'PrefixI 'False) (U1 :: Type -> Type)))) |
TimeSpec structure
Instances
Eq TimeSpec Source # | |
Num TimeSpec Source # | |
Ord TimeSpec Source # | |
Defined in System.Clock | |
Read TimeSpec Source # | |
Show TimeSpec Source # | |
Generic TimeSpec Source # | |
Storable TimeSpec Source # | |
type Rep TimeSpec Source # | |
Defined in System.Clock type Rep TimeSpec = D1 ('MetaData "TimeSpec" "System.Clock" "clock-0.8.2-Gn00uvh2IWgKr3x8wn0zeC" 'False) (C1 ('MetaCons "TimeSpec" 'PrefixI 'True) (S1 ('MetaSel ('Just "sec") 'SourceUnpack 'SourceStrict 'DecidedStrict) (Rec0 Int64) :*: S1 ('MetaSel ('Just "nsec") 'SourceUnpack 'SourceStrict 'DecidedStrict) (Rec0 Int64))) |
getTime :: Clock -> IO TimeSpec Source #
The getTime
function shall return the current value for the
specified clock.
getRes :: Clock -> IO TimeSpec Source #
The getRes
function shall return the resolution of any clock.
Clock resolutions are implementation-defined and cannot be set
by a process.
fromNanoSecs :: Integer -> TimeSpec Source #
TimeSpec from nano seconds.
toNanoSecs :: TimeSpec -> Integer Source #
TimeSpec to nano seconds.
timeSpecAsNanoSecs :: TimeSpec -> Integer Source #
Deprecated: Use toNanoSecs instead! Replaced timeSpecAsNanoSecs with the same signature TimeSpec -> Integer
TimeSpec as nano seconds.