gcrypt: Remove empty hash directories when dropping content
As was recently done with the directory special remote. Note that the top directory passed to removeDirGeneric was changed to avoid deleting .git/annex or .git/annex/objects if they ended up empty. Sponsored-by: Brett Eisenberg on Patreon
This commit is contained in:
parent
3b34266e9e
commit
2807ab0a09
2 changed files with 7 additions and 4 deletions
|
@ -22,7 +22,7 @@ git-annex (10.20230627) UNRELEASED; urgency=medium
|
||||||
* S3: Allow setting publicurl=yes without public=yes, to support
|
* S3: Allow setting publicurl=yes without public=yes, to support
|
||||||
buckets that are configured with a Bucket Policy that allows public
|
buckets that are configured with a Bucket Policy that allows public
|
||||||
access.
|
access.
|
||||||
* directory: Remove empty hash directories when dropping content.
|
* directory, gcrypt: Remove empty hash directories when dropping content.
|
||||||
* dropunused: Support --jobs
|
* dropunused: Support --jobs
|
||||||
|
|
||||||
-- Joey Hess <id@joeyh.name> Mon, 26 Jun 2023 13:10:40 -0400
|
-- Joey Hess <id@joeyh.name> Mon, 26 Jun 2023 13:10:40 -0400
|
||||||
|
|
|
@ -439,8 +439,8 @@ remove r rsyncopts accessmethod k = do
|
||||||
remove' :: Git.Repo -> Remote -> Remote.Rsync.RsyncOpts -> AccessMethod -> Remover
|
remove' :: Git.Repo -> Remote -> Remote.Rsync.RsyncOpts -> AccessMethod -> Remover
|
||||||
remove' repo r rsyncopts accessmethod k
|
remove' repo r rsyncopts accessmethod k
|
||||||
| not $ Git.repoIsUrl repo = guardUsable repo (giveup "cannot access remote") $
|
| not $ Git.repoIsUrl repo = guardUsable repo (giveup "cannot access remote") $
|
||||||
liftIO $ Remote.Directory.removeDirGeneric False
|
liftIO $ Remote.Directory.removeDirGeneric True
|
||||||
(fromRawFilePath (Git.repoPath repo))
|
(gCryptTopDir repo)
|
||||||
(fromRawFilePath (parentDir (toRawFilePath (gCryptLocation repo k))))
|
(fromRawFilePath (parentDir (toRawFilePath (gCryptLocation repo k))))
|
||||||
| Git.repoIsSsh repo = shellOrRsync r removeshell removersync
|
| Git.repoIsSsh repo = shellOrRsync r removeshell removersync
|
||||||
| accessmethod == AccessRsyncOverSsh = removersync
|
| accessmethod == AccessRsyncOverSsh = removersync
|
||||||
|
@ -466,10 +466,13 @@ checkKey' repo r rsyncopts accessmethod k
|
||||||
checkrsync = Remote.Rsync.checkKey rsyncopts k
|
checkrsync = Remote.Rsync.checkKey rsyncopts k
|
||||||
checkshell = Ssh.inAnnex repo k
|
checkshell = Ssh.inAnnex repo k
|
||||||
|
|
||||||
|
gCryptTopDir :: Git.Repo -> FilePath
|
||||||
|
gCryptTopDir repo = Git.repoLocation repo </> fromRawFilePath objectDir
|
||||||
|
|
||||||
{- Annexed objects are hashed using lower-case directories for max
|
{- Annexed objects are hashed using lower-case directories for max
|
||||||
- portability. -}
|
- portability. -}
|
||||||
gCryptLocation :: Git.Repo -> Key -> FilePath
|
gCryptLocation :: Git.Repo -> Key -> FilePath
|
||||||
gCryptLocation repo key = Git.repoLocation repo </> fromRawFilePath objectDir
|
gCryptLocation repo key = gCryptTopDir repo
|
||||||
</> fromRawFilePath (keyPath key (hashDirLower def))
|
</> fromRawFilePath (keyPath key (hashDirLower def))
|
||||||
|
|
||||||
data AccessMethod = AccessRsyncOverSsh | AccessGitAnnexShell
|
data AccessMethod = AccessRsyncOverSsh | AccessGitAnnexShell
|
||||||
|
|
Loading…
Reference in a new issue