diff --git a/conf.py b/conf.py index 96627bc..0e56058 100644 --- a/conf.py +++ b/conf.py @@ -50,7 +50,7 @@ copyright = u'2011, Valentin Lorentz' # The short X.Y version. version = '0.83' # The full version, including alpha/beta/rc tags. -release = '0.83' +release = '0.83.4.1' # The language for content autogenerated by Sphinx. Refer to documentation # for a list of supported languages. diff --git a/index.rst b/index.rst index e0929f5..950357c 100644 --- a/index.rst +++ b/index.rst @@ -9,7 +9,11 @@ Welcome to Limnoria's documentation! Contents: .. toctree:: - :maxdepth: 2 + :maxdepth: 2 + + use/index.rst + plugins/index.rst + core/index.rst Indices and tables ================== diff --git a/use/getting_started.rst b/use/getting_started.rst new file mode 100644 index 0000000..cda8b72 --- /dev/null +++ b/use/getting_started.rst @@ -0,0 +1,112 @@ +.. highlight:: none + +.. _getting-started: + +**************************** +Getting started with Supybot +**************************** + +Conventions used by Supybot and this document +============================================= + +Vocabulary +---------- + +Plugin + A plugin contains commands. A plugin can be loaded and unloaded on + the fly, as you wish. + Plugin names are always capitalized, and may contain other uppercase + letter, as a separation between two words, because they cannot contain + spaces. + +Command + Commands can be called by users of the bot. + Command names are always lowercased; they always have an help message, that + can be requested at any moment + +Argument + Most of the commands requires arguments, in order to give them more + informations about what you want it to do. + +Configuration variable + A configuration variable is set either by a bot owner or by a channel op. + +Syntax of the commands +---------------------- + +The syntax of a command describes how to run a command. +The syntax is given by the help command. +Some examples: + +help [] [] + This is the help of :ref:`command-plugin-help`. + + The chevrons mean you have to replace and by a plugin + name and a command name. + + The brackets mean the argument they wrap is **optional**. + + So, the fellowing commands are correct:: + + help + help PluginName + help PluginName CommandName + help CommandName + +ping takes no arguments + This is the help for :ref:`command-misc-ping`. + + I think it is clear enough. + +join [] + This is the help for :ref:`command-channel-join`. + + It requires a channel name, and the channel key is optional. + + This two commands are ok:: + + join #limnoria + join #limnoria MySecretKey + +utilities last [ ...] + This is the help for :ref:`command-utitilies-last`. + By the way, there is another ``last`` command in the `Misc` plugin, which + doesn't do the same thing, that's why you need to give the plugin name. + + You have to give at least one argument, but you can give as many as you + wish. + +Basics +====== + +Identifying with the bot +------------------------ + +Everything you want to do with your bot should be done on IRC (apart starting +the bot, of course). That's why the first thing you need to do is getting your +bot know your are its owner, unless what it won't obey you for administrative +commands. + +Open a query window with the bot (make sure this is your bot), and write in +it:: + + identify + +where ** and ** are the name and the password you gave to the +*supybot-wizard*. + +Sending the bot a command +------------------------- + +There are four ways to ask the bot to do something: + +* Give the command in private; +* Give the command on a channel with a prefix character, either set in the + wizard or in the configuration; +* Give the command on a channel prefixed by the nick; +* Give the command on a channel, prefixed by a string of characters, set in + the config. + +In this documentation, we the bot is called *mybot*, and its prefix char is @, +because @ is the most common prefix for Supybot; and the bot doesn't have a +prefix string of characters. diff --git a/use/index.rst b/use/index.rst new file mode 100644 index 0000000..2f63d70 --- /dev/null +++ b/use/index.rst @@ -0,0 +1,11 @@ +.. _use-index: + +###################### +The Supybot user guide +###################### + +.. toctree:: + :maxdepth: 3 + + install.rst + getting_started.rst diff --git a/use/install.rst b/use/install.rst new file mode 100644 index 0000000..c9018ea --- /dev/null +++ b/use/install.rst @@ -0,0 +1,238 @@ +.. highlight:: bash + +.. _use-install: + +******************* +Installing Limnoria +******************* + +This is the "easy to follow" guide to installing supybot. The installation +documentation provided with the supybot distribution is really quite good +already, but since people keep coming to IRC, asking a repeating pattern of +questions, we thought it would be a good idea to expand it a bit to make it +a little more of a "foolproof guide". + +Dependencies +============ + +Here's the list of recommended software to run Supybot: + +* Supybot is written in Python, and requires `Python`_ + 2.4 or greater (but not Python 3). +* `Twisted`_ framework 1.2.0 or greater (optional, you probably don't need it). + +.. _Python: http://www.python.org/ +.. _Twisted: http://twistedmatrix.com/ + +Installation: UNIX/Linux/BSD +============================ + +Install Python +-------------- + +Python will usually come by installed by default in your distribution. If not, +grab the appropriate packages from the distribution's repository. + +If you're installing Python using your distribution's packages, you may need a +''python-dev'' or ''python-devel'' package installed, too. To see if this is +the case, open up a terminal, start python, and run: + +.. code-block:: python + + import distutils + +If it works, you're good to go. Otherwise, install the `python-dev` or +`python-devel` package and try again. + +You may also install "manually" by downloading the source archive from +http://python.org, and compiling it. That is outside the scope of this guide, +however. + +Install Supybot +--------------- + +We are now ready to install supybot itself. Most distributions have a supybot +package in the repositories. This is probably the easiest way to install. If +that is what you want to do, that's fine, and you're ready to move on to the +next section. :) + +However, supybot tends to be actively developed, and it's best to grab the +latest codebase. Easiest way to do that is to clone the repository with +running:: + + git clone git://github.com/ProgVal/Limnoria.git + +You can also click the "Downloads" button at the `Limnoria repository`_. Then, +extract the tarball/zipball to some temporary directory, and ``cd`` into the +``supybot`` directory which contains the extracted code. + +.. _Limnoria repository: https://github.com/ProgVal/Limnoria + +If you have root access +^^^^^^^^^^^^^^^^^^^^^^^ + +Run, as root:: + + python setup.py install + +If all goes according to plan, the supybot python module will be installed to +somewhere like ``/usr/lib/python2.x/site-packages``, and a few supybot scripts +will be installed to somewhere like ``/usr/bin`` or ``/usr/local/bin``. + +If you don't have root access, or want a local install +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +You can install Supybot in a local directory by using the ``--prefix`` option +when running ``setup.py``. E.g.:: + + python setup.py install --prefix=$HOME/packages + +to install into a ``packages`` directory inside your home directory. You'll now +have a ``$HOME/packages/bin`` directory containing Supybot programs ('supybot', +``supybot-wizard``, etc.) and a ''$HOME/packages/lib'' directory containing the +Supybot libraries. + +It is also recommended that you setup a proper PYTHONPATH environment variable +in your shell's init file (e.g., the ``~/.bashrc`` for bash, ``~/.tcshrc`` for +tcsh, etc.). This will tell python where to find the supybot python module. + +For bash:: + + export PYTHONPATH=$HOME/packages/lib/python2.x/site-packages + +For (t)csh: + +.. code-block:: csh + + setenv PYTHONPATH $HOME/packages/lib/python2.x/site-packages + +Be sure to replace "2.x" by your Python version (probably either 2.6 or 2.7) + +Configure Supybot +----------------- + +We are now ready to configure Supybot. Supybot creates quite a few auxiliary +files/directories to store its runtime data. It is thus recommended to create +an empty directory from which you'll be running supybot, to keep all the data +in a nice dedicated location. For example, you may create a 'runbot' directory +inside your home directory. + +Now you can cd to your 'runbot' directory, and from within it run +``supybot-wizard``, which will walk you through a series of questions to +generate the bot config file. + +One thing to make sure to do in the wizard, to make your life easier down the +line, is to select **y** for the *Would you like to add an owner user for your +bot?* question, and actually create the owner user. Remember that password, so +that you can later ''identify'' with the bot on IRC and administer it. + +Once you generate the config file, which will be named ``yourbotnick.conf`` +(where "yourbotnick" is the nick you have chosen for your bot in the wizard), +it will be placed in your 'runbot' directory. (As long as you leave the default +answer to the ''Where would you like to create these directories?'' question.) + +Now to start the bot, run, still from within the 'runbot' directory:: + + supybot yourbotnick.conf + +And watch the magic! + +For a tutorial on using and managing the bot from here on, see the `Supybook`_. + +.. _Supybook: http://supybook.fealdia.org/ + +Installation: OS X +================== + +The steps are essentially the same as those of the previous section, except +there are no repositories. Grab the latest python installer for OS X from +http://python.org, and follow the rest of the steps. + +Installation: Windows +===================== + +Install Python +-------------- + +Download the latest Python 2 installer from http://python.org, (Python 2.7, as +of Mars 6, 2011) and run it to install Python. + +The rest of this document will assume that you have Python 2.7, and thus that +your install directory is ''C:\Python27''. + +Install Supybot +--------------- + +We are now ready to install Supybot itself. First, you need to grab the latest +code snapshot of Supybot. Easiest way to do that is to click the "Downloads" +button at the `Limnoria repository`_. + +If you downloaded the code archive, extract it to some temporary directory, +and ``cd`` into the ``supybot`` directory which contains the extracted code. + +Once you have the code archive, extract it to some temporary directory, then +open up a command prompt (Programs -> Run -> ``cmd``) and ``cd`` into the +``supybot`` directory which contains the extracted code. For example, if you +have extracted the archive to ``C:\sometempdir\``, you would enter in the +prompt: + +.. code-block:: bat + + cd "C:\sometempdir\supybot" + +Once there, run the installer to install, with the following command: + +.. code-block:: bat + + C:\Python27\python.exe setup.py install + +This will place some supybot scripts under ``C:\Python27\Scripts\``, and the +supybot python module under ``C:\Python27\Lib\site-packages``. + +.. _Limnoria repository: https://github.com/ProgVal/Limnoria + +Configure Supybot +----------------- + +We are now ready to configure Supybot. Supybot creates quite a few auxiliary +files/directories to store its runtime data. It is thus recommended to create +an empty directory from which you'll be running supybot, to keep all the data +in a nice dedicated location. For example, you may create a 'C:\runbot' for +this purpose. + +Now you open a command prompt, and ``cd`` to your ``C:\runbot`` directory:: + + cd "C:\runbot" + +and from within it run ``supybot-wizard``:: + + C:\Python27\python.exe C:\Python27\Scripts\supybot-wizard + +which will walk you through a series of questions to generate the bot config +file. + +One thing to make sure to do in the wizard, to make your life easier down the +line, is to select *y* for the *Would you like to add an owner user for +your bot?* question, and actually create the owner user. Remember that +password, so that you can later ''identify'' with the bot on IRC and +administer it. + +Once you generate the config file, which will be named ``yourbotnick.conf`` +(where ``yourbotnick`` is the nick you have chosen for your bot in the wizard), +it will be placed in your ``runbot`` directory. (As long as you leave the +default answer to the *Where would you like to create these directories?* +question.) + +Now to start the bot, run, still from within the ``C:\runbot`` directory:: + + C:\Python27\python.exe C:\Python27\Scripts\supybot yourbotnick.conf + +And watch the magic! + +For a tutorial on using and managing the bot from here on, see the `Supybook`_. + +This guide has been mainly written by nanotube (Daniel Folkinshteyn), and is +licensed under the Creative Commons Attribution ShareAlike 3.0 Unported license +and/or the GNU Free Documentation License v 1.3 or later. + +.. _Supybook: http://supybook.fealdia.org/