diff options
author | Tim Peters <tim.peters@gmail.com> | 2003-04-07 17:51:59 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2003-04-07 17:51:59 (GMT) |
commit | df875b99fcb69c18168fb761ddaa722a034175dd (patch) | |
tree | e61ba67f62a7bad46095b5a49523edf475950558 | |
parent | cb8ed53014ea04c2f1f340c720cb670c888df6bb (diff) | |
download | cpython-df875b99fcb69c18168fb761ddaa722a034175dd.zip cpython-df875b99fcb69c18168fb761ddaa722a034175dd.tar.gz cpython-df875b99fcb69c18168fb761ddaa722a034175dd.tar.bz2 |
New private API function _PyInstance_Lookup. gc will use this to figure
out whether __del__ exists, without executing any Python-level code.
-rw-r--r-- | Include/classobject.h | 12 | ||||
-rw-r--r-- | Objects/classobject.c | 21 |
2 files changed, 33 insertions, 0 deletions
diff --git a/Include/classobject.h b/Include/classobject.h index b071e98..1328c27 100644 --- a/Include/classobject.h +++ b/Include/classobject.h @@ -51,6 +51,18 @@ PyAPI_FUNC(PyObject *) PyMethod_Function(PyObject *); PyAPI_FUNC(PyObject *) PyMethod_Self(PyObject *); PyAPI_FUNC(PyObject *) PyMethod_Class(PyObject *); +/* Look up attribute with name (a string) on instance object pinst, using + * only the instance and base class dicts. If a descriptor is found in + * a class dict, the descriptor is returned without calling it. + * Returns NULL if nothing found, else a borrowed reference to the + * value associated with name in the dict in which name was found. + * The point of this routine is that it never calls arbitrary Python + * code, so is always "safe": all it does is dict lookups. The function + * can't fail, never sets an exceptionm, and NULL is not an error (it just + * means "not found"). + */ +PyAPI_FUNC(PyObject *)_PyInstance_Lookup(PyObject *pinst, PyObject *name); + /* Macros for direct access to these values. Type checks are *not* done, so use with care. */ #define PyMethod_GET_FUNCTION(meth) \ diff --git a/Objects/classobject.c b/Objects/classobject.c index 80aabbf..89a3673 100644 --- a/Objects/classobject.c +++ b/Objects/classobject.c @@ -759,6 +759,27 @@ instance_getattr(register PyInstanceObject *inst, PyObject *name) return res; } +/* See classobject.h comments: this only does dict lookups, and is always + * safe to call. + */ +PyObject * +_PyInstance_Lookup(PyObject *pinst, PyObject *name) +{ + PyObject *v; + PyClassObject *class; + PyInstanceObject *inst; /* pinst cast to the right type */ + + assert(PyInstance_Check(pinst)); + inst = (PyInstanceObject *)pinst; + + assert(PyString_Check(name)); + + v = PyDict_GetItem(inst->in_dict, name); + if (v == NULL) + v = class_lookup(inst->in_class, name, &class); + return v; +} + static int instance_setattr1(PyInstanceObject *inst, PyObject *name, PyObject *v) { |