use manifest file instead of blindly removing the whole git-annex.linux directory

FIXME: dirContentsRecursive does not find empty directories
This commit is contained in:
Joey Hess 2013-11-24 01:11:04 -04:00
parent 919a301818
commit 4776e1d7b7
2 changed files with 56 additions and 39 deletions

View file

@ -34,6 +34,7 @@ import qualified Utility.Lsof as Lsof
import qualified Data.Map as M import qualified Data.Map as M
import Data.Tuple.Utils import Data.Tuple.Utils
import Data.Ord
{- Upgrade without interaction in the webapp. -} {- Upgrade without interaction in the webapp. -}
unattendedUpgrade :: Assistant () unattendedUpgrade :: Assistant ()
@ -119,56 +120,70 @@ distributionDownloadComplete d cleanup t
-} -}
upgradeToDistribution :: GitAnnexDistribution -> Assistant () -> FilePath -> Assistant () upgradeToDistribution :: GitAnnexDistribution -> Assistant () -> FilePath -> Assistant ()
upgradeToDistribution d cleanup f = do upgradeToDistribution d cleanup f = do
#ifdef darwin_HOST_OS (program, deleteold) <- unpack
{- OS X uses a dmg, so mount it, and copy the contents into place. -} changeprogram program
error "TODO"
#else
{- Linux uses a tarball, so untar it (into a temp directory)
- and move the directory into place. -}
olddir <- parentDir <$> liftIO readProgramFile
let topdir = parentDir olddir
let newdir = topdir </> "git-annex.linux." ++ distributionVersion d
liftIO $ void $ tryIO $ removeDirectoryRecursive newdir
liftIO $ withTmpDirIn topdir "git-annex.upgrade" $ \tmpdir -> do
let tarball = tmpdir </> "tar"
-- Cannot rely on filename extension, and this also
-- avoids problems if tar doesn't support transparent
-- decompression.
void $ boolSystem "sh"
[ Param "-c"
, Param $ "zcat < " ++ shellEscape f ++
" > " ++ shellEscape tarball
]
tarok <- boolSystem "tar"
[ Param "xf"
, Param tarball
, Param "--directory", File tmpdir
]
unless tarok $
error $ "failed to untar " ++ f
let unpacked = tmpdir </> "git-annex.linux"
unlessM (doesDirectoryExist unpacked) $
error $ "did not find git-annex.linux in " ++ f
renameDirectory unpacked newdir
changeprogram $ newdir </> "git-annex"
cleanup cleanup
prepUpgrade prepUpgrade
url <- runRestart url <- runRestart
{- At this point, the new assistant is fully running, so {- At this point, the new assistant is fully running, so
- it's safe to delete the old version. To make sure we don't - it's safe to delete the old version. -}
- delete something we shouldn't, only delete it if liftIO deleteold
- "git-annex.linux" is in the name.
- This could fail, if the user cannot write to it (unlikely) -}
liftIO $ when ("git-annex.linux" `isPrefixOf` takeFileName olddir) $
void $ removeDirectoryRecursive olddir
postUpgrade url postUpgrade url
#endif
where where
changeprogram program = liftIO $ do changeprogram program = liftIO $ do
unlessM (boolSystem program [Param "version"]) $ unlessM (boolSystem program [Param "version"]) $
error "New git-annex program failed to run! Not using." error "New git-annex program failed to run! Not using."
pf <- programFile pf <- programFile
liftIO $ writeFile pf program liftIO $ writeFile pf program
#ifdef darwin_HOST_OS
{- OS X uses a dmg, so mount it, and copy the contents into place. -}
unpack = do
error "TODO OSX upgrade code"
#else
{- Linux uses a tarball (so could other POSIX systems), so
- untar it (into a temp directory) and move the directory
- into place. -}
unpack = liftIO $ do
olddir <- parentDir <$> readProgramFile
let topdir = parentDir olddir
let newdir = topdir </> "git-annex.linux." ++ distributionVersion d
whenM (doesDirectoryExist newdir) $
error $ "upgrade destination directory " ++ newdir ++ "already exists; not overwriting"
withTmpDirIn topdir "git-annex.upgrade" $ \tmpdir -> do
let tarball = tmpdir </> "tar"
-- Cannot rely on filename extension, and this also
-- avoids problems if tar doesn't support transparent
-- decompression.
void $ boolSystem "sh"
[ Param "-c"
, Param $ "zcat < " ++ shellEscape f ++
" > " ++ shellEscape tarball
]
tarok <- boolSystem "tar"
[ Param "xf"
, Param tarball
, Param "--directory", File tmpdir
]
unless tarok $
error $ "failed to untar " ++ f
let unpacked = tmpdir </> "git-annex.linux"
unlessM (doesDirectoryExist unpacked) $
error $ "did not find git-annex.linux in " ++ f
renameDirectory unpacked newdir
return (newdir </> "git-annex", deleteFromManifest olddir)
#endif
deleteFromManifest :: FilePath -> IO ()
deleteFromManifest dir = do
fs <- map (dir </>) . lines <$> catchDefaultIO "" (readFile manifest)
mapM_ nukeFile fs
nukeFile manifest
mapM_ nukedir =<< sortBy (comparing length) <$> dirContentsRecursive dir
nukedir dir
where
manifest = dir </> "git-annex.MANIFEST"
nukedir = void . tryIO . removeDirectory
{- This is a file that the UpgradeWatcher can watch for modifications to {- This is a file that the UpgradeWatcher can watch for modifications to
- detect when git-annex has been upgraded. - detect when git-annex has been upgraded.

View file

@ -134,6 +134,7 @@ linuxstandalone: Build/Standalone
rm -f "$(LINUXSTANDALONE_DEST)/libdirs.tmp" rm -f "$(LINUXSTANDALONE_DEST)/libdirs.tmp"
cd tmp/git-annex.linux && find . -type f > git-annex.MANIFEST cd tmp/git-annex.linux && find . -type f > git-annex.MANIFEST
cd tmp/git-annex.linux && find . -type l >> git-annex.MANIFEST
cd tmp && tar czf git-annex-standalone-$(shell dpkg --print-architecture).tar.gz git-annex.linux cd tmp && tar czf git-annex-standalone-$(shell dpkg --print-architecture).tar.gz git-annex.linux
OSXAPP_DEST=tmp/build-dmg/git-annex.app OSXAPP_DEST=tmp/build-dmg/git-annex.app
@ -159,6 +160,7 @@ osxapp: Build/Standalone Build/OSXMkLibs
./Build/OSXMkLibs $(OSXAPP_BASE) ./Build/OSXMkLibs $(OSXAPP_BASE)
cd $(OSXAPP_DEST) && find . -type f > Contents/MacOS/bundle/git-annex.MANIFEST cd $(OSXAPP_DEST) && find . -type f > Contents/MacOS/bundle/git-annex.MANIFEST
cd $(OSXAPP_DEST) && find . -type l >> Contents/MacOS/bundle/git-annex.MANIFEST
rm -f tmp/git-annex.dmg rm -f tmp/git-annex.dmg
hdiutil create -format UDBZ -srcfolder tmp/build-dmg \ hdiutil create -format UDBZ -srcfolder tmp/build-dmg \
-volname git-annex -o tmp/git-annex.dmg -volname git-annex -o tmp/git-annex.dmg