summaryrefslogtreecommitdiffstats
path: root/ipalib
diff options
context:
space:
mode:
authorJason Gerard DeRose <jderose@redhat.com>2009-01-21 13:59:55 -0700
committerRob Crittenden <rcritten@redhat.com>2009-02-03 15:28:59 -0500
commit6e53d03c69581982d341f591bfc3a35ec7f324d9 (patch)
tree2daddf0eaef54d4a392816e63300b88a3fdb9838 /ipalib
parente0d428f97aad1f9e9c3faedeaddbcade22927d37 (diff)
downloadfreeipa-6e53d03c69581982d341f591bfc3a35ec7f324d9.tar.gz
freeipa-6e53d03c69581982d341f591bfc3a35ec7f324d9.tar.xz
freeipa-6e53d03c69581982d341f591bfc3a35ec7f324d9.zip
Command.takes_options and Command.takes_args class attributes can now also be a callable
Diffstat (limited to 'ipalib')
-rw-r--r--ipalib/frontend.py18
1 files changed, 14 insertions, 4 deletions
diff --git a/ipalib/frontend.py b/ipalib/frontend.py
index b30205fe8..800bb43b3 100644
--- a/ipalib/frontend.py
+++ b/ipalib/frontend.py
@@ -312,23 +312,33 @@ class Command(plugable.Plugin):
def get_args(self):
"""
- Return iterable with arguments for Command.args namespace.
+ Iterate through parameters for ``Command.args`` namespace.
Subclasses can override this to customize how the arguments
are determined. For an example of why this can be useful,
see `ipalib.crud.Mod`.
"""
- return self.takes_args
+ if callable(self.takes_args):
+ args = self.takes_args()
+ else:
+ args = self.takes_args
+ for arg in args:
+ yield arg
def get_options(self):
"""
- Return iterable with options for Command.options namespace.
+ Iterate through parameters for ``Command.options`` namespace.
Subclasses can override this to customize how the options
are determined. For an example of why this can be useful,
see `ipalib.crud.Mod`.
"""
- return self.takes_options
+ if callable(self.takes_options):
+ options = self.takes_options()
+ else:
+ options = self.takes_options
+ for option in options:
+ yield option
def __create_args(self):
"""