[Zope-Checkins] CVS: Zope/lib/python/ZConfig - Common.py:1.1.4.3 Config.py:1.2.4.4 Context.py:1.1.4.5 __init__.py:1.1.4.4
Chris McDonough
chrism@zope.com
Sun, 24 Nov 2002 18:29:14 -0500
Update of /cvs-repository/Zope/lib/python/ZConfig
In directory cvs.zope.org:/tmp/cvs-serv6683
Modified Files:
Tag: chrism-install-branch
Common.py Config.py Context.py __init__.py
Log Message:
Merge with head.
=== Zope/lib/python/ZConfig/Common.py 1.1.4.2 => 1.1.4.3 ===
--- Zope/lib/python/ZConfig/Common.py:1.1.4.2 Tue Oct 15 20:53:38 2002
+++ Zope/lib/python/ZConfig/Common.py Sun Nov 24 18:28:43 2002
@@ -11,6 +11,17 @@
False = 0
+def asBoolean(s):
+ """Convert a string value to a boolean value."""
+ ss = str(s).lower()
+ if ss in ('yes', 'true', 'on'):
+ return True
+ elif ss in ('no', 'false', 'off'):
+ return False
+ else:
+ raise ValueError("not a valid boolean value: " + repr(s))
+
+
class ConfigurationError(Exception):
def __init__(self, msg):
self.message = msg
=== Zope/lib/python/ZConfig/Config.py 1.2.4.3 => 1.2.4.4 ===
--- Zope/lib/python/ZConfig/Config.py:1.2.4.3 Fri Nov 15 20:26:17 2002
+++ Zope/lib/python/ZConfig/Config.py Sun Nov 24 18:28:43 2002
@@ -75,8 +75,12 @@
else:
return None
- def getChildSections(self):
- return self._sections[:]
+ def getChildSections(self, type=None):
+ if type is None:
+ return self._sections[:]
+ else:
+ type = type.lower()
+ return [sect for sect in self._sections if sect.type == type]
def addValue(self, key, value):
key = key.lower()
@@ -151,20 +155,13 @@
else:
return self.delegate.get(key, default)
- _boolean_values = {
- 'true': True, 'yes': True, 'on': True,
- 'false': False, 'no': False, 'off': False,
- }
-
def getbool(self, key, default=None):
missing = []
s = self.get(key, missing)
if s is missing:
return default
- try:
- return self._boolean_values[s.lower()]
- except KeyError:
- raise ValueError("%s is not a valid boolean value" % repr(s))
+ else:
+ return asBoolean(s)
def getfloat(self, key, default=None, min=None, max=None):
missing = []
=== Zope/lib/python/ZConfig/Context.py 1.1.4.4 => 1.1.4.5 ===
--- Zope/lib/python/ZConfig/Context.py:1.1.4.4 Fri Nov 15 20:26:17 2002
+++ Zope/lib/python/ZConfig/Context.py Sun Nov 24 18:28:43 2002
@@ -41,12 +41,21 @@
from ApacheStyle import Parse
Parse(file, self, section, url)
+ def _normalize_url(self, url):
+ if os.path.exists(url):
+ url = "file://" + urllib.pathname2url(os.path.abspath(url))
+ else:
+ parts = urlparse.urlparse(url)
+ if not parts[0]:
+ raise ValueError("invalid URL, or file does not exist:\n"
+ + repr(url))
+ return url
+
# public API
def load(self, url):
"""Load a resource from a URL or pathname."""
- if os.path.exists(url):
- url = "file://" + urllib.pathname2url(os.path.abspath(url))
+ url = self._normalize_url(url)
top = self.createToplevelSection(url)
self._all_sections.append(top)
self._imports = [top]
=== Zope/lib/python/ZConfig/__init__.py 1.1.4.3 => 1.1.4.4 ===
--- Zope/lib/python/ZConfig/__init__.py:1.1.4.3 Sat Nov 16 01:38:39 2002
+++ Zope/lib/python/ZConfig/__init__.py Sun Nov 24 18:28:43 2002
@@ -31,4 +31,4 @@
def loadschemafile(file, schema, url=None):
from SchemaParser import SchemaContext
return SchemaContext().load(file, url, schema)
-
+