From 1669e80e85adc88f1fa142c7e18775c383af3692 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 29 Jan 2014 15:19:03 -0400 Subject: [PATCH] Windows: Avoid using unix-compat's rename, which refuses to rename directories. Opened a bug about this: https://github.com/jystic/unix-compat/issues/10 --- Annex/Content.hs | 1 - CmdLine/Seek.hs | 2 -- Command/Add.hs | 2 -- Command/Fix.hs | 2 -- Command/FromKey.hs | 2 -- Command/Fsck.hs | 2 -- Command/Import.hs | 2 -- Command/Indirect.hs | 1 - Command/Info.hs | 1 - Command/RecvKey.hs | 2 -- Common.hs | 2 +- Limit.hs | 1 - Test.hs | 1 - Utility/DirWatcher/Win32Notify.hs | 2 +- Utility/Directory.hs | 2 +- Utility/PosixFiles.hs | 30 ++++++++++++++++++++++++++++++ debian/changelog | 2 ++ 17 files changed, 35 insertions(+), 22 deletions(-) create mode 100644 Utility/PosixFiles.hs diff --git a/Annex/Content.hs b/Annex/Content.hs index 98603914ae..45e1fa1829 100644 --- a/Annex/Content.hs +++ b/Annex/Content.hs @@ -35,7 +35,6 @@ module Annex.Content ( ) where import System.IO.Unsafe (unsafeInterleaveIO) -import System.PosixCompat.Files import Common.Annex import Logs.Location diff --git a/CmdLine/Seek.hs b/CmdLine/Seek.hs index c3becefde4..e95b9f0059 100644 --- a/CmdLine/Seek.hs +++ b/CmdLine/Seek.hs @@ -11,8 +11,6 @@ module CmdLine.Seek where -import System.PosixCompat.Files - import Common.Annex import Types.Command import Types.Key diff --git a/Command/Add.hs b/Command/Add.hs index ffa27504a2..d1dcb6025d 100644 --- a/Command/Add.hs +++ b/Command/Add.hs @@ -9,8 +9,6 @@ module Command.Add where -import System.PosixCompat.Files - import Common.Annex import Annex.Exception import Command diff --git a/Command/Fix.hs b/Command/Fix.hs index 9339585d10..f730226e30 100644 --- a/Command/Fix.hs +++ b/Command/Fix.hs @@ -9,8 +9,6 @@ module Command.Fix where -import System.PosixCompat.Files - import Common.Annex import Command import qualified Annex.Queue diff --git a/Command/FromKey.hs b/Command/FromKey.hs index 784731ad78..7eb62fa4e0 100644 --- a/Command/FromKey.hs +++ b/Command/FromKey.hs @@ -7,8 +7,6 @@ module Command.FromKey where -import System.PosixCompat.Files - import Common.Annex import Command import qualified Annex.Queue diff --git a/Command/Fsck.hs b/Command/Fsck.hs index b20bfc8ab1..f6e4fe2733 100644 --- a/Command/Fsck.hs +++ b/Command/Fsck.hs @@ -9,8 +9,6 @@ module Command.Fsck where -import System.PosixCompat.Files - import Common.Annex import Command import qualified Annex diff --git a/Command/Import.hs b/Command/Import.hs index db0f8d3f52..db3601a1b3 100644 --- a/Command/Import.hs +++ b/Command/Import.hs @@ -7,8 +7,6 @@ module Command.Import where -import System.PosixCompat.Files - import Common.Annex import Command import qualified Annex diff --git a/Command/Indirect.hs b/Command/Indirect.hs index 0da10c5795..c0dd57959b 100644 --- a/Command/Indirect.hs +++ b/Command/Indirect.hs @@ -7,7 +7,6 @@ module Command.Indirect where -import System.PosixCompat.Files import Control.Exception.Extensible import Common.Annex diff --git a/Command/Info.hs b/Command/Info.hs index d15fbba57c..98cc49efa9 100644 --- a/Command/Info.hs +++ b/Command/Info.hs @@ -14,7 +14,6 @@ import qualified Data.Map as M import Text.JSON import Data.Tuple import Data.Ord -import System.PosixCompat.Files import Common.Annex import qualified Remote diff --git a/Command/RecvKey.hs b/Command/RecvKey.hs index 5d2a9c5aa2..1794596c57 100644 --- a/Command/RecvKey.hs +++ b/Command/RecvKey.hs @@ -7,8 +7,6 @@ module Command.RecvKey where -import System.PosixCompat.Files - import Common.Annex import Command import CmdLine diff --git a/Common.hs b/Common.hs index a6203b9a69..6612c9c544 100644 --- a/Common.hs +++ b/Common.hs @@ -15,7 +15,6 @@ import Data.String.Utils as X hiding (join) import System.FilePath as X import System.Directory as X import System.IO as X hiding (FilePath) -import System.PosixCompat.Files as X #ifndef mingw32_HOST_OS import System.Posix.IO as X #endif @@ -31,5 +30,6 @@ import Utility.Monad as X import Utility.Data as X import Utility.Applicative as X import Utility.FileSystemEncoding as X +import Utility.PosixFiles as X import Utility.PartialPrelude as X diff --git a/Limit.hs b/Limit.hs index 8250544a45..bc1705beae 100644 --- a/Limit.hs +++ b/Limit.hs @@ -13,7 +13,6 @@ import Data.Time.Clock.POSIX import qualified Data.Set as S import qualified Data.Map as M import System.Path.WildMatch -import System.PosixCompat.Files import Common.Annex import qualified Annex diff --git a/Test.hs b/Test.hs index 0d8e0e3ef8..b7f431d6cb 100644 --- a/Test.hs +++ b/Test.hs @@ -17,7 +17,6 @@ import Test.Tasty.Ingredients.Rerun import Data.Monoid import Options.Applicative hiding (command) -import System.PosixCompat.Files import Control.Exception.Extensible import qualified Data.Map as M import System.IO.HVFS (SystemFS(..)) diff --git a/Utility/DirWatcher/Win32Notify.hs b/Utility/DirWatcher/Win32Notify.hs index 27175e1c8b..ba786839c1 100644 --- a/Utility/DirWatcher/Win32Notify.hs +++ b/Utility/DirWatcher/Win32Notify.hs @@ -11,7 +11,7 @@ import Common hiding (isDirectory) import Utility.DirWatcher.Types import System.Win32.Notify -import qualified System.PosixCompat.Files as Files +import qualified Utility.PosixFiles as Files watchDir :: FilePath -> (FilePath -> Bool) -> WatchHooks -> IO WatchManager watchDir dir ignored hooks = do diff --git a/Utility/Directory.hs b/Utility/Directory.hs index 6caee7efa4..c457de6e3d 100644 --- a/Utility/Directory.hs +++ b/Utility/Directory.hs @@ -10,7 +10,6 @@ module Utility.Directory where import System.IO.Error -import System.PosixCompat.Files import System.Directory import Control.Exception (throw) import Control.Monad @@ -19,6 +18,7 @@ import System.FilePath import Control.Applicative import System.IO.Unsafe (unsafeInterleaveIO) +import Utility.PosixFiles import Utility.SafeCommand import Utility.Tmp import Utility.Exception diff --git a/Utility/PosixFiles.hs b/Utility/PosixFiles.hs new file mode 100644 index 0000000000..2c1a05a6a7 --- /dev/null +++ b/Utility/PosixFiles.hs @@ -0,0 +1,30 @@ +{- POSIX files (and compatablity wrappers). + - + - This is like System.PosixCompat.Files, except with a fixed rename. + - + - Copyright 2014 Joey Hess + - + - Licensed under the GNU GPL version 3 or higher. + -} + +{-# LANGUAGE CPP #-} + +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 System.Win32.File (moveFile) +#endif + +{- System.PosixCompat.Files.rename on Windows calls renameFile, + - so cannot rename directories. Instead, use Win32 moveFile, which can. -} +#ifdef mingw32_HOST_OS +rename :: FilePath -> FilePath -> IO () +rename = moveFile +#endif diff --git a/debian/changelog b/debian/changelog index a6c45e5b02..457e79a0ae 100644 --- a/debian/changelog +++ b/debian/changelog @@ -4,6 +4,8 @@ git-annex (5.20140128) UNRELEASED; urgency=medium on Windows; the lock files have been sorted out. * Fixed direct mode annexed content locking code, which is used to guard against recursive file drops. + * Windows: Avoid using unix-compat's rename, which refuses to rename + directories. -- Joey Hess Tue, 28 Jan 2014 13:57:19 -0400