同じコードで Windows のシグナルについて質問しましたが、別の質問があります
import IO
import Control.Exception hiding (catch)
import Control.Concurrent
import Network
main = withSocketsDo $ do {main'}
main' = listenOn (PortNumber 9900) >>= acceptConnections
acceptConnections sock = do
putStrLn $ "trying to accept" ++ (show sock)-- debug msg
conn@(h,host,port) <- accept sock
print conn -- debug msg
forkIO $ catch (talk conn `finally` hClose h) (\e -> print e)
acceptConnections sock
talk conn@(h,_,_) = hGetLine h >>= hPutStrLn h >> hFlush h >> talk conn
win7 でプログラムを実行すると、ソケットの作成は成功したように見えますが、telnet で接続できず、netstat はプロセスでリッスンしているソケットを表示しません。 (ちなみに、このコードを使用したdebianでは完璧に動作します)