mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-02-21 10:01:54 +00:00
scripts/runner.py: simplify David-Sarah's clever grouped-commands usage trick
This commit is contained in:
parent
e769bbb6dd
commit
5045a8721a
@ -10,40 +10,35 @@ pkg_resources.require('allmydata-tahoe')
|
|||||||
from allmydata.scripts.common import BaseOptions
|
from allmydata.scripts.common import BaseOptions
|
||||||
import debug, create_node, startstop_node, cli, keygen, stats_gatherer
|
import debug, create_node, startstop_node, cli, keygen, stats_gatherer
|
||||||
|
|
||||||
def group(s):
|
def GROUP(s):
|
||||||
return [["\n" + s, None, None, None]]
|
# Usage.parseOptions compares argv[1] against command[0], so it will
|
||||||
|
# effectively ignore any "subcommand" that starts with a newline. We use
|
||||||
|
# these to insert section headers into the --help output.
|
||||||
|
return [("\n" + s, None, None, None)]
|
||||||
|
|
||||||
_commandUsage = ( group("Administration")
|
|
||||||
+ create_node.subCommands
|
|
||||||
+ keygen.subCommands
|
|
||||||
+ stats_gatherer.subCommands
|
|
||||||
+ group("Controlling a node")
|
|
||||||
+ startstop_node.subCommands
|
|
||||||
+ group("Debugging")
|
|
||||||
+ debug.subCommands
|
|
||||||
+ group("Using the filesystem")
|
|
||||||
+ cli.subCommands
|
|
||||||
)
|
|
||||||
|
|
||||||
_subCommands = filter(lambda (a, b, c, d): not a.startswith("\n"), _commandUsage)
|
|
||||||
_synopsis = "Usage: tahoe <command> [command options]"
|
|
||||||
|
|
||||||
class Options(BaseOptions, usage.Options):
|
class Options(BaseOptions, usage.Options):
|
||||||
synopsis = _synopsis
|
synopsis = "Usage: tahoe <command> [command options]"
|
||||||
subCommands = _subCommands
|
subCommands = ( GROUP("Administration")
|
||||||
|
+ create_node.subCommands
|
||||||
|
+ keygen.subCommands
|
||||||
|
+ stats_gatherer.subCommands
|
||||||
|
+ GROUP("Controlling a node")
|
||||||
|
+ startstop_node.subCommands
|
||||||
|
+ GROUP("Debugging")
|
||||||
|
+ debug.subCommands
|
||||||
|
+ GROUP("Using the filesystem")
|
||||||
|
+ cli.subCommands
|
||||||
|
)
|
||||||
|
|
||||||
def getUsage(self, **kwargs):
|
def getUsage(self, **kwargs):
|
||||||
t = _Usage().getUsage(**kwargs)
|
t = usage.Options.getUsage(self, **kwargs)
|
||||||
return t + "\nPlease run 'tahoe <command> --help' for more details on each command.\n"
|
return t + "\nPlease run 'tahoe <command> --help' for more details on each command.\n"
|
||||||
|
|
||||||
def postOptions(self):
|
def postOptions(self):
|
||||||
if not hasattr(self, 'subOptions'):
|
if not hasattr(self, 'subOptions'):
|
||||||
raise usage.UsageError("must specify a command")
|
raise usage.UsageError("must specify a command")
|
||||||
|
|
||||||
class _Usage(BaseOptions, usage.Options):
|
|
||||||
synopsis = _synopsis
|
|
||||||
subCommands = _commandUsage
|
|
||||||
|
|
||||||
def runner(argv,
|
def runner(argv,
|
||||||
run_by_human=True,
|
run_by_human=True,
|
||||||
stdin=sys.stdin, stdout=sys.stdout, stderr=sys.stderr,
|
stdin=sys.stdin, stdout=sys.stdout, stderr=sys.stderr,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user