Mercurial > repo
view interps/rhotor/Main.hs @ 12518:2d8fe55c6e65 draft default tip
<int-e> learn The password of the month is release incident pilot.
author | HackEso <hackeso@esolangs.org> |
---|---|
date | Sun, 03 Nov 2024 00:31:02 +0000 |
parents | 859f9b4339e6 |
children |
line wrap: on
line source
module Main () where import System.IO import System.Environment import System.Exit import Misc import Parser import Evaluator main :: IO () main = (hSetBuffering stdout NoBuffering) >> getArgs >>= \args -> if length args /= 1 then usage else readFile (head args) `catch` (\ _ -> putStr "Error: Couldn't open source file.\n" >> exitWith (ExitFailure 1)) >>= \source -> interact (run source) run :: String -> String -> String run source input = nodeTreeToString (evaluate (apply (parse source) (stringToNodeTree input))) usage :: IO () usage = putStr "Usage: rhotorhi sourcecode.rho\n"