f97c783283
This new approach allows filtering out checks from the default set that are not appropriate for a command, rather than having to list every check that is appropriate. It also reduces some boilerplate. Haskell does not define Eq for functions, so I had to go a long way around with each check having a unique id. Meh.
27 lines
604 B
Haskell
27 lines
604 B
Haskell
{- git-annex command
|
|
-
|
|
- Copyright 2010 Joey Hess <joey@kitenet.net>
|
|
-
|
|
- Licensed under the GNU GPL version 3 or higher.
|
|
-}
|
|
|
|
module Command.Find where
|
|
|
|
import Common.Annex
|
|
import Command
|
|
import Annex.Content
|
|
import Limit
|
|
|
|
def :: [Command]
|
|
def = [command "find" paramPaths seek "lists available files"]
|
|
|
|
seek :: [CommandSeek]
|
|
seek = [withFilesInGit start]
|
|
|
|
start :: FilePath -> CommandStart
|
|
start file = isAnnexed file $ \(key, _) -> do
|
|
-- only files inAnnex are shown, unless the user has requested
|
|
-- others via a limit
|
|
whenM (liftM2 (||) (inAnnex key) limited) $
|
|
liftIO $ putStrLn file
|
|
stop
|