2008-07-09 21:48:17 -04:00
|
|
|
! Copyright (C) 2008 Bruno Deferrari
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2008-07-11 19:23:31 -04:00
|
|
|
USING: kernel fry splitting ascii calendar accessors combinators qualified
|
|
|
|
arrays classes.tuple math.order ;
|
|
|
|
RENAME: join sequences => sjoin
|
|
|
|
EXCLUDE: sequences => join ;
|
2008-07-09 21:48:17 -04:00
|
|
|
IN: irc.messages
|
|
|
|
|
|
|
|
TUPLE: irc-message line prefix command parameters trailing timestamp ;
|
|
|
|
TUPLE: logged-in < irc-message name ;
|
|
|
|
TUPLE: ping < irc-message ;
|
2008-07-11 00:16:15 -04:00
|
|
|
TUPLE: join < irc-message ;
|
2008-07-09 21:48:17 -04:00
|
|
|
TUPLE: part < irc-message channel ;
|
|
|
|
TUPLE: quit < irc-message ;
|
|
|
|
TUPLE: privmsg < irc-message name ;
|
|
|
|
TUPLE: kick < irc-message channel who ;
|
|
|
|
TUPLE: roomlist < irc-message channel names ;
|
|
|
|
TUPLE: nick-in-use < irc-message asterisk name ;
|
|
|
|
TUPLE: notice < irc-message type ;
|
|
|
|
TUPLE: mode < irc-message name channel mode ;
|
2008-07-11 00:16:15 -04:00
|
|
|
TUPLE: names-reply < irc-message who = channel ;
|
2008-07-09 21:48:17 -04:00
|
|
|
TUPLE: unhandled < irc-message ;
|
|
|
|
|
2008-07-14 20:43:42 -04:00
|
|
|
: <irc-client-message> ( command parameters trailing -- irc-message )
|
2008-07-14 20:39:52 -04:00
|
|
|
irc-message new now >>timestamp
|
|
|
|
[ [ (>>trailing) ] [ (>>parameters) ] [ (>>command) ] tri ] keep ;
|
|
|
|
|
2008-07-11 19:23:31 -04:00
|
|
|
GENERIC: irc-message>client-line ( irc-message -- string )
|
|
|
|
|
|
|
|
M: irc-message irc-message>client-line ( irc-message -- string )
|
|
|
|
[ command>> ]
|
|
|
|
[ parameters>> " " sjoin ]
|
|
|
|
[ trailing>> dup [ CHAR: : prefix ] when ]
|
|
|
|
tri 3array " " sjoin ;
|
|
|
|
|
|
|
|
GENERIC: irc-message>server-line ( irc-message -- string )
|
2008-07-15 23:31:06 -04:00
|
|
|
|
2008-07-11 19:23:31 -04:00
|
|
|
M: irc-message irc-message>server-line ( irc-message -- string )
|
|
|
|
drop "not implemented yet" ;
|
|
|
|
|
2008-07-09 21:48:17 -04:00
|
|
|
<PRIVATE
|
|
|
|
! ======================================
|
|
|
|
! Message parsing
|
|
|
|
! ======================================
|
|
|
|
|
|
|
|
: split-at-first ( seq separators -- before after )
|
|
|
|
dupd '[ , member? ] find
|
|
|
|
[ cut 1 tail ]
|
|
|
|
[ swap ]
|
|
|
|
if ;
|
|
|
|
|
|
|
|
: remove-heading-: ( seq -- seq ) dup ":" head? [ 1 tail ] when ;
|
|
|
|
|
|
|
|
: parse-name ( string -- string )
|
|
|
|
remove-heading-: "!" split-at-first drop ;
|
|
|
|
|
|
|
|
: split-prefix ( string -- string/f string )
|
|
|
|
dup ":" head?
|
|
|
|
[ remove-heading-: " " split1 ]
|
|
|
|
[ f swap ]
|
|
|
|
if ;
|
|
|
|
|
|
|
|
: split-trailing ( string -- string string/f )
|
|
|
|
":" split1 ;
|
|
|
|
|
2008-07-14 20:39:52 -04:00
|
|
|
PRIVATE>
|
|
|
|
|
2008-07-09 21:48:17 -04:00
|
|
|
: string>irc-message ( string -- object )
|
|
|
|
dup split-prefix split-trailing
|
|
|
|
[ [ blank? ] trim " " split unclip swap ] dip
|
|
|
|
now irc-message boa ;
|
|
|
|
|
|
|
|
: parse-irc-line ( string -- message )
|
|
|
|
string>irc-message
|
|
|
|
dup command>> {
|
|
|
|
{ "PING" [ \ ping ] }
|
|
|
|
{ "NOTICE" [ \ notice ] }
|
|
|
|
{ "001" [ \ logged-in ] }
|
|
|
|
{ "433" [ \ nick-in-use ] }
|
2008-07-11 00:16:15 -04:00
|
|
|
{ "353" [ \ names-reply ] }
|
2008-07-09 21:48:17 -04:00
|
|
|
{ "JOIN" [ \ join ] }
|
|
|
|
{ "PART" [ \ part ] }
|
|
|
|
{ "PRIVMSG" [ \ privmsg ] }
|
|
|
|
{ "QUIT" [ \ quit ] }
|
|
|
|
{ "MODE" [ \ mode ] }
|
|
|
|
{ "KICK" [ \ kick ] }
|
|
|
|
[ drop \ unhandled ]
|
|
|
|
} case
|
|
|
|
[ [ tuple-slots ] [ parameters>> ] bi append ] dip
|
|
|
|
[ all-slots over [ length ] bi@ min head ] keep slots>tuple ;
|
|
|
|
|