README
author Alexander Solovyov <piranha@piranha.org.ua>
Sat, 18 Jul 2009 00:02:30 +0300
changeset 44 bb7358d6b48f
parent 41 8f651939cab7
child 49 a3feac00d151
permissions -rw-r--r--
manifest doesn't need to be included in repo

.. -*- mode: rst -*-

=============
 Finaloption
=============

Finaloption is a command line parser, intended to make writing command line
applications easy and painless. It uses built-in Python types (lists,
dictionaries, etc) to define options, which makes configuration clear and
concise. Additionally it contains possibility to handle subcommands (i.e.
``hg commit`` or ``svn update``).

JFYI: name is derived from Die Krupps' song Final Option.

Quick example
-------------

That's simple example to show you example of an option definition::

  import sys
  from finaloption import command

  @command(usage='%name [-n] MESSAGE')
  def main(message,
           nonewline=('n', False, 'don\'t print a newline')):
      'Simple echo program'
      sys.stdout.write(message)
      if not nonewline:
          sys.stdout.write('\n')

  if __name__ == '__main__':
      main()

Running this program will print the help::

  echo.py [-n] MESSAGE

  Simple echo program

  options:

   -n --nonewline  don't print a newline
   -h --help       show help

I think this mostly describes what's going to. To learn more, read
`documentation`_.

.. _documentation: http://hg.piranha.org.ua/finaloption/docs/