[Zope-Checkins] CVS: Zope/lib/python/ZConfig - substitution.py:1.4
Chris McDonough
chrism@zope.com
Sat, 2 Aug 2003 01:04:03 -0400
Update of /cvs-repository/Zope/lib/python/ZConfig
In directory cvs.zope.org:/tmp/cvs-serv10833
Modified Files:
substitution.py
Log Message:
Fix bugs introduced by attempting to preserve case.
=== Zope/lib/python/ZConfig/substitution.py 1.3 => 1.4 ===
--- Zope/lib/python/ZConfig/substitution.py:1.3 Fri Aug 1 16:25:59 2003
+++ Zope/lib/python/ZConfig/substitution.py Sat Aug 2 01:03:57 2003
@@ -23,7 +23,7 @@
def substitute(s, mapping):
- """Interpolate variables from `section` into `s`."""
+ """Interpolate variables from `mapping` into `s`."""
if "$" in s:
result = ''
rest = s
@@ -50,9 +50,10 @@
def _split(s):
- # Return a triple: prefix, name, suffix
+ # Return a four tuple: prefix, name, namecase, suffix
# - prefix is text that can be used literally in the result (may be '')
# - name is a referenced name, or None
+ # - namecase is the name with case preserved
# - suffix is trailling text that may contain additional references
# (may be '' or None)
if "$" in s:
@@ -62,7 +63,7 @@
raise ZConfig.SubstitutionSyntaxError(
"illegal lone '$' at end of source")
if c == "$":
- return s[:i+1], None, s[i+2:]
+ return s[:i+1], None, None, s[i+2:]
prefix = s[:i]
if c == "{":
m = _name_match(s, i + 2)
@@ -83,7 +84,7 @@
i = m.end()
return prefix, name.lower(), name, s[i:]
else:
- return s, None, None
+ return s, None, None, None
import re