mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
String method conversion.
This commit is contained in:
parent
51cc3bcd1c
commit
db5ebc7bc9
2 changed files with 11 additions and 12 deletions
|
@ -2,7 +2,6 @@
|
|||
|
||||
Do not import directly; use urllib instead."""
|
||||
|
||||
import string
|
||||
import urllib
|
||||
import os
|
||||
|
||||
|
@ -21,7 +20,7 @@ def url2pathname(pathname):
|
|||
pathname = pathname[2:]
|
||||
elif pathname[:2] == '//':
|
||||
raise RuntimeError, 'Cannot convert non-local URL to pathname'
|
||||
components = string.split(pathname, '/')
|
||||
components = pathname.split('/')
|
||||
# Remove . and embedded ..
|
||||
i = 0
|
||||
while i < len(components):
|
||||
|
@ -37,7 +36,7 @@ def url2pathname(pathname):
|
|||
i = i+1
|
||||
if not components[0]:
|
||||
# Absolute unix path, don't start with colon
|
||||
rv = string.join(components[1:], ':')
|
||||
rv = ':'.join(components[1:])
|
||||
else:
|
||||
# relative unix path, start with colon. First replace
|
||||
# leading .. by empty strings (giving ::file)
|
||||
|
@ -45,7 +44,7 @@ def url2pathname(pathname):
|
|||
while i < len(components) and components[i] == '..':
|
||||
components[i] = ''
|
||||
i = i + 1
|
||||
rv = ':' + string.join(components, ':')
|
||||
rv = ':' + ':'.join(components)
|
||||
# and finally unquote slashes and other funny characters
|
||||
return urllib.unquote(rv)
|
||||
|
||||
|
@ -53,7 +52,7 @@ def pathname2url(pathname):
|
|||
"convert mac pathname to /-delimited pathname"
|
||||
if '/' in pathname:
|
||||
raise RuntimeError, "Cannot convert pathname containing slashes"
|
||||
components = string.split(pathname, ':')
|
||||
components = pathname.split(':')
|
||||
# Remove empty first and/or last component
|
||||
if components[0] == '':
|
||||
del components[0]
|
||||
|
@ -67,9 +66,9 @@ def pathname2url(pathname):
|
|||
components = map(_pncomp2url, components)
|
||||
|
||||
if os.path.isabs(pathname):
|
||||
return '/' + string.join(components, '/')
|
||||
return '/' + '/'.join(components)
|
||||
else:
|
||||
return string.join(components, '/')
|
||||
return '/'.join(components)
|
||||
|
||||
def _pncomp2url(component):
|
||||
component = urllib.quote(component[:31], safe='') # We want to quote slashes
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue