module System.Socket.Internal.Event
( threadWaitWrite', threadWaitRead'
) where
import Control.Concurrent.MVar
import Control.Monad
import Foreign.C.Error
import GHC.Conc (threadWaitReadSTM, threadWaitWriteSTM, atomically)
import System.Posix.Types ( Fd(..) )
import System.Socket.Internal.Socket
threadWaitWrite' :: Fd -> IO (IO ())
threadWaitWrite' fd = do
threadWaitWriteSTM fd >>= return . atomically . fst
threadWaitRead' :: Fd -> IO (IO ())
threadWaitRead' fd = do
threadWaitReadSTM fd >>= return . atomically . fst