aboutsummaryrefslogtreecommitdiff
path: root/src/Fun/Compiler.hs
diff options
context:
space:
mode:
authorMarvin Borner2022-02-20 18:48:30 +0100
committerMarvin Borner2022-02-20 18:48:30 +0100
commitfa02225c5ae8b704408769c70bb47101042762b8 (patch)
tree2bbd0763fccacd0a35631d6ee9a2176ed836eef5 /src/Fun/Compiler.hs
parent5cc450b6e8554f5d982f444b9026447971c94024 (diff)
Haskell ftw
Diffstat (limited to 'src/Fun/Compiler.hs')
-rw-r--r--src/Fun/Compiler.hs17
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