aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Helper.hs
diff options
context:
space:
mode:
authorMarvin Borner2022-08-30 16:14:09 +0200
committerMarvin Borner2022-08-30 16:14:09 +0200
commitea7b6562f41b4f8845828db7ee10e1f9036752e4 (patch)
tree1d5e504b2bbb6ca738b604b081c85c129c0d83b6 /src/Helper.hs
parent78fc68e8718e2e5afffb10c389d2d58bbd3e0681 (diff)
Fixed mixfix matching
Diffstat (limited to 'src/Helper.hs')
-rw-r--r--src/Helper.hs13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/Helper.hs b/src/Helper.hs
index b0dea79..87ae8fc 100644
--- a/src/Helper.hs
+++ b/src/Helper.hs
@@ -14,6 +14,9 @@ import Data.List
import qualified Data.Map as M
import Text.Megaparsec
+invalidProgramState :: a
+invalidProgramState = error "invalid program state"
+
data Context = Context
{ _ctxInput :: String
, _ctxPath :: String
@@ -36,7 +39,7 @@ printContext (Context inp path) = p $ lines inp
errPrefix :: String
errPrefix = "\ESC[101m\ESC[30mERROR\ESC[0m "
-data Error = SyntaxError String | UndefinedIdentifier Identifier | InvalidIndex Int | FailedTest Expression Expression Expression Expression | ContextualError Error Context | SuggestSolution Error String | ImportError String
+data Error = SyntaxError String | UndefinedIdentifier Identifier | UnmatchedMixfix [MixfixIdentifierKind] [Mixfix] | InvalidIndex Int | FailedTest Expression Expression Expression Expression | ContextualError Error Context | SuggestSolution Error String | ImportError String
instance Show Error where
show (ContextualError err ctx) = show err <> "\n" <> (printContext ctx)
show (SuggestSolution err sol) =
@@ -47,6 +50,12 @@ instance Show Error where
errPrefix <> "invalid syntax\n\ESC[105m\ESC[30mnear\ESC[0m " <> err
show (UndefinedIdentifier ident) =
errPrefix <> "undefined identifier " <> show ident
+ show (UnmatchedMixfix ks ms) =
+ errPrefix
+ <> "couldn't find matching mixfix for "
+ <> (intercalate "" (map show ks))
+ <> "\n\ESC[105m\ESC[30mnear\ESC[0m "
+ <> (intercalate " " (map show ms))
show (InvalidIndex err) = errPrefix <> "invalid index " <> show err
show (FailedTest exp1 exp2 red1 red2) =
errPrefix
@@ -97,7 +106,7 @@ printBundle ParseErrorBundle {..} =
data MixfixIdentifierKind = MixfixSome String | MixfixNone
deriving (Ord, Eq)
-instance Show MixfixIdentifierKind where
+instance Show MixfixIdentifierKind where -- don't colorize (due to map)
show (MixfixSome e) = e
show _ = "…"
data Identifier = NormalFunction String | MixfixFunction [MixfixIdentifierKind] | PrefixFunction String | NamespacedFunction String Identifier