1 USING: help.markup help.syntax quotations kernel irc.messages ;
4 HELP: irc-client "IRC Client object" ;
6 HELP: irc-server-chat "Chat for server messages unmanaged by other chats" ;
8 HELP: irc-channel-chat "Chat for irc channels" ;
10 HELP: irc-nick-chat "Chat for irc users" ;
12 HELP: irc-profile "IRC Client profile object" ;
14 HELP: connect-irc "Connecting to an irc server"
15 { $values { "irc-client" "an irc client object" } }
16 { $description "Connects and logins " { $link irc-client } " using the settings specified on its " { $link irc-profile } "." } ;
18 HELP: attach-chat "Chatting with irc channels/users/etc"
19 { $values { "irc-chat" "an irc chat object" } { "irc-client" "an irc client object" } }
20 { $description "Registers " { $snippet "irc-chat" } " with " { $snippet "irc-client" } " and starts listening." } ;
22 HELP: detach-chat "Stop an unregister chat"
23 { $values { "irc-chat" "an irc chat object" } }
24 { $description "Unregisters " { $snippet "irc-chat" } " from " { $snippet "irc-client" } " and stops listening. This is how you part from a channel." } ;
26 HELP: terminate-irc "Terminates an irc client"
27 { $values { "irc-client" "an irc client object" } }
28 { $description "Terminates all activity by " { $link irc-client } " cleaning up resources and notifying chats." } ;
30 HELP: speak "Sends a message through a chat"
31 { $values { "message" "a string or irc message object" } { "irc-chat" "an irc chat object" } }
32 { $description "Sends " { $snippet "message" } " through " { $snippet "irc-chat" } ". Strings are automatically promoted to privmsg objects." } ;
34 HELP: hear "Reads a message from a chat"
35 { $values { "irc-chat" "an irc chat object" } { "message" "an irc message object" } }
36 { $description "Reads " { $snippet "message" } " from " { $snippet "irc-chat" } "." } ;
38 ARTICLE: "irc.client" "IRC Client"
39 "An IRC Client library"
40 { $heading "IRC objects:" }
41 { $subsection irc-client }
42 { $heading "Chat objects:" }
43 { $subsection irc-server-chat }
44 { $subsection irc-channel-chat }
45 { $subsection irc-nick-chat }
46 { $heading "Setup objects:" }
47 { $subsection irc-profile }
49 { $subsection connect-irc }
50 { $subsection terminate-irc }
51 { $subsection attach-chat }
52 { $subsection detach-chat }
55 { $heading "IRC messages" }
56 "Some of the RFC defined irc messages as objects:"
58 { { $link irc-message } "base of all irc messages" }
59 { { $link logged-in } "logged in to server" }
60 { { $link ping } "ping message" }
61 { { $link join } "channel join" }
62 { { $link part } "channel part" }
63 { { $link quit } "quit from irc" }
64 { { $link privmsg } "private message (to client or channel)" }
65 { { $link kick } "kick from channel" }
66 { { $link roomlist } "list of participants in channel" }
67 { { $link nick-in-use } "chosen nick is in use by another client" }
68 { { $link notice } "notice message" }
69 { { $link mode } "mode change" }
70 { { $link unhandled } "uninmplemented/unhandled message" }
72 { $heading "Special messages" }
73 "Some special messages that are created by the library and not by the irc server."
75 { { $link irc-chat-end } "sent to a chat when it has been detached from the client, the chat should stop after it receives this message. " }
76 { { $link irc-end } " sent when the client isn't running anymore, chats should stop after it receives this message." }
77 { { $link irc-disconnected } " sent to notify chats that connection was lost." }
78 { { $link irc-connected } " sent to notify chats that a connection with the irc server was established." } }
80 { $heading "Example:" }
85 "! Create the profile and client objects"
86 "\"irc.freenode.org\" irc-port \"mybot123\" f <irc-profile> <irc-client> bot set"
87 "! Connect to the server"
89 "! Create a channel chat"
90 "\"#mychannel123\" <irc-channel-chat> mychannel set"
91 "! Register and start chat (this joins the channel)"
92 "mychannel get bot get attach-chat"
93 "! Send a message to the channel"
94 "\"what's up?\" mychannel get speak"
95 "! Read a message from the channel"