view paste/paste.14186 @ 12476:3ded3d281de8 draft

<wib_jonas> slashlearn ponderthis//Ponder This are monthly open-ended programming puzzle challenges that some regulars enjoy: https://research.ibm.com/haifa/ponderthis/index.shtml
author HackEso <hackeso@esolangs.org>
date Mon, 27 Feb 2023 10:56:19 +0000
parents e037173e0012
children
line wrap: on
line source

import System.Environment
import System.Process
import System.Exit
import Control.Monad
import Control.Applicative
import Data.List

main = do
    r <- buildRegex . permuteArgs <$> getArgs
    (_, _, _, h) <- createProcess (proc "/hackenv/bin/log" [r])
    exitWith <$> waitForProcess h
   where
     permuteArgs = permutations . join . map words
     buildRegex = oBrackets . intercalate ".*" . map (iBrackets . intercalate "|")
     iBrackets s = "(?:" ++ s ++ ")"
     oBrackets s = "^.*(?:" ++ s ++ ").*$"