aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Helper.hs
blob: a8e393ed2979e4e3f9e134d8b17f147906e05283 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
module Helper where

import           Control.Monad.State
import           Text.Parsec             hiding ( State )

data Error = SyntaxError ParseError | UndeclaredFunction String | DuplicateFunction String | InvalidIndex Int | FatalError String
instance Show Error where
  show (SyntaxError        err) = show err
  show (UndeclaredFunction err) = "ERROR: undeclared function " <> show err
  show (DuplicateFunction  err) = "ERROR: duplicate function " <> show err
  show (InvalidIndex       err) = "ERROR: invalid index " <> show err
  show (FatalError         err) = show err
type Failable = Either Error

data Expression = Bruijn Int | Variable String | Abstraction Expression | Application Expression Expression
  deriving (Ord, Eq)
data Instruction = Define String Expression | Evaluate Expression | Comment String | Load String
  deriving (Show)
instance Show Expression where
  show (Bruijn      x        ) = show x
  show (Variable    var      ) = show var
  show (Abstraction exp      ) = "[" <> show exp <> "]"
  show (Application exp1 exp2) = "(" <> show exp1 <> " " <> show exp2 <> ")"

type Environment = [(String, Expression)]
type Program = State Environment