diff --git a/Command/ImportFeed.hs b/Command/ImportFeed.hs index 379350c80e..6d3a1765b5 100644 --- a/Command/ImportFeed.hs +++ b/Command/ImportFeed.hs @@ -16,7 +16,9 @@ import qualified Data.Set as S import qualified Data.Map as M import Data.Time.Clock import Data.Time.Format +#if ! MIN_VERSION_time(1,5,0) import System.Locale +#endif import Common.Annex import qualified Annex diff --git a/Logs/MetaData.hs b/Logs/MetaData.hs index ed4e2363ee..0dc76214cf 100644 --- a/Logs/MetaData.hs +++ b/Logs/MetaData.hs @@ -41,12 +41,11 @@ import qualified Annex.Branch import qualified Annex import Logs import Logs.SingleValue +import Logs.TimeStamp import qualified Data.Set as S import qualified Data.Map as M import Data.Time.Clock.POSIX -import Data.Time.Format -import System.Locale instance SingleValueSerializable MetaData where serialize = Types.MetaData.serialize @@ -86,7 +85,7 @@ getCurrentMetaData k = do ts = lastchangedval l in M.map (const ts) m lastchangedval l = S.singleton $ toMetaValue $ showts $ changed l - showts = formatTime defaultTimeLocale "%F@%H-%M-%S" . posixSecondsToUTCTime + showts = formatPOSIXTime "%F@%H-%M-%S" {- Adds in some metadata, which can override existing values, or unset - them, but otherwise leaves any existing metadata as-is. -} diff --git a/Logs/TimeStamp.hs b/Logs/TimeStamp.hs index 121b766789..ca26709534 100644 --- a/Logs/TimeStamp.hs +++ b/Logs/TimeStamp.hs @@ -17,9 +17,14 @@ import System.Locale import Common +{- Parses how POSIXTime shows itself: "1431286201.113452s" + - Also handles the format with no fractional seconds. -} parsePOSIXTime :: String -> Maybe POSIXTime #if MIN_VERSION_time(1,5,0) parsePOSIXTime s = utcTimeToPOSIXSeconds <$> parseTimeM True defaultTimeLocale "%s%Qs" s #else parsePOSIXTime s = utcTimeToPOSIXSeconds <$> parseTime defaultTimeLocale "%s%Qs" s #endif + +formatPOSIXTime :: String -> POSIXTime -> String +formatPOSIXTime fmt t = formatTime defaultTimeLocale fmt (posixSecondsToUTCTime t)