summaryrefslogtreecommitdiff
path: root/Command/Migrate.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2012-02-16 16:36:35 -0400
committerGravatar Joey Hess <joey@kitenet.net>2012-02-16 16:36:35 -0400
commitdb6b4cdfcf67cfc3fce5e5f4323aa96a6ebd3e59 (patch)
treea65a129d7289b400e1b558e7b6d3c19eefd54f76 /Command/Migrate.hs
parentaeaaa0ff87e22c3a5b4c9657544224c9db006cde (diff)
rekey: New plumbing level command, can be used to change the keys used for files en masse.
Diffstat (limited to 'Command/Migrate.hs')
-rw-r--r--Command/Migrate.hs39
1 files changed, 22 insertions, 17 deletions
diff --git a/Command/Migrate.hs b/Command/Migrate.hs
index c6b0f086c..795ecc265 100644
--- a/Command/Migrate.hs
+++ b/Command/Migrate.hs
@@ -58,22 +58,27 @@ perform file oldkey newbackend = do
cleantmp tmpfile
case k of
Nothing -> stop
- Just (newkey, _) -> stopUnless (link src newkey) $ do
- -- Update symlink to use the new key.
- liftIO $ removeFile file
-
- -- If the old key had some
- -- associated urls, record them for
- -- the new key as well.
- urls <- getUrls oldkey
- unless (null urls) $
- mapM_ (setUrlPresent newkey) urls
-
- next $ Command.Add.cleanup file newkey True
+ Just (newkey, _) -> stopUnless (linkKey src newkey) $
+ next $ cleanup file oldkey newkey
where
cleantmp t = liftIO $ whenM (doesFileExist t) $ removeFile t
- link src newkey = getViaTmpUnchecked newkey $ \t -> do
- -- Make a hard link to the old backend's
- -- cached key, to avoid wasting disk space.
- liftIO $ unlessM (doesFileExist t) $ createLink src t
- return True
+
+linkKey :: FilePath -> Key -> Annex Bool
+linkKey src newkey = getViaTmpUnchecked newkey $ \t -> do
+ -- Make a hard link to the old backend's
+ -- cached key, to avoid wasting disk space.
+ liftIO $ unlessM (doesFileExist t) $ createLink src t
+ return True
+
+cleanup :: FilePath -> Key -> Key -> CommandCleanup
+cleanup file oldkey newkey = do
+ -- Update symlink to use the new key.
+ liftIO $ removeFile file
+
+ -- If the old key had some associated urls, record them for
+ -- the new key as well.
+ urls <- getUrls oldkey
+ unless (null urls) $
+ mapM_ (setUrlPresent newkey) urls
+
+ Command.Add.cleanup file newkey True