git-annex/Command/VAdd.hs

39 lines
1.1 KiB
Haskell
Raw Normal View History

2014-02-19 00:01:56 +00:00
{- git-annex command
-
- Copyright 2014 Joey Hess <id@joeyh.name>
2014-02-19 00:01:56 +00:00
-
- Licensed under the GNU GPL version 3 or higher.
-}
module Command.VAdd where
import Command
import Annex.View
import Command.View (checkoutViewBranch)
2014-02-19 00:01:56 +00:00
cmd :: Command
cmd = notBareRepo $ notDirect $
command "vadd" SectionMetaData
"add subdirs to current view"
(paramRepeating "FIELD=GLOB")
(withParams seek)
2014-02-19 00:01:56 +00:00
seek :: CmdParams -> CommandSeek
2014-02-19 00:01:56 +00:00
seek = withWords start
start :: [String] -> CommandStart
start params = do
showStart "vadd" ""
withCurrentView $ \view -> do
let (view', change) = refineView view $
map parseViewParam $ reverse params
2014-02-19 00:01:56 +00:00
case change of
Unchanged -> do
showNote "unchanged"
next $ next $ return True
Narrowing -> next $ next $ do
if visibleViewSize view' == visibleViewSize view
then giveup "That would not add an additional level of directory structure to the view. To filter the view, use vfilter instead of vadd."
else checkoutViewBranch view' narrowView
Widening -> giveup "Widening view to match more files is not currently supported."