changeset: 91073:e89c39125892 branch: 2.7 parent: 91068:6dfbe504f659 user: Benjamin Peterson date: Sat Jun 07 16:44:00 2014 -0700 files: Lib/pydoc.py Lib/test/pydoc_mod.py Lib/test/test_pydoc.py Misc/NEWS description: don't remove self from example code in the HTML output (closes #13223) Patch by Víctor Terrón. diff -r 6dfbe504f659 -r e89c39125892 Lib/pydoc.py --- a/Lib/pydoc.py Sat Jun 07 13:50:34 2014 -0700 +++ b/Lib/pydoc.py Sat Jun 07 16:44:00 2014 -0700 @@ -581,10 +581,15 @@ elif pep: url = 'http://www.python.org/dev/peps/pep-%04d/' % int(pep) results.append('%s' % (url, escape(all))) + elif selfdot: + # Create a link for methods like 'self.method(...)' + # and use for attributes like 'self.attr' + if text[end:end+1] == '(': + results.append('self.' + self.namelink(name, methods)) + else: + results.append('self.%s' % name) elif text[end:end+1] == '(': results.append(self.namelink(name, methods, funcs, classes)) - elif selfdot: - results.append('self.%s' % name) else: results.append(self.namelink(name, classes)) here = end diff -r 6dfbe504f659 -r e89c39125892 Lib/test/pydoc_mod.py --- a/Lib/test/pydoc_mod.py Sat Jun 07 13:50:34 2014 -0700 +++ b/Lib/test/pydoc_mod.py Sat Jun 07 16:44:00 2014 -0700 @@ -15,6 +15,16 @@ NO_MEANING = "eggs" pass +class C(object): + def say_no(self): + return "no" + def get_answer(self): + """ Return say_no() """ + return self.say_no() + def is_it_true(self): + """ Return self.get_answer() """ + return self.get_answer() + def doc_func(): """ This function solves all of the world's problems: diff -r 6dfbe504f659 -r e89c39125892 Lib/test/test_pydoc.py --- a/Lib/test/test_pydoc.py Sat Jun 07 13:50:34 2014 -0700 +++ b/Lib/test/test_pydoc.py Sat Jun 07 16:44:00 2014 -0700 @@ -38,6 +38,7 @@ CLASSES __builtin__.object B + C A \x20\x20\x20\x20 class A @@ -59,6 +60,26 @@ | Data and other attributes defined here: |\x20\x20 | NO_MEANING = 'eggs' +\x20\x20\x20\x20 + class C(__builtin__.object) + | Methods defined here: + |\x20\x20 + | get_answer(self) + | Return say_no() + |\x20\x20 + | is_it_true(self) + | Return self.get_answer() + |\x20\x20 + | say_no(self) + |\x20\x20 + | ---------------------------------------------------------------------- + | Data descriptors defined here: + |\x20\x20 + | __dict__ + | dictionary for instance variables (if defined) + |\x20\x20 + | __weakref__ + | list of weak references to the object (if defined) FUNCTIONS doc_func() @@ -108,6 +129,7 @@
B +
C
A @@ -142,6 +164,28 @@ Data and other attributes defined here:
NO_MEANING = 'eggs'
+

+ + + +\x20\x20\x20\x20 + +
 
+class C(__builtin__.object)
    Methods defined here:
+
get_answer(self)
Return say_no()
+ +
is_it_true(self)
Return self.get_answer()
+ +
say_no(self)
+ +
+Data descriptors defined here:
+
__dict__
+
dictionary for instance variables (if defined)
+
+
__weakref__
+
list of weak references to the object (if defined)
+

diff -r 6dfbe504f659 -r e89c39125892 Misc/NEWS --- a/Misc/NEWS Sat Jun 07 13:50:34 2014 -0700 +++ b/Misc/NEWS Sat Jun 07 16:44:00 2014 -0700 @@ -28,6 +28,9 @@ - Issue #21304: Backport the key derivation function hashlib.pbkdf2_hmac from Python 3 per PEP 466. +- Issue #13223: Fix pydoc.writedoc so that the HTML documentation for methods + that use 'self' in the example code is generated correctly. + - Issue #21552: Fixed possible integer overflow of too long string lengths in the tkinter module on 64-bit platforms.