module System.Metrics.Gauge
(
Gauge
, new
, read
, inc
, dec
, add
, subtract
, set
) where
import qualified Data.Atomic as Atomic
import Data.Int (Int64)
import Prelude hiding (subtract, read)
newtype Gauge = C { Gauge -> Atomic
unC :: Atomic.Atomic }
new :: IO Gauge
new :: IO Gauge
new = Atomic -> Gauge
C (Atomic -> Gauge) -> IO Atomic -> IO Gauge
forall a b. (a -> b) -> IO a -> IO b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
`fmap` Int64 -> IO Atomic
Atomic.new Int64
0
read :: Gauge -> IO Int64
read :: Gauge -> IO Int64
read = Atomic -> IO Int64
Atomic.read (Atomic -> IO Int64) -> (Gauge -> Atomic) -> Gauge -> IO Int64
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Gauge -> Atomic
unC
inc :: Gauge -> IO ()
inc :: Gauge -> IO ()
inc Gauge
gauge = Gauge -> Int64 -> IO ()
add Gauge
gauge Int64
1
dec :: Gauge -> IO ()
dec :: Gauge -> IO ()
dec Gauge
gauge = Gauge -> Int64 -> IO ()
subtract Gauge
gauge Int64
1
add :: Gauge -> Int64 -> IO ()
add :: Gauge -> Int64 -> IO ()
add Gauge
gauge = Atomic -> Int64 -> IO ()
Atomic.add (Gauge -> Atomic
unC Gauge
gauge)
subtract :: Gauge -> Int64 -> IO ()
subtract :: Gauge -> Int64 -> IO ()
subtract Gauge
gauge = Atomic -> Int64 -> IO ()
Atomic.subtract (Gauge -> Atomic
unC Gauge
gauge)
set :: Gauge -> Int64 -> IO ()
set :: Gauge -> Int64 -> IO ()
set Gauge
gauge = Atomic -> Int64 -> IO ()
Atomic.write (Gauge -> Atomic
unC Gauge
gauge)