mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +00:00 
			
		
		
		
	From: Sjoerd Mullender
The filename to URL conversion didn't properly quote special characters. The URL to filename didn't properly unquote special chatacters.
This commit is contained in:
		
							parent
							
								
									f61bbc8182
								
							
						
					
					
						commit
						367ac80d3b
					
				
					 2 changed files with 17 additions and 23 deletions
				
			
		| 
						 | 
					@ -10,21 +10,22 @@ def url2pathname(url):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		C:\foo\bar\spam.foo
 | 
							C:\foo\bar\spam.foo
 | 
				
			||||||
	"""
 | 
						"""
 | 
				
			||||||
	import string
 | 
						import string, urllib
 | 
				
			||||||
	if not '|' in url:
 | 
						if not '|' in url:
 | 
				
			||||||
	    # No drive specifier, just convert slashes
 | 
						    # No drive specifier, just convert slashes
 | 
				
			||||||
	    components = string.splitfields(url, '/')
 | 
						    components = string.split(url, '/')
 | 
				
			||||||
	    return string.joinfields(components, '\\')
 | 
						    # make sure not to convert quoted slashes :-)
 | 
				
			||||||
	comp = string.splitfields(url, '|')
 | 
						    return urllib.unquote(string.join(components, '\\'))
 | 
				
			||||||
 | 
						comp = string.split(url, '|')
 | 
				
			||||||
	if len(comp) != 2 or comp[0][-1] not in string.letters:
 | 
						if len(comp) != 2 or comp[0][-1] not in string.letters:
 | 
				
			||||||
		error = 'Bad URL: ' + url
 | 
							error = 'Bad URL: ' + url
 | 
				
			||||||
		raise IOError, error
 | 
							raise IOError, error
 | 
				
			||||||
	drive = string.upper(comp[0][-1])
 | 
						drive = string.upper(comp[0][-1])
 | 
				
			||||||
	components = string.splitfields(comp[1], '/')
 | 
						components = string.split(comp[1], '/')
 | 
				
			||||||
	path = drive + ':'
 | 
						path = drive + ':'
 | 
				
			||||||
	for  comp in components:
 | 
						for  comp in components:
 | 
				
			||||||
		if comp:
 | 
							if comp:
 | 
				
			||||||
			path = path + '\\' + comp
 | 
								path = path + '\\' + urllib.unquote(comp)
 | 
				
			||||||
	return path
 | 
						return path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def pathname2url(p):
 | 
					def pathname2url(p):
 | 
				
			||||||
| 
						 | 
					@ -37,20 +38,20 @@ def pathname2url(p):
 | 
				
			||||||
		///C|/foo/bar/spam.foo
 | 
							///C|/foo/bar/spam.foo
 | 
				
			||||||
	"""
 | 
						"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	import string
 | 
						import string, urllib
 | 
				
			||||||
	if not ':' in p:
 | 
						if not ':' in p:
 | 
				
			||||||
	    # No drive specifier, just convert slashes
 | 
						    # No drive specifier, just convert slashes and quote the name
 | 
				
			||||||
	    components = string.splitfields(p, '\\')
 | 
						    components = string.split(p, '\\')
 | 
				
			||||||
	    return string.joinfields(components, '/')
 | 
						    return urllib.quote(string.join(components, '/'))
 | 
				
			||||||
	comp = string.splitfields(p, ':')
 | 
						comp = string.split(p, ':')
 | 
				
			||||||
	if len(comp) != 2 or len(comp[0]) > 1:
 | 
						if len(comp) != 2 or len(comp[0]) > 1:
 | 
				
			||||||
		error = 'Bad path: ' + p
 | 
							error = 'Bad path: ' + p
 | 
				
			||||||
		raise IOError, error
 | 
							raise IOError, error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	drive = string.upper(comp[0])
 | 
						drive = urllib.quote(string.upper(comp[0]))
 | 
				
			||||||
	components = string.splitfields(comp[1], '\\')
 | 
						components = string.split(comp[1], '\\')
 | 
				
			||||||
	path = '///' + drive + '|'
 | 
						path = '///' + drive + '|'
 | 
				
			||||||
	for comp in components:
 | 
						for comp in components:
 | 
				
			||||||
		if comp:
 | 
							if comp:
 | 
				
			||||||
			path = path + '/' + comp
 | 
								path = path + '/' + urllib.quote(comp)
 | 
				
			||||||
	return path
 | 
						return path
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -38,16 +38,9 @@
 | 
				
			||||||
    from nturl2path import url2pathname, pathname2url 
 | 
					    from nturl2path import url2pathname, pathname2url 
 | 
				
			||||||
else:
 | 
					else:
 | 
				
			||||||
    def url2pathname(pathname):
 | 
					    def url2pathname(pathname):
 | 
				
			||||||
        return pathname
 | 
					        return unquote(pathname)
 | 
				
			||||||
    def pathname2url(pathname):
 | 
					    def pathname2url(pathname):
 | 
				
			||||||
        return pathname
 | 
					        return quote(pathname)
 | 
				
			||||||
 | 
					 | 
				
			||||||
_url2pathname = url2pathname
 | 
					 | 
				
			||||||
def url2pathname(url):
 | 
					 | 
				
			||||||
    return _url2pathname(unquote(url))
 | 
					 | 
				
			||||||
_pathname2url = pathname2url
 | 
					 | 
				
			||||||
def pathname2url(p):
 | 
					 | 
				
			||||||
    return quote(_pathname2url(p))
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This really consists of two pieces:
 | 
					# This really consists of two pieces:
 | 
				
			||||||
# (1) a class which handles opening of all sorts of URLs
 | 
					# (1) a class which handles opening of all sorts of URLs
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue