Index of /sandbox/paultremblay/old/docutils_nest/doc

[ICO]NameLast modifiedSizeDescription

[PARENTDIR]Parent Directory   -  

README: docultils-nest-xml.py

README: docultils-nest-xml.py

Author:

Paul Tremblay

Contact:
phthenry@earthlink.net
Date:
2011-01-09
Web site:

http://docutils.sourceforge.net/

Overview

The script docultils-nest-xml.py extends the power of docultils by allowing XML authors and developers to include nested inline markup in their documents. While docutils allows for infinite nesting on the block level, it limits inline markup to one level. The script docultils-nest-xml.py elminates this shortcomming. An XML author could write a document in rst format, and then with docultils-nest-xml.py translate it to robust XML, which he could then further transform to docbook or any other form of XML he desired. Any type of XML markup is possible using |script_name|.

In addition to allowing for nested markup, docultils-nest-xml.py allows you to choose any type of inline markup you wish.

Because users of docutils expressed differences as to how they wanted to mark inline text, docultils-nest-xml.py allows you to customize the markup.

Quick Example

You wantd to include a comment with emphasized text in your final XML document. You type:

[:comment: Maybe I should include *The Sun Also Rises?*]

You then issue the command:

docultils-nest-xml.py --output my_document.rst

The output is:

<inline arg1 = "comment">Maye I should include <emphasis>The Sun Also
Rises?</emphasis></inline>

Installation

  1. Install python. (http://www.python.org)

  2. Install the docutils package. (http://docutils.sourceforge.net/)

  3. Install the PyXml package. (http://pyxml.sourceforge.net/)

4. Install the docutils_nest. You will need to have cvs installed on your machine.

  1. Open a shell. Type

cvs -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/docutils login

When asked for a password, simpy hit return.

  1. Download the docutils_nest. Type

cvs -z3
-d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/docutils co
sandbox/paultremblay

This command will download the directory sandbox/paultremblay to your current directory. Change to the directory /sandbox/paultremblay.

  1. Run the configuration script to set the path and location of the configuration file.

python configure.py target = <desired location of configuration file>

If no target is provided (or you choose not to run the configuration file), the configuration file will be placed in /etc/docutils_nest.

  1. Install the modules in the usual way:

python setup.py build

python setup.py install

Use

docultils-nest-xml.py --output <outfile> file.rst

You must specify an output option.

In addition, you can specify any options you would if running docutils-xml.py:

docultils-nest-xml.py --indents --quiet --output otupt.xml file.rst

How to markup your document

By default, the nested_inline module uses the following structure to markup text:

[:some-tag test example: text [:nested: more text [text with brackets]]]

This markup gets converted to:

<inline arg1 = "some-tag" arg2 = "test" arg3 = "example">text <inline arg1 =
"nested" more text [text with brackets]</inline></inline>
You begin inline markup with an opening bracket followed by a colon, with no

space. You then fill in the arguments by typing in words after the colon. A colon marks the end of the beginning tag and begins the text. A closing bracket marks the end of the inline text.

Note that you can nest your markup to as many levels as you wish. You can also use brackets just as you norally would and not worry that nest_inline will confuse regular brackets with text meant to be treated as markup. However, the brackets must be matched. Consider this markup:

[:math-formula-containing-closing-bracket: 2x ] ]

You might mean for the first closing bracket to be part of the formula, but the nested_inline module will think it marks the end of your inline text. The script will produce this output:

<inline arg1 = "math-forumla-containing-closing-bracket">2x</inline><problematic
description = "solitary closing bracket my produce output you don't want"/>]

In order to overcome this problem, escape the first closing bracket with literal markup:

[:math-forumula-containing-closing-bracket: 2x ``]`` ]

Errors

The module nested_inline will not produce invalid XML. If you write a file that has the potential to result in ill-formed XML, nested_inline produces an error message, along with an error tag. Consider the following document:

.. If the script converted the brackets to tag, you would get

.. <emphasis><inline arg1 = "markup">text</emphasis></inline>

*[:markup: text*]

The result is:

<emphasis><problematic descrition = "tagging text would result in ill-formed XML"/>[:markup: text</emphasis>]

Customizing Markup

The nested_inline module reads from a customization file in order to determine how inline text is marked up. Change this document in order to change how you want to markup your text.

The configuration file takes 6 values:

  • start-role: the way to mark the start of a role. The default is ":".

  • end-role: the way to mark the end of a role. The default is ":".

  • start-group: the way to mark the start of a group. The default is "[".

  • end-group: the way to mark the end of a group. The default is "]".

  • tag-name: the name of the inline tag. The default is "inline".

  • warning: the name of the warning messge for errors. The default is "problematic".

Let's say you wanted to markup your text using parenethesis rather than brackets, and that you wanted your role to go outside of the parenthesis. You want your tag name to be "inline-tag", and your warning to be "warning." Your configuration file would look like this:

<configure>
  <start-role string = ':'/>
  <end-role string = ':'/>
  <start-group string = '('/>
  <end-group string = ')'/>
  <place-of-role place = 'outside'/>
  <tag-name name = 'inline-tag'/>
  <warning name = 'warning'/>
</configure>

You would then markup your text as:

:comment:(This is a comment with *italics*)

The output would be:

<inline-tag arg1 = "comment">This is a comment with <emhasis>italics</emphasis></inline-tag>

Project Files & Directories

  • README.txt: You're reading it.

*docutils_nest: Contains all the modules for the script to run

*doc: The documentation for the module, including a copy of this README.txt.

*scripts: the script docultils-nest-xml.py.

*test_files: Files to test the script.

Getting Help

Contact me.

Docutils System Messages