diff --git a/Annex/RepoSize.hs b/Annex/RepoSize.hs index 680a6e897b..5bd089299d 100644 --- a/Annex/RepoSize.hs +++ b/Annex/RepoSize.hs @@ -138,11 +138,18 @@ calcJournalledRepoSizes -> M.Map UUID RepoSize -> Sha -> Annex (M.Map UUID (RepoSize, SizeOffset)) -calcJournalledRepoSizes h startmap branchsha = +calcJournalledRepoSizes h startmap branchsha -- Lock the journal to prevent updates to the size offsets -- in the repository size database while this is processing -- the journal files. - lockJournal $ \_jl -> do + | Db.isOpenDb h = lockJournal $ \_jl -> go + -- When the repository is not writable, the database won't have + -- been opened, and locking the journal would also not succeed. + -- But there is no need to lock the journal in this case, + -- since no offsets will be read from the database. + | otherwise = go + where + go = do sizemap <- overLocationLogsJournal startmap branchsha (\k v m' -> pure (accumRepoSizes k v m')) Nothing diff --git a/Database/RepoSize.hs b/Database/RepoSize.hs index 73a1d06700..20de270442 100644 --- a/Database/RepoSize.hs +++ b/Database/RepoSize.hs @@ -23,6 +23,7 @@ module Database.RepoSize ( getRepoSizeHandle, openDb, closeDb, + isOpenDb, lockDbWhile, getRepoSizes, setRepoSizes, @@ -126,6 +127,13 @@ openDb = lockDbWhile permerr $ do -- efficiently. permerr _e = mkhandle Nothing +-- When the repository cannot be written to, openDb returns a +-- RepoSizeHandle that is not actually open, all operations on it will do +-- nothing. +isOpenDb :: RepoSizeHandle -> Bool +isOpenDb (RepoSizeHandle (Just _) _) = True +isOpenDb (RepoSizeHandle Nothing _) = False + closeDb :: RepoSizeHandle -> Annex () closeDb (RepoSizeHandle (Just h) _) = liftIO $ H.closeDb h closeDb (RepoSizeHandle Nothing _) = noop