diff options
author | tv <tv@krebsco.de> | 2021-03-14 22:32:35 +0100 |
---|---|---|
committer | tv <tv@krebsco.de> | 2021-03-14 22:32:35 +0100 |
commit | d151f66a8500f1b0a6aa2224f19e18062b172931 (patch) | |
tree | 24199e10c9ebc72b898188a0f2bdcf4b2e6ee244 /src/Much | |
parent | 032cb86ff8108eb4915a692015da344a41f78506 (diff) |
wipwip
Diffstat (limited to 'src/Much')
-rw-r--r-- | src/Much/Screen.hs | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/Much/Screen.hs b/src/Much/Screen.hs new file mode 100644 index 0000000..47bb90c --- /dev/null +++ b/src/Much/Screen.hs @@ -0,0 +1,32 @@ +{-# LANGUAGE RecordWildCards #-} +module Much.Screen (Screen(..), setScreen, withScreen) where + +import Control.Exception +import Data.List +import System.IO + +data Screen = Screen + { stdinEcho :: Bool + , stdinBufferMode :: BufferMode + , stdoutBufferMode :: BufferMode + , decsetPm :: [Int] + , decrstPm :: [Int] + } + +setScreen :: Screen -> IO Screen +setScreen Screen{..} = get <* set where + get = Screen <$> hGetEcho stdin + <*> hGetBuffering stdin + <*> hGetBuffering stdout + <*> pure decrstPm + <*> pure decsetPm + set = do + hSetEcho stdin stdinEcho + hSetBuffering stdin stdinBufferMode + hSetBuffering stdout stdoutBufferMode + hPutStr stdout $ "\ESC[?" ++ intercalate ";" (map show decsetPm) ++ "h" + hPutStr stdout $ "\ESC[?" ++ intercalate ";" (map show decrstPm) ++ "l" + hFlush stdout + +withScreen :: Screen -> (Screen -> IO a) -> IO a +withScreen s = bracket (setScreen s) setScreen |