module Sound.OpenSoundControl.Time where import Control.Monad import qualified Data.Time as T -- | UTC time is represented as a real number. type UTC = Double -- | NTP time is represented as an integer. type NTP = Integer -- | Convert a real-valued NTP timestamp to an NTP timestamp. ntpr_ntp :: Double -> NTP ntpr_ntp t = round (t * 2^(32::Int)) -- | Convert UTC timestamp to NTP timestamp. utc_ntp :: UTC -> NTP utc_ntp t = ntpr_ntp (t + secdif) where secdif = (70 * 365 + 17) * 24 * 60 * 60 -- | The time at 1970-01-01:00:00:00. utc_base :: T.UTCTime utc_base = T.UTCTime d s where d = T.fromGregorian 1970 1 1 s = T.secondsToDiffTime 0 -- | Read current UTC timestamp. utc :: IO UTC utc = do t <- T.getCurrentTime return (realToFrac (T.diffUTCTime t utc_base)) -- | Read current NTP timestamp. ntp :: IO NTP ntp = liftM utc_ntp utc