fdroidserver.looseversion module

Provides classes to represent module version numbers (one class for each style of version numbering). There are currently two such classes implemented: StrictVersion and LooseVersion.

Every version number class implements the following interface:
  • the ‘parse’ method takes a string and parses it to some internal representation; if the string is an invalid version number, ‘parse’ raises a ValueError exception

  • the class constructor takes an optional string argument which, if supplied, is passed to ‘parse’

  • __str__ reconstructs the string that was passed to ‘parse’ (or an equivalent string – ie. one that will generate an equivalent version number instance)

  • __repr__ generates Python code to recreate the version number instance

  • _cmp compares the current instance with either another instance of the same class or a string (which will be parsed to an instance of the same class, thus must follow the same rules)

class fdroidserver.looseversion.LooseVersion(vstring=None)

Bases: object

Version numbering for anarchists and software realists. Implements the standard interface for version number classes as described above. A version number consists of a series of numbers, separated by either periods or strings of letters. When comparing version numbers, the numeric components will be compared numerically, and the alphabetic components lexically. The following are all valid version numbers, in no particular order:

1.5.1 1.5.2b2 161 3.10a 8.02 3.4j 1996.07.12 3.2.pl0 3.1.1.6 2g6 11g 0.960923 2.2beta29 1.13++ 5.5.kw 2.0b1pl0

In fact, there is no such thing as an invalid version number under this scheme; the rules for comparison are simple and predictable, but may not always give the results you want (for some definition of “want”).

Methods

parse

component_re = re.compile('(\\d+ | [a-z]+ | \\.)', re.VERBOSE)
parse(vstring)
class fdroidserver.looseversion.LooseVersion2(vstring=None)

Bases: LooseVersion

LooseVersion variant that restores Python 2 semantics

In Python 2, comparing LooseVersions where paired components could be string and int always resulted in the string being “greater”. In Python 3, this produced a TypeError.

Methods

parse

parse(vstring)