aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/interpreterbase.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2018-03-13 21:16:30 +0200
committerGitHub <noreply@github.com>2018-03-13 21:16:30 +0200
commit9ecb75670f1a0c3a79c19d057c848323f85639a7 (patch)
treedf0c6b47b9d6f9f40d9c30aa547170114c111951 /mesonbuild/interpreterbase.py
parentae0e469b0692862dae10ceb02799feb3f117ce26 (diff)
parent4d8e4654cb9b3958897d2d230a3714b1abc6b9b4 (diff)
downloadmeson-9ecb75670f1a0c3a79c19d057c848323f85639a7.zip
meson-9ecb75670f1a0c3a79c19d057c848323f85639a7.tar.gz
meson-9ecb75670f1a0c3a79c19d057c848323f85639a7.tar.bz2
Merge pull request #3127 from bluetech/method-permitted-kwargs
Diffstat (limited to 'mesonbuild/interpreterbase.py')
-rw-r--r--mesonbuild/interpreterbase.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/mesonbuild/interpreterbase.py b/mesonbuild/interpreterbase.py
index 170df29..9279506 100644
--- a/mesonbuild/interpreterbase.py
+++ b/mesonbuild/interpreterbase.py
@@ -80,6 +80,22 @@ class permittedKwargs:
return wrapped
+class permittedMethodKwargs:
+
+ def __init__(self, permitted):
+ self.permitted = permitted
+
+ def __call__(self, f):
+ @wraps(f)
+ def wrapped(obj, args, kwargs):
+ for k in kwargs:
+ if k not in self.permitted:
+ mlog.warning('''Passed invalid keyword argument "{}".'''.format(k))
+ mlog.warning('This will become a hard error in the future.')
+ return f(obj, args, kwargs)
+ return wrapped
+
+
class InterpreterException(mesonlib.MesonException):
pass