2010-11-18 17:48:28 +00:00
|
|
|
{- git-annex file copying
|
|
|
|
-
|
|
|
|
- Copyright 2010 Joey Hess <joey@kitenet.net>
|
|
|
|
-
|
|
|
|
- Licensed under the GNU GPL version 3 or higher.
|
|
|
|
-}
|
|
|
|
|
|
|
|
module CopyFile (copyFile) where
|
|
|
|
|
2011-01-05 02:17:18 +00:00
|
|
|
import Control.Monad (when)
|
|
|
|
import System.Directory (doesFileExist, removeFile)
|
|
|
|
|
2010-11-18 17:48:28 +00:00
|
|
|
import Utility
|
|
|
|
import qualified SysConfig
|
|
|
|
|
|
|
|
{- The cp command is used, because I hate reinventing the wheel,
|
|
|
|
- and because this allows easy access to features like cp --reflink. -}
|
|
|
|
copyFile :: FilePath -> FilePath -> IO Bool
|
2011-01-05 02:17:18 +00:00
|
|
|
copyFile src dest = do
|
|
|
|
e <- doesFileExist dest
|
|
|
|
when e $
|
|
|
|
removeFile dest
|
|
|
|
boolSystem "cp" opts
|
2010-11-18 17:48:28 +00:00
|
|
|
where
|
2010-11-22 19:46:57 +00:00
|
|
|
opts = if SysConfig.cp_reflink_auto
|
2011-02-25 05:13:01 +00:00
|
|
|
then ["--reflink=auto", src', dest']
|
2010-11-22 19:46:57 +00:00
|
|
|
else if SysConfig.cp_a
|
2011-02-25 05:13:01 +00:00
|
|
|
then ["-a", src', dest']
|
2010-11-22 19:46:57 +00:00
|
|
|
else if SysConfig.cp_p
|
2011-02-25 05:13:01 +00:00
|
|
|
then ["-p", src', dest']
|
|
|
|
else [src', dest']
|
|
|
|
src' = utilityEscape src
|
|
|
|
dest' = utilityEscape dest
|