1 | /* Cell object implementation */
|
---|
2 |
|
---|
3 | #include "Python.h"
|
---|
4 |
|
---|
5 | PyObject *
|
---|
6 | PyCell_New(PyObject *obj)
|
---|
7 | {
|
---|
8 | PyCellObject *op;
|
---|
9 |
|
---|
10 | op = (PyCellObject *)PyObject_GC_New(PyCellObject, &PyCell_Type);
|
---|
11 | if (op == NULL)
|
---|
12 | return NULL;
|
---|
13 | op->ob_ref = obj;
|
---|
14 | Py_XINCREF(obj);
|
---|
15 |
|
---|
16 | _PyObject_GC_TRACK(op);
|
---|
17 | return (PyObject *)op;
|
---|
18 | }
|
---|
19 |
|
---|
20 | PyObject *
|
---|
21 | PyCell_Get(PyObject *op)
|
---|
22 | {
|
---|
23 | if (!PyCell_Check(op)) {
|
---|
24 | PyErr_BadInternalCall();
|
---|
25 | return NULL;
|
---|
26 | }
|
---|
27 | Py_XINCREF(((PyCellObject*)op)->ob_ref);
|
---|
28 | return PyCell_GET(op);
|
---|
29 | }
|
---|
30 |
|
---|
31 | int
|
---|
32 | PyCell_Set(PyObject *op, PyObject *obj)
|
---|
33 | {
|
---|
34 | if (!PyCell_Check(op)) {
|
---|
35 | PyErr_BadInternalCall();
|
---|
36 | return -1;
|
---|
37 | }
|
---|
38 | Py_XDECREF(((PyCellObject*)op)->ob_ref);
|
---|
39 | Py_XINCREF(obj);
|
---|
40 | PyCell_SET(op, obj);
|
---|
41 | return 0;
|
---|
42 | }
|
---|
43 |
|
---|
44 | static void
|
---|
45 | cell_dealloc(PyCellObject *op)
|
---|
46 | {
|
---|
47 | _PyObject_GC_UNTRACK(op);
|
---|
48 | Py_XDECREF(op->ob_ref);
|
---|
49 | PyObject_GC_Del(op);
|
---|
50 | }
|
---|
51 |
|
---|
52 | static int
|
---|
53 | cell_compare(PyCellObject *a, PyCellObject *b)
|
---|
54 | {
|
---|
55 | if (a->ob_ref == NULL) {
|
---|
56 | if (b->ob_ref == NULL)
|
---|
57 | return 0;
|
---|
58 | return -1;
|
---|
59 | } else if (b->ob_ref == NULL)
|
---|
60 | return 1;
|
---|
61 | return PyObject_Compare(a->ob_ref, b->ob_ref);
|
---|
62 | }
|
---|
63 |
|
---|
64 | static PyObject *
|
---|
65 | cell_repr(PyCellObject *op)
|
---|
66 | {
|
---|
67 | if (op->ob_ref == NULL)
|
---|
68 | return PyString_FromFormat("<cell at %p: empty>", op);
|
---|
69 |
|
---|
70 | return PyString_FromFormat("<cell at %p: %.80s object at %p>",
|
---|
71 | op, op->ob_ref->ob_type->tp_name,
|
---|
72 | op->ob_ref);
|
---|
73 | }
|
---|
74 |
|
---|
75 | static int
|
---|
76 | cell_traverse(PyCellObject *op, visitproc visit, void *arg)
|
---|
77 | {
|
---|
78 | Py_VISIT(op->ob_ref);
|
---|
79 | return 0;
|
---|
80 | }
|
---|
81 |
|
---|
82 | static int
|
---|
83 | cell_clear(PyCellObject *op)
|
---|
84 | {
|
---|
85 | Py_CLEAR(op->ob_ref);
|
---|
86 | return 0;
|
---|
87 | }
|
---|
88 |
|
---|
89 | static PyObject *
|
---|
90 | cell_get_contents(PyCellObject *op, void *closure)
|
---|
91 | {
|
---|
92 | Py_XINCREF(op->ob_ref);
|
---|
93 | return op->ob_ref;
|
---|
94 | }
|
---|
95 |
|
---|
96 | static PyGetSetDef cell_getsetlist[] = {
|
---|
97 | {"cell_contents", (getter)cell_get_contents, NULL},
|
---|
98 | {NULL} /* sentinel */
|
---|
99 | };
|
---|
100 |
|
---|
101 | PyTypeObject PyCell_Type = {
|
---|
102 | PyObject_HEAD_INIT(&PyType_Type)
|
---|
103 | 0,
|
---|
104 | "cell",
|
---|
105 | sizeof(PyCellObject),
|
---|
106 | 0,
|
---|
107 | (destructor)cell_dealloc, /* tp_dealloc */
|
---|
108 | 0, /* tp_print */
|
---|
109 | 0, /* tp_getattr */
|
---|
110 | 0, /* tp_setattr */
|
---|
111 | (cmpfunc)cell_compare, /* tp_compare */
|
---|
112 | (reprfunc)cell_repr, /* tp_repr */
|
---|
113 | 0, /* tp_as_number */
|
---|
114 | 0, /* tp_as_sequence */
|
---|
115 | 0, /* tp_as_mapping */
|
---|
116 | 0, /* tp_hash */
|
---|
117 | 0, /* tp_call */
|
---|
118 | 0, /* tp_str */
|
---|
119 | PyObject_GenericGetAttr, /* tp_getattro */
|
---|
120 | 0, /* tp_setattro */
|
---|
121 | 0, /* tp_as_buffer */
|
---|
122 | Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC,/* tp_flags */
|
---|
123 | 0, /* tp_doc */
|
---|
124 | (traverseproc)cell_traverse, /* tp_traverse */
|
---|
125 | (inquiry)cell_clear, /* tp_clear */
|
---|
126 | 0, /* tp_richcompare */
|
---|
127 | 0, /* tp_weaklistoffset */
|
---|
128 | 0, /* tp_iter */
|
---|
129 | 0, /* tp_iternext */
|
---|
130 | 0, /* tp_methods */
|
---|
131 | 0, /* tp_members */
|
---|
132 | cell_getsetlist, /* tp_getset */
|
---|
133 | };
|
---|