blob: ea23345d7679ff0bd67d3cf5e464bbadd4f1bd74 [file] [log] [blame]
iproctorff8eb922007-07-25 19:06:13 +00001module TSocket(TSocket(..)) where
2import Thrift
3import Data.IORef
4import Network
5import IO
6import Control.Exception
7data TSocket = TSocket{host::[Char],port::PortNumber,chan :: Maybe Handle}
8
9instance TTransport TSocket where
10 tisOpen a = case chan a of
11 Just _ -> True
12 Nothing -> False
13 topen a = do h <- connectTo (host a) (PortNumber (port a))
David Reiss0c90f6f2008-02-06 22:18:40 +000014 return $ (a{chan = Just h})
15 tclose a = case chan a of
iproctorff8eb922007-07-25 19:06:13 +000016 Just h -> do hClose h
17 return $ a{chan=Nothing}
18 Nothing -> return a
19 tread a 0 = return []
David Reiss0c90f6f2008-02-06 22:18:40 +000020 tread a n = case chan a of
iproctorff8eb922007-07-25 19:06:13 +000021 Just h -> handle (\e -> throwDyn (TransportExn "TSocket: Could not read." TE_UNKNOWN))
David Reiss0c90f6f2008-02-06 22:18:40 +000022 (do c <- hGetChar h
iproctorff8eb922007-07-25 19:06:13 +000023 l <- tread a (n-1)
24 return $ c:l)
25 Nothing -> return []
26 twrite a s = case chan a of
27 Just h -> hPutStr h s
28 Nothing -> return ()
29 tflush a = case chan a of
30 Just h -> hFlush h
31 Nothing -> return ()
32
33