home *** CD-ROM | disk | FTP | other *** search
/ The Unsorted BBS Collection / thegreatunsorted.tar / thegreatunsorted / hacking / internet / ircman.asc < prev    next >
Encoding:
Text File  |  1995-03-05  |  83.9 KB  |  2,156 lines

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