summaryrefslogtreecommitdiff
path: root/semantic_version
diff options
context:
space:
mode:
authorRaphaël Barrois <raphael.barrois@polytechnique.org>2016-02-12 00:48:18 +0100
committerRaphaël Barrois <raphael.barrois@polytechnique.org>2016-02-12 00:48:18 +0100
commit15277fdb8ec28790232b4df614e65c8894ef0904 (patch)
tree45e6f1efd6e23df72639ba67f44128d05fc3e6ad /semantic_version
parentd6e5651c340b55606d1f6d346e36ad34935335b6 (diff)
parentec54ee92f1e9ad06d87fc864a08ceb66021c7df0 (diff)
downloadsemantic-version-15277fdb8ec28790232b4df614e65c8894ef0904.tar.gz
Merge branch 'tilde-caret' of https://github.com/skwashd/python-semanticversion into skwashd-tilde-caret
Diffstat (limited to 'semantic_version')
-rw-r--r--semantic_version/base.py20
1 files changed, 18 insertions, 2 deletions
diff --git a/semantic_version/base.py b/semantic_version/base.py
index c81a3de..7451e14 100644
--- a/semantic_version/base.py
+++ b/semantic_version/base.py
@@ -398,11 +398,15 @@ class SpecItem(object):
KIND_LT = '<'
KIND_LTE = '<='
KIND_EQUAL = '=='
+ KIND_SHORTEQ = '='
+ KIND_EMPTY = ''
KIND_GTE = '>='
KIND_GT = '>'
KIND_NEQ = '!='
+ KIND_CARET = '^'
+ KIND_TILDE = '~'
- re_spec = re.compile(r'^(<|<=|==|>=|>|!=)(\d.*)$')
+ re_spec = re.compile(r'^(<|<=|={,2}|>=|>|!=|\^|~)(\d.*)$')
def __init__(self, requirement_string):
kind, spec = self.parse(requirement_string)
@@ -437,7 +441,7 @@ class SpecItem(object):
return version < self.spec
elif self.kind == self.KIND_LTE:
return version <= self.spec
- elif self.kind == self.KIND_EQUAL:
+ elif self.kind in [self.KIND_EQUAL, self.KIND_SHORTEQ, self.KIND_EMPTY]:
return version == self.spec
elif self.kind == self.KIND_GTE:
return version >= self.spec
@@ -445,9 +449,21 @@ class SpecItem(object):
return version > self.spec
elif self.kind == self.KIND_NEQ:
return version != self.spec
+ elif self.kind == self.KIND_CARET:
+ return self.caretCompare(version)
+ elif self.kind == self.KIND_TILDE:
+ return self.tildeCompare(version)
else: # pragma: no cover
raise ValueError('Unexpected match kind: %r' % self.kind)
+ def caretCompare(self, version):
+ max_version = version.next_major()
+ return version >= self.spec and version < max_version
+
+ def tildeCompare(self, version):
+ max_version = version.next_minor()
+ return version >= self.spec and version < max_version
+
def __str__(self):
return '%s%s' % (self.kind, self.spec)