1
1
mirror of https://github.com/github/semantic.git synced 2025-01-01 19:55:34 +03:00

Run commands at every step.

This commit is contained in:
Rob Rix 2018-08-02 16:26:49 -04:00
parent 45f0f6d48c
commit 9220177d5a

View File

@ -23,7 +23,7 @@ import Parsing.Parser (rubyParser)
import Prologue
import Semantic.Graph
import Semantic.IO as IO
import Semantic.Task
import Semantic.Task hiding (Error)
import Semantic.Util
import System.FilePath
import Text.Parser.Char
@ -118,14 +118,20 @@ step :: ( Member REPL effects
-> SubtermAlgebra (Base term) term (TermEvaluator term address value effects a)
-> SubtermAlgebra (Base term) term (TermEvaluator term address value effects a)
step blobs recur term = do
path <- asks modulePath
span <- ask
maybe (pure ()) (\ blob -> output (showExcerpt True span blob "")) (Prelude.lookup path blobs)
str <- prompt
output str
res <- recur term
list
res <- runCommands (recur term)
output "leaving term"
pure res
where list = do
path <- asks modulePath
span <- ask
maybe (pure ()) (\ blob -> output (showExcerpt True span blob "")) (Prelude.lookup path blobs)
runCommand run Step = run
runCommand run List = list >> runCommands run
runCommand run (Error err) = output err >> runCommands run
runCommands run = do
str <- prompt
runCommand run (either Error id (parseString command str))
newtype REPLEff address rest a = REPLEff
@ -168,6 +174,7 @@ instance TokenParsing Parser where
data Command
= Step
| List
| Error String
command :: TokenParsing m => m Command
command = token (char ':' *> (Step <$ string "step" <|> List <$ string "list")) <?> "command"