diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2018-03-13 21:16:30 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-03-13 21:16:30 +0200 |
commit | 9ecb75670f1a0c3a79c19d057c848323f85639a7 (patch) | |
tree | df0c6b47b9d6f9f40d9c30aa547170114c111951 /mesonbuild/interpreterbase.py | |
parent | ae0e469b0692862dae10ceb02799feb3f117ce26 (diff) | |
parent | 4d8e4654cb9b3958897d2d230a3714b1abc6b9b4 (diff) | |
download | meson-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.py | 16 |
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 |