X-Git-Url: https://git.martlubbers.net/?p=cloogle-irc.git;a=blobdiff_plain;f=IRC.dcl;h=ae14b8f625c5effa46a563a2c7e55a95c90c788a;hp=337d6f9c9b2878dc1b4095db58ed421dbb014bf7;hb=3134ab7e61bcbc84560b4a5d613a92b1a48362c2;hpb=a8fbb81c3108a913c6496553346037805157b9c0 diff --git a/IRC.dcl b/IRC.dcl index 337d6f9..ae14b8f 100644 --- a/IRC.dcl +++ b/IRC.dcl @@ -1,36 +1,54 @@ definition module IRC -from Data.Either import :: Either +import IRCBot from Data.Maybe import :: Maybe -from StdOverloaded import class fromInt, class toInt, class toString +from Data.Either import :: Either +from StdOverloaded import class fromInt, class toInt, class toString, class fromString +from Text.Parsers.Simple.Core import :: Error + +:: IRCMessage = + { irc_prefix :: Maybe (Either String IRCUser) + , irc_command :: IRCCommand} -:: IRCCommands +:: IRCUser = + { irc_nick :: String + , irc_user :: Maybe String + , irc_host :: Maybe String + } + +parseIRCMessage :: (String -> Either [Error] IRCMessage) + +instance toString IRCCommand, IRCReplies, IRCErrors, IRCMessage, IRCUser +instance fromInt IRCReplies, IRCErrors +instance toInt IRCReplies, IRCErrors + +:: IRCCommand = ADMIN (Maybe String) | AWAY String - | CONNECT String Int (Maybe String) + | CONNECT String (Maybe (Int, Maybe String)) | DIE | ERROR String | INFO (Maybe String) | INVITE String String | ISON [String] - | JOIN (Either () [(String, Maybe String)]) + | JOIN [(String, Maybe String)] | KICK String String (Maybe String) | KILL String String | LINKS (Maybe (Maybe String, String)) - | LIST [String] + | LIST (Maybe ([String], Maybe String)) | LUSERS (Maybe (String, Maybe String)) - | MODE String + | MODE String String (Maybe String) (Maybe String) (Maybe String) | MOTD (Maybe String) | NAMES [String] - | NICK String + | NICK String (Maybe String) | NJOIN | NOTICE String String | OPER String String | PART [String] | PASS String - | PING [String] - | PONG [String] - | PRIVMSG String String + | PING String (Maybe String) + | PONG String (Maybe String) + | PRIVMSG [String] String | QUIT (Maybe String) | REHASH | RESTART @@ -45,7 +63,7 @@ from StdOverloaded import class fromInt, class toInt, class toString | TIME (Maybe String) | TOPIC String (Maybe String) | TRACE (Maybe String) - | USER String Int String + | USER String String String | USERHOST [String] | USERS (Maybe String) | VERSION (Maybe String) @@ -91,7 +109,3 @@ from StdOverloaded import class fromInt, class toInt, class toString ERR_NOPRIVILEGES | ERR_CHANOPRIVSNEEDED | ERR_CANTKILLSERVER | ERR_RESTRICTED | ERR_UNIQOPPRIVSNEEDED | ERR_NOOPERHOST | ERR_UMODEUNKNOWNFLAG | ERR_USERSDONTMATCH - -instance toString IRCCommands, IRCReplies, IRCErrors -instance fromInt IRCReplies, IRCErrors -instance toInt IRCReplies, IRCErrors