2005-12-25 23:11:57 +00:00

58 lines
1.9 KiB
Haskell

--
-- Copyright (c) 2004 Don Stewart - http://www.cse.unsw.edu.au/~dons
-- GPL version 2 or later (see http://www.gnu.org/copyleft/gpl.html)
--
--
-- | Runplugs: use hs-plugins to run a Haskell expression under
-- controlled conditions.
--
import System.Eval.Haskell (unsafeEval)
import Data.Char (chr)
import Data.Maybe (isJust, fromJust)
import Control.Monad
import System.Random
import System.Exit (exitWith, ExitCode(ExitSuccess))
import System.IO (getContents, putStrLn)
import System.Posix.Resource (setResourceLimit,
Resource(ResourceCPUTime),
ResourceLimits(ResourceLimits),
ResourceLimit(ResourceLimit))
import qualified Control.Exception (catch)
rlimit = ResourceLimit 3
context = prehier ++ datas ++ qualifieds ++ controls
prehier = ["Char", "List", "Maybe", "Numeric", "Random" ]
qualifieds = ["qualified Data.Map as M"
,"qualified Data.Set as S"
,"qualified Data.IntSet as I"]
datas = map ("Data." ++) [
"Bits", "Bool", "Char", "Dynamic", "Either",
"Graph", "Int", "Ix", "List",
"Maybe", "Ratio", "Tree", "Tuple", "Typeable", "Word"
]
controls = map ("Control." ++) ["Monad", "Monad.Reader", "Monad.Fix", "Arrow"]
main = do
setResourceLimit ResourceCPUTime (ResourceLimits rlimit rlimit)
s <- getLine
when (not . null $ s) $ do
x <- sequence (take 3 (repeat $ getStdRandom (randomR (97,122)) >>= return . chr))
s <- unsafeEval ("let { "++x++
" = \n# 1 \"<irc>\"\n"++s++
"\n} in take 2048 (show "++x++
")") context
when (isJust s) $ Control.Exception.catch
(putStrLn $ fromJust s)
(\e -> putStrLn $ "Exception: " ++ show e )
exitWith ExitSuccess