This file is indexed.

/usr/share/doc/rest2web/html/introduction.txt is in rest2web-doc 0.5.2~alpha+svn-r248-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
restindex
    crumb: Introduction
    tags: introduction, site, website
    page-description:
        A gentle introduction to **rest2web**.
    /description
/restindex

==========================
 Introduction to rest2web
==========================
-------------------------------------------
 A Gentle Introduction to the Site Builder
-------------------------------------------

.. contents::
    
What is rest2web ?
==================

{emo;python} **rest2web** is a tool for autogenerating wesites, or parts of
websites. It's main features are :

* Integrated with docutils_.
* Automatically builds index pages and navigation links (sidebars and
  {acro;breadcrumbs;Weird name for navigation links ?}).
* Embedded code in templates for unlimited expressiveness.
* Flexible macro system.
* Uses relative links, so sites can be viewed from the filesystem.
* Unicode internally - so you don't have to be. {sm;:-p}
* Includes features for multiple translations of sites.
* Built-in gallery creator plugin.
* The basic system is very easy to use.
* Lots of powerful (optional) features.

The content can be stored as {acro;HTML}, or in ReST_ format; in which case the
HTML will be generated using docutils_. **rest2web** inserts each page into a
template, and automatically creates index pages for sections, and navigation
links. {sm;:-)}

{acro;ReST} is a {acro;WYSIWYG} text markup format. It is simpler than HTML -
but *very* flexible. A document marked up with reST is still readable as text.
This means that maintaining article contents in reST is a *lot* easier than
maintaining them in HTML.

Adding new pages is as easy as dropping a text file into the right folder.
**rest2web** builds the new page and adds a link to it in the index (optionally
with a description as well). Removing a page is just as easy. Delete the file,
and when you run **rest2web** again it removes the entry. 

**rest2web** includes standard functions to build a sidebar, with links to the
other pages in the directory, or to the other sections in the website. 

Another advantage is that a website can be easily restyled by only changing
template files. It is likely that only a few template files will be needed for
most websites [#]_.

Because rest2web generates sites using *relative paths*, the results can be
viewed from the filesystem. This means that it is an effective way of bundling
documentation.


Internationalization
--------------------

With uservalues_ you can use **rest2web** to create versions of a website in
different languages. Simply create the framework once with your uservalues as
place markers - then create your files with different translations.
**rest2web** will build the website and can handle linking the sites together.

An example of a site that uses this feature is, the `Website of Marius Soutier <http://www.soutier.de>`_.


Static Versus Dynamic
---------------------

{emo;html} rest2web is a dynamic website generation tool - that generates
static (HTML) pages. The rationale of creating static content, is that most
pages will only change occasionally - serving static HTML content is quicker
than generating pages dynamically. Not only that, but static 
content can be served by a lot cheaper hosting account!

Distributing HTML documentation is another reason for wanting static pages.

Why rest2web ?
--------------

**rest2web** comes about from a need for me to restyle a whole website from
badly marked up HTML 4, into beautiful {acro;XHTML} and {acro;CSS;Cascading Style Sheets}.
{sm;:grin:} See the `Voidspace Manifesto`_ for a discussion of my aims and
objectives in the restyle.

An added challenge is that part of the website is already restyled - and the
blog pages are built using a different tool (Firedrop2_, which also uses ReST
incidentally). All this means that rest2web needs to be able to handle
generating just *part* of a website, and indexes for the existing parts where
necessary.

A rest2web Site
===============

**rest2web** is optimized for creating websites with a particular structure. It is aimed at the sort of sites that have sections and subsections. The basic structure is closely related to the directory structure on disk. It is based on having an index page in each directory. Files in that directory are listed in the index page, which can be divided into various sections. {sm;8-)}

Subdirectories have their own index page - that index page will be link to from the 'directory' above. Your website structure is modelled on the directory structure. This is the hierarchy of sections and subsections.

Every text file ('.txt' extension) in a directory will be scanned. If the file starts with a restindex_, then it will be processed.

If you want links to some prebuilt files on an index page, then you can put a relevant text file in the directory with the details (target name, link title, page description, etc) and set ``build: No``. This allows you to use rest2web to just build part of a website - but still include in the index pages that it doesn't build. [#]_

For a good introduction, read the tutorial - `Creating a Site`_. You can also peruse the `Test Site`_ included with this documentation. It illustrates most features of rest2web.

Every page can *also* have a set of uservalues_ that will be inserted into the template. This is another way of putting dynamic values into a template. An obvious use of this system is for providing a website in several different languages.

If you just want to get up and running, you may want to checkout the `Quick Start Guide <quickstart.html>`_ by *Andrew Ittner*.

Downloading
===========

{emo;file1} All distributions include all the documentation and the example site.

Source Distribution
-------------------

**rest2web** is a pure Python programme. If you have Python installed you don't need to compile anything to use the source distribution.

Download **restweb** (2.49mb) from `rest2web-0.5.1.zip <http://www.voidspace.org.uk/cgi-bin/voidspace/downman.py?file=rest2web-0.5.1.zip>`_, or 
`rest2web-0.5.1.tar.gz <http://www.voidspace.org.uk/cgi-bin/voidspace/downman.py?file=rest2web-0.5.1.tar.gz>`_.


Executable Distribution
-----------------------

Download the executable version of **restweb** (3.5mb) from `rest2web-0.4.0alpha-EXE.zip <http://www.voidspace.org.uk/cgi-bin/voidspace/downman.py?file=rest2web-0.4.0alpha-EXE.zip>`_

Subversion Repository
---------------------

You can browse (or download using SVN) the latest development version over at the `SVN Repository`_.  [#]_

The version in SVN is often more up to date than the latest release version - and I *try* not to break the version in SVN (but no guarantees).

The full command is : ``svn co https://svn.rest2web.python-hosting.com/trunk/`` [#]_

.. note::

    If you obtain rest2web from subversion, it won't run from its own
    distribution directory unless you delete the ``__dist__`` file.

Sourceforge
-----------

**rest2web** can also be downloaded from the Sourceforge `rest2web Project Page`_.


Installing
==========

{emo;eyeballz} If you are running the source version of **rest2web**, you need docutils_ installed. It works best with the latest version [#]_.

rest2web itself shouldn't actually need installing. You *can* place the 'rest2web' directory in your 'site-packages' folder if you want to. You should then be able to run 'r2w.py' from anywhere.

You can test rest2web by just double clicking on it. This should build the docs and example site as html, in the *docs_html* directory. It will generate a log of the process in 'log.txt'. If there are any problems then they will be recorded in the log. Please report any bugs to the `rest2web Mailing List`_.

The files in the 'modules' folder are used by macros_. They will also need to be somewhere on ``sys.path`` (e.g. in 'site-packages'.) Alternatively, if the modules directory is in the same directory as 'r2w.py' when you run it, it will automatically be added to the path.

At the Heart
------------

**rest2web** and docutils are both projects written in a language called Python_. In order to use the source version you will need Python installed. 

.. hint::

    If you don't want to (or can't) install Python, then you can use the pre-built executable version instead.
    
    This does limit slightly what you can do with macros and embedded code in the templates. (Basically you can only use the modules that come included or that you create yourself).

The templates_ and macros_ are also done using Python code. If you've never used Python before, don't let this put you off. It's a very easy language to learn and you can learn the basics very quickly. The main Python_ website has distributions for most platforms available for download, as well as links to tutorials and resources for learning Python.

Useful Links
============

* rst-ht2html_ - This is a project with a similar aim, the automatic creation of websites from restructured text. It uses ht2html_, the scripts that generate sites like Python.org_, and Jython.org_. rest2web is more flexible with the templating it allows. It should be possible to generate a much wider range of sites with rest2web.

* docutils_ - this is the Python project that turns reStructuredText into nice XHTML.

* Firedrop2_ - the blog client originally created by `Hans Nowak`_. 

  This project [#]_ produced ``embedded_code.py`` and ``textmacros.py`` which are used by rest2web.  ``embedded_code.py`` is the templating engine used by rest2web.  ``textmacros.py`` adds a simple system of macros_ into **rest2web**.
  
  Firedrop2 also supports alternative text markups *sextile* and *textile*. rest2web may be enhanced to support these (if there is any demand).

    .. note::
    
        I now maintain **Firedrop2**. You can download the latest distribution, and browse the docs over at : http://www.voidspace.org.uk/python/firedrop2/index.shtml. {sm;:cool:}

* webgen_ - A ruby_ project that does a similar thing to **rest2web**. It is *scarily* similar in the way it works. {sm;:lol:} It doesn't work with ReST_ markup however.

* Tahchee_    - an alternative to *rest2web* that uses the cheetah_ templating system.

---------------

Footnotes
=========

.. [#] Many websites will only need a single template file. 
       `Voidspace <http://www.voidspace.org.uk>`_ actually uses two for *all* the
       parts of the site built by rest2web. 
.. [#] It's possible to include details of several of these pages in a single file 
       called 'restindex.txt'. It is basically a series of restindexes in a single file.
.. [#] Many thanks to the decent folks over at `python-hosting.com <http://www.python-hosting.com>`_.
.. [#] For Windoze users, I recommend the SVN client TortoiseSVN_.
.. [#] Version 0.3.9 or later.
.. [#] And **Kaa**, the predecessor to firedrop.

.. _rst-ht2html: http://www.rutherfurd.net/articles/rst-ht2html.html
.. _ht2html: http://ht2html.sourceforge.net/
.. _Python:
.. _python.org: http://www.python.org
.. _jython.org: http://www.jython.org
.. _docutils: http://docutils.sourceforge.net
.. _Hans Nowak: http://zephyrfalcon.org
..  _Firedrop:
.. _firedrop2: http://www.voidspace.org.uk/python/firedrop2/index.shtml
.. _rest: http://docutils.sourceforge.net/rst.html
.. _Voidspace Manifesto: http://www.voidspace.org.uk/documents/voidspace_manifesto.html
.. _pythonutils module: http://www.voidspace.org.uk/python/pythonutils.html
.. _restindex: restindex.html
.. _Creating a site: tutorial.html
.. _rest2web: http://www.voidspace.org.uk/python/rest2web
.. _BSD-License: http://www.voidspace.org.uk/python/license.shtml
.. _Rest2web Mailing List: http://lists.sourceforge.net/lists/listinfo/rest2web-develop
.. _SVN Repository: https://svn.rest2web.python-hosting.com/trunk/
.. _templates: templating.html
.. _macros: macros.html
.. _Test Site: test_site/index.html
.. _rest2web Project Page: http://sourceforge.net/projects/rest2web
.. _uservalues: reference/uservalues.html
.. _TortoiseSVN: http://tortoisesvn.tigris.org/
.. _webgen: http://webgen.rubyforge.org/
.. _ruby: http://www.ruby-lang.org/en/
.. _tahchee: http://www.ivy.fr/tahchee/
.. _cheetah: http://www.cheetahtemplate.org/