use unix-compat 0.5 on windows
That version has my patches for the problems that Utility.PosixFiles was working around, so am able to get rid of that module now. This will later allow bringing back the custom-setup stanza in the cabal file. It will need to depend on unix-compat 0.5 on all OS's, which I'm not ready to do yet. This commit was sponsored by Nick Daly on Patreon.
This commit is contained in:
parent
0f150a054b
commit
3ec579f5e1
9 changed files with 12 additions and 51 deletions
|
@ -50,6 +50,7 @@ module Annex.Content (
|
||||||
) where
|
) where
|
||||||
|
|
||||||
import System.IO.Unsafe (unsafeInterleaveIO)
|
import System.IO.Unsafe (unsafeInterleaveIO)
|
||||||
|
import System.PosixCompat.Files
|
||||||
import qualified Data.Set as S
|
import qualified Data.Set as S
|
||||||
|
|
||||||
import Annex.Common
|
import Annex.Common
|
||||||
|
@ -84,7 +85,6 @@ import Types.Key
|
||||||
import Annex.UUID
|
import Annex.UUID
|
||||||
import Annex.InodeSentinal
|
import Annex.InodeSentinal
|
||||||
import Utility.InodeCache
|
import Utility.InodeCache
|
||||||
import Utility.PosixFiles
|
|
||||||
|
|
||||||
{- Checks if a given key's content is currently present. -}
|
{- Checks if a given key's content is currently present. -}
|
||||||
inAnnex :: Key -> Annex Bool
|
inAnnex :: Key -> Annex Bool
|
||||||
|
|
|
@ -15,11 +15,11 @@ import qualified Git.BuildVersion
|
||||||
import Utility.Path
|
import Utility.Path
|
||||||
import Utility.SafeCommand
|
import Utility.SafeCommand
|
||||||
import Utility.Directory
|
import Utility.Directory
|
||||||
import Utility.PosixFiles
|
|
||||||
import Utility.Exception
|
import Utility.Exception
|
||||||
|
|
||||||
import System.IO
|
import System.IO
|
||||||
import System.FilePath
|
import System.FilePath
|
||||||
|
import System.PosixCompat.Files
|
||||||
import Data.List
|
import Data.List
|
||||||
import Control.Monad
|
import Control.Monad
|
||||||
import Control.Monad.IfElse
|
import Control.Monad.IfElse
|
||||||
|
|
|
@ -18,6 +18,7 @@ import System.IO as X hiding (FilePath)
|
||||||
import System.Posix.IO as X hiding (createPipe)
|
import System.Posix.IO as X hiding (createPipe)
|
||||||
#endif
|
#endif
|
||||||
import System.Exit as X
|
import System.Exit as X
|
||||||
|
import System.PosixCompat.Files as X hiding (fileSize)
|
||||||
|
|
||||||
import Utility.Misc as X
|
import Utility.Misc as X
|
||||||
import Utility.Exception as X
|
import Utility.Exception as X
|
||||||
|
@ -28,7 +29,6 @@ import Utility.Directory as X
|
||||||
import Utility.Monad as X
|
import Utility.Monad as X
|
||||||
import Utility.Data as X
|
import Utility.Data as X
|
||||||
import Utility.Applicative as X
|
import Utility.Applicative as X
|
||||||
import Utility.PosixFiles as X hiding (fileSize)
|
|
||||||
import Utility.FileSize as X
|
import Utility.FileSize as X
|
||||||
import Utility.Network as X
|
import Utility.Network as X
|
||||||
import Utility.Split as X
|
import Utility.Split as X
|
||||||
|
|
|
@ -11,7 +11,7 @@ import Common hiding (isDirectory)
|
||||||
import Utility.DirWatcher.Types
|
import Utility.DirWatcher.Types
|
||||||
|
|
||||||
import System.Win32.Notify
|
import System.Win32.Notify
|
||||||
import qualified Utility.PosixFiles as Files
|
import qualified System.PosixCompat.Files as Files
|
||||||
|
|
||||||
watchDir :: FilePath -> (FilePath -> Bool) -> Bool -> WatchHooks -> IO WatchManager
|
watchDir :: FilePath -> (FilePath -> Bool) -> Bool -> WatchHooks -> IO WatchManager
|
||||||
watchDir dir ignored scanevents hooks = do
|
watchDir dir ignored scanevents hooks = do
|
||||||
|
|
|
@ -16,6 +16,7 @@ module Utility.Directory (
|
||||||
import System.IO.Error
|
import System.IO.Error
|
||||||
import Control.Monad
|
import Control.Monad
|
||||||
import System.FilePath
|
import System.FilePath
|
||||||
|
import System.PosixCompat.Files
|
||||||
import Control.Applicative
|
import Control.Applicative
|
||||||
import Control.Concurrent
|
import Control.Concurrent
|
||||||
import System.IO.Unsafe (unsafeInterleaveIO)
|
import System.IO.Unsafe (unsafeInterleaveIO)
|
||||||
|
@ -31,7 +32,6 @@ import Control.Monad.IfElse
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
import Utility.SystemDirectory
|
import Utility.SystemDirectory
|
||||||
import Utility.PosixFiles
|
|
||||||
import Utility.Tmp
|
import Utility.Tmp
|
||||||
import Utility.Exception
|
import Utility.Exception
|
||||||
import Utility.Monad
|
import Utility.Monad
|
||||||
|
|
|
@ -15,7 +15,7 @@ module Utility.FileMode (
|
||||||
import System.IO
|
import System.IO
|
||||||
import Control.Monad
|
import Control.Monad
|
||||||
import System.PosixCompat.Types
|
import System.PosixCompat.Types
|
||||||
import Utility.PosixFiles
|
import System.PosixCompat.Files
|
||||||
#ifndef mingw32_HOST_OS
|
#ifndef mingw32_HOST_OS
|
||||||
import System.Posix.Files
|
import System.Posix.Files
|
||||||
import Control.Monad.IO.Class (liftIO)
|
import Control.Monad.IO.Class (liftIO)
|
||||||
|
|
|
@ -1,42 +0,0 @@
|
||||||
{- POSIX files (and compatablity wrappers).
|
|
||||||
-
|
|
||||||
- This is like System.PosixCompat.Files, but with a few fixes.
|
|
||||||
-
|
|
||||||
- Copyright 2014 Joey Hess <id@joeyh.name>
|
|
||||||
-
|
|
||||||
- License: BSD-2-clause
|
|
||||||
-}
|
|
||||||
|
|
||||||
{-# LANGUAGE CPP #-}
|
|
||||||
{-# OPTIONS_GHC -fno-warn-tabs #-}
|
|
||||||
|
|
||||||
module Utility.PosixFiles (
|
|
||||||
module X,
|
|
||||||
rename
|
|
||||||
) where
|
|
||||||
|
|
||||||
import System.PosixCompat.Files as X hiding (rename)
|
|
||||||
|
|
||||||
#ifndef mingw32_HOST_OS
|
|
||||||
import System.Posix.Files (rename)
|
|
||||||
#else
|
|
||||||
import qualified System.Win32.File as Win32
|
|
||||||
import qualified System.Win32.HardLink as Win32
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{- System.PosixCompat.Files.rename on Windows calls renameFile,
|
|
||||||
- so cannot rename directories.
|
|
||||||
-
|
|
||||||
- Instead, use Win32 moveFile, which can. It needs to be told to overwrite
|
|
||||||
- any existing file. -}
|
|
||||||
#ifdef mingw32_HOST_OS
|
|
||||||
rename :: FilePath -> FilePath -> IO ()
|
|
||||||
rename src dest = Win32.moveFileEx src dest Win32.mOVEFILE_REPLACE_EXISTING
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{- System.PosixCompat.Files.createLink throws an error, but windows
|
|
||||||
- does support hard links. -}
|
|
||||||
#ifdef mingw32_HOST_OS
|
|
||||||
createLink :: FilePath -> FilePath -> IO ()
|
|
||||||
createLink = Win32.createHardLink
|
|
||||||
#endif
|
|
|
@ -15,13 +15,13 @@ import Control.Monad.IfElse
|
||||||
import System.FilePath
|
import System.FilePath
|
||||||
import System.Directory
|
import System.Directory
|
||||||
import Control.Monad.IO.Class
|
import Control.Monad.IO.Class
|
||||||
|
import System.PosixCompat.Files
|
||||||
#ifndef mingw32_HOST_OS
|
#ifndef mingw32_HOST_OS
|
||||||
import System.Posix.Temp (mkdtemp)
|
import System.Posix.Temp (mkdtemp)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
import Utility.Exception
|
import Utility.Exception
|
||||||
import Utility.FileSystemEncoding
|
import Utility.FileSystemEncoding
|
||||||
import Utility.PosixFiles
|
|
||||||
|
|
||||||
type Template = String
|
type Template = String
|
||||||
|
|
||||||
|
|
|
@ -380,7 +380,11 @@ Executable git-annex
|
||||||
Build-Depends: network (< 2.6), network (>= 2.4)
|
Build-Depends: network (< 2.6), network (>= 2.4)
|
||||||
|
|
||||||
if (os(windows))
|
if (os(windows))
|
||||||
Build-Depends: Win32 (== 2.3.1.1), Win32-extras, unix-compat (>= 0.4.1.3), setenv,
|
Build-Depends:
|
||||||
|
Win32 (== 2.3.1.1),
|
||||||
|
Win32-extras,
|
||||||
|
unix-compat (>= 0.5),
|
||||||
|
setenv,
|
||||||
process (>= 1.4.2.0)
|
process (>= 1.4.2.0)
|
||||||
else
|
else
|
||||||
Build-Depends: unix
|
Build-Depends: unix
|
||||||
|
@ -1026,7 +1030,6 @@ Executable git-annex
|
||||||
Utility.PartialPrelude
|
Utility.PartialPrelude
|
||||||
Utility.Path
|
Utility.Path
|
||||||
Utility.Percentage
|
Utility.Percentage
|
||||||
Utility.PosixFiles
|
|
||||||
Utility.Process
|
Utility.Process
|
||||||
Utility.Process.Shim
|
Utility.Process.Shim
|
||||||
Utility.QuickCheck
|
Utility.QuickCheck
|
||||||
|
|
Loading…
Reference in a new issue