ensure directory exists when locking journal

Fixes git annex init in a bare repository that already has a git-annex
branch.
This commit is contained in:
Joey Hess 2011-11-02 15:09:19 -04:00
parent c33313c50b
commit 5f3dd3d246

View file

@ -250,10 +250,9 @@ files = withIndexUpdate $ do
setJournalFile :: FilePath -> String -> Annex () setJournalFile :: FilePath -> String -> Annex ()
setJournalFile file content = do setJournalFile file content = do
g <- gitRepo g <- gitRepo
liftIO $ catch (write g) $ const $ do liftIO $ doRedo (write g) $ do
createDirectoryIfMissing True $ gitAnnexJournalDir g createDirectoryIfMissing True $ gitAnnexJournalDir g
createDirectoryIfMissing True $ gitAnnexTmpDir g createDirectoryIfMissing True $ gitAnnexTmpDir g
write g
where where
-- journal file is written atomically -- journal file is written atomically
write g = do write g = do
@ -342,7 +341,13 @@ lockJournal a = do
bracketIO (lock file) unlock a bracketIO (lock file) unlock a
where where
lock file = do lock file = do
l <- createFile file stdFileMode l <- doRedo (createFile file stdFileMode) $
createDirectoryIfMissing True $ takeDirectory file
waitToSetLock l (WriteLock, AbsoluteSeek, 0, 0) waitToSetLock l (WriteLock, AbsoluteSeek, 0, 0)
return l return l
unlock = closeFd unlock = closeFd
{- Runs an action, catching failure and running something to fix it up, and
- retrying if necessary. -}
doRedo :: IO a -> IO b -> IO a
doRedo a b = catch a $ const $ b >> a