2005-07-23 00:56:59 -04:00
|
|
|
! Simple IRC bot written in Factor.
|
|
|
|
|
|
|
|
IN: factorbot
|
|
|
|
USING: hashtables http io kernel math namespaces prettyprint
|
|
|
|
sequences strings words ;
|
|
|
|
|
|
|
|
SYMBOL: irc-stream
|
|
|
|
SYMBOL: nickname
|
|
|
|
SYMBOL: speaker
|
|
|
|
SYMBOL: receiver
|
|
|
|
|
|
|
|
: irc-write ( s -- ) irc-stream get stream-write ;
|
|
|
|
: irc-print ( s -- )
|
|
|
|
irc-stream get stream-print
|
|
|
|
irc-stream get stream-flush ;
|
|
|
|
|
|
|
|
: nick ( nick -- )
|
|
|
|
dup nickname set "NICK " irc-write irc-print ;
|
|
|
|
|
|
|
|
: login ( nick -- )
|
|
|
|
dup nick
|
|
|
|
"USER " irc-write irc-write
|
|
|
|
" hostname servername :irc.factor" irc-print ;
|
|
|
|
|
|
|
|
: connect ( server -- ) 6667 <client> irc-stream set ;
|
|
|
|
|
|
|
|
: disconnect ( -- ) irc-stream get stream-close ;
|
|
|
|
|
|
|
|
: join ( chan -- )
|
|
|
|
"JOIN " irc-write irc-print ;
|
|
|
|
|
|
|
|
GENERIC: handle-irc
|
|
|
|
PREDICATE: string privmsg "PRIVMSG" swap subseq? ;
|
|
|
|
|
|
|
|
M: string handle-irc ( line -- )
|
2005-07-23 18:27:29 -04:00
|
|
|
drop ;
|
2005-07-23 00:56:59 -04:00
|
|
|
|
|
|
|
: parse-privmsg ( line -- text )
|
|
|
|
":" ?head drop
|
|
|
|
"!" split1 swap speaker set
|
|
|
|
"PRIVMSG " split1 nip
|
|
|
|
" " split1 swap receiver set
|
|
|
|
":" ?head drop ;
|
|
|
|
|
|
|
|
M: privmsg handle-irc ( line -- )
|
|
|
|
parse-privmsg
|
|
|
|
" " split1 swap
|
|
|
|
[ "factorbot-commands" ] search dup
|
|
|
|
[ execute ] [ 2drop ] ifte ;
|
|
|
|
|
|
|
|
: say ( line nick -- )
|
|
|
|
"PRIVMSG " irc-write irc-write " :" irc-write irc-print ;
|
|
|
|
|
|
|
|
: respond ( line -- )
|
|
|
|
receiver get nickname get = speaker receiver ? get say ;
|
|
|
|
|
|
|
|
: word-string ( word -- string )
|
|
|
|
[
|
|
|
|
"IN: " % dup word-vocabulary %
|
|
|
|
" " % dup definer word-name %
|
|
|
|
" " % dup word-name %
|
|
|
|
"stack-effect" word-prop [ " (" % % ")" % ] when*
|
|
|
|
] make-string ;
|
|
|
|
|
|
|
|
: word-url ( word -- url )
|
|
|
|
[
|
|
|
|
"http://factor.modalwebserver.co.nz/responder/browser/?vocab=" %
|
|
|
|
dup word-vocabulary url-encode %
|
|
|
|
"&word=" %
|
|
|
|
word-name url-encode %
|
|
|
|
] make-string ;
|
|
|
|
|
|
|
|
: irc-loop ( -- )
|
|
|
|
irc-stream get stream-readln
|
2005-07-23 18:27:29 -04:00
|
|
|
[ dup print flush handle-irc irc-loop ] when* ;
|
2005-07-23 00:56:59 -04:00
|
|
|
|
|
|
|
: factorbot
|
|
|
|
"irc.freenode.net" connect
|
|
|
|
"factorbot" login
|
|
|
|
"#concatenative" join
|
|
|
|
irc-loop ;
|
|
|
|
|
|
|
|
IN: factorbot-commands
|
|
|
|
|
|
|
|
: see ( text -- )
|
|
|
|
dup vocabs [ vocab ?hash ] map-with [ ] subset
|
|
|
|
dup empty? [
|
|
|
|
drop
|
|
|
|
"Sorry, I couldn't find anything for " swap append respond
|
|
|
|
] [
|
|
|
|
nip [
|
|
|
|
dup word-string " -- " rot word-url append3 respond
|
2005-07-23 18:27:29 -04:00
|
|
|
] each
|
2005-07-23 00:56:59 -04:00
|
|
|
] ifte ;
|
|
|
|
|
|
|
|
: quit ( text -- )
|
2005-07-23 18:27:29 -04:00
|
|
|
drop speaker get "slava" = [ disconnect ] when ;
|