From e4e85da3a699b0c5828f5680102a47ad653c4f02 Mon Sep 17 00:00:00 2001 From: Mike Koss Date: Mon, 13 Feb 2012 14:17:11 -0800 Subject: [PATCH 1/2] pretty up --help formatting --- tornado/options.py | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/tornado/options.py b/tornado/options.py index feae3292..5d20dcbf 100644 --- a/tornado/options.py +++ b/tornado/options.py @@ -55,7 +55,9 @@ import logging import logging.handlers import re import sys +import os import time +import textwrap from tornado.escape import _unicode @@ -165,21 +167,28 @@ def parse_config_file(path): def print_help(file=sys.stdout): """Prints all the command line options to stdout.""" print >> file, "Usage: %s [OPTIONS]" % sys.argv[0] - print >> file, "" - print >> file, "Options:" + print >> file, "\nOptions:\n" by_group = {} for option in options.itervalues(): by_group.setdefault(option.group_name, []).append(option) for filename, o in sorted(by_group.items()): if filename: - print >> file, filename + print >> file, "\n%s options:\n" % os.path.normpath(filename) o.sort(key=lambda option: option.name) for option in o: prefix = option.name if option.metavar: prefix += "=" + option.metavar - print >> file, " --%-30s %s" % (prefix, option.help or "") + description = option.help or "" + if option.default is not None and option.default != '': + description += " (default %s)" % option.default + lines = textwrap.wrap(description, 79 - 35) + if len(prefix) > 30: + lines.insert(0, '') + print >> file, " --%-30s %s" % (prefix, lines[0]) + for line in lines[1:]: + print >> file, "%-34s %s" % (' ', line) print >> file From dd3ff7f89bdf509083cc18931b9f8e941490fbca Mon Sep 17 00:00:00 2001 From: Mike Koss Date: Fri, 27 Apr 2012 04:16:28 -0700 Subject: [PATCH 2/2] fix bug when no help text given for option - wrap returns empty list --- tornado/options.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tornado/options.py b/tornado/options.py index 5d20dcbf..05e6f6f8 100644 --- a/tornado/options.py +++ b/tornado/options.py @@ -184,7 +184,7 @@ def print_help(file=sys.stdout): if option.default is not None and option.default != '': description += " (default %s)" % option.default lines = textwrap.wrap(description, 79 - 35) - if len(prefix) > 30: + if len(prefix) > 30 or len(lines) == 0: lines.insert(0, '') print >> file, " --%-30s %s" % (prefix, lines[0]) for line in lines[1:]: