aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/mesonlib.py
diff options
context:
space:
mode:
authorSalamandar <felix@piedallu.me>2018-04-26 16:49:13 +0200
committerSalamandar <felix@piedallu.me>2018-06-01 14:23:24 +0200
commitae19fec9528c0e3ff764eca271227c670284909a (patch)
treed91fc8bbfad239abe5e5b306a5a1eff40f844fbd /mesonbuild/mesonlib.py
parentee2f8a0416f6973d03d36601f5dd99db7825ef7f (diff)
downloadmeson-ae19fec9528c0e3ff764eca271227c670284909a.zip
meson-ae19fec9528c0e3ff764eca271227c670284909a.tar.gz
meson-ae19fec9528c0e3ff764eca271227c670284909a.tar.bz2
Add version_compare_condition_with_{min,max} for specific comparison utils.
Split FeatureNew and FeatureDeprecated Implement features report to be printed in some 'dev mode'
Diffstat (limited to 'mesonbuild/mesonlib.py')
-rw-r--r--mesonbuild/mesonlib.py68
1 files changed, 68 insertions, 0 deletions
diff --git a/mesonbuild/mesonlib.py b/mesonbuild/mesonlib.py
index fe426c5..a2f05bc 100644
--- a/mesonbuild/mesonlib.py
+++ b/mesonbuild/mesonlib.py
@@ -487,6 +487,74 @@ def version_compare_many(vstr1, conditions):
found.append(req)
return not_found == [], not_found, found
+
+def version_compare_condition_with_min(condition, minimum):
+ match = numpart.match(minimum.strip())
+ if match is None:
+ msg = 'Uncomparable version string {!r}.'
+ raise MesonException(msg.format(minimum))
+ minimum = match.group(0)
+ if condition.startswith('>='):
+ cmpop = operator.lt
+ condition = condition[2:]
+ elif condition.startswith('<='):
+ return True
+ condition = condition[2:]
+ elif condition.startswith('!='):
+ return True
+ condition = condition[2:]
+ elif condition.startswith('=='):
+ cmpop = operator.lt
+ condition = condition[2:]
+ elif condition.startswith('='):
+ cmpop = operator.lt
+ condition = condition[1:]
+ elif condition.startswith('>'):
+ cmpop = operator.lt
+ condition = condition[1:]
+ elif condition.startswith('<'):
+ return True
+ condition = condition[2:]
+ else:
+ cmpop = operator.eq
+ varr1 = grab_leading_numbers(minimum, True)
+ varr2 = grab_leading_numbers(condition, True)
+ return cmpop(varr1, varr2)
+
+def version_compare_condition_with_max(condition, maximum):
+ match = numpart.match(maximum.strip())
+ if match is None:
+ msg = 'Uncomparable version string {!r}.'
+ raise MesonException(msg.format(maximum))
+ maximum = match.group(0)
+ if condition.startswith('>='):
+ return False
+ condition = condition[2:]
+ elif condition.startswith('<='):
+ cmpop = operator.lt
+ condition = condition[2:]
+ elif condition.startswith('!='):
+ return False
+ condition = condition[2:]
+ elif condition.startswith('=='):
+ cmpop = operator.lt
+ condition = condition[2:]
+ elif condition.startswith('='):
+ cmpop = operator.lt
+ condition = condition[1:]
+ elif condition.startswith('>'):
+ return False
+ condition = condition[1:]
+ elif condition.startswith('<'):
+ cmpop = operator.lt
+ condition = condition[2:]
+ else:
+ cmpop = operator.eq
+ varr1 = grab_leading_numbers(maximum, True)
+ varr2 = grab_leading_numbers(condition, True)
+ return cmpop(varr1, varr2)
+
+
def default_libdir():
if is_debianlike():
try: