[commit: packages/time] format-widths, master, tasty: POSIX: clean up definitions, fix posixToUTCTime (255aa53)
git at git.haskell.org
git at git.haskell.org
Mon Feb 20 21:19:19 UTC 2017
Repository : ssh://git@git.haskell.org/time
On branches: format-widths,master,tasty
Link : http://git.haskell.org/packages/time.git/commitdiff/255aa53abdf6119a2e764de04ab88bdbffec9b4c
>---------------------------------------------------------------
commit 255aa53abdf6119a2e764de04ab88bdbffec9b4c
Author: Ashley Yakeley <ashley at yakeley.org>
Date: Tue Dec 6 23:03:00 2016 -0800
POSIX: clean up definitions, fix posixToUTCTime
>---------------------------------------------------------------
255aa53abdf6119a2e764de04ab88bdbffec9b4c
lib/Data/Time/Clock/POSIX.hs | 22 ++++++++--------------
1 file changed, 8 insertions(+), 14 deletions(-)
diff --git a/lib/Data/Time/Clock/POSIX.hs b/lib/Data/Time/Clock/POSIX.hs
index 94bc8ee..82d18fd 100644
--- a/lib/Data/Time/Clock/POSIX.hs
+++ b/lib/Data/Time/Clock/POSIX.hs
@@ -2,7 +2,7 @@
-- Most people won't need this module.
module Data.Time.Clock.POSIX
(
- posixDayLength,POSIXTime,
+ POSIXTime,
makePOSIXTime,ptSeconds,ptNanoSeconds,
posixSecondsToUTCTime,utcTimeToPOSIXSeconds,
posixToUTCTime,getPOSIXTime,getCurrentTime
@@ -71,14 +71,11 @@ instance NFData POSIXTime where
rnf a = a `seq` ()
posixToUTCTime :: POSIXTime -> UTCTime
-posixToUTCTime (POSIXTime s ns) =
- let (d, s') = s `divMod` posixDayLength
- ps = s' * 1000000000000 + fromIntegral (ns * 1000) -- 'Int64' can hold ps in one day
- in UTCTime (addDays (fromIntegral d) unixEpochDay)
- (picosecondsToDiffTime (fromIntegral ps))
-
-posixDayLength :: Int64
-posixDayLength = 86400
+posixToUTCTime (POSIXTime s ns) = let
+ (d, s') = s `divMod` 86400
+ ps :: Int64
+ ps = s' * 1000000000000 + (fromIntegral ns) * 1000
+ in UTCTime (addDays (fromIntegral d) unixEpochDay) (picosecondsToDiffTime $ fromIntegral ps)
unixEpochDay :: Day
unixEpochDay = ModifiedJulianDay 40587
@@ -115,17 +112,14 @@ getPOSIXTime = do
--------------------------------------------------------------------------------
-posixDayLength_ :: NominalDiffTime
-posixDayLength_ = 86400
-
posixSecondsToUTCTime :: NominalDiffTime -> UTCTime
posixSecondsToUTCTime i = let
- (d,t) = divMod' i posixDayLength_
+ (d,t) = divMod' i nominalDay
in UTCTime (addDays d unixEpochDay) (realToFrac t)
utcTimeToPOSIXSeconds :: UTCTime -> NominalDiffTime
utcTimeToPOSIXSeconds (UTCTime d t) =
- (fromInteger (diffDays d unixEpochDay) * posixDayLength_) + min posixDayLength_ (realToFrac t)
+ (fromInteger (diffDays d unixEpochDay) * nominalDay) + min nominalDay (realToFrac t)
-- | Get the current 'UTCTime' from the system clock.
getCurrentTime :: IO UTCTime
More information about the ghc-commits
mailing list