home *** CD-ROM | disk | FTP | other *** search
/ A Beginner's Guide to the Internet / INTERNET.ISO / text / irc / info / irc_shor.pri < prev    next >
Encoding:
Text File  |  1996-05-06  |  84.0 KB  |  2,169 lines

  1.                            A short IRC primer
  2.                           ====================
  3.  
  4.                                Written by:
  5.                                ~~~~~~~~~~
  6.                       Nicolas Pioch,  (Nap on IRC)
  7.                   < Nicolas.Pioch@grasp.insa-lyon.fr >
  8.  
  9.                            Text conversion by:
  10.                            ~~~~~~~~~~~~~~~~~~~
  11.                       Owe Rasmussen,  (Sorg on IRC)
  12.                       < d1rasmus@dtek.chalmers.se >
  13.  
  14.                     Edition 1.1b,  February 28, 1993.
  15.  
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29.                                 Abstract
  30.                                 ~~~~~~~~
  31.  
  32.    Have  you ever wanted to talk with other computer users in other parts
  33. of  the  world?  Well guess what...  You can!  The program is called IRC,
  34. (Internet  Relay Chat), and it is networked much over North America, Asia
  35. Europe, and Oceania.  This program is a substitution for 'talk', and many
  36. other  multiple  talk  programs  you might have read about.  When you are
  37. talking  on IRC, everything you type will instantly be transmitted around
  38. the  world  to  other users that might be watching their terminals at the
  39. time, they can then type something and respond to your messages, and vice
  40. versa.  I should warn you that the program can be very addictive once you
  41. begin  to make friends and contacts on IRC, especially when you learn how
  42. to discuss in 14 languages...
  43.  
  44.    Topics of discussion on IRC are varied, just like the topics of Usenet
  45. newsgroups  are varied.  Technical and political discussions are popular,
  46. especially  when  world  events  are  in  progress.  IRC is also a way to
  47. expand  your horizons, as people from many countries and cultures are on,
  48. 24  hours a day.  Most conversations are in English, but there are always
  49. channels  in  German,  Japanese,  French, Finnish, and occasionally other
  50. languages.
  51.  
  52.    IRC  gained  international fame during the late Persian Gulf War, when
  53. updates  from  around  the world came across the wire, and most people on
  54. IRC gathered on a single channel to hear these reports.
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.  
  66.                                 CONTENTS
  67.                                ~~~~~~~~~~
  68.  
  69. 1.     Getting started
  70.  
  71.         1.1    Clients and Servers
  72.         1.2    How to Behave on IRC
  73.         1.3    Privacy on IRC
  74.         1.4    First Steps
  75.         1.5    Screen and Keyboard activity
  76.  
  77.  
  78. 2.     Let's go!
  79.  
  80.         2.1    General Commands
  81.         2.2    Communication and Private Conversations
  82.         2.3    Channels and Public Conversations
  83.         2.4    Channel and User Modes
  84.         2.5    Client to Client Protocol
  85.         2.6    Network Related Commands
  86.         2.7    Quick Reference Panel
  87.         2.8    Further into ircII Wizardry
  88.         2.9    Sample .ircrc
  89.         2.10   Writing Automatons
  90.  
  91.  
  92. 3.     Frequently Asked Questions
  93.  
  94.         3.1    How do I set up an IRC client?
  95.         3.2    Which server do I connect to?
  96.         3.3    What are good channels to try while using IRC?
  97.         3.4    How do I get nifty effects with ircII?
  98.         3.5    What if someone tells me to type something cryptic?
  99.         3.6    I get strange characters on my screen, what are they?
  100.         3.7    What about NickServ?
  101.         3.8    I'm being flooded and harassed by a jerk. Help!
  102.         3.9    How do I get rid of a ghosted IRC session?
  103.         3.10   About KILL usage.
  104.         3.11   Where can I find more?
  105.  
  106.  
  107. 4.     Administrativia
  108.  
  109.         4.1    Revision history
  110.         4.2    Release sites for the IRCprimer
  111.         4.3    Copyright (C) 1993 Nicolas PIOCH
  112.         4.4    Credits
  113.  
  114.  
  115.  
  116.                              List of Tables
  117.                              --------------
  118.  
  119.            Table  1:  Editing keys
  120.            Table  2:  Editing commands
  121.            Table  3:  Simple screen activity
  122.            Table  4:  General commands
  123.            Table  5:  Private conversation commands
  124.            Table  6:  Channel commands
  125.            Table  7:  Mode commands
  126.            Table  8:  Channel modes
  127.            Table  9:  User modes
  128.            Table 10:  Client to client commands
  129.            Table 11:  Network related commands
  130.            Table 12:  Setting environment tables
  131.            Table 13:  Environment variables
  132.            Table 14:  Advanced commands
  133.            Table 15:  FTP sites with IRC clients
  134.            Table 16:  Open telnet IRC clients
  135.            Table 17:  Open IRC servers
  136.            Table 18:  Highlighting ircII output
  137.            Table 19:  Nordic countries character translations
  138.            Table 20:  IRC related mailing lists
  139.            Table 21:  IRCprimer release sites
  140.  
  141.  
  142.  
  143.                            1. GETTING STARTED
  144.                            ==================
  145.  
  146.                         1.1  Clients and Servers
  147.                         ~~~~~~~~~~~~~~~~~~~~~~~~
  148.  
  149.    IRC  (original code was written by Jarkko Oikarinen)  is a multi-user,
  150. multi-channel  chatting  network.  It allows people all over the internet
  151. to  talk to one another in real-time.  It is a functional replacement and
  152. improvement to 'talk'; 'talk' is an old, primitive, atrocious, minimalist
  153. sort  of  keyboard/screen  conversation tool, using a grotesque, machine-
  154. dependent  protocol  (blah!).   IRC does everything 'talk' does, but with
  155. better  protocol, allowing more than 2 users to talk at once, with access
  156. across the aggregate Internet, and providing a whole raft of other useful
  157. features.
  158.  
  159.    There  are two ways to enter IRC from a Unix system.  If you are using
  160. the   emacs    (editor  from  Richard  Stallman  and  the  Free  Software
  161. Foundation)   lisp  client,  you  just  have  to type "M-x irc", (if this
  162. doesn't  work  you  may need to load the client into your emacs session).
  163. If  you  are using the C client, (easier for beginners), then you usually
  164. type "irc".  Non-Unix boxes have special clients, each of which has to be
  165. configured using a special procedure. Check the manual or help screen for
  166. more information.
  167.  
  168.    If  you  wish  to be known by a nickname which is not your login name,
  169. type  "irc  nickname"  instead.   Each  IRC  user,  ("client"), chooses a
  170. nickname.   All  communication with another user is either by nickname or
  171. by  the channel that they or you are on  (more information about channels
  172. later on).
  173.  
  174.    The  most important thing to remember about IRC is that you have to be
  175. willing  to explore and learn to use it...  Take you time, try not to get
  176. flustered, enjoy  yourself,  and you will soon be making  new friends all
  177. over the world!
  178.  
  179.    IRC  is  based  on  a  client-server model.  Clients are programs that
  180. connect  to  a  server,  a  server  is  a  program  that transports data,
  181. (messages),  from a user client to another.  There are clients running on
  182. many  different systems, (Unix, emacs, VMS, MSDOS, VM...), that allow you
  183. to  connect to an IRC server.  The client which will be spoken of here is
  184. the  most  widespread:   ircII, (originally designed by Michael Sandrof).
  185. Other clients are similar, and often accept ircII commands.
  186.  
  187.  
  188.  
  189.  
  190.                         1.2  How to behave on IRC
  191.                         ~~~~~~~~~~~~~~~~~~~~~~~~~
  192.  
  193.    The  most  widely  understood  and  spoken language on IRC is English.
  194. However,  as  IRC  is  used in many different countries, English is by no
  195. means  the  only language.  If you want to speak some other language than
  196. English,  (for  example  with your friends), go to a separate channel and
  197. set  the topic to indicate that.  On the other hand, you should check the
  198. topic  before you move  to a channel to see if there are any restrictions
  199. about  language.   On  a  non-restricted channel, please speak a language
  200. everybody can understand. If you want to do otherwise,change channels and
  201. set the topic accordingly.
  202.  
  203.    It's  not  necessary  to  greet  everybody  on  a  channel personally.
  204. Usually  one "Hello!" or equivalent is enough. And don't expect everybody
  205. to  greet  you  back...   On a channel with 20 people that would mean one
  206. screenful of hellos.  It's sensible not to greet, in order not to be rude
  207. to  the rest of the channel.  If you must say hello to somebody you know,
  208. do it with a private message.  The same applies to goodbyes.
  209.  
  210.    Also  note  that using your client facilities, (ircII "ON" command for
  211. instance),  to  automatically say hello or goodbye to people is extremely
  212. poor  etiquette.   Nobody wants to receive autogreets.  They are not only
  213. obviously  automatic,  but  even  if  you  think  you  are polite you are
  214. actually  sounding  insincere  and  also  interfering  with  the personal
  215. environment of the recipient when using autogreets.  If somebody wants to
  216. be autogreeted on joining a channel, he will autogreet himself.
  217.  
  218.   Remember,  people  on  IRC  form  their opinions about you only by your
  219. actions,  writings  and  comments,  so think before you type.  If you use
  220. offensive  words,  you'll be frowned upon.  Do not "dump" to a channel or
  221. user,  (send  large  amounts of unwanted information).  This is likely to
  222. get  you  kicked  off the channel or killed off from IRC.  Dumping causes
  223. network "burps", connections going down because servers cannot handle the
  224. large amount of traffic anymore. Other prohibited actions include:
  225.  
  226.         * Harassing another user.  Harassment is defined as behavior
  227.           towards another user with the purpose of annoying them.
  228.  
  229.         * Annoying a channel with constant beeping.
  230.  
  231.         * Any behavior reducing the functionality of IRC.
  232.  
  233.  
  234.  
  235.  
  236.  
  237.                            1.3  Privacy on IRC
  238.                            ~~~~~~~~~~~~~~~~~~~
  239.  
  240.    You  should always keep in mind that messages you send to someone over
  241. IRC are passed along  all the servers  between you and and the person you
  242. are writing to.  When you're sending a letter to someone,  any postman on
  243. the way could open it and read its contents...
  244.  
  245.    Well,  it's  the same on the network.  Any IRC-Admin could compile its
  246. server  in "debug" mode and log whatever messages are transmitted through
  247. his  node,  (it  has  already  been done), so a good thumb rule is not to
  248. trust the servers.
  249.  
  250.               +-------------------------------------------+
  251.               | IRC IS NOT A SECURE WAY OF COMMUNICATION! |
  252.               +-------------------------------------------+
  253.  
  254.    How  to  establish  direct  communications  between  clients  will  be
  255. explained later, (see DCC CHAT in section 2.5).  This should be used when
  256. you wouldn't want anybody else on IRC to intercept your private messages.
  257.  
  258.  
  259.  
  260.  
  261.  
  262.                             1.4  First Steps
  263.                             ~~~~~~~~~~~~~~~~
  264.  
  265.    Note:   ircII,  the  client  most  people  are using, has most of this
  266. information online.  If you are stuck, type "/HELP" and hit <return>.  To
  267. escape  from HELP mode, keep pressing <return> until your edit line, (the
  268. line  at the bottom of the screen), is empty.  Most of the information in
  269. this  file  can  be found typing these commands:  "/HELP INTRO" or "/HELP
  270. NEWUSER".
  271.  
  272.            +------------------------------------------------+
  273.            | All ircII commands begin with a "/" character. |
  274.            +------------------------------------------------+
  275.  
  276.    The  slash  is  the  default command character.  Commands are not case
  277. sensitive,  and  can  be  abbreviated  to  their first letters: "/SI" and
  278. "/sign  <text>"  stand  for  /SIGNOFF and will both end your IRC session,
  279. (more in section 2.1).
  280.  
  281.    Anything  that  does  not begin with "/" is assumed to be a message to
  282. someone  and will be sent to your current channel, or to a person you are
  283. QUERYing,  (the  QUERY  command  will  be  detailed  later on, maybe even
  284. section 2.2).
  285.  
  286.    If  you  are not sure about the spelling of an ircII command, type the
  287. prefix  of  that command, and press the ESCape key twice; ircII will give
  288. you a listing of commands and aliases that start with that prefix.  Don't
  289. forget the "/" in front of the command though.
  290.  
  291.         /W <ESC><ESC>
  292.         *** Commands:
  293.         ***     WAIT            WALL            WALLOPS         WHICH
  294.         ***     WHILE           WHO             WHOIS           WHOWAS
  295.         ***     WINDOW
  296.         *** Aliases:
  297.         ***     W
  298.  
  299.    This  is  an  example.   Your  screen  may show more aliases, and less
  300. commands  than  shown  here, or less aliases and more commands - in other
  301. words "your mileage may vary"...
  302.  
  303.  
  304.  
  305.  
  306.                     1.5  Screen and Keyboard activity
  307.                     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  308.  
  309.    IRC is a full-screen utility.  It takes over the screen, with the bulk
  310. of  activity  happening  in  the top (N-2) lines, a status line, (vaguely
  311. emacs-like),  on  the  next to last line, and your input being entered on
  312. the  last  line.   When  typing  commands at ircII, you have a minimalist
  313. line-editing facility in an emacs style.
  314.  
  315.  
  316.                          Table 1:  Editing keys
  317.                          ----------------------
  318.            Key      Effects
  319.            ~~~      ~~~~~~~
  320.             ^P      recalls previous command line
  321.             ^N      recalls next command line
  322.             ^F      moves forward one character
  323.             ^B      moves backward one character
  324.             ^A      moves the cursor to the beginning of the line
  325.             ^E      moves the cursor to the end of the line
  326.             ^D      deletes the character under the cursor
  327.             ^K      kills from the cursor to the end
  328.             ^Y      reinserts the last stretch of killed text
  329.             ^U      clears the whole line
  330.             ^L      redraws the screen
  331.  
  332.  
  333.                        Table 2:  Editing commands
  334.                        --------------------------
  335.            Keyword   Action
  336.            ~~~~~~~   ~~~~~~
  337.            !         recalls previous commands for re-editing
  338.            HISTORY   displays the command history
  339.            LASTLOG   lists the most recent messages
  340.            CLEAR     puts some white space on your screen
  341.  
  342.  
  343.    The  !   command  is  used to recall previous commands in your command
  344. history  for  re-execution.   The !  command is unique in that when it is
  345. used,  it  leaves  the  matching  history  entry  in  the  input line for
  346. re-editing.   You can specify a history entry either by its number in the
  347. history  list,  or  by  a  match  with  a given wildcard expression.  For
  348. instance,  "/!10"  will put  entry 10 in the history list  into the input
  349. line.  "/!/MSG" will search the history for a line beginning with a /MSG,
  350. (a "*" is implied at the end).
  351.  
  352. /![<history number>|<history match>]
  353.    Recalls previous commands for re-editing.
  354.  
  355.    The command history can be dumped using:
  356.  
  357. /HISTORY [<number>]
  358.    Displays  the  command  history  on  the  screen.  You can specify the
  359. number of history entries you wish to view as well.
  360.  
  361.  
  362.  
  363.    Almost  everything  happens  in  the  upper bulk  of the screen.  This
  364. includes  both  messages from other users,  as well as  the output of the
  365. control commands.  Normal  messages  from  other  users  appear  with the
  366. originating nickname in  <angle brackets>.  Private messages  arrive with
  367. the originating nickname  in  *asterisks*.  Messages you send to everyone
  368. appear with a preceding  "> "  whereas  messages  you  send  privately to
  369. another  user  appear  with  "-> *nickname*".  Other output  (invitations
  370. from other users  to join channels,  and so forth),  appears interspersed
  371. with other activity on the screen.
  372.  
  373.  
  374.                     Table 3:  Simple screen activity
  375.                     --------------------------------
  376.  
  377.   What is displayed    What you typed      Sender     Recipients
  378.   ~~~~~~~~~~~~~~~~~    ~~~~~~~~~~~~~~      ~~~~~~     ~~~~~~~~~~
  379.   > Morning people     Morning, people     You        Channel
  380.   <some1else> hello                        some1else  Channel
  381.   -> *some1else* hi!   /msg some1else hi!  You        some1else (only)
  382.   *some1else* wassup?                      some1else  You (only)
  383.  
  384.  
  385.  
  386.    Last ircII outputs can be recalled with:
  387.  
  388. /LASTLOG [<number of entries>|<text> [<from entry>]]
  389.    Displays  the  contents  of  the  lastlog.  This is a list of the most
  390. recent  messages  that  have  appeared  on  the  screen,  useful  if  you
  391. inadvertantly  miss  messages.   If  no  arguments  are given, the entire
  392. lastlog  is  displayed.  If the first argument is a number, it determines
  393. how  many  log  entries  to  show.  Otherwise it is searched for in every
  394. lastlog  entry.   The  second  argument determines how many lines back to
  395. start display from.
  396.  
  397.         Example:
  398.  
  399.         /LASTLOG
  400.         > Public message I send to all in the channel
  401.         <some1else> Public message from some1else
  402.         *some1else* Private message sent to me by some1else
  403.         -> *some1else* Private message I send to some1else
  404.  
  405.    Finally, if your screen gets garbage from a 'talk', 'write', 'wall' or
  406. any other form of primitive communication (smirk), hit ^L to redraw it,
  407. or CLEAR it.
  408.  
  409. /CLEAR
  410.    Clears the screen.
  411.  
  412.  
  413.  
  414.  
  415.  
  416.                               2. LET'S GO!
  417.                               ============
  418.  
  419.                          2.1  General  Commands
  420.                          ~~~~~~~~~~~~~~~~~~~~~~
  421.  
  422.                        Table 4:  General commands
  423.                        --------------------------
  424.     Keyword   Action
  425.     ~~~~~~~   ~~~~~~
  426.     NICK      changes your nickname
  427.     QUIT      exits your IRC session, (same as BYE, SIGNOFF and EXIT)
  428.     HELP      prints help on the given command
  429.     WHOIS     displays information about someone
  430.     WHOWAS    displays information about someone who just left
  431.     AWAY      leaves a message saying you're not paying attention
  432.  
  433.  
  434.  
  435. /NICK [<nickname>]
  436.    Changes your nickname to whatever you like.
  437.  
  438.    Everyone  who  wants  to  talk  to  you  sees this name - also, at the
  439. moment, nicknames are limited to 9 characters max.  Your nickname will be
  440. the  same as your login name by default.  You can also set an environment
  441. variable,  IRCNICK,  the  value  of which will be used instead.  Nickname
  442. clashes  are  not  allowed;  this  is  enforced  by the servers.  If your
  443. intended  nickname clashes with someone else's as you enter IRC, you will
  444. not be able to enter until you change it to something else.
  445.  
  446.         /NICK Nappy
  447.         *** Nap is now known as Nappy
  448.  
  449.  
  450.  
  451. /QUIT [<reason>]
  452.    Exits your IRC session.  You can also use BYE, SIGNOFF and EXIT.  If a
  453. reason is supplied, it is displayed to other people on your channels.
  454.  
  455.         /QUIT Lunch Time!
  456.         poly ~ >
  457.  
  458.  
  459.  
  460. /HELP [<command>]
  461.    Shows help on the given command.
  462.  
  463.         /HELP HELP
  464.         Usage: HELP [command]
  465.            Shows help on the given command. The help documentation is set
  466.            up in a  hierarchical fashion.  That  means that  certain help
  467.            topics have sub-topics under them.
  468.         [boring stuff deleted]
  469.  
  470.  
  471.  
  472. /WHOIS [<nickname>]
  473.    Shows information about someone.
  474.  
  475.         /WHOIS Nap
  476.         *** Nap is pioch@poly.polytechnique.fr (Klein bottle for sale...
  477.            inquire within.)
  478.         *** on channels: @#Twilight_Zone @#EU-Opers
  479.         *** on via server poly.polytechnique.fr (Ecole Polytechnique,
  480.           Paris, FRANCE ! )
  481.         *** Nap has a connection to the twilight zone (is an IRC operator)
  482.         *** Nap has been idle 0 seconds
  483.  
  484.         /WHOIS Nappy
  485.         *** Nappy: No such nickname
  486.  
  487.  
  488.    Sometimes WHOIS won't help you much, because the person you want to
  489. know more about just left IRC or changed nick.  However, you can use
  490. WHOWAS to get this information for a while:
  491.  
  492. /WHOWAS [[<server>] <nickname>]
  493.    Shows  information  about who used the given nickname last, even if no
  494. one is currently using it.
  495.  
  496.         /WHOWAS Nappy
  497.         *** Nappy was pioch@poly.polytechnique.fr (Artistic ventures
  498.           highlighted. Rob a museum.) on channel *private*
  499.         *** on irc via server poly.polytechnique.fr (Signoff: Mon Jun 22
  500.           20:15:23)
  501.  
  502.  
  503.    Very  often,  an  unsuccess call to WHOIS will lead you to try WHOWAS.
  504. That's  why  ircII  allows you to "/SET AUTO_WHOWAS ON"; that way, a "***
  505. <nickname>:   No  such  nickname"  message  will automagically generate a
  506. "/WHOWAS  <nickname>".   Try  typing  "/HELP  SET  AUTO_WHOWAS"  for more
  507. information on this topic.
  508.  
  509.  
  510.  
  511. /AWAY [<away message>]
  512.    Leave a message explaining that you are not currently paying attention
  513. to  IRC.   Whenever  someone sends you a MSG or does a WHOIS on you, they
  514. automatically   see  whatever  message  you  set.   Using  AWAY  with  no
  515. parameters marks you as no longer being away.
  516.  
  517.         /AWAY Gone to get a cup of coffee.
  518.         *** You have been marked as being away
  519.  
  520.         /AWAY
  521.         *** You are no longer marked as being away
  522.  
  523.  
  524.  
  525.  
  526.                2.2  Communication and Private Conversation
  527.                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  528.  
  529.                  Table 5: Private conversation commands
  530.                  --------------------------------------
  531.       Keyword  Action
  532.       ~~~~~~~  ~~~~~~
  533.       MSG      sends a private message
  534.       QUERY    starts a private conversation
  535.       NOTICE   sends a private message
  536.       NOTIFY   warns you of people logging in or out IRC
  537.       IGNORE   removes output from specific people off your screen
  538.  
  539.  
  540.    You can use the MSG command, (usually "M" is an alias for it), to send
  541. someone a message that only that person can read.
  542.  
  543. /MSG <nickname>|<channel> <text>
  544.    Send a private message to specified nickname.
  545.  
  546.         /MSG Nap This message is for Nap only.
  547.         -> *Nap* This message is for Nap only.
  548.  
  549.         On my screen will appear:
  550.  
  551.         *YourNick* This message is for Nap only.
  552.  
  553.  
  554.    If you want to send a private message to more than one person, you can
  555. specify a list of nicknames separated by commas, (no spaces).
  556.  
  557.         /MSG Nap,Sorg This message for both Nap and Sorg.
  558.         -> *Nap* This message for both Nap and Sorg.
  559.         -> *Sorg* This message for both Nap and Sorg.
  560.  
  561.  
  562.  
  563.    Two  special  case  nicknames  are defined.  If the nickname is "," (a
  564. comma),  the  message  is sent to the last person who sent you a MSG.  If
  565. the nickname is "." (a period), the message is sent to the last person to
  566. whom you sent a message.
  567.  
  568.    You  can  have  a  private  conversation by only using /MSG.  However,
  569. typing  "/MSG <nick> <text>" or "/MSG .  <text>" gets cumbersome.  That's
  570. where the /QUERY command comes in handy.
  571.  
  572.  
  573. /QUERY [<nickname>|<channel>]
  574.    Starts a private conversation with <nickname>.
  575.  
  576.    All text you type that would normally be sent to your channel now goes
  577. to  the  supplied  nickname  in  the  form  of MSGs.  To cancel a private
  578. conversation, use QUERY with no arguments.
  579.  
  580.         /QUERY Nap
  581.         *** Starting conversation with Nap
  582.  
  583.         Blahblahblah
  584.         -> *Nap* Blahblahblah
  585.  
  586.         /QUERY
  587.         *** Ending conversation with Nap
  588.  
  589.  
  590.  
  591.    There is also another command to send messages, called NOTICE.  Unlike
  592. MSGs,  NOTICEs  are  surrounded  by  '-'  when  printed, and no automated
  593. responses, (such as generated by IGNORE or an automaton), will be sent in
  594. reply.  Services, (robots), on IRC often use this form of interaction.
  595.  
  596.  
  597. /NOTICE <nickname>|<channel> <text>
  598.    Sends a private message to the specified <nickname>.
  599.  
  600.         /NOTICE Nap Better use /MSG instead of /NOTICE.
  601.         -> -Nap- Better use /MSG instead of /NOTICE.
  602.  
  603.         On my screen will appear:
  604.  
  605.         -YourNick- Better use /MSG instead of /NOTICE.
  606.  
  607.  
  608.  
  609.    As you begin to make new friends over IRC, you'll want to mark certain
  610. nicknames such that you will be warned when they signon or off.
  611.  
  612. /NOTIFY [[-]<nickname>]
  613.    Adds or removes <nickname> to the list of people you'll be warned when
  614. they enter or quit IRC   (in ircII versions prior to 2.2, too many people
  615. in the NOTIFY list cause excessive slowness).
  616.  
  617.         /NOTIFY Nap Nappy
  618.         *** Signon by Nap detected
  619.  
  620.         /NOTIFY
  621.         *** Currently present: Nap
  622.         *** Currently absent: Nappy
  623.  
  624.  
  625.  
  626.    Eventually,  you may wish some day not to see messages from a specific
  627. user  on  your  screen.   This  may  happen when someone is dumping large
  628. amounts  of garbage, or if someone is harassing you.  The proper response
  629. to  such a behavior is to  IGNORE that person.  IGNORE is a very powerful
  630. command,  and  can be used in many ways.  However the basic usage of this
  631. tool is the following.
  632.  
  633.  
  634. /IGNORE [<nickname>|<user@host> [[-]<message type>]]
  635.    Suppresses  output from the given people from your screen.  IGNORE can
  636. be  set by nickname or by specifying a userid@hostname format.  Wildcards
  637. may  be  used  in all formats.  Output that can be ignored includes MSGs,
  638. NOTICEs,  PUBLIC messages, INVITEs, ALL or NONE.  Preceding a type with a
  639. "-" indicates removal of ignoring of that type of message.
  640.  
  641.         /IGNORE *@cheshire.oxy.edu ALL
  642.         *** Ignoring ALL messages from *@CHESHIRE.OXY.EDU
  643.  
  644.         /IGNORE
  645.         *** Ignorance list:
  646.         ***     *@CHESHIRE.OXY.EDU      ALL
  647.  
  648.         /IGNORE *@cheshire.oxy.edu NONE
  649.         *** *@cheshire.oxy.edu removed from ignorance list
  650.  
  651.  
  652.  
  653.  
  654.  
  655.                  2.3  Channels and Public Conversations
  656.                  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  657.  
  658.    On  IRC,  there  are  a  lot of places where you can "hang out"; those
  659. places  are  called  'channels', (most of the information in this section
  660. can  also  be  obtained  by  issuing  "/HELP  CHANNEL").  You can compare
  661. conversations  on  a  channel  to a conversation among a group of people:
  662. you  see/hear  everything  that  is  said,  and you can reply to anything
  663. that's  said.   What  you  type  is received by everyone who's willing to
  664. listen  -  and  everyone  who is late will not hear what was said before,
  665. unless  repeated  by  one  of  the  ones who were there.  (Who said "real
  666. life" ?)
  667.  
  668.    All  channels  on IRC have names:  a "#" sign followed by some kind of
  669. text-string,  like "#C++" or "#Asians" or "#EU-Opers".  Usually, the name
  670. of  the channel will indicate the type of conversation that's going on in
  671. there.  Don't count on it, though.
  672.  
  673.                        Table 6:  Channel commands
  674.                        --------------------------
  675.        Keyword   Action
  676.        ~~~~~~~   ~~~~~~
  677.        LIST      lists channels, number of users, topic
  678.        NAMES     shows the nicknames of the users on each channel
  679.        JOIN      sets your current channel, (same as CHANNEL)
  680.        WHO       gives a listing of users
  681.        INVITE    sends an invitation to another user
  682.        LEAVE     leaves a channel, (same as PART)
  683.        KICK      gets rid of someone on a channel
  684.        TOPIC     changes the topic of the channel
  685.        ME        sends anything about you to a channel or QUERY
  686.        DESCRIBE  sends anything about you to a person or channel
  687.  
  688.  
  689.    Every channel has certain characteristics, called channel modes.
  690. These will also be explained below.  Recall the NAMES and LIST
  691. commands; they will show you the names of the existing channels.
  692.  
  693. /LIST [[<flags>] <channel mask>]
  694.   Lists  all  current  "channels",  number  of  users,  and  topic.   The
  695. displayed  list  may  be  quite  long,  so  you can limit it using flags.
  696. "/LIST  -MIN n" for instance removes channels with less than 'n' users of
  697. the output.
  698.  
  699.         Example:
  700.  
  701.         /LIST -MIN 5
  702.         *** #aussies   5
  703.         *** #amiga     5        Daily Amiga Silence...join&enjoy
  704.         *** #hottub    21       Imagine sky, high above...
  705.         *** #tuebingen 11       Happy Borthday CHUCK!!!
  706.         *** #Christian 6        Jesus!
  707.         *** #Twilight_ 15       The Oper Bar & Grill
  708.         *** #initgame  5        More players needed!!!!!!!!!!!!
  709.         *** #Taiwan    8        Welcome good friends.
  710.         *** #espanol   6        EMERGENCIA SE Necesitan Mujeres!
  711.         *** #sherwood  7
  712.         *** #francais  6        on apprend le japonais (japanese welcome)
  713.  
  714.  
  715.  
  716. /NAMES [[<flags>] <channel mask>]
  717.    Shows the nicknames of all users on each "channel", (these may be very
  718. long.  Remember to filter them with "-MIN n" or "-MAX n").
  719.  
  720.         /NAMES -MIN 5
  721.         Pub: #twilight> Mycroft @sojge scorpio @Troy @Avalon @Nap phone
  722.            Merlinus Lumberjak @tzoper
  723.         Pub: #espanol   Cacique Bonjovi leopardo Carina Miguel Cisco r2
  724.         Pub: #amiga     @gio @Radix @xterm @mama @AmiBot 
  725.         Pub: #aussies   @Bleve @GrayElf @Insomniac @Morkeleb @titus
  726.         Pub: #hottub    baby @Aldur KnightOrc @Toasty Gwydion @Belkira
  727.            @Aiken Edge @Spockobot @Nada @ZBot @Aurik @anna @RedBaron
  728.            @Katzen @esashi IceWolf @Eniigma @Digger @TheHeck
  729.  
  730.  
  731.  
  732.    To  join in the conversation on a certain channel you may use the JOIN
  733. command.
  734.  
  735. /JOIN [<channel>]
  736.    Sets your current channel to the supplied channel.
  737.  
  738.         /JOIN #Twilight_Zone
  739.         *** Nap has joined channel #Twilight_Zone
  740.         *** Topic: The Gernsback Continuum
  741.         *** Users on #Twilight_Zone: Nap msa tober phone @julia @SirLance
  742.           igh @Daemon @Avalon @Waftam @Trillian @tzoper
  743.  
  744.    The CHANNEL command has the same effects. Note that if no parameters
  745. are given, your current channel is displayed.
  746.  
  747.    Upon  entering a channel, you are given useful details about it:  list
  748. of  users  talking  in that channel, topic...  Joining a channel does not
  749. cause you to leave your previous channel unless NOVICE is set to ON.  See
  750. "/HELP SET NOVICE".
  751.  
  752.  
  753.  
  754.   Once  in  a  channel, you may wish to get a detailed list of the people
  755. IRCing inside.  That's where the WHO command comes in handy:
  756.  
  757. /WHO [<channel>|<wildcard expression>]
  758.    Gives  a  listing  of  users.   "/WHO *" for the list of users in your
  759. current channel.
  760.  
  761.         /WHO #Twilight_Zone
  762.         Channel    Nickname     S    User@Host (Name)
  763.         #Twilight_ Nap          H*   pioch@poly.polytechnique.fr
  764.           (Quidquid latine dictum sit, altum viditur)
  765.         #Twilight_ msa          H    msa@tel1.tel.vtt.fi (Markku Savela)
  766.         #Twilight_ tober        H    ircuser@kragar.eff.org (tober)
  767.         #Twilight_ phone        H    mrgreen@munagin.ee.mu.OZ.AU (Third
  768.           row seats to the Cure? WHO ME? nah.. *grin*)
  769.         #Twilight_ julia        G*@  julie@turing.acs.Virginia.EDU
  770.           ( Future graduate of ACME Looniversity)
  771.         #Twilight_ SirLance     G*@  lancelot@tdsb-s.mais.hydro.qc.ca
  772.           (Sir Lancelot)
  773.         #Twilight_ igh          G    igh@micom1.servers.unsw.EDU.AU (igh)
  774.         #Twilight_ Daemon       G*@  frechett@spot.Colorado.EDU
  775.           (-=Runaway Daemon=-)
  776.         #Twilight_ Avalon       H*@  avalon@coombs.anu.edu.au (Avalon...)
  777.         #Twilight_ Waftam       G*@  danielce@munagin.ee.mu.OZ.AU (Daniel
  778.           Carosone)
  779.         #Twilight_ Trillian     G*@  hrose@rocza.eff.org ( I turn to
  780.           stone when you are gone )
  781.         #Twilight_ tzoper       H*@  tzoper@azure.acsu.buffalo.edu (/msg
  782.           tzoper help)
  783.  
  784.    The  first  field  is the current channel, then nickname, status, real
  785. name  (in internet user@host form), and a small witty comment you can set
  786. yourself with the environment variable IRCNAME, (this will be detailed in
  787. section  2.8).   Status  indicates  if  a  user is "H"ere or "G"one, (see
  788. AWAY), if IRCop ("*"), and/or chanop ("@").
  789.  
  790.  
  791.  
  792.    It is also possible, when you are already on a channel, to ask someone
  793. to join your channel.  The command is called INVITE.
  794.  
  795. /INVITE <nickname> [<channel>]
  796.    Invites  another  user to a channel.  If no channel is specified, your
  797. current channel is used.
  798.  
  799.         /INVITE Nap
  800.         *** Inviting Nap to channel #Twilight_Zone
  801.  
  802.    If you receive an INVITE message, you can type "/JOIN -INVITE" to join
  803. the channel to which you were last invited, or simply "/JOIN <channel>".
  804.  
  805.  
  806.  
  807.    To  leave  a  channel,  just issue a LEAVE command, (PART has the same
  808. effects):
  809.  
  810. /LEAVE <channel>
  811.    Leave a channel.
  812.  
  813.         /LEAVE #Twilight_Zone
  814.         *** Nap has left #Twilight_Zone
  815.  
  816.  
  817.  
  818.    Well,  you  guessed  it,  if  there  is  a  way to invite someone on a
  819. channel,  there's  also  the  possibility  to KICK someone out of it, for
  820. example  if  this  person  is  behaving  like  a jerk, annoying people or
  821. flooding the channel with unwanted information:
  822.  
  823. /KICK [<channel>] <nickname>
  824.    Kicks  named  user  off a given channel.  Only 'channel operators' are
  825. privileged to use this command.
  826.  
  827.         /KICK #Twilight_Zone Target
  828.         *** Target has been kicked off channel #Twilight_Zone by Nap
  829.  
  830.  
  831.  
  832.    Channels have topics, that indicate the current topic of conversation.
  833. You can change this topic on a channel with the TOPIC command.
  834.  
  835. /TOPIC [[<channel>] <topic for channel>]
  836.     Changes the topic for the channel.
  837.  
  838.         /TOPIC The silent channel.
  839.         *** Nap has changed the topic on channel #EU-Opers to The silent
  840.           channel.
  841.  
  842.  
  843.  
  844.    At  times, you may want to send a description of what you are doing or
  845. how  you  are  feeling  or  just anything  concerning you  to the current
  846. channel  or  query.  It is absolutely good style to not forget the period
  847. at the end of the sentence!
  848.  
  849. /ME <action description>
  850.    Tells the current channel or query about what you are doing.
  851.  
  852.         /ME opens up the fridge.
  853.         * Nap opens up the fridge.
  854.  
  855.         You can also use your own nickname as command, i.e. you can type
  856.         the line with a leading slash:
  857.  
  858.         /Nap reaches out for the orange juice.
  859.         * Nap reaches out for the orange juice.
  860.  
  861.  
  862.    The same goal can be achieved towards a specific nickname using:
  863.  
  864. /DESCRIBE <nickname>|<channel> <action description>
  865.    Sends anything concerning you to the <nickname> or <channel> you pass
  866. as first argument.
  867.  
  868.  
  869.  (Note:  The look of the result depends on each client version, and might
  870.          not be exactly the same as in the examples shown here.)
  871.  
  872.    These  commands  make use of CTCP, a client-to-client protocol crafted
  873. to  perform  specific actions,  but  not understood by all clients, (more
  874. about  CTCP  in  section  2.5).   If  you  get  an  error  message,  your
  875. description may not have arrived properly.
  876.  
  877.  
  878.  
  879.  
  880.  
  881.                        2.4  Channel and User Modes
  882.                        ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  883.  
  884.    Channels can have additional constraints, which can be set by the MODE
  885. command, (most of the information in this section can also be obtained by
  886. issuing  "/HELP MODE").  To understand this, recall that the first person
  887. to JOIN a channel effectively creates it  and is initially "in charge" of
  888. the  channel,  ("Channel Operator" or "chanop").  He/She can subsequently
  889. add those constraints, make other people chanops at leisure.
  890.  
  891.                          Table 7:  Mode commands
  892.                          -----------------------
  893.                   Keyword  Action
  894.                   ~~~~~~~  ~~~~~~
  895.                   MODE     changes channel or user mode
  896.  
  897.  
  898.    Public is the default mode for a channel.  When someone is on a public
  899. channel, he can be seen by all other users, (if his own user mode permits
  900. this).   Anyone  can  notice  users  on  a public channel and join such a
  901. conversation.
  902.  
  903.    Private means that, although anyone can see members of such a channel,
  904. you  can't  tell  what channel they are on unless you are already on that
  905. channel  with  them.   They  just  appear  as "Prv:  *" in LIST or NAMES.
  906. Since  the number of potential channels is in the billions, this is quite
  907. some  security  -  all  you  give away is the acknowledgement that you're
  908. IRCing.
  909.  
  910.    If you are on a secret channel, someone who is not on the same channel
  911. can't  even see that you are there.  Your name does not show up in a LIST
  912. of  active  users.   The  only  indication of your presence is that, when
  913. entering  IRC,  all new users are told that there are "NNNNN users on XXX
  914. servers".   If someone  checks  on all users and finds less than NNNNN of
  915. them,  he  knows  that other people are hiding on secret channels.  But a
  916. secret  channel user still cannot be found except by brute-force checking
  917. through  all  channels,  a  hopeless  proposition in the face of the huge
  918. number  of  possible  channel  names.  Security through obscurity finally
  919. means something.
  920.  
  921.  
  922.  
  923. /MODE <channel>|<nickname> [[+|-]<modechars> [<parameters>]]
  924.    Allows channel operators to change channel mode, or any user to change
  925. their personal mode, (don't use this command too often, it floods the net
  926. with worthless information).
  927.  
  928.         /MODE #Twilight_Zone +m
  929.         *** Mode change "+m" on channel #Twilight_Zone by Nap
  930.  
  931.         /MODE Nap -i
  932.         *** Mode change "-i" for user Nap by poly.polytechnique.fr
  933.  
  934.         And this is how to give 'chanop' status to someone on the channel
  935.  
  936.         /MODE #Twilight_Zone +o sojge
  937.         *** Mode change "+o sojge" on channel #Twilight_Zone by Nap
  938.  
  939.  
  940.  
  941.    A + or - sign  determines whether the mode should be added or deleted.
  942. Try typing  "/HELP MODE"  to  get  further  information.  Channels can be
  943. moderated (only chanops can talk), secret, private, with a limited number
  944. of users, anonymous,  invite-only,  topic-limited,  with a list of banned
  945. users...
  946.  
  947.    The  MODE  command also allows you to modify your personal parameters,
  948. your  "user  mode".   You can check your usermode with the command "/MODE
  949. <YourNick>"  or  sometimes  "/UMODE".   Note that user mode +i may be the
  950. default  on  some  servers,  in  order to protect privacy of users.  This
  951. should  not  be  seen  as  a  problem,  since any user can change his/her
  952. personal mode whatever defaults a server may set.
  953.  
  954.  
  955.                          Table 8:  Channel modes
  956.                          -----------------------
  957.         ModeChar        Effects on channels
  958.         ~~~~~~~~        ~~~~~~~~~~~~~~~~~~~
  959.         b <person>      ban somebody, <person> in "nick!user@host" form
  960.         i               channel is invite-only
  961.         l <number>      channel is limited, <number> users allowed max
  962.         m               channel is moderated, (only chanops can talk)
  963.         n               external /MSGs to channel are not allowed
  964.         o <nick>        makes <nick> a channel operator
  965.         p               channel is private
  966.         s               channel is secret
  967.         t               topic limited, only chanops may change it
  968.  
  969.  
  970.                           Table 9:  User modes
  971.                           --------------------
  972.         ModeChar        Effects on nicknames
  973.         ~~~~~~~~        ~~~~~~~~~~~~~~~~~~~~
  974.         i               makes yourself invisible to anybody that does
  975.                         not know the exact spelling of your nickname
  976.         o               IRC-operator status, can only be set
  977.                         by IRC-ops with OPER
  978.         s               receive server notices
  979.         w               receive wallops (abused and deprecated)
  980.  
  981.  
  982.  
  983.  
  984.  
  985.                      2.5  Client to Client Protocol
  986.                      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  987.  
  988. /CTCP <nickname> <command> [<argument>]
  989.    Allows you to perform certain client specific actions on the network.
  990.  
  991.         /CTCP Nap VERSION
  992.         *** CTCP VERSION reply from Nap: ircII 2.2 *IX
  993.            :ircII 2.2, SL0 The one you thought you'd never see.
  994.  
  995.         This can be used to get information about how long a person has
  996.         been idle:
  997.  
  998.         /CTCP Nap FINGER
  999.         *** CTCP FINGER reply from Nap: PIOCH Nicolas - Nap on IRC, X90,
  1000.           (pioch@poly.polytechnique.fr) Idle 0 seconds
  1001.  
  1002.  
  1003.                   Table 10:  Client to Client Commands
  1004.                   ------------------------------------
  1005.          Keyword    Action
  1006.          ~~~~~~~    ~~~~~~
  1007.          CTCP       performs certain client specific actions
  1008.          DCC        handles direct connections to remote clients
  1009.          DCC SEND   initiates a file transfer
  1010.          DCC GET    accepts a file transfer
  1011.          DCC CLOSE  ends a DCC connection or offer
  1012.          DCC LIST   shows current DCC connections
  1013.          DCC CHAT   initiates a secure chat between two clients
  1014.  
  1015.  
  1016.  
  1017.    There  are  many  other CTCP commands, and new ones are introduced all
  1018. the  time.   There  is  a mechanism for you to find out what you can use:
  1019. CTCP  CLIENTINFO.   To find out about your own client services, execute a
  1020. CLIENTINFO on yourself.
  1021.  
  1022.         /CTCP Nap CLIENTINFO
  1023.         *** CTCP CLIENTINFO reply from Nap: SED VERSION CLIENTINFO
  1024.            USERINFO ERRMSG FINGER TIME ACTION DCC UTC PING :Use
  1025.            CLIENTINFO <COMMAND> to get more specific information
  1026.  
  1027.    If  you are interested in this powerful CTCP mechanism, have a look in
  1028. the  various  ircII  help  files.   "/HELP  CTCP"  might tell you more...
  1029. However  the  client-to-client  protocol  has  a  very  powerful feature:
  1030. Allowing two people to exchange files.
  1031.  
  1032.    To  send  small  text  files,  electronic  mail  is  probably the best
  1033. solution, (don't rely on the user@host given by the WHOIS command to send
  1034. mail.     For    people   registered   on   NickServ,   you   can   "/MSG
  1035. NickServ@Service.de  WHOIS  nick" to get their E-mail address).  However,
  1036. ircII  provides  you a way to establish Direct Client Connections ("DCC")
  1037. to perform functions like sending and receiving files.
  1038.  
  1039.  
  1040.  
  1041. If NickA wants to send a file to NickB, then NickA should type:
  1042.         /DCC SEND NickB filename
  1043.  
  1044. On NickB's screen will appear:
  1045.         *** DCC SEND (filename) request received from NickA
  1046.  
  1047. If he, (NickB), wants to get the file, he just needs to type:
  1048.         /DCC GET NickA filename
  1049.  
  1050. A few seconds later
  1051.         *** DCC GET connection with NickA established
  1052.         *** DCC GET filename connection to NickA completed
  1053. will   inform  both  users  that  data  transfer  has  been  successfully
  1054. completed.
  1055.  
  1056.  
  1057.  
  1058.    Here's a quick overview of the subject:
  1059.  
  1060. /DCC <function> [<arguments>]
  1061.    Handles direct connections to remote clients.  The behavior of  DCC is
  1062. determined by the specified <function>.
  1063.  
  1064.  
  1065. /DCC SEND <nickname> <filename>
  1066.    Initiates a file transfer by direct client connection.
  1067.  
  1068.  
  1069. /DCC GET <nickname> <filename>
  1070.    Accepts  a file transfer by direct client connection.  The sender must
  1071. first have offered the file with DCC SEND.
  1072.  
  1073.  
  1074. /DCC CLOSE <type> <nickname> [<arguments>]
  1075.    Ends  an unwanted DCC connection or offer.  The <type>, <nickname> and
  1076. <arguments>  must  be  the  same  as  those shown by "/DCC LIST".  If the
  1077. arguments  are  not supplied, the oldest connection of the specified type
  1078. is closed.
  1079.  
  1080.  
  1081. /DCC LIST
  1082.    Shows  current /DCC connections with their types, status and nicknames
  1083. involved.
  1084.  
  1085.  
  1086.  
  1087.    More  details  can  be found in ircII online help:  try "/HELP DCC"...
  1088. for more information.
  1089.  
  1090.    However,  if  someone  asks you to send him a file, DON'T do it unless
  1091. you  EXACTLY  know  what  you  are  doing.  For instance,  NEVER send the
  1092. password  file  of  your  system  to  anybody.  This could grant crackers
  1093. illegal   access   to   your  machines,  and  put  you  and  your  system
  1094. administrator in much trouble.
  1095.  
  1096.  
  1097.  
  1098. DCC  also  allows two clients to establish a direct client connection for
  1099. chat.   This  is  a  secure form of communication, since messages are not
  1100. sent through the IRC network.
  1101.  
  1102. /DCC CHAT
  1103.    Initiates  a direct client connection chat to the given nick, who must
  1104. repond  with  DCC  CHAT.   Once  established, messages are sent over with
  1105. "/MSG =Nickname ...".
  1106.  
  1107.  
  1108.  
  1109.  
  1110.  
  1111.                       2.6  Network Related Commands
  1112.                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1113.  
  1114.    If  you encounter any problem, contact your local IRC-Administrator or
  1115. an  IRC-Operator.   An  IRC-Admin is a person who has access to all files
  1116. concerning 'ircd' (the server program).  An IRC-Operator or "IRC-op" is a
  1117. person  who  has  privileges  given  to  him by an IRC-Admin and tries to
  1118. maintain  a  fast  reliable IRC network.  Information on how you can find
  1119. out who he/she is, can be found below.
  1120.  
  1121.   Each  time  you are prompted for a server name, remember you can supply
  1122. the nickname of someone being connected on that server instead.  This may
  1123. be useful at times...
  1124.  
  1125.                    Table 11:  Network related commands
  1126.                    -----------------------------------
  1127.      Keyword  Action
  1128.      ~~~~~~~  ~~~~~~
  1129.      ADMIN    displays information about a server
  1130.      LINKS    shows the servers on the IRC network
  1131.      SERVER   switches your primary server
  1132.      MOTD     displays the server message-of-the-day
  1133.      USERS    prints users logged on the server machine
  1134.      DATE     shows server current date and time
  1135.      TIME     shows server current date and time
  1136.      LUSERS   gives a brief listing of users, servers and operators
  1137.      TRACE    shows the server connections of the given server
  1138.      STATS    shows some irc server usage statistics
  1139.      INFO     shows useless information about IRC
  1140.      VERSION  shows client and server version number
  1141.  
  1142.  
  1143. /ADMIN [<server>]
  1144.    Displays  the  administrative  details  about the given server.  If no
  1145. server is supplied, the server you are connected to is used.
  1146.  
  1147.         /ADMIN
  1148.         ### Administrative info about poly.polytechnique.fr
  1149.         ### Ecole Polytechnique, Palaiseau, FRANCE
  1150.         ### IRC-Administrator Nicolas Pioch (Nap@IRC)
  1151.         ### <pioch@poly.polytechnique.fr>
  1152.  
  1153.  
  1154. /LINKS [[<server>] <wildcard expression>]
  1155.    Shows  a  list  of servers currently connected to the IRC network.  If
  1156. <wildcard expression> is given, /LINKS asks the given <server> for a list
  1157. of servers matching the given expression, (this list can get very long!).
  1158.  
  1159.         /LINKS *po*
  1160.         *** nova.unix.portal.com  7 Cupertino California, USA
  1161.         *** poe.acc.Virginia.EDU  6 University of Virginia 2.7.1f
  1162.         *** polaris.utu.fi        9 University of Turku, Finland
  1163.         *** polaris.ctr.columbia.edu 6 Columbia University, New York City
  1164.         *** csd.postech.ac.kr     4 POSTECH Computer Science Dept.
  1165.         *** cdc853.cdc.polimi.it  2 Polytechnic of Milan, Italy
  1166.         *** poly.polytechnique.fr 0 Ecole Polytechnique, Paris, FRANCE
  1167.  
  1168.  
  1169.  
  1170. /SERVER [<server>|<server number> [<port number>]]
  1171.    Switches your primary server to the supplied <server> at the specified
  1172. <port  number>.   If  no port number is given, the default port number is
  1173. used (normally 6667).
  1174.  
  1175.         /SERVER poly.polytechnique.fr 6667
  1176.         *** Connecting to port 6667 of server poly.polytechnique.fr
  1177.         *** Welcome to the Internet Relay Network, Nap
  1178.         *** Your host is poly.polytechnique.fr, running version 2.7.2g.ID
  1179.         *** This server was created Sat Jan 16 1993 at 12:16:10 MET
  1180.  
  1181.  
  1182.    Occasionally,  you  can switch servers faster than the IRC network can
  1183. send  out  the  information  that you have left your previous server.  So
  1184. don't  be  surprised  if  you are told your nickname is already in use...
  1185. Just wait a moment and set it with /NICK again.
  1186.  
  1187.  
  1188.  
  1189. /MOTD [<server>]
  1190.    Gives the  Message-Of-The-Day for the named server. If no server is
  1191. given, your server is used.
  1192.  
  1193.         /MOTD
  1194.         MOTD - poly.polytechnique.fr message of the day -
  1195.         MOTD -   _____________________________________
  1196.         MOTD -  /\                                    \
  1197.         MOTD -  \_|      Bienvenue sur le serveur      |
  1198.         MOTD -    |         Internet Relay Chat        |
  1199.         MOTD -    |  de l'Ecole Polytechnique, FRANCE  |
  1200.         MOTD -    |   _________________________________|__
  1201.         MOTD -     \_/___________________________________/
  1202.         MOTD - 
  1203.         MOTD -        |    |    |      En cas de probleme,
  1204.         MOTD -       )_)  )_)  )_)           tapez / admin
  1205.         MOTD -      )___))___))___)\
  1206.         MOTD -     )____)____)_____)\\       Nicolas PIOCH
  1207.         MOTD -   _____|____|____|____\\\__     Nap sur IRC
  1208.         MOTD - --\  Welcome on IRC !  /---------
  1209.         MOTD -   ^^^^^^^^^^^^^^^^^^^^^ ^^^ ^^^
  1210.         * End of /MOTD command
  1211.  
  1212.  
  1213.  
  1214. /USERS [<server>]
  1215.    Shows the users logged into the machine where the server is running,
  1216. (it's up to the server administrator to implement this feature or not.
  1217. It may not work on some machines).
  1218.  
  1219.         /USERS
  1220.         *** UserID  Terminal    Host
  1221.         *** pioch   ttyp9       rotule.polytechn
  1222.         *** pioch   ttypc       rotule.polytechn
  1223.         *** pioch   ttyq0       rotule.polytechn
  1224.         *** pioch   ttyq1       rotule.polytechn
  1225.  
  1226.  
  1227.  
  1228. /DATE [<server>]
  1229. /TIME [<server>]
  1230.    Shows the current time of day and date.  If a server is specified, the
  1231. time  of  day  and date are reported from that server.  DATE and TIME are
  1232. identical.
  1233.  
  1234.         /DATE
  1235.         *** poly.polytechnique.fr Saturday June 20 1992 -- 02: 35 +01:00
  1236.  
  1237.  
  1238.  
  1239. /LUSERS
  1240.    Gives  a  brief  listing of the number of servers, operators and users
  1241. matching  the  given  <wildcard  expression>,  as seen from the specified
  1242. <server>.
  1243.  
  1244.         /LUSERS
  1245.         *** There are 1008 users and 291 invisible on 135 servers
  1246.         *** 72 users have connection to the twilight zone
  1247.         *** There are 458 channels
  1248.         *** I have 16 clients and 4 servers
  1249.         *** 22 maximum connections, 19 clients
  1250.  
  1251.  
  1252.  
  1253. /TRACE [<server>]
  1254.    Shows the server connections of the given <server>.
  1255.  
  1256.         /TRACE
  1257.         *** Serv Class[9] ==> 134S 1331C eff.org[192.88.144.3]
  1258.         *** Serv Class[8] ==> 1S 6C Julia.Enst.FR
  1259.         *** Serv Class[8] ==> 1S 6C Eurecom8.Cica.FR[192.70.34.208]
  1260.         *** Serv Class[1] ==> 2S 0C athina.cc.uch.gr[147.52.80.102]
  1261.         *** Serv Class[8] ==> 1S 5C dafne.mines.u-nancy.fr[192.70.66.2]
  1262.         *** Serv Class[8] ==> 1S 0C cnam.cnam.fr
  1263.         *** Class 0 Entries linked: 16
  1264.         *** Class 9 Entries linked: 1
  1265.         *** Class 8 Entries linked: 4
  1266.         *** Class 1 Entries linked: 1
  1267.  
  1268.  
  1269.  
  1270. /STATS c|i|k|l|m|u|y [<server>]
  1271.    Shows some irc server usage statistics.
  1272.  
  1273.         /STATS u
  1274.         *** Server Up 12 days, 12:28:44
  1275.  
  1276.  
  1277.  
  1278. /INFO [<server>]
  1279.    Shows  information about the IRC creators, debuggers, slaves and a lot
  1280. of other people who no longer have much to do with IRC.
  1281.  
  1282.  
  1283.  
  1284. /VERSION
  1285.    Shows the ircII version number and the version number of the server.
  1286.  
  1287.         /VERSION
  1288.         *** Client: ircII 2.2
  1289.         *** Server poly.polytechnique.fr: ircd 2.7.2g.Nap+6(privacy).
  1290.  
  1291.  
  1292.  
  1293.  
  1294.  
  1295.                         2.7 Quick Reference Panel
  1296.                         ~~~~~~~~~~~~~~~~~~~~~~~~~
  1297.  
  1298.        Keyword      Action
  1299.        -------      ------
  1300.        !            recalls previous commands for re-editing
  1301.        ADMIN        displays information about a server
  1302.        AWAY         leaves a message saying you're not paying attention
  1303.        CLEAR        puts some white space on your screen
  1304.        CTCP         performs certain client specific actions
  1305.  
  1306.        DATE         shows server current date and time
  1307.        DCC          handles direct connections to remote clients
  1308.        DESCRIBE     sends anything about you to a person or channel
  1309.        HELP         prints help on the given command
  1310.        HISTORY      displays the command history
  1311.  
  1312.        IGNORE       removes output from specific people off your screen
  1313.        INFO         shows useless information about IRC
  1314.        INVITE       sends an invitation to another user
  1315.        JOIN         sets your current channel
  1316.        KICK         gets rid of someone on a channel
  1317.  
  1318.        LASTLOG      lists the most recent messages
  1319.        LEAVE        leaves a channel
  1320.        LINKS        shows servers on the IRC network
  1321.        LIST         lists channels, number of users, topic
  1322.        LUSERS       gives a brief listing of users, servers and operators
  1323.  
  1324.        ME           sends anything about you to a channel or QUERY
  1325.        MODE         changes channel mode
  1326.        MOTD         displays the server message-of-the-day
  1327.        MSG          sends a private message
  1328.        NAMES        shows the nicknames of users on each channel
  1329.  
  1330.        NICK         changes your nickname
  1331.        NOTICE       sends a private message
  1332.        NOTIFY       warns you of people logging in or out IRC
  1333.        QUERY        starts a private conversation
  1334.        QUIT         exits your IRC session
  1335.  
  1336.        SERVER       switches your primary server
  1337.        STATS        shows some irc server usage statistics
  1338.        TIME         shows server current date and time
  1339.        TOPIC        changes the topic of the channel
  1340.  
  1341.        TRACE        shows the server connections of the given machine
  1342.        USERS        prints users logged on the server machine
  1343.        VERSION      shows client and server version number
  1344.        WHO          gives a listing of users
  1345.        WHOIS        displays information about someone
  1346.  
  1347.        WHOWAS       displays information about someone who just left
  1348.  
  1349.  
  1350.  
  1351.  
  1352.  
  1353.                      2.8 Further into ircII Wizardry
  1354.                      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1355.  
  1356.        Note: This part should be reserved for experienced IRC'ers.
  1357.  
  1358.  
  1359.    Because ircII is not a simple client program, but an Operating System,
  1360. its  programming  language  is  just  as simple as you could expect (it's
  1361. horrendous),  but  if  you  want to get into it, here's a little note for
  1362. you...
  1363.  
  1364.    There  are  a few Unix environment variables you can set in your shell
  1365. configuration file, but you need to find out your shell name before that.
  1366. "echo $SHELL" should give you a hint.
  1367.  
  1368.                 Table 12:  Setting environment variables
  1369.                 ----------------------------------------
  1370.    Shell type      Shell name      Command
  1371.    ~~~~~~~~~~      ~~~~~~~~~~      ~~~~~~~
  1372.    Bourne shells   sh              $ VARNAME="value" ; export VARNAME
  1373.                    ksh             $ export VARNAME="value"
  1374.                    bash            $ export VARNAME="value"
  1375.    C-shells        csh             % setenv VARNAME "value"
  1376.                    tcsh            > setenv VARNAME "value"
  1377.  
  1378.  
  1379.                     Table 13:  Environment variables
  1380.                     --------------------------------
  1381.       Name            Effects
  1382.       ~~~~            ~~~~~~~
  1383.       HOME            where your home directory is
  1384.       IRCNAME         any lunacy you want instead of your real name
  1385.                       (text that appears between parentheses in a WHOIS)
  1386.       IRCNICK         your default IRC nickname
  1387.       IRCPATH         a directory path to LOAD scripts
  1388.       IRCRC           a file to use instead of your $HOME/.ircrc
  1389.       IRCSERVER       a default server list for ircII
  1390.       TERM            your terminal type
  1391.  
  1392.  
  1393.  
  1394.    The command character, (usually "/"), is only necessary when you type
  1395. commands interactively, when you program things it is no more needed, it
  1396. used to be though.
  1397.  
  1398.  
  1399.                        Table 14: Advanced commands
  1400.                        ---------------------------
  1401.     Keyword         Action
  1402.     ~~~~~~~         ~~~~~~
  1403.     #               same as COMMENT except for the lenght
  1404.     @               performs variable expressions
  1405.     ALIAS           creates command aliases
  1406.     ASSIGN          creates user variables (expandable with $)
  1407.     BIND            binds a keystroke sequence to a function
  1408.  
  1409.     CD              changes ircII working directory
  1410.     COMMENT         does nothing, but very useful. Strange, uh?
  1411.     ECHO            displays all of its arguments
  1412.     EXEC            allows you to start subprocesses
  1413.     FLUSH           flushes all pending output from the server
  1414.  
  1415.     IF              standard boolean expression checker
  1416.     LOAD            loads an ircII command script file
  1417.     ON              sets up actions to occur when certain events happen
  1418.     REDIRECT        forwards the output from a command
  1419.     SAVE            saves all ircII settings into a file
  1420.  
  1421.     SAY             same as sending text to a channel
  1422.     SEND            same as sending text to a channel
  1423.     SET             sets a variable to a given value
  1424.     SLEEP           suspends ircII for a few seconds
  1425.     TYPE            simulates keystrokes
  1426.  
  1427.     WAIT            waits for all server output to finish
  1428.     WHILE           another control command to make loops
  1429.     WINDOW          lets you manipulate multiple "windows" in ircII
  1430.     XECHO           like ECHO, but takes flag arguments
  1431.  
  1432.  
  1433.  
  1434.    If you want to type to the channel from within an ALIAS or on BINDing,
  1435. you have to use SAY or SEND.
  1436.  
  1437.    The  ";"  has  a  special  meaning in ALIASes, BINDings and ONs:  it's
  1438. treated  as  command  separator,  that  means  you  can  execute multiple
  1439. commands  in  a  row  separated  by  semicolons.   The semicolons are not
  1440. considered  separators  when  you  use them interactively, (to be able to
  1441. type ";-)"), and within an ircII script file.  You can escape the meaning
  1442. of ";" in an ALIAS with "\;".
  1443.  
  1444.    When  you  use  ircII on a (semi)regular basis, you will discover that
  1445. every  time  you start the program you will issue the same initialization
  1446. sequence.  If that is the case, I have good news for you:  you don't have
  1447. to do that anymore!  ircII will, at startup, load a file called ".ircrc",
  1448. (full  path:   $HOME/.ircrc).  It will treat each line in that file as if
  1449. you typed it manually.
  1450.  
  1451.    For example, if the content of your .ircrc file is:
  1452.  
  1453.         JOIN #Twilight_Zone
  1454.  
  1455.    then each time you will start IRC, you will join this channel.
  1456.  
  1457.  
  1458.  
  1459.     Advanced  commands  may come in handy if you need them.  Feel free to
  1460. browse  in  ircII online help to find out more about them.  A few of them
  1461. are probably worth learning...
  1462.  
  1463.  
  1464.  
  1465.  
  1466.  
  1467.  
  1468.                            2.9  Sample .ircrc
  1469.                            ~~~~~~~~~~~~~~~~~~
  1470.  
  1471.    As a sample, here's part of my .ircrc file.  Since ircII2.2, this file
  1472. can be found in the "script" directory, and loaded with "/load ircprimer"
  1473.  
  1474. # Sample .ircrc script, from the IRCprimer v1.1
  1475. # -------------------------------------------------------------------
  1476. #    IRCII sample configuration file  (~/.ircrc)  (Nicolas Pioch)
  1477. # -------------------------------------------------------------------
  1478. # The aim of this file is to shorten all useful commands to 1 letter.
  1479.  
  1480. set NOVICE off
  1481. set INPUT_ALIASES off
  1482. set AUTO_WHOWAS on
  1483. set SHOW_CHANNEL_NAMES on
  1484. set SHOW_AWAY_ONCE on
  1485.  
  1486. # Speeds up ircII display 2 times
  1487. set SCROLL_LINES 2
  1488.  
  1489. # Put Hack notices down under
  1490. on ^SERVER_NOTICE "\*\*\* Notice -- Hack: *" set status_user Hack: $4-
  1491.  
  1492. # Modified killpath script from YeggMan
  1493. ALIAS kpath ECHO ### Last received KILL for $nkp.path
  1494. @ nkp.path = [<empty>]
  1495. ALIAS nkp.msg ECHO ### $Z -- KILL by $1 for $0 $2-
  1496. ALIAS nkp.idx @ FUNCTION_RETURN = RINDEX(! $0) + 1
  1497. ALIAS nkp.srv @ FUNCTION_RETURN = INDEX(. $MID($nkp.idx($0) 512 $0))
  1498. ON ^SERVER_NOTICE "\*\*\* Notice -- Received KILL*" {
  1499. #    if (index(. $mid(${rindex(! $11) +1} 512 $11))
  1500.         IF ( nkp.srv($11) > -1 )
  1501.             { nkp.msg $7 $9 }
  1502.             { nkp.msg $7 $9 $12- }
  1503.         @ nkp.path = [$7-]
  1504. }
  1505.  
  1506. # Function to strip the less significant part of an internet hostname
  1507. # $userdomain(username@host.subdomain.dom)  returns username@subdomain.dom
  1508. # This eliminates the hostname which may change frequently
  1509. alias userdomain {
  1510.   @ function_return = LEFT($INDEX(@ $0) $0)##[@]##MID(${1+INDEX(. $0)} 99 $0)
  1511. }
  1512.  
  1513. # Who is that ?
  1514. on ^msg * echo *$0!$userdomain($userhost())* $1-
  1515.  
  1516. # /w [<nickname>]                        get info on someone
  1517. # /q [<nickname>]                        query someone
  1518. # /m  <nickname> <text>                  send a message
  1519. # /n  <nickname> <text>                  send a notice
  1520. # /r <text>                              reply to last message I got
  1521. # /a <text>                              followup on my last message
  1522.  
  1523. alias w whois
  1524. alias q query
  1525. alias m msg
  1526. alias n notice
  1527. alias r msg $,
  1528. alias a msg $.
  1529.  
  1530. # /j <channel>                           join a channel
  1531. # /l <channel>                           list people in a channel
  1532. # /ll                                    list in the current channel
  1533. # /i <nickname> [<channel>]              invite someone
  1534. # /hop                                   leave the current channel
  1535.  
  1536. alias j join
  1537. alias l who
  1538. alias ll who *
  1539. alias i invite
  1540. alias hop part $C
  1541.  
  1542. # /o <nickname> [<nickname> <nickname>]  give channel op status
  1543. # /d <nickname> [<nickname> <nickname>]  remove channel op status
  1544. # /k <nickname>                          kick someone
  1545. # /mo [+|-]<modechars>                   change current channel mode
  1546.  
  1547. alias o mode $C +ooo
  1548. alias d mode $C -ooo
  1549. alias k kick $C
  1550. alias mo mode $C
  1551.  
  1552. # the "wrong person" alias! /oops <nickname> to resend message to
  1553. alias oops {
  1554.         @ _whoops = [$B]
  1555.         msg $. Whooops ! Please ignore, that wasn't meant for you.
  1556.         msg $0 $_whoops
  1557. }
  1558.  
  1559. alias unset set -$*
  1560. alias unalias alias -$*
  1561. alias NickServ msg NickServ@Service.de
  1562. alias NoteServ msg NoteServ@Service.de
  1563.  
  1564. # -------------------------------------------------------------------
  1565.  
  1566.  
  1567.  
  1568.  
  1569.  
  1570.                         2.10  Writing automatons
  1571.                         ~~~~~~~~~~~~~~~~~~~~~~~~
  1572.  
  1573.    An  automaton,  (also  called  robot or service), is a program that is
  1574. connected to the IRC network to provide services.  Many people try to set
  1575. that up with a few ircII commands like:
  1576.  
  1577. on ^msg "% help" notice $0 This is LameBot 1.0
  1578.  
  1579.    However,  you  should know that setting up an automaton using ircII ON
  1580. facilities  is  quick  and  dirty, and should be reserved for robots that
  1581. rely  on ircII specific features such as DCC (file servers for instance).
  1582. Writing  a  program  in C, perl or any decent programming language should
  1583. take longer in the beginning, but your efforts will be rewarded.  You can
  1584. download  skeletons  of  such  programs  on  some ftp sites that keep IRC
  1585. related stuff (check in the Frequently Asked Questions part).
  1586.  
  1587.  
  1588.    Although  most  robots-writers  believe  they  have  created  a "smart
  1589. thing",  99%  of  the  robots  online  happen to be a nuisance to the IRC
  1590. community, because a few simple rules were not respected by their owners.
  1591. The main idea is that robots should neither be seen nor heard:
  1592.  
  1593.     * automatons should be clearly identified as such, having "bot",
  1594.       "serv" or "srv" in their nickname.
  1595.  
  1596.     * they should use NOTICES to communicate with the rest
  1597.       of the world, and not reply to NOTICES they get.
  1598.  
  1599.     * they should be able to always be killed (craziness is a
  1600.       frequent disease among robots).
  1601.  
  1602.     * they should be able to be killed remotely by their owner via IRC.
  1603.  
  1604.     * they should not give access to their owner's real files, (bandits
  1605.       have already been able to crack people's accounts through
  1606.       their robots).
  1607.  
  1608.     * they should not send messages to channels (unless the channel
  1609.       is dedicated to that robot).
  1610.  
  1611.    * they should not flood channels with MODE changes. Basically,
  1612.      if you have such a command as:
  1613.  
  1614.         on -JOIN "Lamer #BotTub" mode #BotTub +o Lamer
  1615.  
  1616.   then you are wrong. Because this is what you will get:
  1617.  
  1618. *** Lamer (clueless@where.the.hell) has joined channel #bottub
  1619. *** Mode change "+o Lamer" on channel #bottub by LameBot
  1620. *** Mode change "+o Lamer" on channel #bottub by StupidSrv
  1621. *** Mode change "+ooo Lamer Lamer Lamer" on channel #bottub by FloodServ
  1622. *** Mode change "+o Lamer" on channel #bottub by Dumbbot
  1623.  
  1624.  
  1625.    And  this  will  get  boring  very soon, so don't be surprised if such
  1626. robots  get  banned  from  most channels.  A good kludge is to wait until
  1627. someone  asks explicitly the robot to be opped on a channel.  This could
  1628. be:
  1629.      on -MSG "Lamer op me on #BotTub" mode #BotTub +o Lamer
  1630.  
  1631.  
  1632.    If you don't respect rules 2 and 6 above, this may happen too:
  1633.  
  1634. *** TalkBot (clueless@where.the.hell) has joined channel #bottub
  1635. <LameBot> Hi TalkBot!
  1636. <TalkBot> Hello LameBot! How are you?
  1637. *** Mode change "+o TalkBot" on channel #bottub by LameBot
  1638. <LameBot> Fine thanx.
  1639. <TalkBot> Thank you for the op, LameBot.
  1640. <LameBot> No problem, TalkBot.
  1641. *** Signoff: Talkbot (ircserver.irc.edu where.the.hell)
  1642. *** TalkBot (clueless@where.the.hell) has joined channel #bottub
  1643. *** Mode change "+o TalkBot" on channel #bottub by where.the.hell
  1644. *** Mode change "+o LameBot" on channel #bottub by TalkBot
  1645. *** Mode change "+o TalkBot" on channel #bottub by LameBot
  1646. <TalkBot> Thank you for the op, LameBot.
  1647. <LameBot> No problem, TalkBot.
  1648. ...
  1649.  
  1650.  
  1651. See?  Remember the golden rule:
  1652.  
  1653.     +--------------------------------------------------------------+
  1654.     | A smart bot won't act unless explicitly asked by someone to. |
  1655.     +--------------------------------------------------------------+
  1656.  
  1657.  
  1658.  
  1659.  
  1660.  
  1661.  
  1662.                       3. FREQUENTLY ASKED QUESTIONS
  1663.                       =============================
  1664.  
  1665.                    3.1  How do I set up an IRC client?
  1666.                    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1667.  
  1668.    Here  is  a list of FTP sites from which you can download a client for
  1669. your specific Operating System.
  1670.  
  1671.  
  1672.                   Table 15:  FTP sites with IRC clients
  1673.                   -------------------------------------
  1674.                                UNIX ircII
  1675.                                ~~~~~~~~~~
  1676.               cs.bu.edu                      - /irc/clients
  1677.               ftp.acsu.buffalo.edu           - /pub/irc
  1678.               slopoke.mlb.semi.harris.com    - /pub/irc
  1679.               plod.cmbe.unsw.oz.au           - /pub
  1680.               coombs.anu.edu.au              - /pub/irc
  1681.               nic.funet.fi                   - /pub/unix/irc/ircII
  1682.               ftp.informatik.tu-muenchen.de  - /pub/net/irc
  1683.  
  1684.  
  1685.                                EMACS elisp
  1686.                                ~~~~~~~~~~~
  1687.               cs.bu.edu                       - /irc/clients/elisp
  1688.               slopoke.mlb.semi.harris.com     - /pub/irc/emacs
  1689.               nic.funet.fi                    - /pub/unix/irc/Emacs
  1690.               lehtori.cc.tut.fi               - /pub/irchat
  1691.               ftp.informatik.tu-muenchen.de   - /pub/net/irc
  1692.  
  1693.  
  1694.                                    VMS
  1695.                                    ~~~
  1696.               cs.bu.edu                       - /irc/clients/vms
  1697.               coombs.anu.edu.au               - /pub/irc/vms
  1698.               nic.funet.fi                    - /pub/unix/irc/vms
  1699.               ftp.informatik.tu-muenchen.de   - /pub/net/irc
  1700.  
  1701.  
  1702.                                REXX for VM
  1703.                                ~~~~~~~~~~~
  1704.               ftp.informatik.uni-oldenburg.de - /pub/irc/rxirc
  1705.               ftp.informatik.tu-muenchen.de   - /pub/net/irc/VM
  1706.               cs.bu.edu                       - /irc/clients/rxirc
  1707.               coombs.anu.edu.au               - /pub/irc/rxirc
  1708.               nic.funet.fi                    - /pub/unix/irc/rxirc
  1709.  
  1710.  
  1711.                                   MSDOS
  1712.                                   ~~~~~
  1713.               cs.bu.edu                       - /irc/clients
  1714.               nic.funet.fi                    - /pub/unix/irc/msdos
  1715.  
  1716.  
  1717.                                 Macintosh
  1718.                                 ~~~~~~~~~
  1719.  
  1720.               cs.bu.edu                       - /irc/clients
  1721.               nic.funet.fi                    - /pub/unix/irc/mac
  1722.               sumex.stanford.edu              - /info-mac/comm
  1723.               ftp.ira.uka.de                  - /pub/systems/mac
  1724.  
  1725.  
  1726.    For  Unix  machines,  you  either compile the source yourself, or have
  1727. someone  else  on  your  machine compile the source for you.  The current
  1728. "official"  ircII release is version 2.2.1. That means that it is said to
  1729. be quite bugfree (Hehe, you never know...) In addition to this "official"
  1730. distribution,  you  may  find  preversions of the client to come floating
  1731. around,  for people who like to track down bugs and taste things to come.
  1732. However,  you  should be aware of that those clients are being worked on,
  1733. and may not have full features working properly.
  1734.  
  1735.    Here are the commands to type to setup an ircII client:
  1736.  
  1737.         ~ > ftp
  1738.         ftp> verbose off
  1739.         Verbose mode off.
  1740.         ftp> open cs.bu.edu
  1741.         Name (cs.bu.edu:yourname) : ftp
  1742.         Password: yourname@yourhost
  1743.         ftp> cd irc/clients
  1744.         ftp> bin
  1745.         ftp> get ircII2.2.1.2.tar.Z "|zcat|tar xf -"
  1746.         ftp> get ircII2.2.1help.tar.Z "|zcat|tar xf -"
  1747.         ftp> quit
  1748.         ~ >
  1749.  
  1750.    You now have to go into ircII2.2.1 and read the files  explaining  how
  1751. to achieve a successful installation.  Have a look at README and INSTALL,
  1752. edit   config.h   to  define  DEFAULT_SERVER,  edit  Makefile  to  define
  1753. INSTALL_EXECUTABLE,  IRCII_LIBRARY  and the C compiler you will be using,
  1754. then type make install and wait...
  1755.  
  1756.    If  you  can't set up a client on any local machine, you can still use
  1757. any telnet client:
  1758.  
  1759.                      Table 16:  Open telnet clients
  1760.                      ------------------------------
  1761.       Area      Command                                 login name
  1762.       ~~~~      ~~~~~~~                                 ~~~~~~~~~~
  1763.       America   telnet bradenville.andrew.cmu.edu
  1764.                 telnet chatsubo.nersc.gov               bbs
  1765.  
  1766.       Asia      telnet cc.nsysu.edu.tw                  irc
  1767.  
  1768.       Europe    telnet ircclient.itc.univie.ac.at 6668
  1769.                 telnet irc.ibmpcug.co.uk 9999
  1770.  
  1771.    Please  only use telnet when you have no other way of reaching IRC, as
  1772. this resource is quite limited.
  1773.  
  1774.  
  1775.  
  1776.  
  1777.  
  1778.                    3.2  Which server do I connect to?
  1779.                    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1780.  
  1781.    It's usually best to try and connect to one geographically close, even
  1782. though that may not be the best.  You can always ask when you get on IRC.
  1783. Here's a list of servers available for connection:
  1784.  
  1785.                        Table 17:  Open IRC servers
  1786.                        ---------------------------
  1787.               America   Canada        ug.cs.dal.ca
  1788.               ~~~~~~~   USA           csa.bu.edu
  1789.                                       ucsu.coloradu.edu
  1790.                                       irc.caltech.edu
  1791.  
  1792.               Europe    Finland       nic.funet.fi
  1793.               ~~~~~~    France        poly.polytechnique.fr
  1794.                         Germany       noc.belwue.de
  1795.                         Sweden        irc.nada.kth.se
  1796.  
  1797.               Oceania   Australia     munagin.ee.mu.oz.au
  1798.               ~~~~~~~
  1799.  
  1800.    This  is  by  no  means,  a  comprehensive  list,  but merely a start.
  1801. Connect   to   the   closest  of  these  servers  and  join  the  channel
  1802. #Twilight_Zone  or, if you are in Europe, #EU-Opers.  When you are there,
  1803. immediately  ask  what  you  want.  Don't say "I have a question" because
  1804. then  everyone  will  ignore  you  until you say it a few times, and then
  1805. they'll jump down your throat and rip your lungs out.  No one knows if he
  1806. can answer your question until you ask it.
  1807.  
  1808.  
  1809.  
  1810.  
  1811.  
  1812.            3.3  What are good channels to try while using IRC?
  1813.            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1814.  
  1815.    #Hottub  and #initgame are almost always teeming with people.  #Hottub
  1816. is  meant  to  simulate  a  hot  tub, and #initgame is a non-stop game of
  1817. "inits"  (initials).   Just join the fun and find out!  (German users may
  1818. try channels named after German university towns...)
  1819.  
  1820.    Many  IRC  Operators  are  in #Twilight_Zone, while European Operators
  1821. concentrate in #EU-Opers...  So if you join an Operator channel and don't
  1822. hear  much  talking,  don't worry, it's not because you joined, Operators
  1823. don't talk much on such channels anyways!
  1824.  
  1825.  
  1826.  
  1827.  
  1828.  
  1829.                3.4  How do I get nifty effects with ircII?
  1830.                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1831.  
  1832.    You  can  highlight  messages  you send using control chars:  parts of
  1833. text  surrounded  by  control-b (^B) will appear in video reverse to most
  1834. ircII  users for instance.  However the appearance of such effects relies
  1835. on the terminal abilities of the user you're writing to.
  1836.  
  1837.    In  some  cases keys are already bound to something.  For instance, ^B
  1838. is  normally  bound  to  BACKWARD_CHARACTER, so you will need to define a
  1839. "quote-character" key:  just enter "/BIND ^W QUOTE_CHARACTER" then "/BIND
  1840. ^W^B SELF_INSERT" and it may work...
  1841.  
  1842.                   Table 18:  Highlighting ircII output
  1843.                   ------------------------------------
  1844.                            Key  Effect
  1845.                            ~~~  ~~~~~~
  1846.                            ^B   Video reverse
  1847.                            ^V   Underline
  1848.                            ^_   Bold
  1849.  
  1850.  
  1851.  
  1852.  
  1853.  
  1854.         3.5  What if someone tells me to type something cryptic?
  1855.         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1856.  
  1857.    NEVER  type  anything  anyone tells you to without knowing what it is.
  1858. There  is  a  problem with typing a certain command with the ircII client
  1859. that  gives  anyone immediate control of your client, (and thus can alter
  1860. your account environment also).  Look in the ircII on-line help each time
  1861. you can.
  1862.  
  1863.  
  1864.  
  1865.  
  1866.  
  1867.        3.6  I get strange characters on my screen, what are they?
  1868.        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1869.  
  1870.    IRC  has quite a lot of people from Scandinavian countries, }{|][\ are
  1871. letters  in  their  alphabet  (IRC is supposed to support the ISO Latin-1
  1872. 8-bit  character  set,  but your client  must be able to display them...)
  1873. This  has  been  explained on IRC about a thousand and one times, so read
  1874. the following, do not ask it on IRC:
  1875.  
  1876.            Table 19:  Nordic countries character translations
  1877.            --------------------------------------------------
  1878.     Character  Description
  1879.     ~~~~~~~~~  ~~~~~~~~~~~
  1880.     [, {       'a' with two dots over it
  1881.     ], }       'a' with a small circle above it
  1882.     \, |       'o' with two dots over it, or a dash ("/") through it
  1883.                ("[", "]", and "\" = upper case)
  1884.  
  1885.    In  addition  to  that,  Japanese  IRC'ers  use  a special ANSI escape
  1886. control  sequences  to transmit their Kanji alphabet.  This may also look
  1887. funny  if  you  get  some  of it...  Here's a sample:  [$B$?$K$7[$B;$m$K#
  1888. (nice, uh?)
  1889.  
  1890.  
  1891.  
  1892.  
  1893.  
  1894.                         3.7  What about NickServ?
  1895.                         ~~~~~~~~~~~~~~~~~~~~~~~~~
  1896.    To  quote  from  NickServ's  help  text, NickServ's purpose is to help
  1897. avoiding  nickname confusions on IRC.  There's no such thing as "nickname
  1898. ownership",  however NickServ sends a warning to anyone else who signs on
  1899. with  your  nickname.   If  you don't use IRC for 10 weeks, your nickname
  1900. registration expires for reuse.
  1901.  
  1902.    Only  a  NickServ operator can change your NickServ password.  To find
  1903. out which NickServ operators are on-line, send
  1904.  
  1905.         /MSG NickServ@Service.de OPERWHO
  1906.  
  1907.    Nicknames with a "*" next to them are online at the time.
  1908.  
  1909.  
  1910.  
  1911.  
  1912.  
  1913.  
  1914.            3.8  I'm being flooded or harassed by a jerk. HELP!
  1915.            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1916.  
  1917.    If  somebody is behaving like a jerk on IRC, like dumping to a channel
  1918. Mb's  of garbage, then he should be KICKed and eventually banned from the
  1919. channel, (see "/HELP MODE" for details).
  1920.  
  1921.    If  it's a matter of personal harassment, then you should set a proper
  1922. IGNORE on that person, (preferably on his userid@hostname).  Remember you
  1923. can use wildcard expressions for IGNORE.  More about this in section 2.2.
  1924.  
  1925.  
  1926.  
  1927.  
  1928.  
  1929.             3.9  How do I get rid of a ghosted IRC session?
  1930.             ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  1931.  
  1932.    Sometimes  you  may  have  a  "ghosted"  IRC  session, a process still
  1933. running  on  your machine you would like to get rid of, but can't control
  1934. anymore to issue a QUIT command.  Going back to a unix shell, try listing
  1935. your processes:  ("ps -ux" or "ps -f" depending on your system)
  1936.  
  1937.     poly ~ > ps -ux
  1938.     USER       PID  %CPU %MEM   SZ  RSS TT STAT TIME COMMAND
  1939.     pioch    10410   1.4  0.2  839  402 pf S    0:00 /usr/local/bin/emacs
  1940.     pioch    25441   0.6  0.9 2888 1908 ?  S    0:32 xterm -ls
  1941.     pioch    25444   0.4  0.2  550  341 pf S    0:17 -tcsh (tcsh)
  1942.     pioch    10404   0.1  0.3  897  624 pf S    0:00 irisVx 5 4 10403
  1943.     pioch    25634   0.0  0.3 1022  678 p6 S    0:22 irc
  1944.     pioch    25451   0.0  0.2  953  326 ?  S    0:07 xmailbox
  1945.     pioch    25452   0.0  0.1  386  147 ?  S    0:00 xdaliclock
  1946.     pioch    25459   0.0  0.3 1109  617 ?  S    0:02 xman
  1947.     pioch    10403   0.0  0.1  574  124 pf I    0:00 mapleV
  1948.     pioch    10423   0.0  0.2  614  459 pf R    0:00 /bin/ps -ux
  1949.  
  1950.    Locate the line about your lost IRC session, (irc should appear in the
  1951. COMMAND field of the line), and its PID, (process number, second field of
  1952. the line here).  In this example the PID is 25634, as shown here:
  1953.  
  1954.     USER       PID  %CPU %MEM   SZ  RSS TT STAT TIME COMMAND
  1955.     pioch    25634   0.0  0.3 1022  678 p6 S    0:22 irc
  1956.  
  1957.    All  you  then  need  to  type is "kill -KILL" or "kill -9" immediatly
  1958. followed by the PID found above:  "kill -kill 25634" here.
  1959.  
  1960.    You  can  get  more  details  about  the commands involved here in the
  1961. standard unix manual, ("man 1 ps" or "man 1 kill").
  1962.  
  1963.    If  your  machine  crashed,  and  your nick is still in use on the IRC
  1964. network,  you'll have to wait 4 to 5 minutes for your server to recognize
  1965. the  fact.   Getting  an  Operator  to  kill  the  ghost  is almost never
  1966. necessary,  just  sign  on  as  another  nickname  and wait for the "Ping
  1967. timeout" or "Bad link" message, then you can change your nick back...
  1968.  
  1969.  
  1970.  
  1971.  
  1972.  
  1973.                          3.10  About KILL usage.
  1974.                          ~~~~~~~~~~~~~~~~~~~~~~~
  1975.  
  1976.    KILL  is  a  command restricted to IRC-Operators to deal with protocol
  1977. errors  heavily  reducing the IRC network functionality.  It's to be used
  1978. with extreme caution, if at all.
  1979.  
  1980.       +-----------------------------------------------------------+
  1981.       | KILL should never interfere with channel-operator status. |
  1982.       +-----------------------------------------------------------+
  1983.  
  1984.    If you op someone on a channel, you take the consequences.  If someone
  1985. joins  #Whatever,  you  op  them,  then  they  kick everyone and lock the
  1986. channel  with  some  "Mode  change +ib *!*@*", then suffer it:  it's your
  1987. fault,  don't go whining to an IRC-op to fix it.  If a channel is locked,
  1988. you should start a new one.
  1989.  
  1990.    Effective  methods  to deal with obnoxious people are IGNORE, KICK and
  1991. various MODEs on channels, such as +i and/or +b.
  1992.  
  1993.    If  you  have  been  abusively  killed by an IRC-Operator, abusing his
  1994. power to gain illegal channel-operator status for instance, yell!  Mail a
  1995. log  to his server IRC-Administrator, (see ADMIN), join #Twilight_Zone or
  1996. #EU-Opers for European-related problems, and explain what happened.
  1997.  
  1998.  
  1999.  
  2000.  
  2001.  
  2002.                       3.11  Where can I find more?
  2003.                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  2004.  
  2005.    Should  your  question  not be listed above, you may want to check the
  2006. "Frequently  Unasked  Questions", (FUQ) list, which will be shipping real
  2007. soon now, featuring replies to:
  2008.  
  2009.         <lamer1> Are there any good FTP sites? (1)
  2010.         <lamer2> How do I join a channel?
  2011.         <lamer3> How do I become an IRCop?
  2012.  
  2013.  
  2014.    If you have access to Usenet News, (usually through a program called
  2015. rn, trn, xrn or nn), you may want to join alt.irc debates, flamings and
  2016. whinings.
  2017.  
  2018.    You can also join various IRC related mailing lists.  "Operlist"
  2019. discusses  current  (and  past)  server code, routing and protocol.  Mail
  2020. operlist-request@eff.org     to     join.     Another    mailing    list,
  2021. ircd-three@eff.org  exists  to  discuss  protocol  revisions  for the 3.0
  2022. release  of ircd, currently in planning.  Mail ircd-three-request@eff.org
  2023. to  be  added to that.  There is also low-traffic mailing-lists for ircII
  2024. vmsirc and irchat clients.
  2025.  
  2026.                   Table 20:  IRC related mailing lists
  2027.                   ------------------------------------
  2028.    E-mail for subscriptions       What's being talked about
  2029.    ~~~~~~~~~~~~~~~~~~~~~~~~       ~~~~~~~~~~~~~~~~~~~~~~~~~
  2030.    operlist-request@eff.org       Server code, routing and protocol.
  2031.    ircd-three-request@eff.org     ircd 3.0 protocol
  2032.    listserv@grasp1.univ.lyon1.fr  European IRC-Operators mailing list
  2033.    dl2p+@andrew.cmu.edu           ircII mailing list
  2034.    vmsirc-request@vax1.elon.edu   VMS IRC mailing list
  2035.    irchat-request@cc.tut.fi       irchat mailing list
  2036.  
  2037.  
  2038.    ((1) 129.0.0.1 but you already know that.)
  2039.  
  2040.  
  2041.  
  2042.  
  2043.  
  2044.  
  2045.                            4.  ADMINISTRATIVIA
  2046.                            ===================
  2047.  
  2048.                           4.1  Revision history
  2049.                           ~~~~~~~~~~~~~~~~~~~~~
  2050.    This  is  version 1.1 of this paper.  Version 1.0 of the IRCprimer was
  2051. released  in  postscript  form  in June 1992 because I was sick of people
  2052. asking  for  an  IRC  or  ircII  manual  (and  it was a good way to learn
  2053. LaTeX!).   During  summer  1992  Owe  Rasmussen  did  a  very  nice  text
  2054. conversion  of  the  paper.  Due to the support and many remarks I got, a
  2055. new version  is finally completed  (special thanks to Olaf Titz !), along
  2056. with Owe's plain ascii conversion.
  2057.  
  2058.    The primer is available in 3 formats:
  2059.  
  2060.                   IRCprimer.ps.Z:   Postscript version
  2061.                   IRCprimer.txt:    Plain text version
  2062.                   IRCprimer.tex.Z:  Source code.
  2063.  
  2064.  
  2065.  
  2066.  
  2067.  
  2068.                   4.2  Release sites for the IRCprimer
  2069.                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  2070.  
  2071.    The  latest  version  of  the primer can be found on the following ftp
  2072. sites, thanks to their admins:
  2073.  
  2074.                     Table 21: IRCprimer release sites
  2075.                     ---------------------------------
  2076.                      ftp site           location
  2077.                      ~~~~~~~~           ~~~~~~~~
  2078.                      nic.funet.fi       /pub/unix/irc/docs
  2079.                      cs.bu.edu          /irc/support
  2080.                      coombs.anu.edu.au  /pub/irc/docs
  2081.  
  2082.  
  2083.    Here's how to get the latest primer postscript version for example:
  2084.  
  2085.         ~ > ftp
  2086.         ftp> verbose off
  2087.         Verbose mode off.
  2088.         ftp> open cs.bu.edu
  2089.         Name (cs.bu.edu:yourname): ftp
  2090.         Password: yourname@yourhost
  2091.         ftp> cd irc/support
  2092.         ftp> bin
  2093.         ftp> get IRCprimer.ps.Z
  2094.         ftp> quit
  2095.         ~ > uncompress IRCprimer.ps.Z
  2096.         ~ >
  2097.  
  2098.  
  2099.  
  2100.  
  2101.  
  2102.                   4.3  Copyright (C) 1993 Nicolas PIOCH
  2103.                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  2104.  
  2105.    This  manual  is  free; you can redistribute it and/or modify it under
  2106. the  terms  of  the  GNU  General Public License as published by the Free
  2107. Software Foundation; either version 2 of the license, or (at your option)
  2108. any later version.
  2109.  
  2110.    This  manual  is  distributed  in the hope that it will be useful, but
  2111. WITHOUT   ANY   WARRANTY;   without   even   the   implied   warranty  of
  2112. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
  2113. Public License for more details.
  2114.  
  2115.    You  should  have  received  a  copy of the GNU General Public License
  2116. along with this manual; if not, write to the
  2117.    
  2118.  
  2119.                      Free Software Foundation, Inc.,
  2120.                               675 Mass Ave,
  2121.                         Cambridge, MA 02139, USA.
  2122.  
  2123.  
  2124.  
  2125.  
  2126.  
  2127.                               4.4  Credits
  2128.                               ~~~~~~~~~~~~
  2129.  
  2130.    Interesting  informations  contained in this paper are due to the work
  2131. of various people interested in IRC improvement; I'm only responsible for
  2132. omissions and mistakes :-)
  2133.  
  2134.    It's  impossible  to  give here a full list, however special thanx are
  2135. due to (in analphabetical order):
  2136.  
  2137.  +---------------------------------------------------------------------+
  2138.  |   Real life (uh ?)       IRC          E-mail                        |
  2139.  |   ~~~~~~~~~~~~~~~~       ~~~          ~~~~~~                        |
  2140.  |   Christopher Davis      ckd          ckd@eff.org                   |
  2141.  |   Christophe Wolfhugel   Zolf         wolf@grasp.insa-lyon.fr       |
  2142.  |   Darren Reed            Avalon       avalon@coombs.anu.edu.au      |
  2143.  |   Greg Lindahl,          Wumpus       gl8f@virginia.edu             |
  2144.  |   Helen Rose             Trillian     hrose@eff.org                 |
  2145.  |   Ian Frechette          Daemon       frechett@spot.colorado.edu    |
  2146.  |   Jarkko Oikarinen       WiZ          jto@tolsun.oulu.fi            |
  2147.  |   Jeff Trim                           jtrim@orion.cair.du.edu       |
  2148.  |   Jonathon E. Tidswell   Ernie        jont@cs.su.oz.au              |
  2149.  |   Karl Kleinpaste        poptart      KarlKleinpaste@cs.cmu.edu     |
  2150.  |   Matthew Alderson       thecure      thecure@mullian.ee.mu.oz.au   |
  2151.  |   Matthew Green          phone        phone@coombs.anu.edu.au       |
  2152.  |   Mauri Haikola          Mauri        mjh@stekt.oulu.fi             |
  2153.  |   Michael Sandrof        BigCheese    ms5n+@andrew.cmu.edu          |
  2154.  |   Olaf Titz              praetorius   stitz@ira.uka.de              |
  2155.  |   Ove Ruben R. Olsen     Gnarfer      rubenro@viggo.blh.no          |
  2156.  |   Ronald van Loon        rvl          rvloon@cv.ruu.nl              |
  2157.  |   Troy Rollo             Troy         troy@cbme.unsw.edu.au         |
  2158.  +---------------------------------------------------------------------+
  2159.  
  2160.    Feel  free  to bug me with your comments, I hope I'll have enough time
  2161. to reply.
  2162.  
  2163.                                                Paris, February 21, 1993,
  2164.                                                     Ecole Polytechnique,
  2165.  
  2166.                                                           Nicolas PIOCH.
  2167.  
  2168. .
  2169.