summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Annex/View.hs25
1 files changed, 20 insertions, 5 deletions
diff --git a/Annex/View.hs b/Annex/View.hs
index b5d4ca227..eb3254e8e 100644
--- a/Annex/View.hs
+++ b/Annex/View.hs
@@ -17,11 +17,13 @@ import qualified Git.LsFiles
import Git.UpdateIndex
import Git.Sha
import Git.HashObject
+import Git.Types
import qualified Backend
import Annex.Index
import Annex.Link
import Logs.MetaData
import Logs.View
+import Utility.FileMode
import qualified Data.Set as S
import System.Path.WildMatch
@@ -259,14 +261,27 @@ applyView' mkfileview view = do
void $ stopUpdateIndex uh
void clean
where
- go uh hasher f Nothing = noop -- TODO dotfiles
go uh hasher f (Just (k, _)) = do
metadata <- getCurrentMetaData k
forM_ (fileViews view mkfileview f metadata) $ \fv -> do
- linktarget <- inRepo $ gitAnnexLink fv k
- sha <- hashSymlink' hasher linktarget
- liftIO . Git.UpdateIndex.streamUpdateIndex' uh
- =<< inRepo (Git.UpdateIndex.stageSymlink fv sha)
+ stagesymlink uh hasher fv =<< inRepo (gitAnnexLink fv k)
+ go uh hasher f Nothing
+ | "." `isPrefixOf` f = do
+ s <- liftIO $ getSymbolicLinkStatus f
+ if isSymbolicLink s
+ then stagesymlink uh hasher f =<< liftIO (readSymbolicLink f)
+ else do
+ sha <- liftIO $ Git.HashObject.hashFile hasher f
+ let blobtype = if isExecutable (fileMode s)
+ then ExecutableBlob
+ else FileBlob
+ liftIO . Git.UpdateIndex.streamUpdateIndex' uh
+ =<< inRepo (Git.UpdateIndex.stageFile sha blobtype f)
+ | otherwise = noop
+ stagesymlink uh hasher f linktarget = do
+ sha <- hashSymlink' hasher linktarget
+ liftIO . Git.UpdateIndex.streamUpdateIndex' uh
+ =<< inRepo (Git.UpdateIndex.stageSymlink f sha)
{- Applies a view to the reference branch, generating a new branch
- for the View.