Mercurial > repo
view interps/rhotor/Main.hs @ 11562:6b0304dcec5c draft
<oerjan> ` cd bin; cp welcome \xd0\xb4\xd0\xbe\xd0\xb1\xd1\x80\xd0\xbe-\xd0\xbf\xd0\xbe\xd0\xb6\xd0\xb0\xd0\xbb\xd0\xbe\xd0\xb2\xd0\xb0\xd1\x82\xd1\x8c; sled \xd0\xb4\xd0\xbe\xd0\xb1\xd1\x80\xd0\xbe-\xd0\xbf\xd0\xbe\xd0\xb6\xd0\xb0\xd0\xbb\xd0\xbe\xd0\xb2\xd0\xb0\xd1\x82\xd1\x8c//s,welcome,welcome.ru,
author | HackEso <hackeso@esolangs.org> |
---|---|
date | Wed, 16 May 2018 04:46:17 +0100 |
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"