Idris2/tests/chez/chez020/Popen.idr

30 lines
823 B
Idris
Raw Normal View History

2020-05-23 19:42:05 +03:00
import System
import System.File
import System.Info
import Data.List1
import Data.String
2020-05-23 19:42:05 +03:00
windowsPath : String -> String
windowsPath path =
let replaceSlashes : List Char -> List Char
replaceSlashes [] = []
replaceSlashes ('/' :: cs) = '\\' :: replaceSlashes cs
replaceSlashes (c :: cs) = c :: replaceSlashes cs
in
pack $ replaceSlashes (unpack path)
2020-05-23 19:42:05 +03:00
main : IO ()
main = do
Just cmd <- getEnv "POPEN_CMD"
| Nothing => putStrLn "POPEN_CMD env var not set"
let cmd = if isWindows then windowsPath cmd else cmd
2020-05-23 19:42:05 +03:00
Right fh <- popen cmd Read
| Left err => printLn err
putStrLn "opened"
Right output <- fGetLine fh
| Left err => printLn err
pclose fh
putStrLn "closed"
let (idris2 ::: _) = split ((==) ',') output
2020-05-23 19:42:05 +03:00
putStrLn idris2