summaryrefslogtreecommitdiff
path: root/src/Command
diff options
context:
space:
mode:
authorRoman Smrž <roman.smrz@seznam.cz>2025-03-14 21:18:17 +0100
committerRoman Smrž <roman.smrz@seznam.cz>2025-03-14 21:39:14 +0100
commit3bb1c548e2696abd3f7dc2d7b9fbc27ceb490c36 (patch)
tree67cb5d9f33483fe5393bfda89b10b63c5420e962 /src/Command
parentf8b2df887d3847041a81b00dbea70db30b07eb92 (diff)
Evaluate repo definitions
Diffstat (limited to 'src/Command')
-rw-r--r--src/Command/Checkout.hs10
-rw-r--r--src/Command/Run.hs16
2 files changed, 16 insertions, 10 deletions
diff --git a/src/Command/Checkout.hs b/src/Command/Checkout.hs
index 397db79..3667e76 100644
--- a/src/Command/Checkout.hs
+++ b/src/Command/Checkout.hs
@@ -15,7 +15,7 @@ import Repo
data CheckoutCommand = CheckoutCommand CheckoutOptions (Maybe RepoName) (Maybe Text)
data CheckoutOptions = CheckoutOptions
- { coPath :: Maybe FilePath
+ { coDestination :: Maybe FilePath
, coSubtree :: Maybe FilePath
}
@@ -31,13 +31,13 @@ instance Command CheckoutCommand where
type CommandOptions CheckoutCommand = CheckoutOptions
defaultCommandOptions _ = CheckoutOptions
- { coPath = Nothing
+ { coDestination = Nothing
, coSubtree = Nothing
}
commandOptions _ =
- [ Option [] [ "path" ]
- (ReqArg (\val opts -> opts { coPath = Just val }) "<path>")
+ [ Option [] [ "dest" ]
+ (ReqArg (\val opts -> opts { coDestination = Just val }) "<path>")
"destination path"
, Option [] [ "subtree" ]
(ReqArg (\val opts -> opts { coSubtree = Just val }) "<path>")
@@ -59,4 +59,4 @@ cmdCheckout (CheckoutCommand CheckoutOptions {..} name mbrev) = do
Nothing -> return root
Just subtree -> maybe (fail $ "subtree `" <> subtree <> "' not found in " <> maybe "current worktree" (("revision `" <>) . (<> "'") . T.unpack) mbrev) return =<<
getSubtree subtree root
- checkoutAt tree $ maybe "." id coPath
+ checkoutAt tree $ maybe "." id coDestination
diff --git a/src/Command/Run.hs b/src/Command/Run.hs
index bd29455..b297ec1 100644
--- a/src/Command/Run.hs
+++ b/src/Command/Run.hs
@@ -6,7 +6,8 @@ import Control.Concurrent
import Control.Concurrent.STM
import Control.Exception
import Control.Monad
-import Control.Monad.Reader
+import Control.Monad.Except
+import Control.Monad.IO.Class
import Data.Either
import Data.List
@@ -21,6 +22,7 @@ import System.IO
import Command
import Config
+import Eval
import Job
import Repo
import Terminal
@@ -124,22 +126,25 @@ argumentJobSource :: [ JobName ] -> CommandExec JobSource
argumentJobSource [] = emptyJobSource
argumentJobSource names = do
config <- getConfig
+ einput <- getEvalInput
jobsetJobsEither <- fmap Right $ forM names $ \name ->
case find ((name ==) . jobName) (configJobs config) of
Just job -> return job
Nothing -> tfail $ "job `" <> textJobName name <> "' not found"
jobsetCommit <- sequence . fmap createWipCommit =<< tryGetDefaultRepo
- oneshotJobSource [ JobSet {..} ]
+ oneshotJobSource [ evalJobSet einput JobSet {..} ]
rangeSource :: Text -> Text -> CommandExec JobSource
rangeSource base tip = do
repo <- getDefaultRepo
+ einput <- getEvalInput
commits <- listCommits repo (base <> ".." <> tip)
- oneshotJobSource =<< mapM loadJobSetForCommit commits
+ oneshotJobSource . map (evalJobSet einput) =<< mapM loadJobSetForCommit commits
watchBranchSource :: Text -> CommandExec JobSource
watchBranchSource branch = do
repo <- getDefaultRepo
+ einput <- getEvalInput
getCurrentTip <- watchBranch repo branch
let go prev tmvar = do
cur <- atomically $ do
@@ -150,7 +155,7 @@ watchBranchSource branch = do
Nothing -> retry
commits <- listCommits repo (textCommitId (commitId prev) <> ".." <> textCommitId (commitId cur))
- jobsets <- mapM loadJobSetForCommit commits
+ jobsets <- map (evalJobSet einput) <$> mapM loadJobSetForCommit commits
nextvar <- newEmptyTMVarIO
atomically $ putTMVar tmvar $ Just ( jobsets, JobSource nextvar )
go cur nextvar
@@ -168,12 +173,13 @@ watchBranchSource branch = do
watchTagSource :: Pattern -> CommandExec JobSource
watchTagSource pat = do
chan <- watchTags =<< getDefaultRepo
+ einput <- getEvalInput
let go tmvar = do
tag <- atomically $ readTChan chan
if match pat $ T.unpack $ tagTag tag
then do
- jobset <- loadJobSetForCommit $ tagObject tag
+ jobset <- evalJobSet einput <$> loadJobSetForCommit (tagObject tag)
nextvar <- newEmptyTMVarIO
atomically $ putTMVar tmvar $ Just ( [ jobset ], JobSource nextvar )
go nextvar