diff options
author | Marvin Borner | 2022-02-20 18:48:30 +0100 |
---|---|---|
committer | Marvin Borner | 2022-02-20 18:48:30 +0100 |
commit | fa02225c5ae8b704408769c70bb47101042762b8 (patch) | |
tree | 2bbd0763fccacd0a35631d6ee9a2176ed836eef5 /src/Fun/Compiler.hs | |
parent | 5cc450b6e8554f5d982f444b9026447971c94024 (diff) |
Haskell ftw
Diffstat (limited to 'src/Fun/Compiler.hs')
-rw-r--r-- | src/Fun/Compiler.hs | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/Fun/Compiler.hs b/src/Fun/Compiler.hs new file mode 100644 index 0000000..f7e5c85 --- /dev/null +++ b/src/Fun/Compiler.hs @@ -0,0 +1,17 @@ +module Fun.Compiler where + +import Control.Exception +import Fun.Parser +import Fun.Tree + +parse :: String -> Block -- TODO: Should be tree +parse file = case block file of + Nothing -> error "Invalid program" + Just (a, b) -> a + +compile :: String -> IO () +compile path = do + file <- try $ readFile path + case file of + Left exception -> print (exception :: IOError) + Right file -> putStrLn . show $ parse file |