{-# LINE 1 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LANGUAGE CApiFFI #-}
{-# LANGUAGE Trustworthy #-}
{-# LINE 22 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
module System.Posix.Terminal.Common (
TerminalAttributes,
getTerminalAttributes,
TerminalState(..),
setTerminalAttributes,
CTermios,
TerminalMode(..),
withoutMode,
withMode,
terminalMode,
bitsPerByte,
withBits,
ControlCharacter(..),
controlChar,
withCC,
withoutCC,
inputTime,
withTime,
minInput,
withMinInput,
BaudRate(..),
inputSpeed,
withInputSpeed,
outputSpeed,
withOutputSpeed,
sendBreak,
drainOutput,
QueueSelector(..),
discardData,
FlowAction(..),
controlFlow,
getTerminalProcessGroupID,
setTerminalProcessGroupID,
queryTerminal,
) where
import Data.Bits
import Data.Char
import Foreign.C.Error ( throwErrnoIfMinus1, throwErrnoIfMinus1_ )
import Foreign.C.Types
import Foreign.ForeignPtr ( ForeignPtr, withForeignPtr, mallocForeignPtrBytes )
import Foreign.Marshal.Utils ( copyBytes )
import Foreign.Ptr ( Ptr, plusPtr )
import Foreign.Storable ( Storable(..) )
import System.IO.Unsafe ( unsafePerformIO )
import System.Posix.Types
import System.Posix.Internals ( CTermios )
{-# LINE 91 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
newtype TerminalAttributes = TerminalAttributes (ForeignPtr CTermios)
makeTerminalAttributes :: ForeignPtr CTermios -> TerminalAttributes
makeTerminalAttributes = TerminalAttributes
withTerminalAttributes :: TerminalAttributes -> (Ptr CTermios -> IO a) -> IO a
withTerminalAttributes (TerminalAttributes termios) = withForeignPtr termios
data TerminalMode
= InterruptOnBreak
| MapCRtoLF
| IgnoreBreak
| IgnoreCR
| IgnoreParityErrors
| MapLFtoCR
| CheckParity
| StripHighBit
| StartStopInput
| StartStopOutput
| MarkParityErrors
| ProcessOutput
| LocalMode
| ReadEnable
| TwoStopBits
| HangupOnClose
| EnableParity
| OddParity
| EnableEcho
| EchoErase
| EchoKill
| EchoLF
| ProcessInput
| ExtendedFunctions
| KeyboardInterrupts
| NoFlushOnInterrupt
| BackgroundWriteInterrupt
withoutMode :: TerminalAttributes -> TerminalMode -> TerminalAttributes
withoutMode termios InterruptOnBreak = clearInputFlag (2) termios
{-# LINE 146 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios MapCRtoLF = clearInputFlag (256) termios
{-# LINE 147 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios IgnoreBreak = clearInputFlag (1) termios
{-# LINE 148 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios IgnoreCR = clearInputFlag (128) termios
{-# LINE 149 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios IgnoreParityErrors = clearInputFlag (4) termios
{-# LINE 150 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios MapLFtoCR = clearInputFlag (64) termios
{-# LINE 151 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios CheckParity = clearInputFlag (16) termios
{-# LINE 152 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios StripHighBit = clearInputFlag (32) termios
{-# LINE 153 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios StartStopInput = clearInputFlag (1024) termios
{-# LINE 154 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios StartStopOutput = clearInputFlag (512) termios
{-# LINE 155 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios MarkParityErrors = clearInputFlag (8) termios
{-# LINE 156 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios ProcessOutput = clearOutputFlag (1) termios
{-# LINE 157 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios LocalMode = clearControlFlag (32768) termios
{-# LINE 158 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios ReadEnable = clearControlFlag (2048) termios
{-# LINE 159 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios TwoStopBits = clearControlFlag (1024) termios
{-# LINE 160 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios HangupOnClose = clearControlFlag (16384) termios
{-# LINE 161 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios EnableParity = clearControlFlag (4096) termios
{-# LINE 162 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios OddParity = clearControlFlag (8192) termios
{-# LINE 163 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios EnableEcho = clearLocalFlag (8) termios
{-# LINE 164 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios EchoErase = clearLocalFlag (2) termios
{-# LINE 165 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios EchoKill = clearLocalFlag (4) termios
{-# LINE 166 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios EchoLF = clearLocalFlag (16) termios
{-# LINE 167 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios ProcessInput = clearLocalFlag (256) termios
{-# LINE 168 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios ExtendedFunctions = clearLocalFlag (1024) termios
{-# LINE 169 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios KeyboardInterrupts = clearLocalFlag (128) termios
{-# LINE 170 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios NoFlushOnInterrupt = setLocalFlag (2147483648) termios
{-# LINE 171 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withoutMode termios BackgroundWriteInterrupt = clearLocalFlag (4194304) termios
{-# LINE 172 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode :: TerminalAttributes -> TerminalMode -> TerminalAttributes
withMode termios InterruptOnBreak = setInputFlag (2) termios
{-# LINE 175 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios MapCRtoLF = setInputFlag (256) termios
{-# LINE 176 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios IgnoreBreak = setInputFlag (1) termios
{-# LINE 177 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios IgnoreCR = setInputFlag (128) termios
{-# LINE 178 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios IgnoreParityErrors = setInputFlag (4) termios
{-# LINE 179 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios MapLFtoCR = setInputFlag (64) termios
{-# LINE 180 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios CheckParity = setInputFlag (16) termios
{-# LINE 181 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios StripHighBit = setInputFlag (32) termios
{-# LINE 182 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios StartStopInput = setInputFlag (1024) termios
{-# LINE 183 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios StartStopOutput = setInputFlag (512) termios
{-# LINE 184 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios MarkParityErrors = setInputFlag (8) termios
{-# LINE 185 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios ProcessOutput = setOutputFlag (1) termios
{-# LINE 186 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios LocalMode = setControlFlag (32768) termios
{-# LINE 187 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios ReadEnable = setControlFlag (2048) termios
{-# LINE 188 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios TwoStopBits = setControlFlag (1024) termios
{-# LINE 189 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios HangupOnClose = setControlFlag (16384) termios
{-# LINE 190 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios EnableParity = setControlFlag (4096) termios
{-# LINE 191 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios OddParity = setControlFlag (8192) termios
{-# LINE 192 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios EnableEcho = setLocalFlag (8) termios
{-# LINE 193 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios EchoErase = setLocalFlag (2) termios
{-# LINE 194 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios EchoKill = setLocalFlag (4) termios
{-# LINE 195 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios EchoLF = setLocalFlag (16) termios
{-# LINE 196 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios ProcessInput = setLocalFlag (256) termios
{-# LINE 197 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios ExtendedFunctions = setLocalFlag (1024) termios
{-# LINE 198 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios KeyboardInterrupts = setLocalFlag (128) termios
{-# LINE 199 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios NoFlushOnInterrupt = clearLocalFlag (2147483648) termios
{-# LINE 200 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withMode termios BackgroundWriteInterrupt = setLocalFlag (4194304) termios
{-# LINE 201 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode :: TerminalMode -> TerminalAttributes -> Bool
terminalMode InterruptOnBreak = testInputFlag (2)
{-# LINE 204 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode MapCRtoLF = testInputFlag (256)
{-# LINE 205 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode IgnoreBreak = testInputFlag (1)
{-# LINE 206 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode IgnoreCR = testInputFlag (128)
{-# LINE 207 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode IgnoreParityErrors = testInputFlag (4)
{-# LINE 208 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode MapLFtoCR = testInputFlag (64)
{-# LINE 209 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode CheckParity = testInputFlag (16)
{-# LINE 210 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode StripHighBit = testInputFlag (32)
{-# LINE 211 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode StartStopInput = testInputFlag (1024)
{-# LINE 212 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode StartStopOutput = testInputFlag (512)
{-# LINE 213 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode MarkParityErrors = testInputFlag (8)
{-# LINE 214 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode ProcessOutput = testOutputFlag (1)
{-# LINE 215 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode LocalMode = testControlFlag (32768)
{-# LINE 216 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode ReadEnable = testControlFlag (2048)
{-# LINE 217 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode TwoStopBits = testControlFlag (1024)
{-# LINE 218 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode HangupOnClose = testControlFlag (16384)
{-# LINE 219 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode EnableParity = testControlFlag (4096)
{-# LINE 220 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode OddParity = testControlFlag (8192)
{-# LINE 221 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode EnableEcho = testLocalFlag (8)
{-# LINE 222 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode EchoErase = testLocalFlag (2)
{-# LINE 223 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode EchoKill = testLocalFlag (4)
{-# LINE 224 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode EchoLF = testLocalFlag (16)
{-# LINE 225 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode ProcessInput = testLocalFlag (256)
{-# LINE 226 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode ExtendedFunctions = testLocalFlag (1024)
{-# LINE 227 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode KeyboardInterrupts = testLocalFlag (128)
{-# LINE 228 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode NoFlushOnInterrupt = not . testLocalFlag (2147483648)
{-# LINE 229 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
terminalMode BackgroundWriteInterrupt = testLocalFlag (4194304)
{-# LINE 230 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
bitsPerByte :: TerminalAttributes -> Int
bitsPerByte termios = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
cflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) p
{-# LINE 235 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $! (word2Bits (cflag .&. (768)))
{-# LINE 236 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
where
word2Bits :: CTcflag -> Int
word2Bits x =
if x == (0) then 5
{-# LINE 240 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (256) then 6
{-# LINE 241 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (512) then 7
{-# LINE 242 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (768) then 8
{-# LINE 243 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else 0
withBits :: TerminalAttributes -> Int -> TerminalAttributes
withBits termios bits = unsafePerformIO $ do
withNewTermios termios $ \p -> do
cflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) p
{-# LINE 249 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 16)) p
{-# LINE 250 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((cflag .&. complement (768)) .|. mask bits)
{-# LINE 251 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
where
mask :: Int -> CTcflag
mask 5 = (0)
{-# LINE 254 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
mask 6 = (256)
{-# LINE 255 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
mask 7 = (512)
{-# LINE 256 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
mask 8 = (768)
{-# LINE 257 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
mask _ = error "withBits bit value out of range [5..8]"
data ControlCharacter
= EndOfFile
| EndOfLine
| Erase
| Interrupt
| Kill
| Quit
| Start
| Stop
| Suspend
controlChar :: TerminalAttributes -> ControlCharacter -> Maybe Char
controlChar termios cc = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
let c_cc = ((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p
{-# LINE 274 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
val <- peekElemOff c_cc (cc2Word cc)
if val == ((255)::CCc)
{-# LINE 276 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
then return Nothing
else return (Just (chr (fromEnum val)))
withCC :: TerminalAttributes
-> (ControlCharacter, Char)
-> TerminalAttributes
withCC termios (cc, c) = unsafePerformIO $ do
withNewTermios termios $ \p -> do
let c_cc = ((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p
{-# LINE 285 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
pokeElemOff c_cc (cc2Word cc) (fromIntegral (ord c) :: CCc)
withoutCC :: TerminalAttributes
-> ControlCharacter
-> TerminalAttributes
withoutCC termios cc = unsafePerformIO $ do
withNewTermios termios $ \p -> do
let c_cc = ((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p
{-# LINE 293 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
pokeElemOff c_cc (cc2Word cc) ((255) :: CCc)
{-# LINE 294 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
inputTime :: TerminalAttributes -> Int
inputTime termios = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
c <- peekElemOff (((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p) (17)
{-# LINE 299 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return (fromEnum (c :: CCc))
withTime :: TerminalAttributes -> Int -> TerminalAttributes
withTime termios time = unsafePerformIO $ do
withNewTermios termios $ \p -> do
let c_cc = ((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p
{-# LINE 305 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
pokeElemOff c_cc (17) (fromIntegral time :: CCc)
{-# LINE 306 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
minInput :: TerminalAttributes -> Int
minInput termios = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
c <- peekElemOff (((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p) (16)
{-# LINE 311 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return (fromEnum (c :: CCc))
withMinInput :: TerminalAttributes -> Int -> TerminalAttributes
withMinInput termios count = unsafePerformIO $ do
withNewTermios termios $ \p -> do
let c_cc = ((\hsc_ptr -> hsc_ptr `plusPtr` 32)) p
{-# LINE 317 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
pokeElemOff c_cc (16) (fromIntegral count :: CCc)
{-# LINE 318 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
data BaudRate
= B0
| B50
| B75
| B110
| B134
| B150
| B200
| B300
| B600
| B1200
| B1800
| B2400
| B4800
| B9600
| B19200
| B38400
| B57600
| B115200
inputSpeed :: TerminalAttributes -> BaudRate
inputSpeed termios = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
w <- c_cfgetispeed p
return (word2Baud w)
foreign import capi unsafe "termios.h cfgetispeed"
c_cfgetispeed :: Ptr CTermios -> IO CSpeed
withInputSpeed :: TerminalAttributes -> BaudRate -> TerminalAttributes
withInputSpeed termios br = unsafePerformIO $ do
withNewTermios termios $ \p -> c_cfsetispeed p (baud2Word br)
foreign import capi unsafe "termios.h cfsetispeed"
c_cfsetispeed :: Ptr CTermios -> CSpeed -> IO CInt
outputSpeed :: TerminalAttributes -> BaudRate
outputSpeed termios = unsafePerformIO $ do
withTerminalAttributes termios $ \p -> do
w <- c_cfgetospeed p
return (word2Baud w)
foreign import capi unsafe "termios.h cfgetospeed"
c_cfgetospeed :: Ptr CTermios -> IO CSpeed
withOutputSpeed :: TerminalAttributes -> BaudRate -> TerminalAttributes
withOutputSpeed termios br = unsafePerformIO $ do
withNewTermios termios $ \p -> c_cfsetospeed p (baud2Word br)
foreign import capi unsafe "termios.h cfsetospeed"
c_cfsetospeed :: Ptr CTermios -> CSpeed -> IO CInt
getTerminalAttributes :: Fd -> IO TerminalAttributes
getTerminalAttributes (Fd fd) = do
fp <- mallocForeignPtrBytes (72)
{-# LINE 377 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p ->
throwErrnoIfMinus1_ "getTerminalAttributes" (c_tcgetattr fd p)
return $ makeTerminalAttributes fp
foreign import capi unsafe "termios.h tcgetattr"
c_tcgetattr :: CInt -> Ptr CTermios -> IO CInt
data TerminalState
= Immediately
| WhenDrained
| WhenFlushed
setTerminalAttributes :: Fd
-> TerminalAttributes
-> TerminalState
-> IO ()
setTerminalAttributes (Fd fd) termios state = do
withTerminalAttributes termios $ \p ->
throwErrnoIfMinus1_ "setTerminalAttributes"
(c_tcsetattr fd (state2Int state) p)
where
state2Int :: TerminalState -> CInt
state2Int Immediately = (0)
{-# LINE 403 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
state2Int WhenDrained = (1)
{-# LINE 404 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
state2Int WhenFlushed = (2)
{-# LINE 405 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
foreign import capi unsafe "termios.h tcsetattr"
c_tcsetattr :: CInt -> CInt -> Ptr CTermios -> IO CInt
sendBreak :: Fd -> Int -> IO ()
sendBreak (Fd fd) duration
= throwErrnoIfMinus1_ "sendBreak" (c_tcsendbreak fd (fromIntegral duration))
foreign import capi unsafe "termios.h tcsendbreak"
c_tcsendbreak :: CInt -> CInt -> IO CInt
drainOutput :: Fd -> IO ()
{-# LINE 427 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
drainOutput (Fd fd) = throwErrnoIfMinus1_ "drainOutput" (c_tcdrain fd)
foreign import capi safe "termios.h tcdrain"
c_tcdrain :: CInt -> IO CInt
{-# LINE 436 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
data QueueSelector
= InputQueue
| OutputQueue
| BothQueues
discardData :: Fd -> QueueSelector -> IO ()
discardData (Fd fd) queue =
throwErrnoIfMinus1_ "discardData" (c_tcflush fd (queue2Int queue))
where
queue2Int :: QueueSelector -> CInt
queue2Int InputQueue = (1)
{-# LINE 451 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
queue2Int OutputQueue = (2)
{-# LINE 452 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
queue2Int BothQueues = (3)
{-# LINE 453 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
foreign import capi unsafe "termios.h tcflush"
c_tcflush :: CInt -> CInt -> IO CInt
data FlowAction
= SuspendOutput
| RestartOutput
| TransmitStop
| TransmitStart
controlFlow :: Fd -> FlowAction -> IO ()
controlFlow (Fd fd) action =
throwErrnoIfMinus1_ "controlFlow" (c_tcflow fd (action2Int action))
where
action2Int :: FlowAction -> CInt
action2Int SuspendOutput = (1)
{-# LINE 472 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
action2Int RestartOutput = (2)
{-# LINE 473 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
action2Int TransmitStop = (3)
{-# LINE 474 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
action2Int TransmitStart = (4)
{-# LINE 475 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
foreign import capi unsafe "termios.h tcflow"
c_tcflow :: CInt -> CInt -> IO CInt
getTerminalProcessGroupID :: Fd -> IO ProcessGroupID
getTerminalProcessGroupID (Fd fd) = do
throwErrnoIfMinus1 "getTerminalProcessGroupID" (c_tcgetpgrp fd)
foreign import ccall unsafe "tcgetpgrp"
c_tcgetpgrp :: CInt -> IO CPid
setTerminalProcessGroupID :: Fd -> ProcessGroupID -> IO ()
setTerminalProcessGroupID (Fd fd) pgid =
throwErrnoIfMinus1_ "setTerminalProcessGroupID" (c_tcsetpgrp fd pgid)
foreign import ccall unsafe "tcsetpgrp"
c_tcsetpgrp :: CInt -> CPid -> IO CInt
queryTerminal :: Fd -> IO Bool
queryTerminal (Fd fd) = do
r <- c_isatty fd
return (r == 1)
foreign import ccall unsafe "isatty"
c_isatty :: CInt -> IO CInt
cc2Word :: ControlCharacter -> Int
cc2Word EndOfFile = (0)
{-# LINE 521 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word EndOfLine = (1)
{-# LINE 522 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Erase = (3)
{-# LINE 523 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Interrupt = (8)
{-# LINE 524 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Kill = (5)
{-# LINE 525 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Quit = (9)
{-# LINE 526 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Suspend = (10)
{-# LINE 527 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Start = (12)
{-# LINE 528 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cc2Word Stop = (13)
{-# LINE 529 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word :: BaudRate -> CSpeed
baud2Word B0 = (0)
{-# LINE 534 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B50 = (50)
{-# LINE 535 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B75 = (75)
{-# LINE 536 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B110 = (110)
{-# LINE 537 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B134 = (134)
{-# LINE 538 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B150 = (150)
{-# LINE 539 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B200 = (200)
{-# LINE 540 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B300 = (300)
{-# LINE 541 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B600 = (600)
{-# LINE 542 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B1200 = (1200)
{-# LINE 543 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B1800 = (1800)
{-# LINE 544 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B2400 = (2400)
{-# LINE 545 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B4800 = (4800)
{-# LINE 546 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B9600 = (9600)
{-# LINE 547 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B19200 = (19200)
{-# LINE 548 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B38400 = (38400)
{-# LINE 549 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 550 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B57600 = (57600)
{-# LINE 551 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 554 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 555 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
baud2Word B115200 = (115200)
{-# LINE 556 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 559 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
word2Baud :: CSpeed -> BaudRate
word2Baud x =
if x == (0) then B0
{-# LINE 566 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (50) then B50
{-# LINE 567 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (75) then B75
{-# LINE 568 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (110) then B110
{-# LINE 569 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (134) then B134
{-# LINE 570 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (150) then B150
{-# LINE 571 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (200) then B200
{-# LINE 572 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (300) then B300
{-# LINE 573 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (600) then B600
{-# LINE 574 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (1200) then B1200
{-# LINE 575 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (1800) then B1800
{-# LINE 576 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (2400) then B2400
{-# LINE 577 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (4800) then B4800
{-# LINE 578 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (9600) then B9600
{-# LINE 579 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (19200) then B19200
{-# LINE 580 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (38400) then B38400
{-# LINE 581 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 582 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (57600) then B57600
{-# LINE 583 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 584 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 585 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else if x == (115200) then B115200
{-# LINE 586 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
{-# LINE 587 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
else error "unknown baud rate"
clearInputFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
clearInputFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 594 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 597 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
iflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 0)) p2
{-# LINE 598 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 0)) p1 (iflag .&. complement flag)
{-# LINE 599 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
setInputFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
setInputFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 606 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 609 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
iflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 0)) p2
{-# LINE 610 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 0)) p1 (iflag .|. flag)
{-# LINE 611 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
testInputFlag :: CTcflag -> TerminalAttributes -> Bool
testInputFlag flag termios = unsafePerformIO $
withTerminalAttributes termios $ \p -> do
iflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 0)) p
{-# LINE 619 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $! ((iflag .&. flag) /= 0)
clearControlFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
clearControlFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 626 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 629 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) p2
{-# LINE 630 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 16)) p1 (cflag .&. complement flag)
{-# LINE 631 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
setControlFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
setControlFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 638 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 641 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
cflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) p2
{-# LINE 642 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 16)) p1 (cflag .|. flag)
{-# LINE 643 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
testControlFlag :: CTcflag -> TerminalAttributes -> Bool
testControlFlag flag termios = unsafePerformIO $
withTerminalAttributes termios $ \p -> do
cflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) p
{-# LINE 651 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $! ((cflag .&. flag) /= 0)
clearLocalFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
clearLocalFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 658 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 661 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
lflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 24)) p2
{-# LINE 662 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 24)) p1 (lflag .&. complement flag)
{-# LINE 663 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
setLocalFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
setLocalFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 670 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 673 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
lflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 24)) p2
{-# LINE 674 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 24)) p1 (lflag .|. flag)
{-# LINE 675 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
testLocalFlag :: CTcflag -> TerminalAttributes -> Bool
testLocalFlag flag termios = unsafePerformIO $
withTerminalAttributes termios $ \p -> do
lflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 24)) p
{-# LINE 683 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $! ((lflag .&. flag) /= 0)
clearOutputFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
clearOutputFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 690 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 693 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
oflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 8)) p2
{-# LINE 694 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 8)) p1 (oflag .&. complement flag)
{-# LINE 695 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
setOutputFlag :: CTcflag -> TerminalAttributes -> TerminalAttributes
setOutputFlag flag termios = unsafePerformIO $ do
fp <- mallocForeignPtrBytes (72)
{-# LINE 702 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 705 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
oflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 8)) p2
{-# LINE 706 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 8)) p1 (oflag .|. flag)
{-# LINE 707 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $ makeTerminalAttributes fp
testOutputFlag :: CTcflag -> TerminalAttributes -> Bool
testOutputFlag flag termios = unsafePerformIO $
withTerminalAttributes termios $ \p -> do
oflag <- ((\hsc_ptr -> peekByteOff hsc_ptr 8)) p
{-# LINE 715 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
return $! ((oflag .&. flag) /= 0)
withNewTermios :: TerminalAttributes -> (Ptr CTermios -> IO a)
-> IO TerminalAttributes
withNewTermios termios action = do
fp1 <- mallocForeignPtrBytes (72)
{-# LINE 721 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
withForeignPtr fp1 $ \p1 -> do
withTerminalAttributes termios $ \p2 -> do
copyBytes p1 p2 (72)
{-# LINE 724 "libraries/unix/System/Posix/Terminal/Common.hsc" #-}
_ <- action p1
return ()
return $ makeTerminalAttributes fp1