diff options
author | Tim Peters <tim.peters@gmail.com> | 2001-09-24 22:40:47 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2001-09-24 22:40:47 (GMT) |
commit | f4aad8eb28606a7cfa0266a1f2c28c003e8cd36e (patch) | |
tree | 98efdfd327e87131957fb63a8e062d1c8533382e | |
parent | 66c1a525e08fda439ddda3b6371236df1398cfd5 (diff) | |
download | cpython-f4aad8eb28606a7cfa0266a1f2c28c003e8cd36e.zip cpython-f4aad8eb28606a7cfa0266a1f2c28c003e8cd36e.tar.gz cpython-f4aad8eb28606a7cfa0266a1f2c28c003e8cd36e.tar.bz2 |
+ Text-mode (but not yet GUI mode) pydoc now produces useful stuff for
properties: the docstring (if any) is displayed, and the getter, setter
and deleter (if any) functions are named. All that is shown indented
after the property name.
+ Text-mode pydoc class display now draws a horizontal line between
class attribute groups (similar to GUI mode -- while visually more
intrusive in text mode, it's still an improvement).
-rwxr-xr-x | Lib/pydoc.py | 44 |
1 files changed, 35 insertions, 9 deletions
diff --git a/Lib/pydoc.py b/Lib/pydoc.py index a6f9fa9..4bf1940 100755 --- a/Lib/pydoc.py +++ b/Lib/pydoc.py @@ -991,29 +991,55 @@ class TextDoc(Doc): contents = doc and [doc + '\n'] or [] push = contents.append + # Cute little class to pump out a horizontal rule between sections. + class HorizontalRule: + def __init__(self): + self.needone = 0 + def maybe(self): + if self.needone: + push('-' * 70) + self.needone = 1 + hr = HorizontalRule() + def spill(msg, attrs, predicate): ok, attrs = _split_list(attrs, predicate) if ok: + hr.maybe() push(msg) for name, kind, homecls, value in ok: push(self.document(getattr(object, name), name, mod, object)) return attrs - # pydoc can't make any reasonable sense of properties on its own, - # and it doesn't appear that the getter, setter and del'er methods - # are discoverable. For now, just pump out their names. def spillproperties(msg, attrs, predicate): ok, attrs = _split_list(attrs, predicate) if ok: + hr.maybe() push(msg) for name, kind, homecls, value in ok: - push(name + '\n') + push(name) + need_blank_after_doc = 0 + doc = getdoc(value) or '' + if doc: + push(self.indent(doc)) + need_blank_after_doc = 1 + for attr, tag in [("fset", " setter"), + ("fget", " getter"), + ("fdel", " deleter")]: + func = getattr(value, attr) + if func is not None: + if need_blank_after_doc: + push('') + need_blank_after_doc = 0 + base = self.docother(func, name + tag, mod, 70) + push(self.indent(base)) + push('') return attrs def spilldata(msg, attrs, predicate): ok, attrs = _split_list(attrs, predicate) if ok: + hr.maybe() push(msg) for name, kind, homecls, value in ok: doc = getattr(value, "__doc__", None) @@ -1040,15 +1066,15 @@ class TextDoc(Doc): attrs.sort(lambda t1, t2: cmp(t1[0], t2[0])) # Pump out the attrs, segregated by kind. - attrs = spill("* Methods %s:\n" % tag, attrs, + attrs = spill("Methods %s:\n" % tag, attrs, lambda t: t[1] == 'method') - attrs = spill("* Class methods %s:\n" % tag, attrs, + attrs = spill("Class methods %s:\n" % tag, attrs, lambda t: t[1] == 'class method') - attrs = spill("* Static methods %s:\n" % tag, attrs, + attrs = spill("Static methods %s:\n" % tag, attrs, lambda t: t[1] == 'static method') - attrs = spillproperties("* Properties %s:\n" % tag, attrs, + attrs = spillproperties("Properties %s:\n" % tag, attrs, lambda t: t[1] == 'property') - attrs = spilldata("* Data %s:\n" % tag, attrs, + attrs = spilldata("Data %s:\n" % tag, attrs, lambda t: t[1] == 'data') assert attrs == [] |