diff options
Diffstat (limited to 'testsuite/tests/lib/IO/readwrite002.hs')
-rw-r--r-- | testsuite/tests/lib/IO/readwrite002.hs | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/testsuite/tests/lib/IO/readwrite002.hs b/testsuite/tests/lib/IO/readwrite002.hs new file mode 100644 index 0000000000..4bb607e395 --- /dev/null +++ b/testsuite/tests/lib/IO/readwrite002.hs @@ -0,0 +1,49 @@ +-- !!! Testing RW handles + +import System.IO +import System.IO.Error +import System.Directory (removeFile, doesFileExist) +import Control.Monad +import System.Cmd + +-- This test is weird, full marks to whoever dreamt it up! + +main :: IO () +main = do + let username = "readwrite002.inout" + f <- doesFileExist username + when f (removeFile username) + cd <- openFile username ReadWriteMode + + -- binary mode needed, otherwise newline translation gives + -- unpredictable results. + hSetBinaryMode cd True + +-- Leva buffering on to make things more interesting: +-- hSetBuffering stdin NoBuffering +-- hSetBuffering stdout NoBuffering +-- hSetBuffering cd NoBuffering + hPutStr cd speakString + hSeek cd AbsoluteSeek 0 + speak cd `catch` \ err -> if isEOFError err then putStrLn "\nCaught EOF" else ioError err + hSeek cd AbsoluteSeek 0 + hSetBuffering cd LineBuffering + speak cd `catch` \ err -> if isEOFError err then putStrLn "\nCaught EOF" else ioError err + return () + hSeek cd AbsoluteSeek 0 + hSetBuffering cd (BlockBuffering Nothing) + speak cd `catch` \ err -> if isEOFError err then putStrLn "\nCaught EOF" else ioError err + +speakString = "##############################\n" + +speak cd = do + (do + ready <- hReady cd + if ready then + hGetChar cd >>= putChar + else + return () + ready <- hReady stdin + if ready then (do { ch <- getChar; hPutChar cd ch}) + else return ()) + speak cd |