summaryrefslogtreecommitdiff
path: root/examples/big/MAP/MkBig.hs
blob: 0ea4e0b1839702232390a106764dab6d0e241f4a (plain)
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
module Main where

import TransBig

import IO ( stdin, hGetContents )
import System ( getArgs, getProgName )

import LexLisp
import ParLisp
import SkelLisp
import PrintLisp
import AbsLisp
import ErrM

type ParseFun a = [Token] -> Err a

myLLexer = myLexer

type Verbosity = Int

putStrV :: Verbosity -> String -> IO ()
putStrV v s = if v > 1 then putStrLn s else return ()

runFile :: Verbosity -> ParseFun Prog -> FilePath -> IO ()
runFile v p f = putStrLn f >> readFile f >>= run v p

run :: Verbosity -> ParseFun Prog -> String -> IO ()
run v p s = let ts = myLLexer s in case p ts of
           Bad s    -> do putStrLn "\nParse              Failed...\n"
                          putStrV v "Tokens:"
                          putStrV v $ show ts
                          putStrLn s
           Ok  tree -> do putStrLn "\nParse Successful!"
                          transTree tree



main :: IO ()
main = do 
  runFile 0 pProg infile

infile = "bigwordlist.en"