File: index.rst

package info (click to toggle)
versiontools 1.9.1-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 208 kB
  • sloc: python: 466; makefile: 5
file content (70 lines) | stat: -rw-r--r-- 2,374 bytes parent folder | download | duplicates (4)
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
Version Tools Documentation
===========================

.. seealso:: To get started quickly see :ref:`usage`
.. seealso:: See what's new in :ref:`version_1_9_1`

.. note::
    This document may be out of date, the bleeding edge version is always
    available at http://versiontools.rtfd.org/

Installation
============

This package is being actively maintained and published in the `Python Package
Index <http://http://pypi.python.org>`_. You can install it if you have `pip
<http://pip.openplans.org/>`_ tool using just one line::

    $ pip install versiontools

Features
========

* A piece of code that allows you to keep a **single version definition**
  inside your package or module. No more hacks in setup.py, no more
  duplicates in setup.py and somewhere else. Just **one** version per
  package.
* :class:`~versiontools.Version` objects can produce nice version strings for
  released files that are compliant with :pep:`386`. Releases, alphas, betas,
  development snaphots. All of those get good version strings out of the box.
* Version objects understand the :abbr:`VCS (Version Control System)` used by
  your project. Git, Mercurial and Bazaar are supported out of the box.
  Custom systems can be added by 3rd party plugins.
* Version object that compares as a tuple of values and sorts properly.
* Zero-dependency install! If all you care about is handling setup() to get
  nice tarball names then you don't need to depend on versiontools (no
  setup_requires, no install_requires!). You will need to bundle a small
  support module though.

__version__ to string conversion
================================

This is pulled from the documentation of the string method on the
:class:`~versiontools.Version` class. In general you don't need to explicitly
use that class to benefit from this system. To learn more check the
:ref:`usage` section.

.. automethod:: versiontools.Version.__str__
    :noindex:

.. note::
    This logic is implemented in :meth:`versiontools.Version.__str__()`
    and can be overridden by sub-classes. You can use project-specific
    logic if required. To do that replace __version__ with an instance
    of your sub-class.

Indices and tables
==================

.. toctree::
    :maxdepth: 3
    
    usage.rst
    vcs-integration.rst
    reference.rst
    changes.rst

* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`