diff options
author | Joey Hess <joey@kitenet.net> | 2013-01-18 12:20:08 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2013-01-18 12:20:08 -0400 |
commit | 72445900116cfce9daa8841097096db3b64a3b16 (patch) | |
tree | 257034c1124155dbe77ee5d800c38c3b4bd927d3 /Annex | |
parent | c327bfbe6d90643a0d1fd714d4e1b2d826243ede (diff) |
Fix direct mode mapping code to always store direct mode filenames relative to the top of the repository, even when operating inside a subdirectory.
Diffstat (limited to 'Annex')
-rw-r--r-- | Annex/Content/Direct.hs | 31 | ||||
-rw-r--r-- | Annex/Direct.hs | 3 |
2 files changed, 23 insertions, 11 deletions
diff --git a/Annex/Content/Direct.hs b/Annex/Content/Direct.hs index 778a86f0a..822ae0608 100644 --- a/Annex/Content/Direct.hs +++ b/Annex/Content/Direct.hs @@ -29,7 +29,7 @@ import Logs.Location import System.Posix.Types -{- Files in the tree that are associated with a key. -} +{- Absolute FilePaths of Files in the tree that are associated with a key. -} associatedFiles :: Key -> Annex [FilePath] associatedFiles key = do files <- associatedFilesRelative key @@ -44,7 +44,7 @@ associatedFilesRelative key = do liftIO $ catchDefaultIO [] $ lines <$> readFile mapping {- Changes the associated files information for a key, applying a - - transformation to the list. Returns a copy of the new info. -} + - transformation to the list. Returns new associatedFiles value. -} changeAssociatedFiles :: Key -> ([FilePath] -> [FilePath]) -> Annex [FilePath] changeAssociatedFiles key transform = do mapping <- inRepo $ gitAnnexMapping key @@ -52,22 +52,33 @@ changeAssociatedFiles key transform = do let files' = transform files when (files /= files') $ liftIO $ viaTmp writeFile mapping $ unlines files' - return files' + top <- fromRepo Git.repoPath + return $ map (top </>) files' +{- Removes an associated file. Returns new associatedFiles value. -} removeAssociatedFile :: Key -> FilePath -> Annex [FilePath] removeAssociatedFile key file = do - fs <- changeAssociatedFiles key $ filter (/= normalise file) + file' <- normaliseAssociatedFile file + fs <- changeAssociatedFiles key $ filter (/= file') when (null fs) $ logStatus key InfoMissing return fs +{- Adds an associated file. Returns new associatedFiles value. -} addAssociatedFile :: Key -> FilePath -> Annex [FilePath] -addAssociatedFile key file = changeAssociatedFiles key $ \files -> - if file' `elem` files - then files - else file':files - where - file' = normalise file +addAssociatedFile key file = do + file' <- normaliseAssociatedFile file + changeAssociatedFiles key $ \files -> do + if file' `elem` files + then files + else file':files + +{- Associated files are always stored relative to the top of the repository. + - The input FilePath is relative to the CWD. -} +normaliseAssociatedFile :: FilePath -> Annex FilePath +normaliseAssociatedFile file = do + top <- fromRepo Git.repoPath + liftIO $ relPathDirToFile top <$> absPath file {- Checks if a file in the tree, associated with a key, has not been modified. - diff --git a/Annex/Direct.hs b/Annex/Direct.hs index e0d3f9d79..71ba4b41e 100644 --- a/Annex/Direct.hs +++ b/Annex/Direct.hs @@ -172,7 +172,8 @@ toDirectGen :: Key -> FilePath -> Annex (Maybe (Annex ())) toDirectGen k f = do loc <- inRepo $ gitAnnexLocation k createContentDir loc -- thaws directory too - locs <- filter (/= normalise f) <$> addAssociatedFile k f + top <- fromRepo Git.repoPath + locs <- filter (/= normalise (top </> f)) <$> addAssociatedFile k f case locs of [] -> ifM (liftIO $ doesFileExist loc) ( return $ Just $ do |