cpython/Lib/nturl2path.py

67 lines
2.3 KiB
Python
Raw Normal View History

"""Convert a NT pathname to a file URL and vice versa."""
1996-06-27 03:47:56 +08:00
def url2pathname(url):
"""OS-specific conversion from a relative URL of the 'file' scheme
to a file system path; not recommended for general use."""
# e.g.
# ///C|/foo/bar/spam.foo
# becomes
# C:\foo\bar\spam.foo
import string, urllib.parse
# Windows itself uses ":" even in URLs.
url = url.replace(':', '|')
2001-01-15 08:50:52 +08:00
if not '|' in url:
# No drive specifier, just convert slashes
if url[:4] == '////':
# path is something like ////host/path/on/remote/host
# convert this to \\host\path\on\remote\host
# (notice halving of slashes at the start of the path)
url = url[2:]
2001-02-09 19:10:16 +08:00
components = url.split('/')
2001-01-15 08:50:52 +08:00
# make sure not to convert quoted slashes :-)
return urllib.parse.unquote('\\'.join(components))
2001-02-09 19:10:16 +08:00
comp = url.split('|')
if len(comp) != 2 or comp[0][-1] not in string.ascii_letters:
2001-01-15 08:50:52 +08:00
error = 'Bad URL: ' + url
2007-08-30 09:19:48 +08:00
raise IOError(error)
2001-02-09 19:10:16 +08:00
drive = comp[0][-1].upper()
components = comp[1].split('/')
2001-01-15 08:50:52 +08:00
path = drive + ':'
for comp in components:
2001-01-15 08:50:52 +08:00
if comp:
path = path + '\\' + urllib.parse.unquote(comp)
# Issue #11474 - handing url such as |c/|
if path.endswith(':') and url.endswith('/'):
path += '\\'
2001-01-15 08:50:52 +08:00
return path
1996-06-27 03:47:56 +08:00
def pathname2url(p):
"""OS-specific conversion from a file system path to a relative URL
of the 'file' scheme; not recommended for general use."""
# e.g.
# C:\foo\bar\spam.foo
# becomes
# ///C|/foo/bar/spam.foo
import urllib.parse
2001-01-15 08:50:52 +08:00
if not ':' in p:
# No drive specifier, just convert slashes and quote the name
if p[:2] == '\\\\':
# path is something like \\host\path\on\remote\host
# convert this to ////host/path/on/remote/host
# (notice doubling of slashes at the start of the path)
p = '\\\\' + p
2001-02-09 19:10:16 +08:00
components = p.split('\\')
return urllib.parse.quote('/'.join(components))
2001-02-09 19:10:16 +08:00
comp = p.split(':')
2001-01-15 08:50:52 +08:00
if len(comp) != 2 or len(comp[0]) > 1:
error = 'Bad path: ' + p
2007-08-30 09:19:48 +08:00
raise IOError(error)
1996-06-27 03:47:56 +08:00
drive = urllib.parse.quote(comp[0].upper())
2001-02-09 19:10:16 +08:00
components = comp[1].split('\\')
path = '///' + drive + ':'
2001-01-15 08:50:52 +08:00
for comp in components:
if comp:
path = path + '/' + urllib.parse.quote(comp)
2001-01-15 08:50:52 +08:00
return path