summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZachary Ware <zachary.ware@gmail.com>2014-07-10 16:18:00 (GMT)
committerZachary Ware <zachary.ware@gmail.com>2014-07-10 16:18:00 (GMT)
commiteb43214427b1ae6d7095bdd2333e9bc2220f9449 (patch)
tree77bc2894579fc239b8d6f6e3f4fbfc358901b525
parent7cca28ffa2efff47d4c53080f49c5b5c8eebbc19 (diff)
downloadcpython-eb43214427b1ae6d7095bdd2333e9bc2220f9449.zip
cpython-eb43214427b1ae6d7095bdd2333e9bc2220f9449.tar.gz
cpython-eb43214427b1ae6d7095bdd2333e9bc2220f9449.tar.bz2
Issue #21942: Fixed source file viewing in pydoc's server mode on Windows.
-rwxr-xr-xLib/pydoc.py8
-rw-r--r--Lib/test/test_pydoc.py7
-rw-r--r--Misc/NEWS2
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 = '<big><big><strong>%s</strong></big></big>' % 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 = '<pre>%s</pre>' % 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.