Archived
1
0
Fork 0

Wrote the ping pong stuff

This commit is contained in:
Julien Dessaux 2009-08-07 00:19:14 +02:00
parent 2f270f8bdf
commit 14f87adb8b
3 changed files with 28 additions and 2 deletions

View file

@ -4,9 +4,12 @@ module Hsbot.IRC
, connectServer
, initServer
, parseIrcMsg
, ping
, pong
)where
import Control.Monad
import Data.List(isPrefixOf)
import Network
import qualified Network.IRC as IRC
import System.IO
@ -56,3 +59,11 @@ initServer (server, handle) = do
mapM_ (sendstr handle . IRC.encode . IRC.joinChan) (channels server)
return ()
-- | Check if a message is a PING
ping :: String -> Bool
ping = isPrefixOf "PING :"
-- | Send a pong message given a ping message
pong :: Handle -> String -> IO ()
pong handle str = sendstr handle $ "PONG " ++ (drop 5 str)

View file

@ -2,6 +2,9 @@ module Hsbot.Main
( imain
) where
import Control.Concurrent
import Control.Concurrent.Chan
import Control.Monad
import System.IO
import System.Plugins
@ -18,9 +21,18 @@ imain modul' reboot = imain' modul' reboot newbot
-- | Bot's main entry point
imain' :: Module -> Reboot -> Bot -> IO ()
imain' modul' reboot bot = do
putStrLn "yeah"
putStrLn "Connecting servers..."
servers' <- mapM connectServer (ircServers C.config)
putStrLn "Joining channels..."
mapM_ initServer servers'
return ()
-- | Thread entry point for socket listeners
listener :: (Chan IrcOutput) -> (IrcServer, Handle) -> IO ()
listener chan (server, handle) = forever $ do
str <- hGetLine handle
writeChan chan (Str str)
if ping str then pong handle str
else return ()