diff options
| author | Jenkins <jenkins@review.openstack.org> | 2012-12-04 09:44:31 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2012-12-04 09:44:31 +0000 |
| commit | 45e6afcbf51f07a381b17fbe30a87776ee84ad59 (patch) | |
| tree | 347fd445ae3dbee24630d83a5b4564fd87ac5f51 /openstack/common | |
| parent | e2fdbd38da576edfd40aeac3956eb48ae1d0e08a (diff) | |
| parent | 1e4753263fd8fad9db57558f6db7d6206da33439 (diff) | |
| download | oslo-45e6afcbf51f07a381b17fbe30a87776ee84ad59.tar.gz oslo-45e6afcbf51f07a381b17fbe30a87776ee84ad59.tar.xz oslo-45e6afcbf51f07a381b17fbe30a87776ee84ad59.zip | |
Merge "Add a CLI argument validation utility"
Diffstat (limited to 'openstack/common')
| -rw-r--r-- | openstack/common/cliutils.py | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/openstack/common/cliutils.py b/openstack/common/cliutils.py new file mode 100644 index 0000000..8f4dc44 --- /dev/null +++ b/openstack/common/cliutils.py @@ -0,0 +1,66 @@ +# vim: tabstop=4 shiftwidth=4 softtabstop=4 + +# Copyright 2012 Red Hat, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + +import inspect +import string + + +class MissingArgs(Exception): + + def __init__(self, missing): + self.missing = missing + + def __str__(self): + if len(self.missing) == 1: + return ("An argument is missing: %(missing)s" % + dict(missing=self.missing[0])) + else: + return ("%(num)d arguments are missing: %(missing)s" % + dict(num=len(self.missing), + missing=string.join(self.missing, ', '))) + + +def validate_args(fn, *args, **kwargs): + """Check that the supplied args are sufficient for calling a function. + + >>> validate_args(lambda a: None) + Traceback (most recent call last): + ... + MissingArgs: An argument is missing: a + >>> validate_args(lambda a, b, c, d: None, 0, c=1) + Traceback (most recent call last): + ... + MissingArgs: 2 arguments are missing: b, d + + :param fn: the function to check + :param arg: the positional arguments supplied + :param kwargs: the keyword arguments supplied + """ + argspec = inspect.getargspec(fn) + + num_defaults = len(argspec.defaults or []) + required_args = argspec.args[:len(argspec.args) - num_defaults] + + def isbound(method): + return getattr(method, 'im_self', None) is not None + + if isbound(fn): + required_args.pop(0) + + missing = [arg for arg in required_args if arg not in kwargs] + missing = missing[len(args):] + if missing: + raise MissingArgs(missing) |
