batchStart folded into only caller
This commit is contained in:
Joey Hess 2020-09-16 10:18:36 -04:00
parent fcf5d11c63
commit 7b4c7a7ffc
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38

View file

@ -42,6 +42,8 @@ parseBatchOption = go
-- In batch mode, one line at a time is read, parsed, and a reply output to -- In batch mode, one line at a time is read, parsed, and a reply output to
-- stdout. In non batch mode, the command's parameters are parsed and -- stdout. In non batch mode, the command's parameters are parsed and
-- a reply output for each. -- a reply output for each.
--
-- Note that the actions are not run concurrently.
batchable :: (opts -> SeekInput -> String -> Annex Bool) -> Parser opts -> CmdParamsDesc -> CommandParser batchable :: (opts -> SeekInput -> String -> Annex Bool) -> Parser opts -> CmdParamsDesc -> CommandParser
batchable handler parser paramdesc = batchseeker <$> batchparser batchable handler parser paramdesc = batchseeker <$> batchparser
where where
@ -104,24 +106,23 @@ batchCommandAction a = maybe (batchBadInput (Batch BatchLine)) (const noop)
-- Reads lines of batch input and passes the filepaths to a CommandStart -- Reads lines of batch input and passes the filepaths to a CommandStart
-- to handle them. -- to handle them.
-- --
-- Absolute filepaths are converted to relative. -- Absolute filepaths are converted to relative, because in non-batch
-- mode, that is done when CmdLine.Seek uses git ls-files.
-- --
-- File matching options are not checked. -- File matching options are checked, and non-matching files skipped.
batchStart :: BatchFormat -> (SeekInput -> FilePath -> CommandStart) -> Annex ()
batchStart fmt a = batchInput fmt (Right <$$> liftIO . relPathCwdToFile) $
batchCommandAction . uncurry a
-- Like batchStart, but checks the file matching options
-- and skips non-matching files.
batchFilesMatching :: BatchFormat -> ((SeekInput, RawFilePath) -> CommandStart) -> Annex () batchFilesMatching :: BatchFormat -> ((SeekInput, RawFilePath) -> CommandStart) -> Annex ()
batchFilesMatching fmt a = do batchFilesMatching fmt a = do
matcher <- getMatcher matcher <- getMatcher
batchStart fmt $ \si f -> go $ \si f ->
let f' = toRawFilePath f let f' = toRawFilePath f
in ifM (matcher $ MatchingFile $ FileInfo f' f') in ifM (matcher $ MatchingFile $ FileInfo f' f')
( a (si, f') ( a (si, f')
, return Nothing , return Nothing
) )
where
go a' = batchInput fmt
(Right <$$> liftIO . relPathCwdToFile)
(batchCommandAction . uncurry a')
batchAnnexedFilesMatching :: BatchFormat -> AnnexedFileSeeker -> Annex () batchAnnexedFilesMatching :: BatchFormat -> AnnexedFileSeeker -> Annex ()
batchAnnexedFilesMatching fmt seeker = batchFilesMatching fmt $ \(si, bf) -> batchAnnexedFilesMatching fmt seeker = batchFilesMatching fmt $ \(si, bf) ->