From eb43214427b1ae6d7095bdd2333e9bc2220f9449 Mon Sep 17 00:00:00 2001 From: Zachary Ware Date: Thu, 10 Jul 2014 11:18:00 -0500 Subject: Issue #21942: Fixed source file viewing in pydoc's server mode on Windows. --- Lib/pydoc.py | 8 +++----- Lib/test/test_pydoc.py | 7 ++----- Misc/NEWS | 2 ++ 3 files changed, 7 insertions(+), 10 deletions(-) diff --git a/Lib/pydoc.py b/Lib/pydoc.py index cc43684..37abf67 100755 --- a/Lib/pydoc.py +++ b/Lib/pydoc.py @@ -64,6 +64,7 @@ import re import sys import time import tokenize +import urllib.parse import warnings from collections import deque from reprlib import Repr @@ -648,10 +649,7 @@ class HTMLDoc(Doc): head = '%s' % linkedname try: path = inspect.getabsfile(object) - url = path - if sys.platform == 'win32': - import nturl2path - url = nturl2path.pathname2url(path) + url = urllib.parse.quote(path) filelink = self.filelink(url, path) except TypeError: filelink = '(built-in)' @@ -2353,7 +2351,7 @@ def _url_handler(url, content_type="text/html"): def html_getfile(path): """Get and display a source file listing safely.""" - path = path.replace('%20', ' ') + path = urllib.parse.unquote(path) with tokenize.open(path) as fp: lines = html.escape(fp.read()) body = '
%s
' % lines diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py index 3bce66e..a513fa6 100644 --- a/Lib/test/test_pydoc.py +++ b/Lib/test/test_pydoc.py @@ -14,6 +14,7 @@ import test.support import time import types import unittest +import urllib.parse import xml.etree import textwrap from io import StringIO @@ -406,11 +407,7 @@ class PydocDocTest(unittest.TestCase): def test_html_doc(self): result, doc_loc = get_pydoc_html(pydoc_mod) mod_file = inspect.getabsfile(pydoc_mod) - if sys.platform == 'win32': - import nturl2path - mod_url = nturl2path.pathname2url(mod_file) - else: - mod_url = mod_file + mod_url = urllib.parse.quote(mod_file) expected_html = expected_html_pattern % ( (mod_url, mod_file, doc_loc) + expected_html_data_docstrings) diff --git a/Misc/NEWS b/Misc/NEWS index 907e140..e5869d9 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -27,6 +27,8 @@ Core and Builtins Library ------- +- Issue #21942: Fixed source file viewing in pydoc's server mode on Windows. + - Issue #11259: asynchat.async_chat().set_terminator() now raises a ValueError if the number of received bytes is negative. -- cgit v0.12