[Zope-Checkins] CVS: Packages/ZConfig - matcher.py:1.1.2.28
Fred L. Drake, Jr.
fred@zope.com
Tue, 31 Dec 2002 17:06:13 -0500
Update of /cvs-repository/Packages/ZConfig
In directory cvs.zope.org:/tmp/cvs-serv21657
Modified Files:
Tag: zconfig-schema-devel-branch
matcher.py
Log Message:
SectionValue: Override __setattr__() and __setitem__(), so that the
config values that are accessible by both name and position are kept
in sync.
=== Packages/ZConfig/matcher.py 1.1.2.27 => 1.1.2.28 ===
--- Packages/ZConfig/matcher.py:1.1.2.27 Thu Dec 19 16:11:22 2002
+++ Packages/ZConfig/matcher.py Tue Dec 31 17:06:12 2002
@@ -209,13 +209,18 @@
class SectionValue:
- """Generic 'bag-of-values' object for a section."""
+ """Generic 'bag-of-values' object for a section.
+
+ Derived classes should always call the SectionValue constructor
+ before attempting to modify self.
+ """
def __init__(self, attrnames, values, name, type):
- self._attrnames = attrnames
- self._values = values
- self.__name__ = name
- self.__type__ = type
+ d = self.__dict__
+ d['_attrnames'] = attrnames
+ d['_values'] = values
+ d['__name__'] = name
+ d['__type__'] = type
def __repr__(self):
if self.__name__:
@@ -235,9 +240,22 @@
raise TypeError("SectionValue does not support slicing")
return self._values[index]
+ def __setitem__(self, index, value):
+ if isinstance(index, types.SliceType):
+ raise TypeError("SectionValue does not support slicing")
+ self._values[index] = value
+
def __getattr__(self, name):
try:
i = self._attrnames.index(name)
except ValueError:
raise AttributeError, name
return self._values[i]
+
+ def __setattr__(self, name, value):
+ try:
+ i = self._attrnames.index(name)
+ except ValueError:
+ self.__dict__[name] = value
+ else:
+ self._values[i] = value