touch files with high-resolution timestamp
Needs unix 2.7.2, but that was included in ghc 8.0.1 (and much older) so not really a new dep.
This commit is contained in:
parent
94b7968f1f
commit
5d97898a7c
5 changed files with 19 additions and 26 deletions
|
@ -1,6 +1,6 @@
|
|||
{- More control over touching a file.
|
||||
{- Portability shim for touching a file.
|
||||
-
|
||||
- Copyright 2011 Joey Hess <id@joeyh.name>
|
||||
- Copyright 2011-2018 Joey Hess <id@joeyh.name>
|
||||
-
|
||||
- License: BSD-2-clause
|
||||
-}
|
||||
|
@ -8,42 +8,34 @@
|
|||
{-# LANGUAGE CPP #-}
|
||||
|
||||
module Utility.Touch (
|
||||
TimeSpec(..),
|
||||
touchBoth,
|
||||
touch
|
||||
) where
|
||||
|
||||
#if ! defined(mingw32_HOST_OS)
|
||||
|
||||
#if MIN_VERSION_unix(2,7,0)
|
||||
|
||||
import System.Posix.Files
|
||||
import System.Posix.Types
|
||||
|
||||
newtype TimeSpec = TimeSpec EpochTime
|
||||
import Data.Time.Clock.POSIX
|
||||
|
||||
{- Changes the access and modification times of an existing file.
|
||||
Can follow symlinks, or not. Throws IO error on failure. -}
|
||||
touchBoth :: FilePath -> TimeSpec -> TimeSpec -> Bool -> IO ()
|
||||
touchBoth file (TimeSpec atime) (TimeSpec mtime) follow
|
||||
| follow = setFileTimes file atime mtime
|
||||
| otherwise = setSymbolicLinkTimesHiRes file (realToFrac atime) (realToFrac mtime)
|
||||
Can follow symlinks, or not. -}
|
||||
touchBoth :: FilePath -> POSIXTime -> POSIXTime -> Bool -> IO ()
|
||||
touchBoth file atime mtime follow
|
||||
| follow = setFileTimesHiRes file atime mtime
|
||||
| otherwise = setSymbolicLinkTimesHiRes file atime mtime
|
||||
|
||||
touch :: FilePath -> TimeSpec -> Bool -> IO ()
|
||||
{- Changes the access and modification times of an existing file
|
||||
- to the same value. Can follow symlinks, or not. -}
|
||||
touch :: FilePath -> POSIXTime -> Bool -> IO ()
|
||||
touch file mtime = touchBoth file mtime mtime
|
||||
|
||||
#else
|
||||
import Utility.Touch.Old
|
||||
#endif
|
||||
|
||||
#else
|
||||
|
||||
import System.PosixCompat
|
||||
|
||||
newtype TimeSpec = TimeSpec EpochTime
|
||||
import Data.Time.Clock.POSIX
|
||||
|
||||
{- Noop for Windows -}
|
||||
touchBoth :: FilePath -> TimeSpec -> TimeSpec -> Bool -> IO ()
|
||||
touchBoth :: FilePath -> POSIXTime -> POSIXTime -> Bool -> IO ()
|
||||
touchBoth _ _ _ _ = return ()
|
||||
|
||||
touch :: FilePath -> TimeSpec -> Bool -> IO ()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue