From: "André Erdmann" <dywi@mailerd.de>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/R_overlay:master commit in: roverlay/
Date: Tue, 17 Sep 2013 16:40:56 +0000 (UTC) [thread overview]
Message-ID: <1379431568.f2caad3d9b949a0a0ca52219d467fbdc8c75499d.dywi@gentoo> (raw)
commit: f2caad3d9b949a0a0ca52219d467fbdc8c75499d
Author: André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue Sep 17 15:26:08 2013 +0000
Commit: André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue Sep 17 15:26:08 2013 +0000
URL: http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=f2caad3d
argparser,argutil: support subparsers
---
roverlay/argparser.py | 54 +++++++++++++++++++++++++++++++++++-----------
roverlay/argutil.py | 60 +++++++++++++++++++++++++++++++++++++++++++++++++--
2 files changed, 100 insertions(+), 14 deletions(-)
diff --git a/roverlay/argparser.py b/roverlay/argparser.py
index 5b28d0f..d52a1e2 100644
--- a/roverlay/argparser.py
+++ b/roverlay/argparser.py
@@ -6,6 +6,7 @@
import argparse
import collections
+import sys
import roverlay.core
import roverlay.argutil
@@ -566,6 +567,7 @@ class RoverlayArgumentParserBase ( roverlay.argutil.ArgumentParserProxy ):
class RoverlayArgumentParser ( RoverlayArgumentParserBase ):
MULTIPLE_COMMANDS = False
+ COMMAND_SUBPARSERS = None
COMMAND_DESCRIPTION = None
DEFAULT_COMMAND = None
@@ -582,6 +584,18 @@ class RoverlayArgumentParser ( RoverlayArgumentParserBase ):
assert self.default_command in self.COMMAND_DESCRIPTION
# --- end of __init__ (...) ---
+ def get_args_to_parse ( self ):
+ if self.__class__.COMMAND_SUBPARSERS is None:
+ return sys.argv[1:]
+ else:
+ args = sys.argv[1:]
+
+ if any ( command in args for command in self.COMMAND_DESCRIPTION ):
+ return args
+ else:
+ return args + [ self.default_command ]
+ # --- end of get_args_to_parse (...) ---
+
def get_commands ( self ):
if self.MULTIPLE_COMMANDS:
return self.command
@@ -590,23 +604,39 @@ class RoverlayArgumentParser ( RoverlayArgumentParserBase ):
# --- end of get_commands (...) ---
def setup_actions ( self ):
- arg = self.add_argument_group (
- "actions", title="actions",
- description=self.format_command_map ( self.COMMAND_DESCRIPTION ),
- )
+ if self.__class__.COMMAND_SUBPARSERS is None:
+ arg = self.add_argument_group (
+ "actions", title="actions",
+ description=self.format_command_map ( self.COMMAND_DESCRIPTION ),
+ )
- arg (
- 'command', default=self.default_command, metavar='<action>',
- nargs=( "*" if self.MULTIPLE_COMMANDS else "?" ),
- choices=self.COMMAND_DESCRIPTION.keys(),
- flags=self.ARG_HELP_DEFAULT,
- help="action to perform"
- )
+ arg (
+ 'command', default=self.default_command, metavar='<action>',
+ nargs=( "*" if self.MULTIPLE_COMMANDS else "?" ),
+ choices=self.COMMAND_DESCRIPTION.keys(),
+ flags=self.ARG_HELP_DEFAULT,
+ help="action to perform"
+ )
- return arg
+ return arg
+ else:
+ self.add_subparsers (
+ title="commands",
+ description=self.format_command_map ( self.COMMAND_DESCRIPTION ),
+ dest="command",
+ help="action to perform [%(default)s]",
+ )
+ # set_defaults() not necessary due to get_args_to_parse()
+ self.parser.set_defaults ( command=self.default_command )
+
+ for command in self.COMMAND_DESCRIPTION:
+ subparser = self.add_subparser ( command )
+
+ return None
# --- end of setup_actions (...) ---
def parse_actions ( self ):
+ print ( self.parsed )
self.command = self.parsed ['command']
# --- end of parse_actions (...) ---
diff --git a/roverlay/argutil.py b/roverlay/argutil.py
index c3981e5..7c36980 100644
--- a/roverlay/argutil.py
+++ b/roverlay/argutil.py
@@ -8,6 +8,7 @@ import os
import argparse
import pwd
import grp
+import sys
from roverlay.config.entryutil import deref_entry_safe
@@ -158,6 +159,9 @@ class ArgumentParserError ( Exception ):
class ArgumentGroupExists ( ArgumentParserError ):
pass
+class SubparserExists ( ArgumentParserError ):
+ pass
+
class ArgumentFlagException ( ArgumentParserError ):
pass
@@ -207,10 +211,54 @@ class ArgumentParserProxy ( object ):
self.defaults = dict ( defaults )
self._argument_groups = dict()
+ self._subparsers = dict()
+ self._subparser_ctrl = None
self.parsed = None
# --- end of __init__ (...) ---
+ def add_subparsers ( self, ignore_exist=False, **kwargs ):
+ if self._subparser_ctrl is None:
+ self._subparser_ctrl = self.parser.add_subparsers ( **kwargs )
+ elif not ignore_exist:
+ raise AssertionError ( "add_subparsers() already called!" )
+
+ return self._subparser_ctrl
+ # --- end of add_subparsers (...) ---
+
+ def add_subparser ( self,
+ command, defaults=True, proxy_cls=None, **parser_kwargs
+ ):
+ if command in self._subparsers:
+ raise SubparserExists ( command )
+ else:
+ if proxy_cls is None:
+ get_proxy = ArgumentParserProxy.wrap
+ elif proxy_cls is True:
+ get_proxy = self.__class__.wrap
+ elif hasattr ( proxy_cls, 'wrap' ):
+ get_proxy = proxy_cls.wrap
+ else:
+ get_proxy = proxy_cls
+
+ parser = (
+ self.add_subparsers ( ignore_exist=True ).add_parser (
+ command, **parser_kwargs
+ )
+ )
+
+ proxy = get_proxy (
+ parser,
+ defaults = ( self.defaults if defaults is True else defaults )
+ )
+ self._subparsers [command] = proxy
+ return proxy
+ # --- end of add_subparser (...) ---
+
+ def get_subparser ( self, name ):
+ return self._subparsers [name]
+ # --- end of get_subparser (...) ---
+
def get_options ( self ):
return self.parsed
# --- end of get_options (...) ---
@@ -331,12 +379,20 @@ class ArgumentParserProxy ( object ):
)
# --- end of group_arg (...) ---
- def parse_args ( self, *args, **kwargs ):
- self.parsed = self.parser.parse_args ( *args, **kwargs )
+ def get_args_to_parse ( self ):
+ return sys.argv[1:]
+ # --- end of get_args_to_parse (...) ---
+
+ def parse_args ( self, args=None, namespace=None ):
+ self.parsed = self.parser.parse_args (
+ args = ( self.get_args_to_parse() if args is None else args ),
+ namespace = namespace,
+ )
return self.parsed
# --- end of parse_args (...) ---
def parse ( self, *args, **kwargs ):
+ print ( "ArgumentParserProxy.parse() is deprecated. Use parse_args()." )
return self.parse_args ( *args, **kwargs )
# --- end of parse (...) ---
next reply other threads:[~2013-09-17 16:41 UTC|newest]
Thread overview: 159+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-09-17 16:40 André Erdmann [this message]
-- strict thread matches above, loose matches on Subject: below --
2015-01-26 17:41 [gentoo-commits] proj/R_overlay:master commit in: roverlay/ André Erdmann
2015-01-26 17:41 André Erdmann
2014-07-18 16:20 André Erdmann
2014-07-18 2:50 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-07-18 2:28 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-07-16 15:14 André Erdmann
2014-06-05 22:09 André Erdmann
2014-04-01 16:38 André Erdmann
2014-02-16 16:30 André Erdmann
2014-02-15 19:49 André Erdmann
2014-02-15 19:49 André Erdmann
2014-01-25 18:14 André Erdmann
2013-12-11 18:40 André Erdmann
2013-12-11 18:40 André Erdmann
2013-09-23 15:30 André Erdmann
2013-09-20 15:57 André Erdmann
2013-09-19 15:00 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-16 13:43 André Erdmann
2013-09-13 15:10 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-11 11:14 André Erdmann
2013-09-11 10:19 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-06 17:27 André Erdmann
2013-09-06 17:27 André Erdmann
2013-09-03 15:50 André Erdmann
2013-09-02 12:27 André Erdmann
2013-09-02 8:44 André Erdmann
2013-08-30 14:49 André Erdmann
2013-08-30 14:49 André Erdmann
2013-08-29 12:36 André Erdmann
2013-08-29 12:36 André Erdmann
2013-08-28 15:54 André Erdmann
2013-08-27 15:39 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-19 15:42 André Erdmann
2013-08-16 14:05 André Erdmann
2013-08-16 11:02 André Erdmann
2013-08-16 10:43 André Erdmann
2013-08-16 10:43 André Erdmann
2013-08-14 14:56 André Erdmann
2013-08-14 14:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-12 8:28 André Erdmann
2013-08-12 8:18 André Erdmann
2013-08-07 16:10 André Erdmann
2013-08-02 14:30 André Erdmann
2013-08-02 10:34 André Erdmann
2013-08-02 10:34 André Erdmann
2013-08-01 12:44 André Erdmann
2013-08-01 12:44 André Erdmann
2013-07-29 14:56 André Erdmann
2013-07-29 8:55 André Erdmann
2013-07-26 13:02 André Erdmann
2013-07-23 7:51 André Erdmann
2013-07-23 7:51 André Erdmann
2013-07-19 18:00 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-23 7:51 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-17 18:05 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-17 18:05 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-15 22:31 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-16 16:36 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-12 13:57 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-19 18:58 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-22 15:24 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-19 18:58 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-19 18:59 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-13 16:34 André Erdmann
2013-06-05 18:08 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-13 16:34 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-05 18:08 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-13 16:34 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-04 21:06 André Erdmann
2013-04-25 16:44 André Erdmann
2013-04-25 16:44 André Erdmann
2013-03-05 11:27 André Erdmann
2013-02-09 20:45 André Erdmann
2013-02-05 17:48 André Erdmann
2013-02-05 17:48 André Erdmann
2013-01-30 20:16 André Erdmann
2013-01-30 20:16 André Erdmann
2013-01-28 23:54 André Erdmann
2013-01-28 23:54 André Erdmann
2013-01-28 23:54 André Erdmann
2012-10-02 10:04 André Erdmann
2012-08-20 11:16 André Erdmann
2012-08-13 18:07 André Erdmann
2012-08-09 9:26 André Erdmann
2012-08-08 23:46 André Erdmann
2012-08-08 23:46 André Erdmann
2012-08-07 8:50 André Erdmann
2012-08-02 15:14 André Erdmann
2012-08-01 7:25 André Erdmann
2012-07-31 17:51 André Erdmann
2012-07-30 8:52 André Erdmann
2012-07-30 8:52 André Erdmann
2012-07-24 16:59 [gentoo-commits] proj/R_overlay:overlay_wip " André Erdmann
2012-07-30 8:52 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-18 16:49 [gentoo-commits] proj/R_overlay:overlay_wip " André Erdmann
2012-07-30 8:52 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-16 16:15 André Erdmann
2012-07-16 16:15 André Erdmann
2012-07-16 16:15 [gentoo-commits] proj/R_overlay:depres_wip " André Erdmann
2012-07-16 16:15 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-10 17:43 André Erdmann
2012-07-09 17:19 André Erdmann
2012-07-04 18:21 André Erdmann
2012-07-04 18:21 André Erdmann
2012-07-03 17:48 André Erdmann
2012-06-28 13:29 André Erdmann
2012-06-26 15:42 André Erdmann
2012-06-25 18:19 André Erdmann
2012-06-21 16:55 André Erdmann
2012-06-20 19:03 André Erdmann
2012-06-20 19:03 André Erdmann
2012-06-18 16:27 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-12 17:17 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-05 17:30 André Erdmann
2012-06-04 19:07 André Erdmann
2012-06-04 19:07 André Erdmann
2012-06-04 15:43 André Erdmann
2012-06-01 16:19 André Erdmann
2012-06-01 16:19 André Erdmann
2012-06-01 15:46 André Erdmann
2012-05-31 18:24 André Erdmann
2012-05-30 20:15 André Erdmann
2012-05-30 19:36 André Erdmann
2012-05-30 19:36 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-26 13:14 André Erdmann
2012-05-26 13:14 André Erdmann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1379431568.f2caad3d9b949a0a0ca52219d467fbdc8c75499d.dywi@gentoo \
--to=dywi@mailerd.de \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox