Commit 9cfb84f3 authored by Jeremy Hylton's avatar Jeremy Hylton

Remove big whole in cc_getattr().

Only expose the items attribute of the special dict inside the cache.
Exposing other methods that mutate the dict is dangerous, because of
the ref count games the cache plays.
parent 45f6d248
...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them. ...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them.
static char cPickleCache_doc_string[] = static char cPickleCache_doc_string[] =
"Defines the PickleCache used by ZODB Connection objects.\n" "Defines the PickleCache used by ZODB Connection objects.\n"
"\n" "\n"
"$Id: cPickleCache.c,v 1.83 2003/05/01 17:08:39 jeremy Exp $\n"; "$Id: cPickleCache.c,v 1.84 2003/05/13 23:15:16 jeremy Exp $\n";
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;} #define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E)) #define UNLESS(E) if(!(E))
...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self) ...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self)
static PyObject * static PyObject *
cc_getattr(ccobject *self, char *name) cc_getattr(ccobject *self, char *name)
{ {
PyObject *r;
if(*name=='c') if(*name=='c')
{ {
if(strcmp(name,"cache_age")==0) if(strcmp(name,"cache_age")==0)
...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name) ...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name)
return PyDict_Copy(self->data); return PyDict_Copy(self->data);
} }
} }
if((*name=='h' && strcmp(name, "has_key")==0) ||
(*name=='i' && strcmp(name, "items")==0) ||
(*name=='k' && strcmp(name, "keys")==0)
)
return PyObject_GetAttrString(self->data, name);
if((r=Py_FindMethod(cc_methods, (PyObject *)self, name))) if (strcmp(name, "items") == 0)
return r;
PyErr_Clear();
return PyObject_GetAttrString(self->data, name); return PyObject_GetAttrString(self->data, name);
return Py_FindMethod(cc_methods, (PyObject *)self, name);
} }
static int static int
......
...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them. ...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them.
static char cPickleCache_doc_string[] = static char cPickleCache_doc_string[] =
"Defines the PickleCache used by ZODB Connection objects.\n" "Defines the PickleCache used by ZODB Connection objects.\n"
"\n" "\n"
"$Id: cPickleCache.c,v 1.83 2003/05/01 17:08:39 jeremy Exp $\n"; "$Id: cPickleCache.c,v 1.84 2003/05/13 23:15:16 jeremy Exp $\n";
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;} #define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E)) #define UNLESS(E) if(!(E))
...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self) ...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self)
static PyObject * static PyObject *
cc_getattr(ccobject *self, char *name) cc_getattr(ccobject *self, char *name)
{ {
PyObject *r;
if(*name=='c') if(*name=='c')
{ {
if(strcmp(name,"cache_age")==0) if(strcmp(name,"cache_age")==0)
...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name) ...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name)
return PyDict_Copy(self->data); return PyDict_Copy(self->data);
} }
} }
if((*name=='h' && strcmp(name, "has_key")==0) ||
(*name=='i' && strcmp(name, "items")==0) ||
(*name=='k' && strcmp(name, "keys")==0)
)
return PyObject_GetAttrString(self->data, name);
if((r=Py_FindMethod(cc_methods, (PyObject *)self, name))) if (strcmp(name, "items") == 0)
return r;
PyErr_Clear();
return PyObject_GetAttrString(self->data, name); return PyObject_GetAttrString(self->data, name);
return Py_FindMethod(cc_methods, (PyObject *)self, name);
} }
static int static int
......
...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them. ...@@ -90,7 +90,7 @@ process must skip such objects, rather than deactivating them.
static char cPickleCache_doc_string[] = static char cPickleCache_doc_string[] =
"Defines the PickleCache used by ZODB Connection objects.\n" "Defines the PickleCache used by ZODB Connection objects.\n"
"\n" "\n"
"$Id: cPickleCache.c,v 1.83 2003/05/01 17:08:39 jeremy Exp $\n"; "$Id: cPickleCache.c,v 1.84 2003/05/13 23:15:16 jeremy Exp $\n";
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;} #define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E)) #define UNLESS(E) if(!(E))
...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self) ...@@ -626,8 +626,6 @@ cc_dealloc(ccobject *self)
static PyObject * static PyObject *
cc_getattr(ccobject *self, char *name) cc_getattr(ccobject *self, char *name)
{ {
PyObject *r;
if(*name=='c') if(*name=='c')
{ {
if(strcmp(name,"cache_age")==0) if(strcmp(name,"cache_age")==0)
...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name) ...@@ -646,16 +644,10 @@ cc_getattr(ccobject *self, char *name)
return PyDict_Copy(self->data); return PyDict_Copy(self->data);
} }
} }
if((*name=='h' && strcmp(name, "has_key")==0) ||
(*name=='i' && strcmp(name, "items")==0) ||
(*name=='k' && strcmp(name, "keys")==0)
)
return PyObject_GetAttrString(self->data, name);
if((r=Py_FindMethod(cc_methods, (PyObject *)self, name))) if (strcmp(name, "items") == 0)
return r;
PyErr_Clear();
return PyObject_GetAttrString(self->data, name); return PyObject_GetAttrString(self->data, name);
return Py_FindMethod(cc_methods, (PyObject *)self, name);
} }
static int static int
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment