From 51b639595858c8395f3beb01659ffe0ea69aaf8b Mon Sep 17 00:00:00 2001 From: Jason Gerard DeRose Date: Wed, 10 Sep 2008 01:03:59 +0000 Subject: 277: Added public.generate_argument() function; added corresponding unit tests --- ipalib/public.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'ipalib/public.py') diff --git a/ipalib/public.py b/ipalib/public.py index fb7a80b9..772490d0 100644 --- a/ipalib/public.py +++ b/ipalib/public.py @@ -198,6 +198,21 @@ class Option(plugable.ReadOnly): ) +def generate_argument(name): + """ + Returns an `Option` instance using argument ``name``. + """ + if name.endswith('?'): + kw = dict(required=False, multivalue=False) + elif name.endswith('*'): + kw = dict(required=False, multivalue=True) + elif name.endswith('+'): + kw = dict(required=True, multivalue=True) + else: + kw = dict(required=True, multivalue=False) + return Option(name.rstrip('?*+'), ipa_types.Unicode(), **kw) + + class Command(plugable.Plugin): __public__ = frozenset(( 'get_default', -- cgit