2009-04-12 15:47:55 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								! Copyright (C) 2009 Bruno Deferrari  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								! See http://factorcode.org/license.txt for BSD license.  
						 
					
						
							
								
									
										
										
										
											2009-04-08 23:04:42 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								USING:  help.markup  help.syntax  quotations  kernel  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								irc.messages irc.messages.base irc.messages.parser irc.client.chats ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								IN:  irc.client  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  connect-irc  "Connecting to an irc server"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "irc-client"  "an irc client object"  } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Connects and logins "  { $link irc-client } " using the settings specified on its "  { $link irc-profile } "."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								HELP:  attach-chat  "Chatting with irc channels/users/etc"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "irc-chat"  "an irc chat object"  } { "irc-client"  "an irc client object"  } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Registers "  { $snippet "irc-chat"  } " with "  { $snippet "irc-client"  } " and starts listening."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-10-06 16:56:54 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								HELP:  detach-chat  "Stop an unregister chat"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "irc-chat"  "an irc chat object"  } }
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $description "Unregisters "  { $snippet "irc-chat"  } " from "  { $snippet "irc-client"  } " and stops listening. This is how you part from a channel."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-07-08 15:57:53 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								HELP:  terminate-irc  "Terminates an irc client"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "irc-client"  "an irc client object"  } }
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $description "Terminates all activity by "  { $link irc-client } " cleaning up resources and notifying chats."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								HELP:  speak  "Sends a message through a chat"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "message"  "a string or irc message object"  } { "irc-chat"  "an irc chat object"  } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Sends "  { $snippet "message"  } " through "  { $snippet "irc-chat"  } ". Strings are automatically promoted to privmsg objects."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-07-08 15:57:53 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								HELP:  hear  "Reads a message from a chat"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "irc-chat"  "an irc chat object"  } { "message"  "an irc message object"  } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Reads "  { $snippet "message"  } " from "  { $snippet "irc-chat"  } "."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-07-08 15:57:53 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								ARTICLE: "irc.client"  "IRC Client" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"An IRC Client library"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $heading "IRC objects:"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections irc-client }
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $heading "Chat objects:"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    irc-server-chat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    irc-channel-chat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    irc-nick-chat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{ $heading "Setup objects:"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections irc-profile }
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{ $heading "Words:"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    connect-irc
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    terminate-irc
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    attach-chat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    detach-chat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    hear
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    speak
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{ $heading "IRC messages"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"Some of the RFC defined irc messages as objects:"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $table
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link irc-message } "base of all irc messages"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-03-05 20:11:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  { { $link rpl-welcome } "logged in to server"  }
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  { { $link ping } "ping message"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link join  } "channel join"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link part } "channel part"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link quit } "quit from irc"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link privmsg } "private message (to client or channel)"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link kick } "kick from channel"  }
							 
						 
					
						
							
								
									
										
										
										
											2009-03-05 20:11:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  { { $link rpl-names } "list of participants in channel"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link rpl-nickname-in-use } "chosen nick is in use by another client"  }
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  { { $link notice } "notice message"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link mode } "mode change"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link unhandled } "uninmplemented/unhandled message"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2009-04-08 23:04:42 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{ $heading "Special messages"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"Some special messages that are created by the library and not by the irc server."  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $table
							 
						 
					
						
							
								
									
										
										
										
											2008-10-06 16:56:54 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  { { $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. "  }
							 
						 
					
						
							
								
									
										
										
										
											2009-04-12 15:52:24 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  { { $link irc-end } " sent when the client isn't running anymore, the chat should stop after it receives this message."  }
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  { { $link irc-disconnected } " sent to notify chats that connection was lost."  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  { { $link irc-connected } " sent to notify chats that a connection with the irc server was established."  } }
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $heading "Example:"  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $code
							 
						 
					
						
							
								
									
										
										
										
											2009-04-08 23:04:42 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  "USING: irc.client irc.client.chats ;" 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  "SYMBOL: bot" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "SYMBOL: mychannel" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "! Create the profile and client objects" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "\"irc.freenode.org\" irc-port \"mybot123\" f <irc-profile> <irc-client> bot set" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "! Connect to the server" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "bot get connect-irc" 
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  "! Create a channel chat" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "\"#mychannel123\" <irc-channel-chat> mychannel set" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "! Register and start chat (this joins the channel)" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "mychannel get bot get attach-chat" 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  "! Send a message to the channel" 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-08 23:04:42 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  "\"Hello World!\" mychannel get speak" 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  "! Read a message from the channel" 
							 
						 
					
						
							
								
									
										
										
										
											2008-10-05 19:18:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  "mychannel get hear" 
							 
						 
					
						
							
								
									
										
										
										
											2008-06-09 19:40:54 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-10-06 16:56:54 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								ABOUT: "irc.client"