summaryrefslogtreecommitdiffstats
path: root/Lib/plat-riscos/rourl2path.py
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2001-03-02 05:58:11 (GMT)
committerGuido van Rossum <guido@python.org>2001-03-02 05:58:11 (GMT)
commit228d80736c39e41a6b46dad211df0ba871b0c8f8 (patch)
treec15c8ecf8664d6c225b6d2f2821068c31e2302d8 /Lib/plat-riscos/rourl2path.py
parentc92cdf7aa770ee84a2c8e8f219fde4889e5adc92 (diff)
downloadcpython-228d80736c39e41a6b46dad211df0ba871b0c8f8.zip
cpython-228d80736c39e41a6b46dad211df0ba871b0c8f8.tar.gz
cpython-228d80736c39e41a6b46dad211df0ba871b0c8f8.tar.bz2
RISCOS files by dschwertberger
Diffstat (limited to 'Lib/plat-riscos/rourl2path.py')
-rw-r--r--Lib/plat-riscos/rourl2path.py82
1 files changed, 82 insertions, 0 deletions
diff --git a/Lib/plat-riscos/rourl2path.py b/Lib/plat-riscos/rourl2path.py
new file mode 100644
index 0000000..033e621
--- /dev/null
+++ b/Lib/plat-riscos/rourl2path.py
@@ -0,0 +1,82 @@
+"""riscos specific module for conversion between pathnames and URLs.
+Based on macurl2path.
+Do not import directly, use urllib instead."""
+
+import string
+import urllib
+import os
+
+def url2pathname(pathname):
+ "Convert /-delimited pathname to mac pathname"
+ #
+ # XXXX The .. handling should be fixed...
+ #
+ tp = urllib.splittype(pathname)[0]
+ if tp and tp <> 'file':
+ raise RuntimeError, 'Cannot convert non-local URL to pathname'
+ components = string.split(pathname, '/')
+ # Remove . and embedded ..
+ i = 0
+ while i < len(components):
+ if components[i] == '.':
+ del components[i]
+ elif components[i] == '..' and i > 0 and \
+ components[i-1] not in ('', '..'):
+ del components[i-1:i+1]
+ i = i-1
+ elif components[i] == '' and i > 0 and components[i-1] <> '':
+ del components[i]
+ else:
+ if components[i]<>'..' and string.find(components[i], '.')<>-1 :
+ components[i] = string.join(string.split(components[i],'.'),'/')
+ i = i+1
+ if not components[0]:
+ # Absolute unix path, don't start with colon
+ return string.join(components[1:], '.')
+ else:
+ # relative unix path, start with colon. First replace
+ # leading .. by empty strings (giving ::file)
+ i = 0
+ while i < len(components) and components[i] == '..':
+ components[i] = '^'
+ i = i + 1
+ return string.join(components, '.')
+
+def pathname2url(pathname):
+ "convert mac pathname to /-delimited pathname"
+ if '/' in pathname:
+ raise RuntimeError, "Cannot convert pathname containing slashes"
+ components = string.split(pathname, ':')
+ # Replace empty string ('::') by .. (will result in '/../' later)
+ for i in range(1, len(components)):
+ if components[i] == '':
+ components[i] = '..'
+ # Truncate names longer than 31 bytes
+ components = map(lambda x: x[:31], components)
+
+ if os.path.isabs(pathname):
+ return '/' + string.join(components, '/')
+ else:
+ return string.join(components, '/')
+
+def test():
+ for url in ["index.html",
+ "/SCSI::SCSI4/$/Anwendung/Comm/Apps/!Fresco/Welcome",
+ "../index.html",
+ "bar/index.html",
+ "/foo/bar/index.html",
+ "/foo/bar/",
+ "/"]:
+ print `url`, '->', `url2pathname(url)`
+ for path in ["drive:",
+ "drive:dir:",
+ "drive:dir:file",
+ "drive:file",
+ "file",
+ ":file",
+ ":dir:",
+ ":dir:file"]:
+ print `path`, '->', `pathname2url(path)`
+
+if __name__ == '__main__':
+ test()