[Zope-Checkins] CVS: Zope/lib/Components/ExtensionClass/src - Acquisition.c:1.61
Shane Hathaway
shane@zope.com
Tue, 10 Jun 2003 11:28:46 -0400
Update of /cvs-repository/Zope/lib/Components/ExtensionClass/src
In directory cvs.zope.org:/tmp/cvs-serv30834
Modified Files:
Acquisition.c
Log Message:
Fixed a potential Python 2.2+ bug and tidied the code slightly.
In Python 2.2 and above, getattr operations distinguish
AttributeErrors from other kinds of operations. But Wrapper_acquire
was masking some errors as AttributeErrors. Fixed.
Added a comment explaining apply_filter, added curly brackets to
disambiguate nesting in Wrapper_acquire, and re-indented to clarify.
=== Zope/lib/Components/ExtensionClass/src/Acquisition.c 1.60 => 1.61 ===
--- Zope/lib/Components/ExtensionClass/src/Acquisition.c:1.60 Wed Nov 13 12:45:53 2002
+++ Zope/lib/Components/ExtensionClass/src/Acquisition.c Tue Jun 10 11:28:46 2003
@@ -346,6 +346,16 @@
apply_filter(PyObject *filter, PyObject *inst, PyObject *oname, PyObject *r,
PyObject *extra, PyObject *orig)
{
+ /* Calls the filter, passing arguments.
+
+ Returns 1 if the filter accepts the value, 0 if not, -1 if an
+ exception occurred.
+
+ Note the special reference counting rule: This function decrements
+ the refcount of 'r' when it returns 0 or -1. When it returns 1, it
+ leaves the refcount unchanged.
+ */
+
PyObject *fr;
int ir;
@@ -518,12 +528,11 @@
else
{
if ((r=PyObject_GetAttr(self->container,oname))) {
- if (r == Acquired)
- {
- Py_DECREF(r);
- }
+ if (r == Acquired) {
+ Py_DECREF(r);
+ }
else {
- if (filter)
+ if (filter) {
switch(apply_filter(filter,self->container,oname,r,
extra,orig))
{
@@ -533,12 +542,16 @@
if (has__of__(r)) ASSIGN(r,__of__(r,OBJECT(self)));
return r;
}
- else
- {
- if (has__of__(r)) ASSIGN(r,__of__(r,OBJECT(self)));
- return r;
- }
+ }
+ else {
+ if (has__of__(r)) ASSIGN(r,__of__(r,OBJECT(self)));
+ return r;
+ }
}
+ }
+ else {
+ /* May be AttributeError or some other kind of error */
+ return NULL;
}
}
}