[Zodb-checkins] CVS: StandaloneZConfig/ZConfig - loader.py:1.31
Fred L. Drake, Jr.
fred at zope.com
Thu Feb 5 12:03:35 EST 2004
Update of /cvs-repository/StandaloneZConfig/ZConfig
In directory cvs.zope.org:/tmp/cvs-serv16683/ZConfig
Modified Files:
loader.py
Log Message:
improve exception messages for resources that cannot be opened
=== StandaloneZConfig/ZConfig/loader.py 1.30 => 1.31 ===
--- StandaloneZConfig/ZConfig/loader.py:1.30 Tue Feb 3 17:36:29 2004
+++ StandaloneZConfig/ZConfig/loader.py Thu Feb 5 12:03:04 2004
@@ -101,27 +101,45 @@
except urllib2.URLError, e:
# urllib2.URLError has a particularly hostile str(), so we
# generally don't want to pass it along to the user.
- error = ZConfig.ConfigurationError("error opening resource %s: %s"
- % (url, e.reason))
- error.url = url
- raise error
+ self._raise_open_error(url, e.reason)
except (IOError, OSError), e:
# Python 2.1 raises a different error from Python 2.2+,
# so we catch both to make sure we detect the situation.
- error = ZConfig.ConfigurationError("error opening resource %s: %s"
- % (url, str(e)))
- error.url = url
- raise error
+ self._raise_open_error(url, str(e))
return self.createResource(file, url)
+ def _raise_open_error(self, url, message):
+ if url[:7].lower() == "file://":
+ what = "file"
+ ident = urllib.url2pathname(url[7:])
+ else:
+ what = "URL"
+ ident = url
+ error = ZConfig.ConfigurationError("error opening %s %s: %s"
+ % (what, ident, message))
+ error.url = url
+ raise error
+
def normalizeURL(self, url):
- if os.path.exists(url) or ":" not in url:
+ if self.isPath(url):
url = "file://" + urllib.pathname2url(os.path.abspath(url))
url, fragment = ZConfig.url.urldefrag(url)
if fragment:
raise ZConfig.ConfigurationError(
"fragment identifiers are not supported")
return url
+
+ def isPath(self, s):
+ """Return True iff 's' should be handled as a filesystem path."""
+ if ":" in s:
+ # XXX This assumes that one-character scheme identifiers
+ # are always Windows drive letters; I don't know of any
+ # one-character scheme identifiers.
+ scheme, rest = urllib.splittype(s)
+ return len(scheme) == 1
+ else:
+ return True
+
def _url_from_file(file):
More information about the Zodb-checkins
mailing list