Cmd._run(), as conceived for working with lib.App, is meant to be an async method. To be conservative about changes, jw-pkg's legacy way of handling _run() was kept when deriving from libApp, and async was not propagated down to the _run() implementations. This commit rectifies that before adding additional subcommands.
Signed-off-by: Jan Lindemann <jan@janware.com>
23 lines
735 B
Python
23 lines
735 B
Python
# -*- coding: utf-8 -*-
|
|
|
|
from argparse import Namespace, ArgumentParser
|
|
|
|
from ..Cmd import Cmd
|
|
from ..CmdProjects import CmdProjects
|
|
|
|
class CmdSummary(Cmd): # export
|
|
|
|
def __init__(self, parent: CmdProjects) -> None:
|
|
super().__init__(parent, 'summary', help='Print summary description of given modules')
|
|
|
|
def add_arguments(self, parser: ArgumentParser) -> None:
|
|
super().add_arguments(parser)
|
|
parser.add_argument('module', nargs='*', help='Modules')
|
|
|
|
async def _run(self, args: Namespace) -> None:
|
|
r = []
|
|
for m in args.module:
|
|
summary = self.app.get_value(m, "summary", None)
|
|
if summary is not None:
|
|
r.append(summary)
|
|
print(' '.join(r))
|