Commit 2fc01093 authored by Jack Jansen's avatar Jack Jansen

Rewrite of normpath() by Corran Webster, so trailing :s are removed

(except for : and volume:, where they are needed).
parent 2afffd42
...@@ -179,39 +179,30 @@ def expanduser(path): ...@@ -179,39 +179,30 @@ def expanduser(path):
norm_error = 'macpath.norm_error: path cannot be normalized' norm_error = 'macpath.norm_error: path cannot be normalized'
def normpath(s): def normpath(s):
"""Normalize a pathname: get rid of '::' sequences by backing up, """Normalize a pathname. Will return the same result for
e.g., 'foo:bar::bletch' becomes 'foo:bletch'. equivalent paths."""
Raise the exception norm_error below if backing up is impossible,
e.g., for '::foo'.""" if ":" not in s:
# XXX The Unix version doesn't raise an exception but simply return ":"+s
# returns an unnormalized path. Should do so here too.
comps = string.splitfields(s, ":")
import string i = 1
if ':' not in s: while i < len(comps)-1:
return ':' + s if comps[i] == "" and comps[i-1] != "":
f = string.splitfields(s, ':') if i > 1:
pre = [] del comps[i-1:i+1]
post = [] i = i-1
if not f[0]:
pre = f[:1]
f = f[1:]
if not f[len(f)-1]:
post = f[-1:]
f = f[:-1]
res = []
for seg in f:
if seg:
res.append(seg)
else: else:
if not res: raise norm_error, 'path starts with ::' # best way to handle this is to raise an exception
del res[len(res)-1] raise norm_error, 'Cannot use :: immedeately after volume name'
if not (pre or res): else:
raise norm_error, 'path starts with volume::' i = i + 1
if pre: res = pre + res
if post: res = res + post s = string.join(comps, ":")
s = res[0]
for seg in res[1:]: # remove trailing ":" except for ":" and "Volume:"
s = s + ':' + seg if s[-1] == ":" and len(comps) > 2 and s != ":"*len(s):
s = s[:-1]
return s return s
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment