LIB/GTK: remove the rest of the directory package

This commit is contained in:
Julian Ospald 2015-12-27 19:26:58 +01:00
parent aba62f03f2
commit 54af33f3a7
No known key found for this signature in database
GPG Key ID: 220CD1C5BDEED020
6 changed files with 55 additions and 47 deletions

View File

@ -28,10 +28,10 @@ library
MyPrelude MyPrelude
build-depends: base >= 4.7, build-depends: base >= 4.7,
bytestring,
data-default, data-default,
bifunctors >= 5, bifunctors >= 5,
containers, containers,
directory >= 1.1.0.0 && < 1.2.3.0,
filepath >= 1.3.0.0, filepath >= 1.3.0.0,
hinotify, hinotify,
mtl >= 2.2, mtl >= 2.2,
@ -63,13 +63,13 @@ executable hsfm-gtk
build-depends: hsfm, build-depends: hsfm,
base >= 4.7, base >= 4.7,
bytestring,
Cabal >= 1.22.0.0, Cabal >= 1.22.0.0,
containers, containers,
data-default, data-default,
gtk3 >= 0.14.1, gtk3 >= 0.14.1,
glib >= 0.13, glib >= 0.13,
bifunctors >= 5, bifunctors >= 5,
directory >= 1.1.0.0 && < 1.2.3.0,
filepath >= 1.3.0.0, filepath >= 1.3.0.0,
hinotify, hinotify,
mtl >= 2.2, mtl >= 2.2,

View File

@ -86,10 +86,6 @@ import Safe
atDef atDef
, initDef , initDef
) )
import System.Directory
(
canonicalizePath
)
import System.FilePath import System.FilePath
( (
combine combine
@ -605,18 +601,6 @@ normalize fp =
ff x y = x ++ [y] ff x y = x ++ [y]
-- |Like `canonicalizePath` from System.Directory, but preserves the last
-- component if it's a symlink.
canonicalizePath' :: FilePath -> IO FilePath
canonicalizePath' fp = do
-- TODO: throw fileDoesNotExist error earlier
isSymlink <- PF.isSymbolicLink <$> PF.getSymbolicLinkStatus fp
if isSymlink
then do
cbase <- canonicalizePath (baseDir fp)
return $ cbase </> topDir fp
else canonicalizePath fp
---- IO HELPERS: ---- ---- IO HELPERS: ----

View File

@ -88,11 +88,6 @@ import Safe
( (
headDef headDef
) )
import System.Directory
(
doesFileExist
, doesDirectoryExist
)
import System.Environment import System.Environment
( (
getArgs getArgs

View File

@ -57,11 +57,6 @@ import GUI.Gtk.Utils
import IO.Error import IO.Error
import IO.File import IO.File
import IO.Utils import IO.Utils
import System.Directory
(
doesFileExist
, doesDirectoryExist
)
import System.FilePath import System.FilePath
( (
isAbsolute isAbsolute

View File

@ -45,11 +45,6 @@ import Foreign.C.Error
, Errno , Errno
) )
import IO.Utils import IO.Utils
import System.Directory
(
doesDirectoryExist
, doesFileExist
)
import System.FilePath import System.FilePath
( (
equalFilePath equalFilePath
@ -151,3 +146,26 @@ catchErrno en a1 a2 =
if errno == en if errno == en
then a2 then a2
else ioError e else ioError e
handleIOError :: (IOError -> IO a) -> IO a -> IO a
handleIOError a1 a2 = catchIOError a2 a1
-- |Checks if the given file exists and is not a directory. This follows
-- symlinks, but will return True if the symlink is broken.
doesFileExist :: FilePath -> IO Bool
doesFileExist fp =
handleIOError (\_ -> return False) $ do
fs <- catchIOError (PF.getFileStatus fp) $ \_ ->
PF.getSymbolicLinkStatus fp
return $ not . PF.isDirectory $ fs
-- |Checks if the given file exists and is a directory. This follows
-- symlinks, but will return False if the symlink is broken.
doesDirectoryExist :: FilePath -> IO Bool
doesDirectoryExist fp =
handleIOError (\_ -> return False) $ do
fs <- PF.getFileStatus fp
return $ PF.isDirectory fs

View File

@ -48,11 +48,6 @@ import Foreign.C.Error
) )
import IO.Error import IO.Error
import IO.Utils import IO.Utils
import System.Directory
(
doesDirectoryExist
, removeDirectoryRecursive
)
import System.FilePath import System.FilePath
( (
(</>) (</>)
@ -65,7 +60,9 @@ import System.Posix.Directory
import System.Posix.Files import System.Posix.Files
( (
createSymbolicLink createSymbolicLink
, fileMode
, readSymbolicLink , readSymbolicLink
, getSymbolicLinkStatus
, groupExecuteMode , groupExecuteMode
, groupReadMode , groupReadMode
, groupWriteMode , groupWriteMode
@ -94,7 +91,7 @@ import System.Process
, ProcessHandle , ProcessHandle
) )
import qualified System.Directory as SD import qualified Data.ByteString as BS
@ -191,7 +188,8 @@ copyDir cm from@(_ :/ Dir fromn _)
throwDirDoesExist destdir throwDirDoesExist destdir
createDirectory destdir newDirPerms createDirectory destdir newDirPerms
Replace -> do Replace -> do
whenM (doesDirectoryExist destdir) (removeDirectoryRecursive destdir) whenM (doesDirectoryExist destdir)
(deleteDirRecursive =<< Data.DirTree.readFile destdir)
createDirectory destdir newDirPerms createDirectory destdir newDirPerms
recreateSymlink' f destdir = do recreateSymlink' f destdir = do
let destfilep = fullPath destdir </> (name . file $ f) let destfilep = fullPath destdir </> (name . file $ f)
@ -219,6 +217,19 @@ recreateSymlink symf@(_ :/ SymLink {})
recreateSymlink _ _ = throw $ InvalidOperation "wrong input type" recreateSymlink _ _ = throw $ InvalidOperation "wrong input type"
-- |TODO: handle EAGAIN exception for non-blocking IO
-- |Low-level function to copy a given file to the given path. The fileMode
-- is preserved.
copyFile' :: FilePath -> FilePath -> IO ()
copyFile' from to = do
fromFstatus <- getSymbolicLinkStatus from
fromContent <- BS.readFile from
fd <- System.Posix.IO.createFile to
(System.Posix.Files.fileMode fromFstatus)
closeFd fd
BS.writeFile to fromContent
-- |Copies the given file to the given file destination. -- |Copies the given file to the given file destination.
-- Excludes symlinks. -- Excludes symlinks.
copyFile :: AnchoredFile FileInfo -- ^ source file copyFile :: AnchoredFile FileInfo -- ^ source file
@ -229,7 +240,7 @@ copyFile from@(_ :/ RegFile {}) to@(_ :/ RegFile {}) = do
let from' = fullPath from let from' = fullPath from
to' = fullPath to to' = fullPath to
throwSameFile from' to' throwSameFile from' to'
SD.copyFile from' to' copyFile' from' to'
copyFile _ _ = throw $ InvalidOperation "wrong input type" copyFile _ _ = throw $ InvalidOperation "wrong input type"
@ -244,7 +255,7 @@ copyFileToDir from@(_ :/ RegFile fn _)
do do
let from' = fullPath from let from' = fullPath from
to' = fullPath to </> fn to' = fullPath to </> fn
SD.copyFile from' to' copyFile' from' to'
copyFileToDir _ _ = throw $ InvalidOperation "wrong input type" copyFileToDir _ _ = throw $ InvalidOperation "wrong input type"
@ -298,11 +309,17 @@ deleteDir f@(_ :/ Dir {})
deleteDir _ = throw $ InvalidOperation "wrong input type" deleteDir _ = throw $ InvalidOperation "wrong input type"
-- |Deletes the given directory recursively, never symlinks. -- |Deletes the given directory recursively.
deleteDirRecursive :: AnchoredFile FileInfo -> IO () deleteDirRecursive :: AnchoredFile FileInfo -> IO ()
deleteDirRecursive (_ :/ SymLink {}) = return () deleteDirRecursive f@(_ :/ Dir {}) = do
deleteDirRecursive f@(_ :/ Dir {}) let fp = fullPath f
= removeDirectoryRecursive (fullPath f) files <- readDirectory' fp
for_ files $ \file ->
case file of
(_ :/ SymLink {}) -> deleteSymlink file
(_ :/ Dir {}) -> deleteDirRecursive file
(_ :/ f) -> removeLink (fullPath file)
removeDirectory fp
deleteDirRecursive _ = throw $ InvalidOperation "wrong input type" deleteDirRecursive _ = throw $ InvalidOperation "wrong input type"
@ -422,4 +439,3 @@ newDirPerms
`unionFileModes` groupReadMode `unionFileModes` groupReadMode
`unionFileModes` otherExecuteMode `unionFileModes` otherExecuteMode
`unionFileModes` otherReadMode `unionFileModes` otherReadMode