blob: 32e8d2a8dfc1df0981fbb09401bd34b2330112f0 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002/* Class object implementation */
3
Guido van Rossumc0b618a1997-05-02 03:12:38 +00004#include "Python.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +00005#include "structmember.h"
Guido van Rossum04691fc1992-08-12 15:35:34 +00006
Guido van Rossum915f0eb2001-10-17 20:26:38 +00007#define TP_DESCR_GET(t) \
8 (PyType_HasFeature(t, Py_TPFLAGS_HAVE_CLASS) ? (t)->tp_descr_get : NULL)
9
Neil Schemenauer29bfc072001-01-04 01:43:46 +000010
Guido van Rossum52ca98a1994-09-05 07:32:29 +000011/* Forward */
Tim Petersdbd9ba62000-07-09 03:09:57 +000012static PyObject *class_lookup(PyClassObject *, PyObject *,
13 PyClassObject **);
14static PyObject *instance_getattr1(PyInstanceObject *, PyObject *);
15static PyObject *instance_getattr2(PyInstanceObject *, PyObject *);
Guido van Rossum52ca98a1994-09-05 07:32:29 +000016
Guido van Rossuma63eff61998-05-29 21:37:21 +000017static PyObject *getattrstr, *setattrstr, *delattrstr;
18
Fred Drake79912472000-07-09 04:06:11 +000019
Guido van Rossumc0b618a1997-05-02 03:12:38 +000020PyObject *
Fred Drake79912472000-07-09 04:06:11 +000021PyClass_New(PyObject *bases, PyObject *dict, PyObject *name)
22 /* bases is NULL or tuple of classobjects! */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000023{
Guido van Rossumc0b618a1997-05-02 03:12:38 +000024 PyClassObject *op, *dummy;
Guido van Rossum7cc56eb1997-09-12 20:04:46 +000025 static PyObject *docstr, *modstr, *namestr;
Guido van Rossum019f4241996-08-21 14:54:28 +000026 if (docstr == NULL) {
Guido van Rossuma412d241997-01-18 07:59:12 +000027 docstr= PyString_InternFromString("__doc__");
Guido van Rossum019f4241996-08-21 14:54:28 +000028 if (docstr == NULL)
29 return NULL;
30 }
Guido van Rossum7cc56eb1997-09-12 20:04:46 +000031 if (modstr == NULL) {
32 modstr= PyString_InternFromString("__module__");
33 if (modstr == NULL)
34 return NULL;
35 }
36 if (namestr == NULL) {
37 namestr= PyString_InternFromString("__name__");
38 if (namestr == NULL)
39 return NULL;
40 }
Guido van Rossum04d73c41997-10-07 14:54:11 +000041 if (name == NULL || !PyString_Check(name)) {
Tim Peters6d6c1a32001-08-02 04:15:00 +000042 PyErr_SetString(PyExc_TypeError,
Guido van Rossum04d73c41997-10-07 14:54:11 +000043 "PyClass_New: name must be a string");
44 return NULL;
45 }
46 if (dict == NULL || !PyDict_Check(dict)) {
Tim Peters6d6c1a32001-08-02 04:15:00 +000047 PyErr_SetString(PyExc_TypeError,
Guido van Rossum04d73c41997-10-07 14:54:11 +000048 "PyClass_New: dict must be a dictionary");
49 return NULL;
50 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +000051 if (PyDict_GetItem(dict, docstr) == NULL) {
52 if (PyDict_SetItem(dict, docstr, Py_None) < 0)
Guido van Rossume7d444f1995-01-07 12:35:18 +000053 return NULL;
54 }
Guido van Rossum7cc56eb1997-09-12 20:04:46 +000055 if (PyDict_GetItem(dict, modstr) == NULL) {
56 PyObject *globals = PyEval_GetGlobals();
57 if (globals != NULL) {
Guido van Rossum04d73c41997-10-07 14:54:11 +000058 PyObject *modname = PyDict_GetItem(globals, namestr);
59 if (modname != NULL) {
60 if (PyDict_SetItem(dict, modstr, modname) < 0)
Guido van Rossum7cc56eb1997-09-12 20:04:46 +000061 return NULL;
62 }
63 }
64 }
Guido van Rossume2966a61991-12-10 13:53:23 +000065 if (bases == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +000066 bases = PyTuple_New(0);
Guido van Rossume2966a61991-12-10 13:53:23 +000067 if (bases == NULL)
Guido van Rossume5372401993-03-16 12:15:04 +000068 return NULL;
Guido van Rossume2966a61991-12-10 13:53:23 +000069 }
Guido van Rossum04d73c41997-10-07 14:54:11 +000070 else {
Guido van Rossum28d80b12001-09-07 21:08:32 +000071 int i, n;
72 PyObject *base;
Guido van Rossum04d73c41997-10-07 14:54:11 +000073 if (!PyTuple_Check(bases)) {
Tim Peters6d6c1a32001-08-02 04:15:00 +000074 PyErr_SetString(PyExc_TypeError,
Guido van Rossum04d73c41997-10-07 14:54:11 +000075 "PyClass_New: bases must be a tuple");
76 return NULL;
77 }
Guido van Rossum28d80b12001-09-07 21:08:32 +000078 n = PyTuple_Size(bases);
79 for (i = 0; i < n; i++) {
80 base = PyTuple_GET_ITEM(bases, i);
81 if (!PyClass_Check(base)) {
82 if (PyCallable_Check(
83 (PyObject *) base->ob_type))
84 return PyObject_CallFunction(
85 (PyObject *) base->ob_type,
86 "OOO",
87 name,
88 bases,
89 dict);
Tim Peters6d6c1a32001-08-02 04:15:00 +000090 PyErr_SetString(PyExc_TypeError,
Guido van Rossum04d73c41997-10-07 14:54:11 +000091 "PyClass_New: base must be a class");
92 return NULL;
93 }
94 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +000095 Py_INCREF(bases);
Guido van Rossum04d73c41997-10-07 14:54:11 +000096 }
Neil Schemenauere83c00e2001-08-29 23:54:21 +000097 op = PyObject_GC_New(PyClassObject, &PyClass_Type);
Guido van Rossume2966a61991-12-10 13:53:23 +000098 if (op == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +000099 Py_DECREF(bases);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000100 return NULL;
Guido van Rossume2966a61991-12-10 13:53:23 +0000101 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000102 op->cl_bases = bases;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000103 Py_INCREF(dict);
Guido van Rossum81daa321993-05-20 14:24:46 +0000104 op->cl_dict = dict;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000105 Py_XINCREF(name);
Guido van Rossum94308391991-10-20 20:11:48 +0000106 op->cl_name = name;
Guido van Rossum2878a691996-08-09 20:53:24 +0000107 if (getattrstr == NULL) {
Guido van Rossuma412d241997-01-18 07:59:12 +0000108 getattrstr = PyString_InternFromString("__getattr__");
109 setattrstr = PyString_InternFromString("__setattr__");
110 delattrstr = PyString_InternFromString("__delattr__");
Guido van Rossum2878a691996-08-09 20:53:24 +0000111 }
112 op->cl_getattr = class_lookup(op, getattrstr, &dummy);
113 op->cl_setattr = class_lookup(op, setattrstr, &dummy);
114 op->cl_delattr = class_lookup(op, delattrstr, &dummy);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000115 Py_XINCREF(op->cl_getattr);
116 Py_XINCREF(op->cl_setattr);
117 Py_XINCREF(op->cl_delattr);
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000118 _PyObject_GC_TRACK(op);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000119 return (PyObject *) op;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000120}
121
Guido van Rossumb479dc52001-09-05 22:52:50 +0000122PyObject *
123PyMethod_Function(PyObject *im)
124{
125 if (!PyMethod_Check(im)) {
126 PyErr_BadInternalCall();
127 return NULL;
128 }
129 return ((PyMethodObject *)im)->im_func;
130}
131
132PyObject *
133PyMethod_Self(PyObject *im)
134{
135 if (!PyMethod_Check(im)) {
136 PyErr_BadInternalCall();
137 return NULL;
138 }
139 return ((PyMethodObject *)im)->im_self;
140}
141
142PyObject *
143PyMethod_Class(PyObject *im)
144{
145 if (!PyMethod_Check(im)) {
146 PyErr_BadInternalCall();
147 return NULL;
148 }
149 return ((PyMethodObject *)im)->im_class;
150}
151
Guido van Rossumbea18cc2002-06-14 20:41:17 +0000152PyDoc_STRVAR(class_doc,
153"classobj(name, bases, dict)\n\
154\n\
155Create a class object. The name must be a string; the second argument\n\
156a tuple of classes, and the third a dictionary.");
157
158static PyObject *
Tim Peters6d6c1a32001-08-02 04:15:00 +0000159class_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
160{
161 PyObject *name, *bases, *dict;
162 static char *kwlist[] = {"name", "bases", "dict", 0};
163
164 if (!PyArg_ParseTupleAndKeywords(args, kwds, "SOO", kwlist,
165 &name, &bases, &dict))
166 return NULL;
167 return PyClass_New(bases, dict, name);
168}
169
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000170/* Class methods */
171
172static void
Fred Drake79912472000-07-09 04:06:11 +0000173class_dealloc(PyClassObject *op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000174{
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000175 _PyObject_GC_UNTRACK(op);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000176 Py_DECREF(op->cl_bases);
177 Py_DECREF(op->cl_dict);
178 Py_XDECREF(op->cl_name);
Guido van Rossum152d8171998-08-04 14:59:16 +0000179 Py_XDECREF(op->cl_getattr);
180 Py_XDECREF(op->cl_setattr);
181 Py_XDECREF(op->cl_delattr);
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000182 PyObject_GC_Del(op);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000183}
184
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000185static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000186class_lookup(PyClassObject *cp, PyObject *name, PyClassObject **pclass)
Guido van Rossum81daa321993-05-20 14:24:46 +0000187{
188 int i, n;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000189 PyObject *value = PyDict_GetItem(cp->cl_dict, name);
Guido van Rossum81daa321993-05-20 14:24:46 +0000190 if (value != NULL) {
191 *pclass = cp;
192 return value;
193 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000194 n = PyTuple_Size(cp->cl_bases);
Guido van Rossum81daa321993-05-20 14:24:46 +0000195 for (i = 0; i < n; i++) {
Guido van Rossum7cc56eb1997-09-12 20:04:46 +0000196 /* XXX What if one of the bases is not a class? */
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000197 PyObject *v = class_lookup(
198 (PyClassObject *)
199 PyTuple_GetItem(cp->cl_bases, i), name, pclass);
Guido van Rossum81daa321993-05-20 14:24:46 +0000200 if (v != NULL)
201 return v;
202 }
203 return NULL;
204}
205
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000206static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000207class_getattr(register PyClassObject *op, PyObject *name)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000208{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000209 register PyObject *v;
210 register char *sname = PyString_AsString(name);
211 PyClassObject *class;
Tim Peters6d6c1a32001-08-02 04:15:00 +0000212 descrgetfunc f;
213
Guido van Rossum2878a691996-08-09 20:53:24 +0000214 if (sname[0] == '_' && sname[1] == '_') {
215 if (strcmp(sname, "__dict__") == 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000216 if (PyEval_GetRestricted()) {
217 PyErr_SetString(PyExc_RuntimeError,
218 "class.__dict__ not accessible in restricted mode");
Guido van Rossum10393b11995-01-10 10:39:49 +0000219 return NULL;
220 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000221 Py_INCREF(op->cl_dict);
Guido van Rossum10393b11995-01-10 10:39:49 +0000222 return op->cl_dict;
223 }
Guido van Rossum2878a691996-08-09 20:53:24 +0000224 if (strcmp(sname, "__bases__") == 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000225 Py_INCREF(op->cl_bases);
Guido van Rossum10393b11995-01-10 10:39:49 +0000226 return op->cl_bases;
227 }
Guido van Rossum2878a691996-08-09 20:53:24 +0000228 if (strcmp(sname, "__name__") == 0) {
Guido van Rossum10393b11995-01-10 10:39:49 +0000229 if (op->cl_name == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000230 v = Py_None;
Guido van Rossum10393b11995-01-10 10:39:49 +0000231 else
232 v = op->cl_name;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000233 Py_INCREF(v);
Guido van Rossum10393b11995-01-10 10:39:49 +0000234 return v;
235 }
Guido van Rossum94308391991-10-20 20:11:48 +0000236 }
Guido van Rossum81daa321993-05-20 14:24:46 +0000237 v = class_lookup(op, name, &class);
Guido van Rossumb3f72581993-05-21 19:56:10 +0000238 if (v == NULL) {
Fred Drake661ea262000-10-24 19:57:45 +0000239 PyErr_Format(PyExc_AttributeError,
240 "class %.50s has no attribute '%.400s'",
241 PyString_AS_STRING(op->cl_name), sname);
Guido van Rossumb3f72581993-05-21 19:56:10 +0000242 return NULL;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000243 }
Guido van Rossum915f0eb2001-10-17 20:26:38 +0000244 f = TP_DESCR_GET(v->ob_type);
Tim Peters6d6c1a32001-08-02 04:15:00 +0000245 if (f == NULL)
246 Py_INCREF(v);
247 else
248 v = f(v, (PyObject *)NULL, (PyObject *)op);
Guido van Rossumb3f72581993-05-21 19:56:10 +0000249 return v;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000250}
251
Guido van Rossuma63eff61998-05-29 21:37:21 +0000252static void
Fred Drake79912472000-07-09 04:06:11 +0000253set_slot(PyObject **slot, PyObject *v)
Guido van Rossuma63eff61998-05-29 21:37:21 +0000254{
255 PyObject *temp = *slot;
256 Py_XINCREF(v);
257 *slot = v;
258 Py_XDECREF(temp);
259}
260
Guido van Rossum7ba30431998-07-08 13:34:48 +0000261static void
Fred Drake79912472000-07-09 04:06:11 +0000262set_attr_slots(PyClassObject *c)
Guido van Rossum7ba30431998-07-08 13:34:48 +0000263{
264 PyClassObject *dummy;
265
266 set_slot(&c->cl_getattr, class_lookup(c, getattrstr, &dummy));
267 set_slot(&c->cl_setattr, class_lookup(c, setattrstr, &dummy));
268 set_slot(&c->cl_delattr, class_lookup(c, delattrstr, &dummy));
269}
270
Guido van Rossuma63eff61998-05-29 21:37:21 +0000271static char *
Fred Drake79912472000-07-09 04:06:11 +0000272set_dict(PyClassObject *c, PyObject *v)
Guido van Rossuma63eff61998-05-29 21:37:21 +0000273{
Guido van Rossuma63eff61998-05-29 21:37:21 +0000274 if (v == NULL || !PyDict_Check(v))
275 return "__dict__ must be a dictionary object";
276 set_slot(&c->cl_dict, v);
Guido van Rossum7ba30431998-07-08 13:34:48 +0000277 set_attr_slots(c);
Guido van Rossuma63eff61998-05-29 21:37:21 +0000278 return "";
279}
280
281static char *
Fred Drake79912472000-07-09 04:06:11 +0000282set_bases(PyClassObject *c, PyObject *v)
Guido van Rossuma63eff61998-05-29 21:37:21 +0000283{
Guido van Rossuma63eff61998-05-29 21:37:21 +0000284 int i, n;
285
286 if (v == NULL || !PyTuple_Check(v))
287 return "__bases__ must be a tuple object";
288 n = PyTuple_Size(v);
289 for (i = 0; i < n; i++) {
290 PyObject *x = PyTuple_GET_ITEM(v, i);
291 if (!PyClass_Check(x))
292 return "__bases__ items must be classes";
293 if (PyClass_IsSubclass(x, (PyObject *)c))
294 return "a __bases__ item causes an inheritance cycle";
295 }
296 set_slot(&c->cl_bases, v);
Guido van Rossum7ba30431998-07-08 13:34:48 +0000297 set_attr_slots(c);
Guido van Rossuma63eff61998-05-29 21:37:21 +0000298 return "";
299}
300
301static char *
Fred Drake79912472000-07-09 04:06:11 +0000302set_name(PyClassObject *c, PyObject *v)
Guido van Rossuma63eff61998-05-29 21:37:21 +0000303{
Guido van Rossuma63eff61998-05-29 21:37:21 +0000304 if (v == NULL || !PyString_Check(v))
305 return "__name__ must be a string object";
Guido van Rossumad89bbc2000-06-28 21:57:18 +0000306 if (strlen(PyString_AS_STRING(v)) != (size_t)PyString_GET_SIZE(v))
Guido van Rossuma63eff61998-05-29 21:37:21 +0000307 return "__name__ must not contain null bytes";
308 set_slot(&c->cl_name, v);
309 return "";
310}
311
Guido van Rossum94308391991-10-20 20:11:48 +0000312static int
Fred Drake79912472000-07-09 04:06:11 +0000313class_setattr(PyClassObject *op, PyObject *name, PyObject *v)
Guido van Rossum94308391991-10-20 20:11:48 +0000314{
Guido van Rossumb2173c31997-08-25 21:23:56 +0000315 char *sname;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000316 if (PyEval_GetRestricted()) {
317 PyErr_SetString(PyExc_RuntimeError,
Guido van Rossumac21f6a1995-08-04 04:05:31 +0000318 "classes are read-only in restricted mode");
319 return -1;
320 }
Guido van Rossumb2173c31997-08-25 21:23:56 +0000321 sname = PyString_AsString(name);
322 if (sname[0] == '_' && sname[1] == '_') {
323 int n = PyString_Size(name);
324 if (sname[n-1] == '_' && sname[n-2] == '_') {
Guido van Rossuma63eff61998-05-29 21:37:21 +0000325 char *err = NULL;
326 if (strcmp(sname, "__dict__") == 0)
327 err = set_dict(op, v);
328 else if (strcmp(sname, "__bases__") == 0)
329 err = set_bases(op, v);
330 else if (strcmp(sname, "__name__") == 0)
331 err = set_name(op, v);
332 else if (strcmp(sname, "__getattr__") == 0)
333 set_slot(&op->cl_getattr, v);
334 else if (strcmp(sname, "__setattr__") == 0)
335 set_slot(&op->cl_setattr, v);
336 else if (strcmp(sname, "__delattr__") == 0)
337 set_slot(&op->cl_delattr, v);
338 /* For the last three, we fall through to update the
339 dictionary as well. */
340 if (err != NULL) {
341 if (*err == '\0')
342 return 0;
343 PyErr_SetString(PyExc_TypeError, err);
Guido van Rossumb2173c31997-08-25 21:23:56 +0000344 return -1;
345 }
346 }
347 }
Guido van Rossum94472a01992-09-04 09:45:18 +0000348 if (v == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000349 int rv = PyDict_DelItem(op->cl_dict, name);
Guido van Rossum94472a01992-09-04 09:45:18 +0000350 if (rv < 0)
Fred Drake661ea262000-10-24 19:57:45 +0000351 PyErr_Format(PyExc_AttributeError,
352 "class %.50s has no attribute '%.400s'",
353 PyString_AS_STRING(op->cl_name), sname);
Guido van Rossum94472a01992-09-04 09:45:18 +0000354 return rv;
355 }
Guido van Rossum94308391991-10-20 20:11:48 +0000356 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000357 return PyDict_SetItem(op->cl_dict, name, v);
Guido van Rossum94308391991-10-20 20:11:48 +0000358}
359
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000360static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000361class_repr(PyClassObject *op)
Guido van Rossum25831651993-05-19 14:50:45 +0000362{
Guido van Rossum4a2a6211997-10-20 23:26:11 +0000363 PyObject *mod = PyDict_GetItemString(op->cl_dict, "__module__");
Guido van Rossum25831651993-05-19 14:50:45 +0000364 char *name;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000365 if (op->cl_name == NULL || !PyString_Check(op->cl_name))
Guido van Rossum25831651993-05-19 14:50:45 +0000366 name = "?";
367 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000368 name = PyString_AsString(op->cl_name);
Guido van Rossum4a2a6211997-10-20 23:26:11 +0000369 if (mod == NULL || !PyString_Check(mod))
Martin v. Löwiscf95f9c2001-09-18 20:23:28 +0000370 return PyString_FromFormat("<class ?.%s at %p>", name, op);
Guido van Rossum4a2a6211997-10-20 23:26:11 +0000371 else
Barry Warsaw7ce36942001-08-24 18:34:26 +0000372 return PyString_FromFormat("<class %s.%s at %p>",
373 PyString_AsString(mod),
374 name, op);
Guido van Rossum25831651993-05-19 14:50:45 +0000375}
376
Guido van Rossum4a2a6211997-10-20 23:26:11 +0000377static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000378class_str(PyClassObject *op)
Guido van Rossum4a2a6211997-10-20 23:26:11 +0000379{
380 PyObject *mod = PyDict_GetItemString(op->cl_dict, "__module__");
381 PyObject *name = op->cl_name;
382 PyObject *res;
383 int m, n;
384
385 if (name == NULL || !PyString_Check(name))
386 return class_repr(op);
387 if (mod == NULL || !PyString_Check(mod)) {
388 Py_INCREF(name);
389 return name;
390 }
391 m = PyString_Size(mod);
392 n = PyString_Size(name);
393 res = PyString_FromStringAndSize((char *)NULL, m+1+n);
394 if (res != NULL) {
395 char *s = PyString_AsString(res);
396 memcpy(s, PyString_AsString(mod), m);
397 s += m;
398 *s++ = '.';
399 memcpy(s, PyString_AsString(name), n);
400 }
401 return res;
402}
403
Jeremy Hylton8caad492000-06-23 14:18:11 +0000404static int
405class_traverse(PyClassObject *o, visitproc visit, void *arg)
406{
407 int err;
408 if (o->cl_bases) {
409 err = visit(o->cl_bases, arg);
410 if (err)
411 return err;
412 }
413 if (o->cl_dict) {
414 err = visit(o->cl_dict, arg);
415 if (err)
416 return err;
417 }
418 if (o->cl_name) {
419 err = visit(o->cl_name, arg);
420 if (err)
421 return err;
422 }
423 if (o->cl_getattr) {
424 err = visit(o->cl_getattr, arg);
425 if (err)
426 return err;
427 }
428 if (o->cl_setattr) {
429 err = visit(o->cl_setattr, arg);
430 if (err)
431 return err;
432 }
433 if (o->cl_delattr) {
434 err = visit(o->cl_delattr, arg);
435 if (err)
436 return err;
437 }
438 return 0;
439}
440
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000441PyTypeObject PyClass_Type = {
442 PyObject_HEAD_INIT(&PyType_Type)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000443 0,
Guido van Rossumbea18cc2002-06-14 20:41:17 +0000444 "classobj",
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000445 sizeof(PyClassObject),
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000446 0,
Guido van Rossum8998b4f2001-01-17 15:28:20 +0000447 (destructor)class_dealloc, /* tp_dealloc */
448 0, /* tp_print */
449 0, /* tp_getattr */
450 0, /* tp_setattr */
451 0, /* tp_compare */
452 (reprfunc)class_repr, /* tp_repr */
453 0, /* tp_as_number */
454 0, /* tp_as_sequence */
455 0, /* tp_as_mapping */
456 0, /* tp_hash */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000457 PyInstance_New, /* tp_call */
Guido van Rossum8998b4f2001-01-17 15:28:20 +0000458 (reprfunc)class_str, /* tp_str */
459 (getattrofunc)class_getattr, /* tp_getattro */
460 (setattrofunc)class_setattr, /* tp_setattro */
461 0, /* tp_as_buffer */
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000462 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC,/* tp_flags */
Guido van Rossumbea18cc2002-06-14 20:41:17 +0000463 class_doc, /* tp_doc */
Guido van Rossum8998b4f2001-01-17 15:28:20 +0000464 (traverseproc)class_traverse, /* tp_traverse */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000465 0, /* tp_clear */
466 0, /* tp_richcompare */
467 0, /* tp_weaklistoffset */
468 0, /* tp_iter */
469 0, /* tp_iternext */
470 0, /* tp_methods */
471 0, /* tp_members */
472 0, /* tp_getset */
473 0, /* tp_base */
474 0, /* tp_dict */
475 0, /* tp_descr_get */
476 0, /* tp_descr_set */
477 0, /* tp_dictoffset */
478 0, /* tp_init */
479 0, /* tp_alloc */
480 class_new, /* tp_new */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000481};
482
Guido van Rossum81daa321993-05-20 14:24:46 +0000483int
Fred Drake79912472000-07-09 04:06:11 +0000484PyClass_IsSubclass(PyObject *class, PyObject *base)
Guido van Rossum81daa321993-05-20 14:24:46 +0000485{
486 int i, n;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000487 PyClassObject *cp;
Guido van Rossum81daa321993-05-20 14:24:46 +0000488 if (class == base)
489 return 1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000490 if (class == NULL || !PyClass_Check(class))
Guido van Rossumeb6b33a1993-05-25 09:38:27 +0000491 return 0;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000492 cp = (PyClassObject *)class;
493 n = PyTuple_Size(cp->cl_bases);
Guido van Rossum81daa321993-05-20 14:24:46 +0000494 for (i = 0; i < n; i++) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000495 if (PyClass_IsSubclass(PyTuple_GetItem(cp->cl_bases, i), base))
Guido van Rossum81daa321993-05-20 14:24:46 +0000496 return 1;
497 }
498 return 0;
499}
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000500
Guido van Rossum81daa321993-05-20 14:24:46 +0000501
502/* Instance objects */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000503
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000504PyObject *
Fred Drake5cc2c8c2001-01-28 03:53:08 +0000505PyInstance_NewRaw(PyObject *klass, PyObject *dict)
506{
507 PyInstanceObject *inst;
508
509 if (!PyClass_Check(klass)) {
510 PyErr_BadInternalCall();
511 return NULL;
512 }
513 if (dict == NULL) {
514 dict = PyDict_New();
515 if (dict == NULL)
516 return NULL;
517 }
518 else {
519 if (!PyDict_Check(dict)) {
520 PyErr_BadInternalCall();
521 return NULL;
522 }
523 Py_INCREF(dict);
524 }
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000525 inst = PyObject_GC_New(PyInstanceObject, &PyInstance_Type);
Fred Drake5cc2c8c2001-01-28 03:53:08 +0000526 if (inst == NULL) {
527 Py_DECREF(dict);
528 return NULL;
529 }
Fred Drake4e262a92001-03-22 18:26:47 +0000530 inst->in_weakreflist = NULL;
Fred Drake5cc2c8c2001-01-28 03:53:08 +0000531 Py_INCREF(klass);
532 inst->in_class = (PyClassObject *)klass;
533 inst->in_dict = dict;
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000534 _PyObject_GC_TRACK(inst);
Fred Drake5cc2c8c2001-01-28 03:53:08 +0000535 return (PyObject *)inst;
536}
537
538PyObject *
539PyInstance_New(PyObject *klass, PyObject *arg, PyObject *kw)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000540{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000541 register PyInstanceObject *inst;
542 PyObject *init;
543 static PyObject *initstr;
Fred Drake5cc2c8c2001-01-28 03:53:08 +0000544
545 inst = (PyInstanceObject *) PyInstance_NewRaw(klass, NULL);
Guido van Rossume8122f11991-05-05 20:03:07 +0000546 if (inst == NULL)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000547 return NULL;
Guido van Rossum2878a691996-08-09 20:53:24 +0000548 if (initstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +0000549 initstr = PyString_InternFromString("__init__");
Jeremy Hylton9e392e22000-04-26 20:39:20 +0000550 init = instance_getattr2(inst, initstr);
Guido van Rossum25831651993-05-19 14:50:45 +0000551 if (init == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000552 if ((arg != NULL && (!PyTuple_Check(arg) ||
553 PyTuple_Size(arg) != 0))
554 || (kw != NULL && (!PyDict_Check(kw) ||
555 PyDict_Size(kw) != 0))) {
556 PyErr_SetString(PyExc_TypeError,
Guido van Rossuma83f2701995-07-26 18:07:32 +0000557 "this constructor takes no arguments");
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000558 Py_DECREF(inst);
Guido van Rossum25831651993-05-19 14:50:45 +0000559 inst = NULL;
560 }
561 }
562 else {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000563 PyObject *res = PyEval_CallObjectWithKeywords(init, arg, kw);
564 Py_DECREF(init);
Guido van Rossum25831651993-05-19 14:50:45 +0000565 if (res == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000566 Py_DECREF(inst);
Guido van Rossum25831651993-05-19 14:50:45 +0000567 inst = NULL;
568 }
569 else {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000570 if (res != Py_None) {
571 PyErr_SetString(PyExc_TypeError,
Guido van Rossum25831651993-05-19 14:50:45 +0000572 "__init__() should return None");
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000573 Py_DECREF(inst);
Guido van Rossum25831651993-05-19 14:50:45 +0000574 inst = NULL;
575 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000576 Py_DECREF(res);
Guido van Rossum25831651993-05-19 14:50:45 +0000577 }
578 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000579 return (PyObject *)inst;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000580}
581
Guido van Rossum21ed88c1991-04-04 10:42:10 +0000582/* Instance methods */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000583
Guido van Rossumbea18cc2002-06-14 20:41:17 +0000584PyDoc_STRVAR(instance_doc,
585"instance(class[, dict])\n\
586\n\
587Create an instance without calling its __init__() method.\n\
588The class must be a classic class.\n\
589If present, dict must be a dictionary or None.");
590
591static PyObject *
592instance_new(PyTypeObject* type, PyObject* args, PyObject *kw)
593{
594 PyObject *klass;
595 PyObject *dict = Py_None;
596
597 if (!PyArg_ParseTuple(args, "O!|O:instance",
598 &PyClass_Type, &klass, &dict))
599 return NULL;
600
601 if (dict == Py_None)
602 dict = NULL;
603 else if (!PyDict_Check(dict)) {
604 PyErr_SetString(PyExc_TypeError,
605 "instance() second arg must be dictionary or None");
606 return NULL;
607 }
608 return PyInstance_NewRaw(klass, dict);
609}
610
611
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000612static void
Fred Drake79912472000-07-09 04:06:11 +0000613instance_dealloc(register PyInstanceObject *inst)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000614{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000615 PyObject *error_type, *error_value, *error_traceback;
616 PyObject *del;
617 static PyObject *delstr;
Tim Peters34592512002-07-11 06:23:50 +0000618
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000619 _PyObject_GC_UNTRACK(inst);
Fred Drakec916f5a2001-10-26 17:56:51 +0000620 if (inst->in_weakreflist != NULL)
621 PyObject_ClearWeakRefs((PyObject *) inst);
Fred Drake41deb1e2001-02-01 05:27:45 +0000622
Tim Peters6b184912000-09-17 14:40:17 +0000623 /* Temporarily resurrect the object. */
Tim Peters34592512002-07-11 06:23:50 +0000624 assert(inst->ob_type == &PyInstance_Type);
625 assert(inst->ob_refcnt == 0);
626 inst->ob_refcnt = 1;
Tim Peters6b184912000-09-17 14:40:17 +0000627
628 /* Save the current exception, if any. */
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000629 PyErr_Fetch(&error_type, &error_value, &error_traceback);
Tim Peters6b184912000-09-17 14:40:17 +0000630 /* Execute __del__ method, if any. */
Guido van Rossum2878a691996-08-09 20:53:24 +0000631 if (delstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +0000632 delstr = PyString_InternFromString("__del__");
Jeremy Hylton9e392e22000-04-26 20:39:20 +0000633 if ((del = instance_getattr2(inst, delstr)) != NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000634 PyObject *res = PyEval_CallObject(del, (PyObject *)NULL);
Tim Peters6b184912000-09-17 14:40:17 +0000635 if (res == NULL)
Jeremy Hyltonb709df32000-09-01 02:47:25 +0000636 PyErr_WriteUnraisable(del);
Guido van Rossum0dfcf751996-08-12 22:00:53 +0000637 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000638 Py_DECREF(res);
639 Py_DECREF(del);
Guido van Rossum25831651993-05-19 14:50:45 +0000640 }
Tim Peters6b184912000-09-17 14:40:17 +0000641 /* Restore the saved exception. */
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000642 PyErr_Restore(error_type, error_value, error_traceback);
Tim Peters34592512002-07-11 06:23:50 +0000643
Tim Peters6b184912000-09-17 14:40:17 +0000644 /* Undo the temporary resurrection; can't use DECREF here, it would
645 * cause a recursive call.
646 */
Tim Peters34592512002-07-11 06:23:50 +0000647 assert(inst->ob_refcnt > 0);
648 if (--inst->ob_refcnt == 0) {
649 Py_DECREF(inst->in_class);
650 Py_XDECREF(inst->in_dict);
651 PyObject_GC_Del(inst);
Sjoerd Mullender740f3571995-08-28 09:00:43 +0000652 }
Tim Peters34592512002-07-11 06:23:50 +0000653 else {
654 int refcnt = inst->ob_refcnt;
655 /* __del__ resurrected it! Make it look like the original
656 * Py_DECREF never happened.
657 */
658 _Py_NewReference((PyObject *)inst);
659 inst->ob_refcnt = refcnt;
660 _PyObject_GC_TRACK(inst);
661 /* If Py_REF_DEBUG, the original decref dropped _Py_RefTotal,
662 * but _Py_NewReference bumped it again, so that's a wash.
663 * If Py_TRACE_REFS, _Py_NewReference re-added self to the
664 * object chain, so no more to do there either.
665 * If COUNT_ALLOCS, the original decref bumped tp_frees, and
666 * _Py_NewReference bumped tp_allocs: both of those need to
667 * be undone.
668 */
Tim Peters6b184912000-09-17 14:40:17 +0000669#ifdef COUNT_ALLOCS
Tim Peters34592512002-07-11 06:23:50 +0000670 --inst->ob_type->tp_frees;
671 --inst->ob_type->tp_allocs;
Tim Peters6b184912000-09-17 14:40:17 +0000672#endif
Tim Peters34592512002-07-11 06:23:50 +0000673 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000674}
675
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000676static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000677instance_getattr1(register PyInstanceObject *inst, PyObject *name)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000678{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000679 register PyObject *v;
680 register char *sname = PyString_AsString(name);
Guido van Rossum2878a691996-08-09 20:53:24 +0000681 if (sname[0] == '_' && sname[1] == '_') {
682 if (strcmp(sname, "__dict__") == 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000683 if (PyEval_GetRestricted()) {
684 PyErr_SetString(PyExc_RuntimeError,
685 "instance.__dict__ not accessible in restricted mode");
Guido van Rossum10393b11995-01-10 10:39:49 +0000686 return NULL;
687 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000688 Py_INCREF(inst->in_dict);
Sjoerd Mullender3bb8a051993-10-22 12:04:32 +0000689 return inst->in_dict;
690 }
Guido van Rossum2878a691996-08-09 20:53:24 +0000691 if (strcmp(sname, "__class__") == 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000692 Py_INCREF(inst->in_class);
693 return (PyObject *)inst->in_class;
Sjoerd Mullender3bb8a051993-10-22 12:04:32 +0000694 }
Guido van Rossum94308391991-10-20 20:11:48 +0000695 }
Jeremy Hylton9e392e22000-04-26 20:39:20 +0000696 v = instance_getattr2(inst, name);
697 if (v == NULL) {
Fred Drake661ea262000-10-24 19:57:45 +0000698 PyErr_Format(PyExc_AttributeError,
699 "%.50s instance has no attribute '%.400s'",
Jeremy Hylton9e392e22000-04-26 20:39:20 +0000700 PyString_AS_STRING(inst->in_class->cl_name), sname);
701 }
702 return v;
703}
704
705static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000706instance_getattr2(register PyInstanceObject *inst, PyObject *name)
Jeremy Hylton9e392e22000-04-26 20:39:20 +0000707{
708 register PyObject *v;
709 PyClassObject *class;
Tim Peters6d6c1a32001-08-02 04:15:00 +0000710 descrgetfunc f;
711
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000712 v = PyDict_GetItem(inst->in_dict, name);
Guido van Rossumf23c41d2001-08-17 13:43:27 +0000713 if (v != NULL) {
714 Py_INCREF(v);
715 return v;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000716 }
Guido van Rossumf23c41d2001-08-17 13:43:27 +0000717 v = class_lookup(inst->in_class, name, &class);
718 if (v != NULL) {
719 Py_INCREF(v);
Guido van Rossum915f0eb2001-10-17 20:26:38 +0000720 f = TP_DESCR_GET(v->ob_type);
Tim Peters6d6c1a32001-08-02 04:15:00 +0000721 if (f != NULL) {
722 PyObject *w = f(v, (PyObject *)inst,
723 (PyObject *)(inst->in_class));
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000724 Py_DECREF(v);
Guido van Rossum21d335e1993-10-15 13:01:11 +0000725 v = w;
726 }
Guido van Rossumb3f72581993-05-21 19:56:10 +0000727 }
728 return v;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000729}
730
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000731static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000732instance_getattr(register PyInstanceObject *inst, PyObject *name)
Guido van Rossume7737541994-09-05 07:31:41 +0000733{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000734 register PyObject *func, *res;
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000735 res = instance_getattr1(inst, name);
736 if (res == NULL && (func = inst->in_class->cl_getattr) != NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000737 PyObject *args;
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000738 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
739 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000740 PyErr_Clear();
741 args = Py_BuildValue("(OO)", inst, name);
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000742 if (args == NULL)
Guido van Rossume7737541994-09-05 07:31:41 +0000743 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000744 res = PyEval_CallObject(func, args);
745 Py_DECREF(args);
Guido van Rossume7737541994-09-05 07:31:41 +0000746 }
747 return res;
748}
749
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000750static int
Fred Drake79912472000-07-09 04:06:11 +0000751instance_setattr1(PyInstanceObject *inst, PyObject *name, PyObject *v)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000752{
Guido van Rossum94472a01992-09-04 09:45:18 +0000753 if (v == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000754 int rv = PyDict_DelItem(inst->in_dict, name);
Guido van Rossum94472a01992-09-04 09:45:18 +0000755 if (rv < 0)
Fred Drake661ea262000-10-24 19:57:45 +0000756 PyErr_Format(PyExc_AttributeError,
757 "%.50s instance has no attribute '%.400s'",
758 PyString_AS_STRING(inst->in_class->cl_name),
759 PyString_AS_STRING(name));
Guido van Rossum94472a01992-09-04 09:45:18 +0000760 return rv;
761 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000762 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000763 return PyDict_SetItem(inst->in_dict, name, v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000764}
765
Guido van Rossume7737541994-09-05 07:31:41 +0000766static int
Fred Drake79912472000-07-09 04:06:11 +0000767instance_setattr(PyInstanceObject *inst, PyObject *name, PyObject *v)
Guido van Rossume7737541994-09-05 07:31:41 +0000768{
Guido van Rossumb2173c31997-08-25 21:23:56 +0000769 PyObject *func, *args, *res, *tmp;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000770 char *sname = PyString_AsString(name);
Guido van Rossumb2173c31997-08-25 21:23:56 +0000771 if (sname[0] == '_' && sname[1] == '_') {
772 int n = PyString_Size(name);
Guido van Rossum2878a691996-08-09 20:53:24 +0000773 if (sname[n-1] == '_' && sname[n-2] == '_') {
Guido van Rossumb2173c31997-08-25 21:23:56 +0000774 if (strcmp(sname, "__dict__") == 0) {
775 if (PyEval_GetRestricted()) {
776 PyErr_SetString(PyExc_RuntimeError,
777 "__dict__ not accessible in restricted mode");
778 return -1;
779 }
780 if (v == NULL || !PyDict_Check(v)) {
781 PyErr_SetString(PyExc_TypeError,
782 "__dict__ must be set to a dictionary");
783 return -1;
784 }
785 tmp = inst->in_dict;
786 Py_INCREF(v);
787 inst->in_dict = v;
788 Py_DECREF(tmp);
789 return 0;
790 }
791 if (strcmp(sname, "__class__") == 0) {
792 if (PyEval_GetRestricted()) {
793 PyErr_SetString(PyExc_RuntimeError,
794 "__class__ not accessible in restricted mode");
795 return -1;
796 }
797 if (v == NULL || !PyClass_Check(v)) {
798 PyErr_SetString(PyExc_TypeError,
799 "__class__ must be set to a class");
800 return -1;
801 }
802 tmp = (PyObject *)(inst->in_class);
803 Py_INCREF(v);
804 inst->in_class = (PyClassObject *)v;
805 Py_DECREF(tmp);
806 return 0;
807 }
Guido van Rossume7737541994-09-05 07:31:41 +0000808 }
Guido van Rossume7737541994-09-05 07:31:41 +0000809 }
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000810 if (v == NULL)
811 func = inst->in_class->cl_delattr;
812 else
813 func = inst->in_class->cl_setattr;
814 if (func == NULL)
815 return instance_setattr1(inst, name, v);
816 if (v == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000817 args = Py_BuildValue("(OO)", inst, name);
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000818 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000819 args = Py_BuildValue("(OOO)", inst, name, v);
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000820 if (args == NULL)
821 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000822 res = PyEval_CallObject(func, args);
823 Py_DECREF(args);
Guido van Rossum52ca98a1994-09-05 07:32:29 +0000824 if (res == NULL)
825 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000826 Py_DECREF(res);
Guido van Rossume7737541994-09-05 07:31:41 +0000827 return 0;
828}
829
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000830static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000831instance_repr(PyInstanceObject *inst)
Guido van Rossum04691fc1992-08-12 15:35:34 +0000832{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000833 PyObject *func;
834 PyObject *res;
835 static PyObject *reprstr;
Guido van Rossum04691fc1992-08-12 15:35:34 +0000836
Guido van Rossum2878a691996-08-09 20:53:24 +0000837 if (reprstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +0000838 reprstr = PyString_InternFromString("__repr__");
Guido van Rossum2878a691996-08-09 20:53:24 +0000839 func = instance_getattr(inst, reprstr);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000840 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000841 PyObject *classname, *mod;
Guido van Rossum25831651993-05-19 14:50:45 +0000842 char *cname;
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000843 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
844 return NULL;
845 PyErr_Clear();
846 classname = inst->in_class->cl_name;
847 mod = PyDict_GetItemString(inst->in_class->cl_dict,
848 "__module__");
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000849 if (classname != NULL && PyString_Check(classname))
850 cname = PyString_AsString(classname);
Guido van Rossum25831651993-05-19 14:50:45 +0000851 else
852 cname = "?";
Guido van Rossumb7f1afe1997-12-03 00:06:02 +0000853 if (mod == NULL || !PyString_Check(mod))
Barry Warsaw7ce36942001-08-24 18:34:26 +0000854 return PyString_FromFormat("<?.%s instance at %p>",
855 cname, inst);
Guido van Rossumb7f1afe1997-12-03 00:06:02 +0000856 else
Barry Warsaw7ce36942001-08-24 18:34:26 +0000857 return PyString_FromFormat("<%s.%s instance at %p>",
858 PyString_AsString(mod),
859 cname, inst);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000860 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000861 res = PyEval_CallObject(func, (PyObject *)NULL);
862 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000863 return res;
864}
865
Guido van Rossum82c690f2001-04-30 14:39:18 +0000866static PyObject *
867instance_str(PyInstanceObject *inst)
868{
869 PyObject *func;
870 PyObject *res;
871 static PyObject *strstr;
872
873 if (strstr == NULL)
874 strstr = PyString_InternFromString("__str__");
875 func = instance_getattr(inst, strstr);
876 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000877 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
878 return NULL;
Guido van Rossum82c690f2001-04-30 14:39:18 +0000879 PyErr_Clear();
880 return instance_repr(inst);
881 }
882 res = PyEval_CallObject(func, (PyObject *)NULL);
883 Py_DECREF(func);
884 return res;
885}
886
Guido van Rossum9bfef441993-03-29 10:43:31 +0000887static long
Fred Drake79912472000-07-09 04:06:11 +0000888instance_hash(PyInstanceObject *inst)
Guido van Rossum9bfef441993-03-29 10:43:31 +0000889{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000890 PyObject *func;
891 PyObject *res;
Guido van Rossum8a0c3451993-04-08 12:56:19 +0000892 long outcome;
Guido van Rossum65e8bd72001-01-18 23:46:31 +0000893 static PyObject *hashstr, *eqstr, *cmpstr;
Guido van Rossum9bfef441993-03-29 10:43:31 +0000894
Guido van Rossum2878a691996-08-09 20:53:24 +0000895 if (hashstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +0000896 hashstr = PyString_InternFromString("__hash__");
Guido van Rossum2878a691996-08-09 20:53:24 +0000897 func = instance_getattr(inst, hashstr);
Guido van Rossum9bfef441993-03-29 10:43:31 +0000898 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000899 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
900 return -1;
901 PyErr_Clear();
Guido van Rossum65e8bd72001-01-18 23:46:31 +0000902 /* If there is no __eq__ and no __cmp__ method, we hash on the
903 address. If an __eq__ or __cmp__ method exists, there must
904 be a __hash__. */
Guido van Rossum65e8bd72001-01-18 23:46:31 +0000905 if (eqstr == NULL)
906 eqstr = PyString_InternFromString("__eq__");
907 func = instance_getattr(inst, eqstr);
Guido van Rossum8a0c3451993-04-08 12:56:19 +0000908 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000909 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
910 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000911 PyErr_Clear();
Guido van Rossum65e8bd72001-01-18 23:46:31 +0000912 if (cmpstr == NULL)
913 cmpstr = PyString_InternFromString("__cmp__");
914 func = instance_getattr(inst, cmpstr);
915 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +0000916 if (!PyErr_ExceptionMatches(
917 PyExc_AttributeError))
918 return -1;
Guido van Rossum65e8bd72001-01-18 23:46:31 +0000919 PyErr_Clear();
920 return _Py_HashPointer(inst);
921 }
Guido van Rossum8a0c3451993-04-08 12:56:19 +0000922 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000923 PyErr_SetString(PyExc_TypeError, "unhashable instance");
Guido van Rossum9bfef441993-03-29 10:43:31 +0000924 return -1;
925 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000926 res = PyEval_CallObject(func, (PyObject *)NULL);
927 Py_DECREF(func);
Guido van Rossum9bfef441993-03-29 10:43:31 +0000928 if (res == NULL)
929 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000930 if (PyInt_Check(res)) {
931 outcome = PyInt_AsLong(res);
Guido van Rossum9bfef441993-03-29 10:43:31 +0000932 if (outcome == -1)
933 outcome = -2;
934 }
935 else {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000936 PyErr_SetString(PyExc_TypeError,
937 "__hash__() should return an int");
Guido van Rossum9bfef441993-03-29 10:43:31 +0000938 outcome = -1;
939 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000940 Py_DECREF(res);
Guido van Rossum9bfef441993-03-29 10:43:31 +0000941 return outcome;
942}
943
Jeremy Hylton8caad492000-06-23 14:18:11 +0000944static int
945instance_traverse(PyInstanceObject *o, visitproc visit, void *arg)
946{
947 int err;
948 if (o->in_class) {
949 err = visit((PyObject *)(o->in_class), arg);
950 if (err)
951 return err;
952 }
953 if (o->in_dict) {
954 err = visit(o->in_dict, arg);
955 if (err)
956 return err;
957 }
Jeremy Hyltond22162b2000-06-23 17:14:56 +0000958 return 0;
Jeremy Hylton8caad492000-06-23 14:18:11 +0000959}
960
Guido van Rossum213c7a62001-04-23 14:08:49 +0000961static PyObject *getitemstr, *setitemstr, *delitemstr, *lenstr;
962static PyObject *iterstr, *nextstr;
Guido van Rossum2878a691996-08-09 20:53:24 +0000963
Guido van Rossum9bfef441993-03-29 10:43:31 +0000964static int
Fred Drake79912472000-07-09 04:06:11 +0000965instance_length(PyInstanceObject *inst)
Guido van Rossum04691fc1992-08-12 15:35:34 +0000966{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000967 PyObject *func;
968 PyObject *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +0000969 int outcome;
970
Guido van Rossum2878a691996-08-09 20:53:24 +0000971 if (lenstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +0000972 lenstr = PyString_InternFromString("__len__");
Guido van Rossum2878a691996-08-09 20:53:24 +0000973 func = instance_getattr(inst, lenstr);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000974 if (func == NULL)
975 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000976 res = PyEval_CallObject(func, (PyObject *)NULL);
977 Py_DECREF(func);
Guido van Rossumd014ea61992-11-26 10:30:26 +0000978 if (res == NULL)
979 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000980 if (PyInt_Check(res)) {
981 outcome = PyInt_AsLong(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000982 if (outcome < 0)
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000983 PyErr_SetString(PyExc_ValueError,
984 "__len__() should return >= 0");
Guido van Rossum04691fc1992-08-12 15:35:34 +0000985 }
986 else {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000987 PyErr_SetString(PyExc_TypeError,
988 "__len__() should return an int");
Guido van Rossum04691fc1992-08-12 15:35:34 +0000989 outcome = -1;
990 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000991 Py_DECREF(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +0000992 return outcome;
993}
994
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000995static PyObject *
Fred Drake79912472000-07-09 04:06:11 +0000996instance_subscript(PyInstanceObject *inst, PyObject *key)
Guido van Rossum04691fc1992-08-12 15:35:34 +0000997{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000998 PyObject *func;
999 PyObject *arg;
1000 PyObject *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001001
Guido van Rossum2878a691996-08-09 20:53:24 +00001002 if (getitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001003 getitemstr = PyString_InternFromString("__getitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001004 func = instance_getattr(inst, getitemstr);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001005 if (func == NULL)
1006 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001007 arg = Py_BuildValue("(O)", key);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001008 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001009 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001010 return NULL;
1011 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001012 res = PyEval_CallObject(func, arg);
1013 Py_DECREF(func);
1014 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001015 return res;
1016}
1017
Guido van Rossum9bfef441993-03-29 10:43:31 +00001018static int
Fred Drake79912472000-07-09 04:06:11 +00001019instance_ass_subscript(PyInstanceObject *inst, PyObject *key, PyObject *value)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001020{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001021 PyObject *func;
1022 PyObject *arg;
1023 PyObject *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001024
Guido van Rossum2878a691996-08-09 20:53:24 +00001025 if (value == NULL) {
1026 if (delitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001027 delitemstr = PyString_InternFromString("__delitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001028 func = instance_getattr(inst, delitemstr);
1029 }
1030 else {
1031 if (setitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001032 setitemstr = PyString_InternFromString("__setitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001033 func = instance_getattr(inst, setitemstr);
1034 }
Guido van Rossum04691fc1992-08-12 15:35:34 +00001035 if (func == NULL)
1036 return -1;
1037 if (value == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001038 arg = Py_BuildValue("(O)", key);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001039 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001040 arg = Py_BuildValue("(OO)", key, value);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001041 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001042 Py_DECREF(func);
Guido van Rossum6d946f91992-08-14 13:49:30 +00001043 return -1;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001044 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001045 res = PyEval_CallObject(func, arg);
1046 Py_DECREF(func);
1047 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001048 if (res == NULL)
1049 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001050 Py_DECREF(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001051 return 0;
1052}
1053
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001054static PyMappingMethods instance_as_mapping = {
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001055 (inquiry)instance_length, /* mp_length */
1056 (binaryfunc)instance_subscript, /* mp_subscript */
1057 (objobjargproc)instance_ass_subscript, /* mp_ass_subscript */
Guido van Rossum04691fc1992-08-12 15:35:34 +00001058};
1059
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001060static PyObject *
Fred Drake79912472000-07-09 04:06:11 +00001061instance_item(PyInstanceObject *inst, int i)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001062{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001063 PyObject *func, *arg, *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001064
Guido van Rossum2878a691996-08-09 20:53:24 +00001065 if (getitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001066 getitemstr = PyString_InternFromString("__getitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001067 func = instance_getattr(inst, getitemstr);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001068 if (func == NULL)
1069 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001070 arg = Py_BuildValue("(i)", i);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001071 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001072 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001073 return NULL;
1074 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001075 res = PyEval_CallObject(func, arg);
1076 Py_DECREF(func);
1077 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001078 return res;
1079}
1080
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001081static PyObject *
Thomas Wouters1d75a792000-08-17 22:37:32 +00001082sliceobj_from_intint(int i, int j)
1083{
1084 PyObject *start, *end, *res;
1085
1086 start = PyInt_FromLong((long)i);
1087 if (!start)
1088 return NULL;
Tim Peters34592512002-07-11 06:23:50 +00001089
Thomas Wouters1d75a792000-08-17 22:37:32 +00001090 end = PyInt_FromLong((long)j);
1091 if (!end) {
1092 Py_DECREF(start);
1093 return NULL;
1094 }
1095 res = PySlice_New(start, end, NULL);
1096 Py_DECREF(start);
1097 Py_DECREF(end);
1098 return res;
1099}
1100
1101
1102static PyObject *
Fred Drake79912472000-07-09 04:06:11 +00001103instance_slice(PyInstanceObject *inst, int i, int j)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001104{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001105 PyObject *func, *arg, *res;
1106 static PyObject *getslicestr;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001107
Guido van Rossum2878a691996-08-09 20:53:24 +00001108 if (getslicestr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001109 getslicestr = PyString_InternFromString("__getslice__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001110 func = instance_getattr(inst, getslicestr);
Thomas Wouters1d75a792000-08-17 22:37:32 +00001111
1112 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001113 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1114 return NULL;
Thomas Wouters1d75a792000-08-17 22:37:32 +00001115 PyErr_Clear();
1116
1117 if (getitemstr == NULL)
1118 getitemstr = PyString_InternFromString("__getitem__");
1119 func = instance_getattr(inst, getitemstr);
1120 if (func == NULL)
1121 return NULL;
1122 arg = Py_BuildValue("(N)", sliceobj_from_intint(i, j));
Tim Peters34592512002-07-11 06:23:50 +00001123 } else
Thomas Wouters1d75a792000-08-17 22:37:32 +00001124 arg = Py_BuildValue("(ii)", i, j);
Tim Peters34592512002-07-11 06:23:50 +00001125
Guido van Rossum04691fc1992-08-12 15:35:34 +00001126 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001127 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001128 return NULL;
1129 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001130 res = PyEval_CallObject(func, arg);
1131 Py_DECREF(func);
1132 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001133 return res;
1134}
1135
1136static int
Fred Drake79912472000-07-09 04:06:11 +00001137instance_ass_item(PyInstanceObject *inst, int i, PyObject *item)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001138{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001139 PyObject *func, *arg, *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001140
Guido van Rossum2878a691996-08-09 20:53:24 +00001141 if (item == NULL) {
1142 if (delitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001143 delitemstr = PyString_InternFromString("__delitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001144 func = instance_getattr(inst, delitemstr);
1145 }
1146 else {
1147 if (setitemstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001148 setitemstr = PyString_InternFromString("__setitem__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001149 func = instance_getattr(inst, setitemstr);
1150 }
Guido van Rossum04691fc1992-08-12 15:35:34 +00001151 if (func == NULL)
Guido van Rossum6d946f91992-08-14 13:49:30 +00001152 return -1;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001153 if (item == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001154 arg = Py_BuildValue("i", i);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001155 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001156 arg = Py_BuildValue("(iO)", i, item);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001157 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001158 Py_DECREF(func);
Guido van Rossum6d946f91992-08-14 13:49:30 +00001159 return -1;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001160 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001161 res = PyEval_CallObject(func, arg);
1162 Py_DECREF(func);
1163 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001164 if (res == NULL)
1165 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001166 Py_DECREF(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001167 return 0;
1168}
1169
1170static int
Fred Drake79912472000-07-09 04:06:11 +00001171instance_ass_slice(PyInstanceObject *inst, int i, int j, PyObject *value)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001172{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001173 PyObject *func, *arg, *res;
1174 static PyObject *setslicestr, *delslicestr;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001175
Guido van Rossum2878a691996-08-09 20:53:24 +00001176 if (value == NULL) {
1177 if (delslicestr == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001178 delslicestr =
1179 PyString_InternFromString("__delslice__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001180 func = instance_getattr(inst, delslicestr);
Thomas Wouters1d75a792000-08-17 22:37:32 +00001181 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001182 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1183 return -1;
Thomas Wouters1d75a792000-08-17 22:37:32 +00001184 PyErr_Clear();
1185 if (delitemstr == NULL)
1186 delitemstr =
1187 PyString_InternFromString("__delitem__");
1188 func = instance_getattr(inst, delitemstr);
1189 if (func == NULL)
1190 return -1;
1191
1192 arg = Py_BuildValue("(N)",
1193 sliceobj_from_intint(i, j));
1194 } else
1195 arg = Py_BuildValue("(ii)", i, j);
Guido van Rossum2878a691996-08-09 20:53:24 +00001196 }
1197 else {
1198 if (setslicestr == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001199 setslicestr =
1200 PyString_InternFromString("__setslice__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001201 func = instance_getattr(inst, setslicestr);
Thomas Wouters1d75a792000-08-17 22:37:32 +00001202 if (func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001203 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1204 return -1;
Thomas Wouters1d75a792000-08-17 22:37:32 +00001205 PyErr_Clear();
1206 if (setitemstr == NULL)
1207 setitemstr =
1208 PyString_InternFromString("__setitem__");
1209 func = instance_getattr(inst, setitemstr);
1210 if (func == NULL)
1211 return -1;
1212
1213 arg = Py_BuildValue("(NO)",
1214 sliceobj_from_intint(i, j), value);
1215 } else
1216 arg = Py_BuildValue("(iiO)", i, j, value);
Guido van Rossum2878a691996-08-09 20:53:24 +00001217 }
Guido van Rossum04691fc1992-08-12 15:35:34 +00001218 if (arg == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001219 Py_DECREF(func);
Guido van Rossum6d946f91992-08-14 13:49:30 +00001220 return -1;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001221 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001222 res = PyEval_CallObject(func, arg);
1223 Py_DECREF(func);
1224 Py_DECREF(arg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001225 if (res == NULL)
1226 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001227 Py_DECREF(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001228 return 0;
1229}
1230
Tim Peterscb8d3682001-05-05 21:05:01 +00001231static int
1232instance_contains(PyInstanceObject *inst, PyObject *member)
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001233{
1234 static PyObject *__contains__;
Tim Peterscb8d3682001-05-05 21:05:01 +00001235 PyObject *func;
1236
1237 /* Try __contains__ first.
1238 * If that can't be done, try iterator-based searching.
1239 */
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001240
1241 if(__contains__ == NULL) {
1242 __contains__ = PyString_InternFromString("__contains__");
1243 if(__contains__ == NULL)
1244 return -1;
1245 }
1246 func = instance_getattr(inst, __contains__);
Tim Peterscb8d3682001-05-05 21:05:01 +00001247 if (func) {
1248 PyObject *res;
1249 int ret;
1250 PyObject *arg = Py_BuildValue("(O)", member);
1251 if(arg == NULL) {
1252 Py_DECREF(func);
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001253 return -1;
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001254 }
Tim Peterscb8d3682001-05-05 21:05:01 +00001255 res = PyEval_CallObject(func, arg);
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001256 Py_DECREF(func);
Tim Peterscb8d3682001-05-05 21:05:01 +00001257 Py_DECREF(arg);
Tim Peters34592512002-07-11 06:23:50 +00001258 if(res == NULL)
Tim Peterscb8d3682001-05-05 21:05:01 +00001259 return -1;
1260 ret = PyObject_IsTrue(res);
1261 Py_DECREF(res);
1262 return ret;
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001263 }
Tim Peterscb8d3682001-05-05 21:05:01 +00001264
1265 /* Couldn't find __contains__. */
1266 if (PyErr_ExceptionMatches(PyExc_AttributeError)) {
1267 /* Assume the failure was simply due to that there is no
1268 * __contains__ attribute, and try iterating instead.
1269 */
1270 PyErr_Clear();
Tim Peters16a77ad2001-09-08 04:00:12 +00001271 return _PySequence_IterSearch((PyObject *)inst, member,
1272 PY_ITERSEARCH_CONTAINS);
Tim Peterscb8d3682001-05-05 21:05:01 +00001273 }
1274 else
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001275 return -1;
Guido van Rossumee28c3a2000-02-28 15:03:15 +00001276}
1277
Fred Drake79912472000-07-09 04:06:11 +00001278static PySequenceMethods
1279instance_as_sequence = {
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001280 (inquiry)instance_length, /* sq_length */
1281 0, /* sq_concat */
1282 0, /* sq_repeat */
1283 (intargfunc)instance_item, /* sq_item */
1284 (intintargfunc)instance_slice, /* sq_slice */
1285 (intobjargproc)instance_ass_item, /* sq_ass_item */
1286 (intintobjargproc)instance_ass_slice, /* sq_ass_slice */
1287 (objobjproc)instance_contains, /* sq_contains */
Guido van Rossum04691fc1992-08-12 15:35:34 +00001288};
1289
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001290static PyObject *
Fred Drake79912472000-07-09 04:06:11 +00001291generic_unary_op(PyInstanceObject *self, PyObject *methodname)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001292{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001293 PyObject *func, *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001294
1295 if ((func = instance_getattr(self, methodname)) == NULL)
1296 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001297 res = PyEval_CallObject(func, (PyObject *)NULL);
1298 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001299 return res;
1300}
1301
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001302static PyObject *
1303generic_binary_op(PyObject *v, PyObject *w, char *opname)
Guido van Rossum03093a21994-09-28 15:51:32 +00001304{
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001305 PyObject *result;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001306 PyObject *args;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001307 PyObject *func = PyObject_GetAttrString(v, opname);
Guido van Rossume7d444f1995-01-07 12:35:18 +00001308 if (func == NULL) {
Guido van Rossum617c1b01998-05-28 19:50:02 +00001309 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001310 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001311 PyErr_Clear();
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001312 Py_INCREF(Py_NotImplemented);
1313 return Py_NotImplemented;
Guido van Rossume7d444f1995-01-07 12:35:18 +00001314 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001315 args = Py_BuildValue("(O)", w);
Guido van Rossum03093a21994-09-28 15:51:32 +00001316 if (args == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001317 Py_DECREF(func);
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001318 return NULL;
Guido van Rossum03093a21994-09-28 15:51:32 +00001319 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001320 result = PyEval_CallObject(func, args);
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001321 Py_DECREF(args);
1322 Py_DECREF(func);
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001323 return result;
1324}
1325
1326
1327static PyObject *coerce_obj;
1328
1329/* Try one half of a binary operator involving a class instance. */
1330static PyObject *
Tim Peters34592512002-07-11 06:23:50 +00001331half_binop(PyObject *v, PyObject *w, char *opname, binaryfunc thisfunc,
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001332 int swapped)
1333{
1334 PyObject *args;
1335 PyObject *coercefunc;
1336 PyObject *coerced = NULL;
1337 PyObject *v1;
1338 PyObject *result;
Tim Peters34592512002-07-11 06:23:50 +00001339
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001340 if (!PyInstance_Check(v)) {
1341 Py_INCREF(Py_NotImplemented);
1342 return Py_NotImplemented;
1343 }
1344
1345 if (coerce_obj == NULL) {
1346 coerce_obj = PyString_InternFromString("__coerce__");
1347 if (coerce_obj == NULL)
1348 return NULL;
1349 }
1350 coercefunc = PyObject_GetAttr(v, coerce_obj);
1351 if (coercefunc == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001352 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1353 return NULL;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001354 PyErr_Clear();
1355 return generic_binary_op(v, w, opname);
1356 }
1357
1358 args = Py_BuildValue("(O)", w);
1359 if (args == NULL) {
1360 return NULL;
1361 }
1362 coerced = PyEval_CallObject(coercefunc, args);
1363 Py_DECREF(args);
1364 Py_DECREF(coercefunc);
1365 if (coerced == NULL) {
1366 return NULL;
1367 }
1368 if (coerced == Py_None || coerced == Py_NotImplemented) {
1369 Py_DECREF(coerced);
1370 return generic_binary_op(v, w, opname);
1371 }
1372 if (!PyTuple_Check(coerced) || PyTuple_Size(coerced) != 2) {
1373 Py_DECREF(coerced);
1374 PyErr_SetString(PyExc_TypeError,
1375 "coercion should return None or 2-tuple");
1376 return NULL;
1377 }
1378 v1 = PyTuple_GetItem(coerced, 0);
1379 w = PyTuple_GetItem(coerced, 1);
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001380 if (v1->ob_type == v->ob_type && PyInstance_Check(v)) {
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001381 /* prevent recursion if __coerce__ returns self as the first
1382 * argument */
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001383 result = generic_binary_op(v1, w, opname);
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001384 } else {
1385 if (swapped)
1386 result = (thisfunc)(w, v1);
1387 else
1388 result = (thisfunc)(v1, w);
1389 }
1390 Py_DECREF(coerced);
1391 return result;
1392}
1393
1394/* Implement a binary operator involving at least one class instance. */
1395static PyObject *
1396do_binop(PyObject *v, PyObject *w, char *opname, char *ropname,
1397 binaryfunc thisfunc)
1398{
1399 PyObject *result = half_binop(v, w, opname, thisfunc, 0);
1400 if (result == Py_NotImplemented) {
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001401 Py_DECREF(result);
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001402 result = half_binop(w, v, ropname, thisfunc, 1);
1403 }
1404 return result;
1405}
1406
1407static PyObject *
1408do_binop_inplace(PyObject *v, PyObject *w, char *iopname, char *opname,
1409 char *ropname, binaryfunc thisfunc)
1410{
1411 PyObject *result = half_binop(v, w, iopname, thisfunc, 0);
1412 if (result == Py_NotImplemented) {
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001413 Py_DECREF(result);
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001414 result = do_binop(v, w, opname, ropname, thisfunc);
1415 }
1416 return result;
Guido van Rossum03093a21994-09-28 15:51:32 +00001417}
1418
Guido van Rossum879c5811995-01-10 15:24:06 +00001419static int
Fred Drake79912472000-07-09 04:06:11 +00001420instance_coerce(PyObject **pv, PyObject **pw)
Guido van Rossum879c5811995-01-10 15:24:06 +00001421{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001422 PyObject *v = *pv;
1423 PyObject *w = *pw;
Guido van Rossum3931df91997-11-18 19:23:07 +00001424 PyObject *coercefunc;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001425 PyObject *args;
1426 PyObject *coerced;
Guido van Rossum879c5811995-01-10 15:24:06 +00001427
Guido van Rossum2878a691996-08-09 20:53:24 +00001428 if (coerce_obj == NULL) {
Guido van Rossuma412d241997-01-18 07:59:12 +00001429 coerce_obj = PyString_InternFromString("__coerce__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001430 if (coerce_obj == NULL)
1431 return -1;
1432 }
Guido van Rossum3931df91997-11-18 19:23:07 +00001433 coercefunc = PyObject_GetAttr(v, coerce_obj);
1434 if (coercefunc == NULL) {
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001435 /* No __coerce__ method */
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001436 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1437 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001438 PyErr_Clear();
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001439 return 1;
Guido van Rossum879c5811995-01-10 15:24:06 +00001440 }
1441 /* Has __coerce__ method: call it */
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001442 args = Py_BuildValue("(O)", w);
Guido van Rossum879c5811995-01-10 15:24:06 +00001443 if (args == NULL) {
1444 return -1;
1445 }
Guido van Rossum3931df91997-11-18 19:23:07 +00001446 coerced = PyEval_CallObject(coercefunc, args);
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001447 Py_DECREF(args);
Guido van Rossum3931df91997-11-18 19:23:07 +00001448 Py_DECREF(coercefunc);
Guido van Rossum879c5811995-01-10 15:24:06 +00001449 if (coerced == NULL) {
1450 /* __coerce__ call raised an exception */
1451 return -1;
1452 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001453 if (coerced == Py_None || coerced == Py_NotImplemented) {
Guido van Rossum879c5811995-01-10 15:24:06 +00001454 /* __coerce__ says "I can't do it" */
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001455 Py_DECREF(coerced);
Guido van Rossum879c5811995-01-10 15:24:06 +00001456 return 1;
1457 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001458 if (!PyTuple_Check(coerced) || PyTuple_Size(coerced) != 2) {
Guido van Rossum879c5811995-01-10 15:24:06 +00001459 /* __coerce__ return value is malformed */
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001460 Py_DECREF(coerced);
1461 PyErr_SetString(PyExc_TypeError,
Guido van Rossum879c5811995-01-10 15:24:06 +00001462 "coercion should return None or 2-tuple");
1463 return -1;
1464 }
1465 /* __coerce__ returned two new values */
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001466 *pv = PyTuple_GetItem(coerced, 0);
1467 *pw = PyTuple_GetItem(coerced, 1);
1468 Py_INCREF(*pv);
1469 Py_INCREF(*pw);
1470 Py_DECREF(coerced);
Guido van Rossum879c5811995-01-10 15:24:06 +00001471 return 0;
1472}
1473
Guido van Rossum04691fc1992-08-12 15:35:34 +00001474#define UNARY(funcname, methodname) \
Thomas Woutersc3073522000-07-23 22:09:59 +00001475static PyObject *funcname(PyInstanceObject *self) { \
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001476 static PyObject *o; \
Guido van Rossuma412d241997-01-18 07:59:12 +00001477 if (o == NULL) o = PyString_InternFromString(methodname); \
Guido van Rossum2878a691996-08-09 20:53:24 +00001478 return generic_unary_op(self, o); \
Guido van Rossum04691fc1992-08-12 15:35:34 +00001479}
1480
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001481#define BINARY(f, m, n) \
1482static PyObject *f(PyObject *v, PyObject *w) { \
1483 return do_binop(v, w, "__" m "__", "__r" m "__", n); \
1484}
1485
1486#define BINARY_INPLACE(f, m, n) \
1487static PyObject *f(PyObject *v, PyObject *w) { \
1488 return do_binop_inplace(v, w, "__i" m "__", "__" m "__", \
1489 "__r" m "__", n); \
1490}
1491
Guido van Rossum04691fc1992-08-12 15:35:34 +00001492UNARY(instance_neg, "__neg__")
1493UNARY(instance_pos, "__pos__")
1494UNARY(instance_abs, "__abs__")
1495
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001496BINARY(instance_or, "or", PyNumber_Or)
1497BINARY(instance_and, "and", PyNumber_And)
1498BINARY(instance_xor, "xor", PyNumber_Xor)
1499BINARY(instance_lshift, "lshift", PyNumber_Lshift)
1500BINARY(instance_rshift, "rshift", PyNumber_Rshift)
1501BINARY(instance_add, "add", PyNumber_Add)
1502BINARY(instance_sub, "sub", PyNumber_Subtract)
1503BINARY(instance_mul, "mul", PyNumber_Multiply)
1504BINARY(instance_div, "div", PyNumber_Divide)
1505BINARY(instance_mod, "mod", PyNumber_Remainder)
1506BINARY(instance_divmod, "divmod", PyNumber_Divmod)
Guido van Rossum4668b002001-08-08 05:00:18 +00001507BINARY(instance_floordiv, "floordiv", PyNumber_FloorDivide)
1508BINARY(instance_truediv, "truediv", PyNumber_TrueDivide)
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001509
1510BINARY_INPLACE(instance_ior, "or", PyNumber_InPlaceOr)
1511BINARY_INPLACE(instance_ixor, "xor", PyNumber_InPlaceXor)
1512BINARY_INPLACE(instance_iand, "and", PyNumber_InPlaceAnd)
1513BINARY_INPLACE(instance_ilshift, "lshift", PyNumber_InPlaceLshift)
1514BINARY_INPLACE(instance_irshift, "rshift", PyNumber_InPlaceRshift)
1515BINARY_INPLACE(instance_iadd, "add", PyNumber_InPlaceAdd)
1516BINARY_INPLACE(instance_isub, "sub", PyNumber_InPlaceSubtract)
1517BINARY_INPLACE(instance_imul, "mul", PyNumber_InPlaceMultiply)
1518BINARY_INPLACE(instance_idiv, "div", PyNumber_InPlaceDivide)
1519BINARY_INPLACE(instance_imod, "mod", PyNumber_InPlaceRemainder)
Guido van Rossum4668b002001-08-08 05:00:18 +00001520BINARY_INPLACE(instance_ifloordiv, "floordiv", PyNumber_InPlaceFloorDivide)
1521BINARY_INPLACE(instance_itruediv, "truediv", PyNumber_InPlaceTrueDivide)
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001522
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001523/* Try a 3-way comparison, returning an int; v is an instance. Return:
1524 -2 for an exception;
1525 -1 if v < w;
1526 0 if v == w;
1527 1 if v > w;
1528 2 if this particular 3-way comparison is not implemented or undefined.
1529*/
1530static int
1531half_cmp(PyObject *v, PyObject *w)
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001532{
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001533 static PyObject *cmp_obj;
1534 PyObject *args;
Guido van Rossum3202c6f2001-01-29 23:50:25 +00001535 PyObject *cmp_func;
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001536 PyObject *result;
1537 long l;
1538
1539 assert(PyInstance_Check(v));
1540
1541 if (cmp_obj == NULL) {
1542 cmp_obj = PyString_InternFromString("__cmp__");
1543 if (cmp_obj == NULL)
1544 return -2;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001545 }
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001546
Guido van Rossum3202c6f2001-01-29 23:50:25 +00001547 cmp_func = PyObject_GetAttr(v, cmp_obj);
1548 if (cmp_func == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001549 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1550 return -2;
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001551 PyErr_Clear();
1552 return 2;
1553 }
1554
1555 args = Py_BuildValue("(O)", w);
1556 if (args == NULL)
1557 return -2;
1558
Guido van Rossum3202c6f2001-01-29 23:50:25 +00001559 result = PyEval_CallObject(cmp_func, args);
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001560 Py_DECREF(args);
Guido van Rossum3202c6f2001-01-29 23:50:25 +00001561 Py_DECREF(cmp_func);
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001562
1563 if (result == NULL)
1564 return -2;
1565
1566 if (result == Py_NotImplemented) {
1567 Py_DECREF(result);
1568 return 2;
1569 }
1570
1571 l = PyInt_AsLong(result);
1572 Py_DECREF(result);
1573 if (l == -1 && PyErr_Occurred()) {
1574 PyErr_SetString(PyExc_TypeError,
1575 "comparison did not return an int");
1576 return -2;
1577 }
1578
1579 return l < 0 ? -1 : l > 0 ? 1 : 0;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001580}
1581
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001582/* Try a 3-way comparison, returning an int; either v or w is an instance.
1583 We first try a coercion. Return:
1584 -2 for an exception;
1585 -1 if v < w;
1586 0 if v == w;
1587 1 if v > w;
1588 2 if this particular 3-way comparison is not implemented or undefined.
1589 THIS IS ONLY CALLED FROM object.c!
1590*/
1591static int
1592instance_compare(PyObject *v, PyObject *w)
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001593{
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001594 int c;
1595
1596 c = PyNumber_CoerceEx(&v, &w);
1597 if (c < 0)
1598 return -2;
1599 if (c == 0) {
1600 /* If neither is now an instance, use regular comparison */
1601 if (!PyInstance_Check(v) && !PyInstance_Check(w)) {
1602 c = PyObject_Compare(v, w);
1603 Py_DECREF(v);
1604 Py_DECREF(w);
1605 if (PyErr_Occurred())
1606 return -2;
1607 return c < 0 ? -1 : c > 0 ? 1 : 0;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001608 }
1609 }
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001610 else {
1611 /* The coercion didn't do anything.
1612 Treat this the same as returning v and w unchanged. */
1613 Py_INCREF(v);
1614 Py_INCREF(w);
1615 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001616
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001617 if (PyInstance_Check(v)) {
1618 c = half_cmp(v, w);
1619 if (c <= 1) {
1620 Py_DECREF(v);
1621 Py_DECREF(w);
1622 return c;
1623 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001624 }
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001625 if (PyInstance_Check(w)) {
1626 c = half_cmp(w, v);
1627 if (c <= 1) {
1628 Py_DECREF(v);
1629 Py_DECREF(w);
1630 if (c >= -1)
1631 c = -c;
1632 return c;
1633 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001634 }
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001635 Py_DECREF(v);
1636 Py_DECREF(w);
1637 return 2;
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001638}
1639
Guido van Rossum9bfef441993-03-29 10:43:31 +00001640static int
Fred Drake79912472000-07-09 04:06:11 +00001641instance_nonzero(PyInstanceObject *self)
Guido van Rossum04691fc1992-08-12 15:35:34 +00001642{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001643 PyObject *func, *res;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001644 long outcome;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001645 static PyObject *nonzerostr;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001646
Guido van Rossum2878a691996-08-09 20:53:24 +00001647 if (nonzerostr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001648 nonzerostr = PyString_InternFromString("__nonzero__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001649 if ((func = instance_getattr(self, nonzerostr)) == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001650 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1651 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001652 PyErr_Clear();
Guido van Rossum2878a691996-08-09 20:53:24 +00001653 if (lenstr == NULL)
Guido van Rossuma412d241997-01-18 07:59:12 +00001654 lenstr = PyString_InternFromString("__len__");
Guido van Rossum2878a691996-08-09 20:53:24 +00001655 if ((func = instance_getattr(self, lenstr)) == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001656 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1657 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001658 PyErr_Clear();
Guido van Rossum04691fc1992-08-12 15:35:34 +00001659 /* Fall back to the default behavior:
1660 all instances are nonzero */
1661 return 1;
1662 }
1663 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001664 res = PyEval_CallObject(func, (PyObject *)NULL);
1665 Py_DECREF(func);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001666 if (res == NULL)
1667 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001668 if (!PyInt_Check(res)) {
1669 Py_DECREF(res);
1670 PyErr_SetString(PyExc_TypeError,
1671 "__nonzero__ should return an int");
Guido van Rossum04691fc1992-08-12 15:35:34 +00001672 return -1;
1673 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001674 outcome = PyInt_AsLong(res);
1675 Py_DECREF(res);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001676 if (outcome < 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001677 PyErr_SetString(PyExc_ValueError,
1678 "__nonzero__ should return >= 0");
Guido van Rossum04691fc1992-08-12 15:35:34 +00001679 return -1;
1680 }
1681 return outcome > 0;
1682}
1683
1684UNARY(instance_invert, "__invert__")
Guido van Rossum1899c2e1992-09-12 11:09:23 +00001685UNARY(instance_int, "__int__")
1686UNARY(instance_long, "__long__")
1687UNARY(instance_float, "__float__")
1688UNARY(instance_oct, "__oct__")
1689UNARY(instance_hex, "__hex__")
1690
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001691static PyObject *
1692bin_power(PyObject *v, PyObject *w)
1693{
1694 return PyNumber_Power(v, w, Py_None);
1695}
1696
Guido van Rossum03093a21994-09-28 15:51:32 +00001697/* This version is for ternary calls only (z != None) */
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001698static PyObject *
Fred Drake79912472000-07-09 04:06:11 +00001699instance_pow(PyObject *v, PyObject *w, PyObject *z)
Tim Peters34592512002-07-11 06:23:50 +00001700{
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001701 if (z == Py_None) {
1702 return do_binop(v, w, "__pow__", "__rpow__", bin_power);
Guido van Rossum03093a21994-09-28 15:51:32 +00001703 }
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001704 else {
1705 PyObject *func;
1706 PyObject *args;
1707 PyObject *result;
1708
1709 /* XXX Doesn't do coercions... */
1710 func = PyObject_GetAttrString(v, "__pow__");
1711 if (func == NULL)
1712 return NULL;
1713 args = Py_BuildValue("(OO)", w, z);
1714 if (args == NULL) {
1715 Py_DECREF(func);
1716 return NULL;
1717 }
1718 result = PyEval_CallObject(func, args);
1719 Py_DECREF(func);
1720 Py_DECREF(args);
1721 return result;
1722 }
Guido van Rossum03093a21994-09-28 15:51:32 +00001723}
1724
Thomas Wouterse289e0b2000-08-24 20:08:19 +00001725static PyObject *
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001726bin_inplace_power(PyObject *v, PyObject *w)
Thomas Wouterse289e0b2000-08-24 20:08:19 +00001727{
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001728 return PyNumber_InPlacePower(v, w, Py_None);
Thomas Wouterse289e0b2000-08-24 20:08:19 +00001729}
1730
1731
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001732static PyObject *
1733instance_ipow(PyObject *v, PyObject *w, PyObject *z)
1734{
1735 if (z == Py_None) {
1736 return do_binop_inplace(v, w, "__ipow__", "__pow__",
1737 "__rpow__", bin_inplace_power);
1738 }
1739 else {
1740 /* XXX Doesn't do coercions... */
1741 PyObject *func;
1742 PyObject *args;
1743 PyObject *result;
1744
1745 func = PyObject_GetAttrString(v, "__ipow__");
1746 if (func == NULL) {
1747 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1748 return NULL;
1749 PyErr_Clear();
1750 return instance_pow(v, w, z);
1751 }
1752 args = Py_BuildValue("(OO)", w, z);
1753 if (args == NULL) {
1754 Py_DECREF(func);
1755 return NULL;
1756 }
1757 result = PyEval_CallObject(func, args);
1758 Py_DECREF(func);
1759 Py_DECREF(args);
1760 return result;
1761 }
1762}
1763
1764
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001765/* Map rich comparison operators to their __xx__ namesakes */
Jeremy Hylton1b0feb42001-05-11 14:48:41 +00001766#define NAME_OPS 6
1767static PyObject **name_op = NULL;
1768
Tim Peters34592512002-07-11 06:23:50 +00001769static int
Guido van Rossum0ba9e3a2001-05-22 02:33:08 +00001770init_name_op(void)
Jeremy Hylton1b0feb42001-05-11 14:48:41 +00001771{
1772 int i;
1773 char *_name_op[] = {
1774 "__lt__",
1775 "__le__",
1776 "__eq__",
1777 "__ne__",
1778 "__gt__",
1779 "__ge__",
1780 };
1781
1782 name_op = (PyObject **)malloc(sizeof(PyObject *) * NAME_OPS);
1783 if (name_op == NULL)
1784 return -1;
1785 for (i = 0; i < NAME_OPS; ++i) {
1786 name_op[i] = PyString_InternFromString(_name_op[i]);
1787 if (name_op[i] == NULL)
1788 return -1;
1789 }
1790 return 0;
1791}
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001792
1793static PyObject *
1794half_richcompare(PyObject *v, PyObject *w, int op)
1795{
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001796 PyObject *method;
1797 PyObject *args;
1798 PyObject *res;
1799
1800 assert(PyInstance_Check(v));
1801
Jeremy Hylton1b0feb42001-05-11 14:48:41 +00001802 if (name_op == NULL) {
1803 if (init_name_op() < 0)
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001804 return NULL;
Jeremy Hylton1b0feb42001-05-11 14:48:41 +00001805 }
1806 /* If the instance doesn't define an __getattr__ method, use
1807 instance_getattr2 directly because it will not set an
1808 exception on failure. */
1809 if (((PyInstanceObject *)v)->in_class->cl_getattr == NULL) {
Tim Peters34592512002-07-11 06:23:50 +00001810 method = instance_getattr2((PyInstanceObject *)v,
Jeremy Hylton1b0feb42001-05-11 14:48:41 +00001811 name_op[op]);
1812 if (method == NULL) {
1813 assert(!PyErr_Occurred());
1814 res = Py_NotImplemented;
1815 Py_INCREF(res);
1816 return res;
1817 }
1818 } else {
1819 method = PyObject_GetAttr(v, name_op[op]);
1820 if (method == NULL) {
1821 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1822 return NULL;
1823 PyErr_Clear();
1824 res = Py_NotImplemented;
1825 Py_INCREF(res);
1826 return res;
1827 }
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001828 }
1829
1830 args = Py_BuildValue("(O)", w);
1831 if (args == NULL) {
1832 Py_DECREF(method);
1833 return NULL;
1834 }
1835
1836 res = PyEval_CallObject(method, args);
1837 Py_DECREF(args);
1838 Py_DECREF(method);
1839
1840 return res;
1841}
1842
1843/* Map rich comparison operators to their swapped version, e.g. LT --> GT */
1844static int swapped_op[] = {Py_GT, Py_GE, Py_EQ, Py_NE, Py_LT, Py_LE};
1845
1846static PyObject *
1847instance_richcompare(PyObject *v, PyObject *w, int op)
1848{
1849 PyObject *res;
1850
1851 if (PyInstance_Check(v)) {
1852 res = half_richcompare(v, w, op);
1853 if (res != Py_NotImplemented)
1854 return res;
1855 Py_DECREF(res);
1856 }
1857
1858 if (PyInstance_Check(w)) {
1859 res = half_richcompare(w, v, swapped_op[op]);
1860 if (res != Py_NotImplemented)
1861 return res;
1862 Py_DECREF(res);
1863 }
1864
1865 Py_INCREF(Py_NotImplemented);
1866 return Py_NotImplemented;
1867}
1868
Neil Schemenauer29bfc072001-01-04 01:43:46 +00001869
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001870/* Get the iterator */
1871static PyObject *
1872instance_getiter(PyInstanceObject *self)
1873{
1874 PyObject *func;
1875
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001876 if (iterstr == NULL) {
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001877 iterstr = PyString_InternFromString("__iter__");
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001878 if (iterstr == NULL)
1879 return NULL;
1880 }
1881 if (getitemstr == NULL) {
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001882 getitemstr = PyString_InternFromString("__getitem__");
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001883 if (getitemstr == NULL)
1884 return NULL;
1885 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001886
1887 if ((func = instance_getattr(self, iterstr)) != NULL) {
1888 PyObject *res = PyEval_CallObject(func, (PyObject *)NULL);
1889 Py_DECREF(func);
Guido van Rossum213c7a62001-04-23 14:08:49 +00001890 if (res != NULL && !PyIter_Check(res)) {
1891 PyErr_Format(PyExc_TypeError,
1892 "__iter__ returned non-iterator "
1893 "of type '%.100s'",
1894 res->ob_type->tp_name);
1895 Py_DECREF(res);
1896 res = NULL;
1897 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001898 return res;
1899 }
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001900 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1901 return NULL;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001902 PyErr_Clear();
1903 if ((func = instance_getattr(self, getitemstr)) == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001904 PyErr_SetString(PyExc_TypeError,
1905 "iteration over non-sequence");
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001906 return NULL;
1907 }
1908 Py_DECREF(func);
Guido van Rossum213c7a62001-04-23 14:08:49 +00001909 return PySeqIter_New((PyObject *)self);
1910}
1911
1912
1913/* Call the iterator's next */
1914static PyObject *
1915instance_iternext(PyInstanceObject *self)
1916{
1917 PyObject *func;
1918
1919 if (nextstr == NULL)
1920 nextstr = PyString_InternFromString("next");
1921
1922 if ((func = instance_getattr(self, nextstr)) != NULL) {
1923 PyObject *res = PyEval_CallObject(func, (PyObject *)NULL);
1924 Py_DECREF(func);
1925 if (res != NULL) {
1926 return res;
1927 }
1928 if (PyErr_ExceptionMatches(PyExc_StopIteration)) {
1929 PyErr_Clear();
1930 return NULL;
1931 }
1932 return NULL;
1933 }
1934 PyErr_SetString(PyExc_TypeError, "instance has no next() method");
1935 return NULL;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001936}
1937
Tim Peters6d6c1a32001-08-02 04:15:00 +00001938static PyObject *
1939instance_call(PyObject *func, PyObject *arg, PyObject *kw)
1940{
Guido van Rossum16b93b32002-06-13 21:32:51 +00001941 PyThreadState *tstate = PyThreadState_GET();
Tim Peters6d6c1a32001-08-02 04:15:00 +00001942 PyObject *res, *call = PyObject_GetAttrString(func, "__call__");
1943 if (call == NULL) {
1944 PyInstanceObject *inst = (PyInstanceObject*) func;
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00001945 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
1946 return NULL;
Tim Peters6d6c1a32001-08-02 04:15:00 +00001947 PyErr_Clear();
1948 PyErr_Format(PyExc_AttributeError,
1949 "%.200s instance has no __call__ method",
1950 PyString_AsString(inst->in_class->cl_name));
1951 return NULL;
1952 }
Guido van Rossum16b93b32002-06-13 21:32:51 +00001953 /* We must check and increment the recursion depth here. Scenario:
1954 class A:
1955 pass
1956 A.__call__ = A() # that's right
1957 a = A() # ok
1958 a() # infinite recursion
1959 This bounces between instance_call() and PyObject_Call() without
1960 ever hitting eval_frame() (which has the main recursion check). */
1961 if (tstate->recursion_depth++ > Py_GetRecursionLimit()) {
1962 PyErr_SetString(PyExc_RuntimeError,
1963 "maximum __call__ recursion depth exceeded");
1964 res = NULL;
1965 }
1966 else
1967 res = PyObject_Call(call, arg, kw);
1968 tstate->recursion_depth--;
Tim Peters6d6c1a32001-08-02 04:15:00 +00001969 Py_DECREF(call);
1970 return res;
1971}
1972
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001973
Guido van Rossumc0b618a1997-05-02 03:12:38 +00001974static PyNumberMethods instance_as_number = {
Guido van Rossum8998b4f2001-01-17 15:28:20 +00001975 (binaryfunc)instance_add, /* nb_add */
1976 (binaryfunc)instance_sub, /* nb_subtract */
1977 (binaryfunc)instance_mul, /* nb_multiply */
1978 (binaryfunc)instance_div, /* nb_divide */
1979 (binaryfunc)instance_mod, /* nb_remainder */
1980 (binaryfunc)instance_divmod, /* nb_divmod */
1981 (ternaryfunc)instance_pow, /* nb_power */
1982 (unaryfunc)instance_neg, /* nb_negative */
1983 (unaryfunc)instance_pos, /* nb_positive */
1984 (unaryfunc)instance_abs, /* nb_absolute */
1985 (inquiry)instance_nonzero, /* nb_nonzero */
1986 (unaryfunc)instance_invert, /* nb_invert */
1987 (binaryfunc)instance_lshift, /* nb_lshift */
1988 (binaryfunc)instance_rshift, /* nb_rshift */
1989 (binaryfunc)instance_and, /* nb_and */
1990 (binaryfunc)instance_xor, /* nb_xor */
1991 (binaryfunc)instance_or, /* nb_or */
1992 (coercion)instance_coerce, /* nb_coerce */
1993 (unaryfunc)instance_int, /* nb_int */
1994 (unaryfunc)instance_long, /* nb_long */
1995 (unaryfunc)instance_float, /* nb_float */
1996 (unaryfunc)instance_oct, /* nb_oct */
1997 (unaryfunc)instance_hex, /* nb_hex */
1998 (binaryfunc)instance_iadd, /* nb_inplace_add */
1999 (binaryfunc)instance_isub, /* nb_inplace_subtract */
2000 (binaryfunc)instance_imul, /* nb_inplace_multiply */
2001 (binaryfunc)instance_idiv, /* nb_inplace_divide */
2002 (binaryfunc)instance_imod, /* nb_inplace_remainder */
2003 (ternaryfunc)instance_ipow, /* nb_inplace_power */
2004 (binaryfunc)instance_ilshift, /* nb_inplace_lshift */
2005 (binaryfunc)instance_irshift, /* nb_inplace_rshift */
2006 (binaryfunc)instance_iand, /* nb_inplace_and */
2007 (binaryfunc)instance_ixor, /* nb_inplace_xor */
2008 (binaryfunc)instance_ior, /* nb_inplace_or */
Guido van Rossum4668b002001-08-08 05:00:18 +00002009 (binaryfunc)instance_floordiv, /* nb_floor_divide */
2010 (binaryfunc)instance_truediv, /* nb_true_divide */
2011 (binaryfunc)instance_ifloordiv, /* nb_inplace_floor_divide */
2012 (binaryfunc)instance_itruediv, /* nb_inplace_true_divide */
Guido van Rossum04691fc1992-08-12 15:35:34 +00002013};
2014
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002015PyTypeObject PyInstance_Type = {
2016 PyObject_HEAD_INIT(&PyType_Type)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002017 0,
Guido van Rossum21ed88c1991-04-04 10:42:10 +00002018 "instance",
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002019 sizeof(PyInstanceObject),
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002020 0,
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002021 (destructor)instance_dealloc, /* tp_dealloc */
2022 0, /* tp_print */
2023 0, /* tp_getattr */
2024 0, /* tp_setattr */
2025 instance_compare, /* tp_compare */
2026 (reprfunc)instance_repr, /* tp_repr */
2027 &instance_as_number, /* tp_as_number */
2028 &instance_as_sequence, /* tp_as_sequence */
2029 &instance_as_mapping, /* tp_as_mapping */
2030 (hashfunc)instance_hash, /* tp_hash */
Tim Peters6d6c1a32001-08-02 04:15:00 +00002031 instance_call, /* tp_call */
Guido van Rossum82c690f2001-04-30 14:39:18 +00002032 (reprfunc)instance_str, /* tp_str */
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002033 (getattrofunc)instance_getattr, /* tp_getattro */
2034 (setattrofunc)instance_setattr, /* tp_setattro */
2035 0, /* tp_as_buffer */
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002036 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | Py_TPFLAGS_CHECKTYPES,/*tp_flags*/
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002037 instance_doc, /* tp_doc */
Jeremy Hylton8caad492000-06-23 14:18:11 +00002038 (traverseproc)instance_traverse, /* tp_traverse */
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002039 0, /* tp_clear */
2040 instance_richcompare, /* tp_richcompare */
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00002041 offsetof(PyInstanceObject, in_weakreflist), /* tp_weaklistoffset */
2042 (getiterfunc)instance_getiter, /* tp_iter */
Guido van Rossum213c7a62001-04-23 14:08:49 +00002043 (iternextfunc)instance_iternext, /* tp_iternext */
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002044 0, /* tp_methods */
2045 0, /* tp_members */
2046 0, /* tp_getset */
2047 0, /* tp_base */
2048 0, /* tp_dict */
2049 0, /* tp_descr_get */
2050 0, /* tp_descr_set */
2051 0, /* tp_dictoffset */
2052 0, /* tp_init */
2053 0, /* tp_alloc */
2054 instance_new, /* tp_new */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002055};
2056
2057
Guido van Rossum81daa321993-05-20 14:24:46 +00002058/* Instance method objects are used for two purposes:
2059 (a) as bound instance methods (returned by instancename.methodname)
2060 (b) as unbound methods (returned by ClassName.methodname)
2061 In case (b), im_self is NULL
2062*/
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002063
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002064static PyMethodObject *free_list;
2065
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002066PyObject *
Fred Drake79912472000-07-09 04:06:11 +00002067PyMethod_New(PyObject *func, PyObject *self, PyObject *class)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002068{
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002069 register PyMethodObject *im;
Guido van Rossum7859f871998-07-08 14:58:16 +00002070 if (!PyCallable_Check(func)) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002071 PyErr_BadInternalCall();
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002072 return NULL;
2073 }
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002074 im = free_list;
2075 if (im != NULL) {
2076 free_list = (PyMethodObject *)(im->im_self);
Guido van Rossumb18618d2000-05-03 23:44:39 +00002077 PyObject_INIT(im, &PyMethod_Type);
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002078 }
2079 else {
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002080 im = PyObject_GC_New(PyMethodObject, &PyMethod_Type);
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002081 if (im == NULL)
2082 return NULL;
2083 }
Fred Drakedb81e8d2001-03-23 04:19:27 +00002084 im->im_weakreflist = NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002085 Py_INCREF(func);
Guido van Rossume8122f11991-05-05 20:03:07 +00002086 im->im_func = func;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002087 Py_XINCREF(self);
Guido van Rossume8122f11991-05-05 20:03:07 +00002088 im->im_self = self;
Guido van Rossumcdf0d752001-08-17 12:07:34 +00002089 Py_XINCREF(class);
Guido van Rossum81daa321993-05-20 14:24:46 +00002090 im->im_class = class;
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002091 _PyObject_GC_TRACK(im);
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002092 return (PyObject *)im;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002093}
2094
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002095/* Descriptors for PyMethod attributes */
2096
2097/* im_class, im_func and im_self are stored in the PyMethod object */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002098
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002099#define OFF(x) offsetof(PyMethodObject, x)
Guido van Rossum3f5da241990-12-20 15:06:42 +00002100
Guido van Rossum6f799372001-09-20 20:46:19 +00002101static PyMemberDef instancemethod_memberlist[] = {
2102 {"im_class", T_OBJECT, OFF(im_class), READONLY|RESTRICTED,
2103 "the class associated with a method"},
2104 {"im_func", T_OBJECT, OFF(im_func), READONLY|RESTRICTED,
2105 "the function (or other callable) implementing a method"},
2106 {"im_self", T_OBJECT, OFF(im_self), READONLY|RESTRICTED,
2107 "the instance to which a method is bound; None for unbound methods"},
Guido van Rossum3f5da241990-12-20 15:06:42 +00002108 {NULL} /* Sentinel */
2109};
2110
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002111/* The getattr() implementation for PyMethod objects is similar to
2112 PyObject_GenericGetAttr(), but instead of looking in __dict__ it
2113 asks im_self for the attribute. Then the error handling is a bit
2114 different because we want to preserve the exception raised by the
2115 delegate, unless we have an alternative from our class. */
2116
2117static PyObject *
2118instancemethod_getattro(PyObject *obj, PyObject *name)
2119{
2120 PyMethodObject *im = (PyMethodObject *)obj;
2121 PyTypeObject *tp = obj->ob_type;
Guido van Rossum915f0eb2001-10-17 20:26:38 +00002122 PyObject *descr = NULL, *res;
2123 descrgetfunc f = NULL;
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002124
Guido van Rossum915f0eb2001-10-17 20:26:38 +00002125 if (PyType_HasFeature(tp, Py_TPFLAGS_HAVE_CLASS)) {
2126 if (tp->tp_dict == NULL) {
2127 if (PyType_Ready(tp) < 0)
2128 return NULL;
2129 }
2130 descr = _PyType_Lookup(tp, name);
Barry Warsawd6a9e842001-01-15 20:40:19 +00002131 }
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002132
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002133 f = NULL;
2134 if (descr != NULL) {
Guido van Rossum915f0eb2001-10-17 20:26:38 +00002135 f = TP_DESCR_GET(descr->ob_type);
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002136 if (f != NULL && PyDescr_IsData(descr))
2137 return f(descr, obj, (PyObject *)obj->ob_type);
2138 }
2139
2140 res = PyObject_GetAttr(im->im_func, name);
2141 if (res != NULL || !PyErr_ExceptionMatches(PyExc_AttributeError))
2142 return res;
2143
2144 if (f != NULL) {
2145 PyErr_Clear();
2146 return f(descr, obj, (PyObject *)obj->ob_type);
2147 }
2148
2149 if (descr != NULL) {
2150 PyErr_Clear();
2151 Py_INCREF(descr);
2152 return descr;
2153 }
2154
2155 assert(PyErr_Occurred());
2156 return NULL;
Guido van Rossum3f5da241990-12-20 15:06:42 +00002157}
2158
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002159PyDoc_STRVAR(instancemethod_doc,
2160"instancemethod(function, instance, class)\n\
2161\n\
2162Create an instance method object.");
2163
2164static PyObject *
2165instancemethod_new(PyTypeObject* type, PyObject* args, PyObject *kw)
2166{
2167 PyObject *func;
2168 PyObject *self;
2169 PyObject *classObj;
2170
2171 if (!PyArg_ParseTuple(args, "OOO:instancemethod",
2172 &func, &self, &classObj))
2173 return NULL;
2174 if (!PyCallable_Check(func)) {
2175 PyErr_SetString(PyExc_TypeError,
2176 "first argument must be callable");
2177 return NULL;
2178 }
2179 if (self == Py_None)
2180 self = NULL;
2181 return PyMethod_New(func, self, classObj);
2182}
2183
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002184static void
Fred Drake79912472000-07-09 04:06:11 +00002185instancemethod_dealloc(register PyMethodObject *im)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002186{
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002187 _PyObject_GC_UNTRACK(im);
Fred Drakec916f5a2001-10-26 17:56:51 +00002188 if (im->im_weakreflist != NULL)
2189 PyObject_ClearWeakRefs((PyObject *)im);
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002190 Py_DECREF(im->im_func);
2191 Py_XDECREF(im->im_self);
Guido van Rossumcdf0d752001-08-17 12:07:34 +00002192 Py_XDECREF(im->im_class);
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002193 im->im_self = (PyObject *)free_list;
2194 free_list = im;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002195}
2196
Guido van Rossumebc8c511992-09-03 20:39:51 +00002197static int
Fred Drake79912472000-07-09 04:06:11 +00002198instancemethod_compare(PyMethodObject *a, PyMethodObject *b)
Guido van Rossumebc8c511992-09-03 20:39:51 +00002199{
Guido van Rossume9df7271995-04-06 14:46:51 +00002200 if (a->im_self != b->im_self)
2201 return (a->im_self < b->im_self) ? -1 : 1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002202 return PyObject_Compare(a->im_func, b->im_func);
Guido van Rossumebc8c511992-09-03 20:39:51 +00002203}
2204
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002205static PyObject *
Fred Drake79912472000-07-09 04:06:11 +00002206instancemethod_repr(PyMethodObject *a)
Guido van Rossum25831651993-05-19 14:50:45 +00002207{
Tim Peters6d6c1a32001-08-02 04:15:00 +00002208 PyObject *self = a->im_self;
Guido van Rossum7859f871998-07-08 14:58:16 +00002209 PyObject *func = a->im_func;
Tim Peters6d6c1a32001-08-02 04:15:00 +00002210 PyObject *klass = a->im_class;
2211 PyObject *funcname = NULL, *klassname = NULL, *result = NULL;
2212 char *sfuncname = "?", *sklassname = "?";
2213
2214 funcname = PyObject_GetAttrString(func, "__name__");
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002215 if (funcname == NULL) {
2216 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
2217 return NULL;
Tim Peters6d6c1a32001-08-02 04:15:00 +00002218 PyErr_Clear();
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002219 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00002220 else if (!PyString_Check(funcname)) {
2221 Py_DECREF(funcname);
2222 funcname = NULL;
Guido van Rossum7859f871998-07-08 14:58:16 +00002223 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00002224 else
2225 sfuncname = PyString_AS_STRING(funcname);
Guido van Rossum40667692001-08-17 13:59:27 +00002226 if (klass == NULL)
Tim Peters6d6c1a32001-08-02 04:15:00 +00002227 klassname = NULL;
Guido van Rossum40667692001-08-17 13:59:27 +00002228 else {
2229 klassname = PyObject_GetAttrString(klass, "__name__");
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002230 if (klassname == NULL) {
2231 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
2232 return NULL;
Guido van Rossum40667692001-08-17 13:59:27 +00002233 PyErr_Clear();
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002234 }
Guido van Rossum40667692001-08-17 13:59:27 +00002235 else if (!PyString_Check(klassname)) {
2236 Py_DECREF(klassname);
2237 klassname = NULL;
2238 }
2239 else
2240 sklassname = PyString_AS_STRING(klassname);
Guido van Rossum7859f871998-07-08 14:58:16 +00002241 }
Guido van Rossum81daa321993-05-20 14:24:46 +00002242 if (self == NULL)
Barry Warsaw7ce36942001-08-24 18:34:26 +00002243 result = PyString_FromFormat("<unbound method %s.%s>",
2244 sklassname, sfuncname);
Guido van Rossum81daa321993-05-20 14:24:46 +00002245 else {
Tim Peters6d6c1a32001-08-02 04:15:00 +00002246 /* XXX Shouldn't use repr() here! */
2247 PyObject *selfrepr = PyObject_Repr(self);
2248 if (selfrepr == NULL)
2249 goto fail;
2250 if (!PyString_Check(selfrepr)) {
2251 Py_DECREF(selfrepr);
2252 goto fail;
2253 }
Barry Warsaw7ce36942001-08-24 18:34:26 +00002254 result = PyString_FromFormat("<bound method %s.%s of %s>",
2255 sklassname, sfuncname,
2256 PyString_AS_STRING(selfrepr));
Tim Peters6d6c1a32001-08-02 04:15:00 +00002257 Py_DECREF(selfrepr);
Guido van Rossum81daa321993-05-20 14:24:46 +00002258 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00002259 fail:
Guido van Rossum42636dc1999-10-11 14:03:12 +00002260 Py_XDECREF(funcname);
Tim Peters6d6c1a32001-08-02 04:15:00 +00002261 Py_XDECREF(klassname);
2262 return result;
Guido van Rossum25831651993-05-19 14:50:45 +00002263}
2264
Guido van Rossum9bfef441993-03-29 10:43:31 +00002265static long
Fred Drake79912472000-07-09 04:06:11 +00002266instancemethod_hash(PyMethodObject *a)
Guido van Rossum9bfef441993-03-29 10:43:31 +00002267{
2268 long x, y;
Guido van Rossum81daa321993-05-20 14:24:46 +00002269 if (a->im_self == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002270 x = PyObject_Hash(Py_None);
Guido van Rossum81daa321993-05-20 14:24:46 +00002271 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002272 x = PyObject_Hash(a->im_self);
Guido van Rossum9bfef441993-03-29 10:43:31 +00002273 if (x == -1)
2274 return -1;
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002275 y = PyObject_Hash(a->im_func);
Guido van Rossum9bfef441993-03-29 10:43:31 +00002276 if (y == -1)
2277 return -1;
2278 return x ^ y;
2279}
2280
Jeremy Hylton8caad492000-06-23 14:18:11 +00002281static int
2282instancemethod_traverse(PyMethodObject *im, visitproc visit, void *arg)
2283{
2284 int err;
2285 if (im->im_func) {
2286 err = visit(im->im_func, arg);
2287 if (err)
2288 return err;
2289 }
2290 if (im->im_self) {
2291 err = visit(im->im_self, arg);
2292 if (err)
2293 return err;
2294 }
2295 if (im->im_class) {
2296 err = visit(im->im_class, arg);
2297 if (err)
2298 return err;
2299 }
Jeremy Hyltond22162b2000-06-23 17:14:56 +00002300 return 0;
Jeremy Hylton8caad492000-06-23 14:18:11 +00002301}
2302
Guido van Rossuma15dece2001-08-24 18:48:27 +00002303static char *
2304getclassname(PyObject *class)
2305{
2306 PyObject *name;
2307
2308 if (class == NULL)
2309 name = NULL;
2310 else
2311 name = PyObject_GetAttrString(class, "__name__");
2312 if (name == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002313 /* This function cannot return an exception */
Guido van Rossuma15dece2001-08-24 18:48:27 +00002314 PyErr_Clear();
2315 return "?";
2316 }
2317 if (!PyString_Check(name)) {
2318 Py_DECREF(name);
2319 return "?";
2320 }
2321 PyString_InternInPlace(&name);
2322 Py_DECREF(name);
2323 return PyString_AS_STRING(name);
2324}
2325
2326static char *
2327getinstclassname(PyObject *inst)
2328{
2329 PyObject *class;
2330 char *name;
2331
2332 if (inst == NULL)
2333 return "nothing";
2334
2335 class = PyObject_GetAttrString(inst, "__class__");
2336 if (class == NULL) {
Guido van Rossume7b8ecf2002-06-13 21:42:04 +00002337 /* This function cannot return an exception */
Guido van Rossuma15dece2001-08-24 18:48:27 +00002338 PyErr_Clear();
2339 class = (PyObject *)(inst->ob_type);
2340 Py_INCREF(class);
2341 }
2342 name = getclassname(class);
2343 Py_XDECREF(class);
2344 return name;
2345}
2346
Tim Peters6d6c1a32001-08-02 04:15:00 +00002347static PyObject *
2348instancemethod_call(PyObject *func, PyObject *arg, PyObject *kw)
2349{
2350 PyObject *self = PyMethod_GET_SELF(func);
2351 PyObject *class = PyMethod_GET_CLASS(func);
2352 PyObject *result;
2353
2354 func = PyMethod_GET_FUNCTION(func);
2355 if (self == NULL) {
2356 /* Unbound methods must be called with an instance of
2357 the class (or a derived class) as first argument */
2358 int ok;
2359 if (PyTuple_Size(arg) >= 1)
2360 self = PyTuple_GET_ITEM(arg, 0);
2361 if (self == NULL)
2362 ok = 0;
2363 else {
2364 ok = PyObject_IsInstance(self, class);
2365 if (ok < 0)
2366 return NULL;
2367 }
2368 if (!ok) {
2369 PyErr_Format(PyExc_TypeError,
Guido van Rossuma15dece2001-08-24 18:48:27 +00002370 "unbound method %s%s must be called with "
2371 "%s instance as first argument "
2372 "(got %s%s instead)",
Tim Peters6d6c1a32001-08-02 04:15:00 +00002373 PyEval_GetFuncName(func),
Guido van Rossuma15dece2001-08-24 18:48:27 +00002374 PyEval_GetFuncDesc(func),
2375 getclassname(class),
2376 getinstclassname(self),
2377 self == NULL ? "" : " instance");
Tim Peters6d6c1a32001-08-02 04:15:00 +00002378 return NULL;
2379 }
2380 Py_INCREF(arg);
2381 }
2382 else {
2383 int argcount = PyTuple_Size(arg);
2384 PyObject *newarg = PyTuple_New(argcount + 1);
2385 int i;
2386 if (newarg == NULL)
2387 return NULL;
2388 Py_INCREF(self);
2389 PyTuple_SET_ITEM(newarg, 0, self);
2390 for (i = 0; i < argcount; i++) {
2391 PyObject *v = PyTuple_GET_ITEM(arg, i);
2392 Py_XINCREF(v);
2393 PyTuple_SET_ITEM(newarg, i+1, v);
2394 }
2395 arg = newarg;
2396 }
2397 result = PyObject_Call((PyObject *)func, arg, kw);
2398 Py_DECREF(arg);
2399 return result;
2400}
2401
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002402static PyObject *
Guido van Rossumf23c41d2001-08-17 13:43:27 +00002403instancemethod_descr_get(PyObject *meth, PyObject *obj, PyObject *class)
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002404{
Guido van Rossumf23c41d2001-08-17 13:43:27 +00002405 /* Don't rebind an already bound method, or an unbound method
2406 of a class that's not a base class of class */
2407 if (PyMethod_GET_SELF(meth) != NULL ||
2408 (PyMethod_GET_CLASS(meth) != NULL &&
2409 !PyObject_IsSubclass(class, PyMethod_GET_CLASS(meth)))) {
Guido van Rossum501c7c72001-08-16 20:41:56 +00002410 Py_INCREF(meth);
2411 return meth;
2412 }
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002413 if (obj == Py_None)
2414 obj = NULL;
Guido van Rossumf23c41d2001-08-17 13:43:27 +00002415 return PyMethod_New(PyMethod_GET_FUNCTION(meth), obj, class);
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002416}
2417
Guido van Rossumc0b618a1997-05-02 03:12:38 +00002418PyTypeObject PyMethod_Type = {
2419 PyObject_HEAD_INIT(&PyType_Type)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002420 0,
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002421 "instancemethod",
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002422 sizeof(PyMethodObject),
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002423 0,
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002424 (destructor)instancemethod_dealloc, /* tp_dealloc */
2425 0, /* tp_print */
2426 0, /* tp_getattr */
2427 0, /* tp_setattr */
2428 (cmpfunc)instancemethod_compare, /* tp_compare */
2429 (reprfunc)instancemethod_repr, /* tp_repr */
2430 0, /* tp_as_number */
2431 0, /* tp_as_sequence */
2432 0, /* tp_as_mapping */
2433 (hashfunc)instancemethod_hash, /* tp_hash */
Tim Peters6d6c1a32001-08-02 04:15:00 +00002434 instancemethod_call, /* tp_call */
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002435 0, /* tp_str */
2436 (getattrofunc)instancemethod_getattro, /* tp_getattro */
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002437 PyObject_GenericSetAttr, /* tp_setattro */
Guido van Rossum8998b4f2001-01-17 15:28:20 +00002438 0, /* tp_as_buffer */
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002439 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC,/* tp_flags */
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002440 instancemethod_doc, /* tp_doc */
Jeremy Hylton8caad492000-06-23 14:18:11 +00002441 (traverseproc)instancemethod_traverse, /* tp_traverse */
Fred Drakedb81e8d2001-03-23 04:19:27 +00002442 0, /* tp_clear */
2443 0, /* tp_richcompare */
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002444 offsetof(PyMethodObject, im_weakreflist), /* tp_weaklistoffset */
2445 0, /* tp_iter */
2446 0, /* tp_iternext */
2447 0, /* tp_methods */
Guido van Rossumf0b35e12001-09-18 03:53:24 +00002448 instancemethod_memberlist, /* tp_members */
Guido van Rossum56ff3872001-10-22 02:00:09 +00002449 0, /* tp_getset */
Guido van Rossum23cc2b42001-08-15 17:52:31 +00002450 0, /* tp_base */
2451 0, /* tp_dict */
2452 instancemethod_descr_get, /* tp_descr_get */
2453 0, /* tp_descr_set */
2454 0, /* tp_dictoffset */
Guido van Rossumbea18cc2002-06-14 20:41:17 +00002455 0, /* tp_init */
2456 0, /* tp_alloc */
2457 instancemethod_new, /* tp_new */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002458};
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002459
2460/* Clear out the free list */
2461
2462void
Fred Drake79912472000-07-09 04:06:11 +00002463PyMethod_Fini(void)
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002464{
2465 while (free_list) {
Guido van Rossumb18618d2000-05-03 23:44:39 +00002466 PyMethodObject *im = free_list;
2467 free_list = (PyMethodObject *)(im->im_self);
Neil Schemenauere83c00e2001-08-29 23:54:21 +00002468 PyObject_GC_Del(im);
Guido van Rossuma0d349f1997-08-05 02:06:53 +00002469 }
2470}