aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Eval.hs
diff options
context:
space:
mode:
authorMarvin Borner2022-06-17 21:10:06 +0200
committerMarvin Borner2022-06-17 21:10:06 +0200
commit3a8e9afd461cf648fc6904df64eb76a3a95eeb99 (patch)
tree71ced441ef9c19d3de7d5c178a923eb668745a0d /src/Eval.hs
parentbfc12aff90252dbcd9c40a1d095052ed771d4e56 (diff)
Some binary magic
Diffstat (limited to 'src/Eval.hs')
-rw-r--r--src/Eval.hs57
1 files changed, 43 insertions, 14 deletions
diff --git a/src/Eval.hs b/src/Eval.hs
index a5941c1..a5c29bf 100644
--- a/src/Eval.hs
+++ b/src/Eval.hs
@@ -5,6 +5,8 @@ module Eval
import Binary
import Control.Exception
import Control.Monad.State
+import qualified Data.BitString as Bit
+import qualified Data.ByteString as Byte
import Debug.Trace
import Helper
import Parser
@@ -66,6 +68,29 @@ eval (line : ls) env = case parse parseLine "FILE" line of
in case res of
Left err -> print err >> eval ls env'
Right _ -> eval ls env'
+ Import path ->
+ liftIO
+ $ (try $ readFile path :: IO (Either IOError String))
+ >>= (\case -- TODO: Make this more abstract and reusable
+ Left exception -> print (exception :: IOError) >> pure env
+ Right file -> eval (filter (not . null) $ lines file) [] >>= pure
+ )
+ Evaluate exp ->
+ let (res, env') = evalExp exp `runState` env
+ in putStrLn
+ (case res of
+ Left err -> show err
+ Right exp ->
+ "<> "
+ <> (show exp)
+ <> "\n*> "
+ <> (show reduced)
+ <> "\t("
+ <> (show $ binaryToDecimal reduced)
+ <> ")"
+ where reduced = reduce exp
+ )
+ >> eval ls env
Test exp1 exp2 ->
let (res, _) = evalTest exp1 exp2 `runState` env
in case res of
@@ -114,7 +139,7 @@ evalRepl line env = case parse parseReplLine "REPL" line of
where reduced = reduce exp
)
>> pure env
- Load path ->
+ Import path ->
liftIO
$ (try $ readFile path :: IO (Either IOError String))
>>= (\case -- TODO: Make this more abstract and reusable
@@ -145,26 +170,26 @@ evalFile path = do
Right file -> do
env <- eval (filter (not . null) $ lines file) []
case evalFunc "main" env of
- Nothing -> putStrLn $ "main function not found"
+ Nothing -> putStrLn $ "ERROR: main function not found"
Just exp -> print exp
-compile :: String -> IO ()
-compile path = do
+compile :: String -> (a -> IO ()) -> (String -> a) -> IO ()
+compile path write conv = do
file <- try $ readFile path :: IO (Either IOError String)
case file of
Left exception -> print (exception :: IOError)
Right file -> do
env <- eval (filter (not . null) $ lines file) []
case lookup "main" env of
- Nothing -> putStrLn $ "main function not found"
- Just exp -> putStrLn $ toBinary exp
+ Nothing -> putStrLn $ "ERROR: main function not found"
+ Just exp -> write $ conv $ toBinary exp
-exec :: String -> IO ()
-exec path = do
- file <- try $ readFile path :: IO (Either IOError String)
+exec :: String -> (String -> IO (Either IOError a)) -> (a -> String) -> IO ()
+exec path read conv = do
+ file <- read path
case file of
Left exception -> print (exception :: IOError)
- Right file -> print $ reduce $ fromBinary file
+ Right file -> print $ reduce $ fromBinary $ conv file
repl :: Environment -> InputT IO ()
repl env =
@@ -183,7 +208,11 @@ evalMain = do
case args of
[] -> runInputT defaultSettings { historyFile = Just ".bruijn-history" }
$ repl []
- ["-c", path] -> compile path -- TODO: -C: raw binary
- ["-e", path] -> exec path -- TODO: -E: raw binary
- [path] -> evalFile path
- _ -> usage
+ ["-c", path] ->
+ compile path (Byte.putStr . Bit.realizeBitStringStrict) toBitString
+ ["-C", path] -> compile path putStrLn id
+ ["-e", path] ->
+ exec path (try . Byte.readFile) (fromBitString . Bit.bitString)
+ ["-E", path] -> exec path (try . readFile) id
+ ['-' : _] -> usage
+ [path ] -> evalFile path