LIB: restructure copyDir
This commit is contained in:
parent
0f1c8dafe8
commit
51fffabe22
@ -101,7 +101,22 @@ copyDir cm from@(Dir fn _ _, _) to@(Dir {}, _) = do
|
||||
dirSanityThrow top
|
||||
throwDestinationInSource fromp top
|
||||
|
||||
-- what to do with target directory
|
||||
createDestdir destdir
|
||||
|
||||
newDest <- zipLazy mkDirInfo mkFileInfo destdir
|
||||
|
||||
for_ (goAllDown from) $ \f ->
|
||||
-- TODO: maybe do this strict?
|
||||
case f of
|
||||
-- recreate symlink
|
||||
sz@(Dir { name = n, dir = (DirInfo { sym = True }) }, _) ->
|
||||
recreateSymlink newDest n sz
|
||||
sz@(Dir {}, _) ->
|
||||
copyDir cm sz newDest
|
||||
sz@(File {}, _) ->
|
||||
copyFileToDir sz newDest
|
||||
where
|
||||
createDestdir destdir =
|
||||
case cm of
|
||||
Merge ->
|
||||
createDirectoryIfMissing False destdir
|
||||
@ -111,29 +126,18 @@ copyDir cm from@(Dir fn _ _, _) to@(Dir {}, _) = do
|
||||
Replace -> do
|
||||
whenM (doesDirectoryExist destdir) (removeDirectoryRecursive destdir)
|
||||
createDirectory destdir
|
||||
|
||||
newDest <- zipLazy mkDirInfo mkFileInfo destdir
|
||||
|
||||
for_ (goAllDown from) $ \f ->
|
||||
-- TODO: maybe do this strict?
|
||||
case f of
|
||||
-- recreate symlink
|
||||
sz@(Dir { name = n, dir = (DirInfo { sym = True }) }, _) -> do
|
||||
recreateSymlink newDest n sz = do
|
||||
let sympoint = getFullPath newDest </> n
|
||||
|
||||
-- delete old file/dir to be able to create symlink
|
||||
case cm of
|
||||
Merge ->
|
||||
-- delete old file/dir to be able to create symlink
|
||||
for_ (goDown n newDest) $ \odtz ->
|
||||
easyDelete odtz
|
||||
_ -> return ()
|
||||
|
||||
symname <- readSymbolicLink (getFullPath sz)
|
||||
createSymbolicLink symname sympoint
|
||||
sz@(Dir {}, _) ->
|
||||
copyDir cm sz newDest
|
||||
sz@(File {}, _) ->
|
||||
copyFileToDir sz newDest
|
||||
|
||||
copyDir _ from@(File _ _, _) _ = throw $ NotADir (getFullPath from)
|
||||
copyDir _ _ to@(File _ _, _) = throw $ NotADir (getFullPath to)
|
||||
|
Loading…
Reference in New Issue
Block a user