2007-04-19 20:47:36 +00:00
|
|
|
# Copyright (c) 2004-2007 Bryce "Zooko" Wilcox-O'Hearn
|
|
|
|
# mailto:zooko@zooko.com
|
|
|
|
# http://zooko.com/repos/pyutil
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
# of this work to deal in this work without restriction (including the rights
|
|
|
|
# to use, modify, distribute, sublicense, and/or sell copies).
|
|
|
|
|
|
|
|
"""
|
|
|
|
extended version number class
|
|
|
|
"""
|
|
|
|
|
|
|
|
from distutils import version
|
|
|
|
|
|
|
|
# End users see version strings like this:
|
|
|
|
|
|
|
|
# "1.0.0"
|
|
|
|
# ^ ^ ^
|
|
|
|
# | | |
|
|
|
|
# | | '- micro version number
|
|
|
|
# | '- minor version number
|
|
|
|
# '- major version number
|
|
|
|
|
|
|
|
# The first number is "major version number". The second number is the "minor
|
|
|
|
# version number" -- it gets bumped whenever we make a new release that adds or
|
|
|
|
# changes functionality. The third version is the "micro version number" -- it
|
|
|
|
# gets bumped whenever we make a new release that doesn't add or change
|
|
|
|
# functionality, but just fixes bugs (including performance issues).
|
|
|
|
|
|
|
|
# Early-adopter end users see version strings like this:
|
|
|
|
|
|
|
|
# "1.0.0a1"
|
|
|
|
# ^ ^ ^^^
|
|
|
|
# | | |||
|
|
|
|
# | | ||'- release number
|
|
|
|
# | | |'- alpha or beta (or none)
|
|
|
|
# | | '- micro version number
|
|
|
|
# | '- minor version number
|
|
|
|
# '- major version number
|
|
|
|
|
|
|
|
# The optional "a" or "b" stands for "alpha release" or "beta release"
|
|
|
|
# respectively. The number after "a" or "b" gets bumped every time we
|
|
|
|
# make a new alpha or beta release. This has the same form and the same
|
|
|
|
# meaning as version numbers of releases of Python.
|
|
|
|
|
|
|
|
# Developers see "full version strings", like this:
|
|
|
|
|
2007-05-04 03:31:27 +00:00
|
|
|
# "1.0.0a1-55"
|
|
|
|
# ^ ^ ^^^ ^
|
|
|
|
# | | ||| |
|
|
|
|
# | | ||| |
|
2007-04-19 20:47:36 +00:00
|
|
|
# | | ||| '- nano version number
|
|
|
|
# | | ||'- release number
|
|
|
|
# | | |'- alpha or beta (or none)
|
|
|
|
# | | '- micro version number
|
|
|
|
# | '- minor version number
|
|
|
|
# '- major version number
|
|
|
|
|
|
|
|
# The next number is the "nano version number". It is meaningful only to
|
|
|
|
# developers. It gets bumped whenever a developer changes anything that another
|
|
|
|
# developer might care about.
|
|
|
|
|
|
|
|
class Tag(str):
|
|
|
|
def __cmp__(t1, t2):
|
|
|
|
if t1 == t2:
|
|
|
|
return 0
|
|
|
|
if t1 == "UNSTABLE" and t2 == "STABLE":
|
|
|
|
return 1
|
|
|
|
if t1 == "STABLE" and t2 == "UNSTABLE":
|
|
|
|
return -1
|
|
|
|
return -2 # who knows
|
|
|
|
|
|
|
|
class Version:
|
|
|
|
def __init__(self, vstring=None):
|
|
|
|
if vstring:
|
|
|
|
self.parse(vstring)
|
|
|
|
|
|
|
|
def parse(self, vstring):
|
|
|
|
i = vstring.find('-')
|
2007-05-04 03:31:27 +00:00
|
|
|
if i != -1:
|
2007-04-19 20:47:36 +00:00
|
|
|
svstring = vstring[:i]
|
|
|
|
estring = vstring[i+1:]
|
|
|
|
else:
|
|
|
|
svstring = vstring
|
|
|
|
estring = None
|
|
|
|
|
|
|
|
self.strictversion = version.StrictVersion(svstring)
|
|
|
|
|
2007-05-04 03:31:27 +00:00
|
|
|
self.nanovernum = None
|
|
|
|
self.tags = []
|
2007-04-19 20:47:36 +00:00
|
|
|
if estring:
|
2007-05-04 03:31:27 +00:00
|
|
|
self.nanovernum = estring
|
|
|
|
|
|
|
|
self.fullstr = str(self.strictversion)
|
|
|
|
if self.nanovernum is not None:
|
|
|
|
self.fullstr += "-" + str(self.nanovernum)
|
|
|
|
if self.tags:
|
|
|
|
self.fullstr += '_'.join(self.tags)
|
|
|
|
|
2007-04-19 20:47:36 +00:00
|
|
|
def tags(self):
|
|
|
|
return self.tags
|
|
|
|
|
|
|
|
def user_str(self):
|
|
|
|
return self.strictversion.__str__()
|
|
|
|
|
|
|
|
def full_str(self):
|
|
|
|
return self.fullstr
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.full_str()
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return self.__str__()
|
|
|
|
|
|
|
|
def __cmp__ (self, other):
|
|
|
|
if isinstance(other, basestring):
|
|
|
|
other = Version(other)
|
|
|
|
|
|
|
|
res = cmp(self.strictversion, other.strictversion)
|
|
|
|
if res != 0:
|
|
|
|
return res
|
|
|
|
|
|
|
|
res = cmp(self.nanovernum, other.nanovernum)
|
|
|
|
if res != 0:
|
|
|
|
return res
|
|
|
|
|
|
|
|
return cmp(self.tags, other.tags)
|