diff options
author | Guido van Rossum <guido@python.org> | 1999-03-12 14:31:10 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1999-03-12 14:31:10 (GMT) |
commit | 367ac80d3ba72223865003cb24d4ff5abea8400c (patch) | |
tree | 29266f148cd691d70a4de5fd6137c8aa9db8b859 /Lib/nturl2path.py | |
parent | f61bbc818223a3adc83775f7c176872b436a49e1 (diff) | |
download | cpython-367ac80d3ba72223865003cb24d4ff5abea8400c.zip cpython-367ac80d3ba72223865003cb24d4ff5abea8400c.tar.gz cpython-367ac80d3ba72223865003cb24d4ff5abea8400c.tar.bz2 |
From: Sjoerd Mullender
The filename to URL conversion didn't properly quote special
characters.
The URL to filename didn't properly unquote special chatacters.
Diffstat (limited to 'Lib/nturl2path.py')
-rw-r--r-- | Lib/nturl2path.py | 29 |
1 files changed, 15 insertions, 14 deletions
diff --git a/Lib/nturl2path.py b/Lib/nturl2path.py index a25dc2a..d86bbc2 100644 --- a/Lib/nturl2path.py +++ b/Lib/nturl2path.py @@ -10,21 +10,22 @@ def url2pathname(url): C:\foo\bar\spam.foo """ - import string + import string, urllib if not '|' in url: # No drive specifier, just convert slashes - components = string.splitfields(url, '/') - return string.joinfields(components, '\\') - comp = string.splitfields(url, '|') + components = string.split(url, '/') + # make sure not to convert quoted slashes :-) + return urllib.unquote(string.join(components, '\\')) + comp = string.split(url, '|') if len(comp) != 2 or comp[0][-1] not in string.letters: error = 'Bad URL: ' + url raise IOError, error drive = string.upper(comp[0][-1]) - components = string.splitfields(comp[1], '/') + components = string.split(comp[1], '/') path = drive + ':' for comp in components: if comp: - path = path + '\\' + comp + path = path + '\\' + urllib.unquote(comp) return path def pathname2url(p): @@ -37,20 +38,20 @@ def pathname2url(p): ///C|/foo/bar/spam.foo """ - import string + import string, urllib if not ':' in p: - # No drive specifier, just convert slashes - components = string.splitfields(p, '\\') - return string.joinfields(components, '/') - comp = string.splitfields(p, ':') + # No drive specifier, just convert slashes and quote the name + components = string.split(p, '\\') + return urllib.quote(string.join(components, '/')) + comp = string.split(p, ':') if len(comp) != 2 or len(comp[0]) > 1: error = 'Bad path: ' + p raise IOError, error - drive = string.upper(comp[0]) - components = string.splitfields(comp[1], '\\') + drive = urllib.quote(string.upper(comp[0])) + components = string.split(comp[1], '\\') path = '///' + drive + '|' for comp in components: if comp: - path = path + '/' + comp + path = path + '/' + urllib.quote(comp) return path |