blob: 18914d8f50561ae4c16d4e29a0a3278c6e008a25 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002/* Module object implementation */
3
Guido van Rossumc0b618a1997-05-02 03:12:38 +00004#include "Python.h"
Tim Peters6d6c1a32001-08-02 04:15:00 +00005#include "structmember.h"
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00006
7typedef struct {
Guido van Rossumc0b618a1997-05-02 03:12:38 +00008 PyObject_HEAD
9 PyObject *md_dict;
10} PyModuleObject;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000011
Neil Schemenauerf23473f2001-10-21 22:28:58 +000012static PyMemberDef module_members[] = {
Tim Peters6d6c1a32001-08-02 04:15:00 +000013 {"__dict__", T_OBJECT, offsetof(PyModuleObject, md_dict), READONLY},
14 {0}
15};
16
Guido van Rossumc0b618a1997-05-02 03:12:38 +000017PyObject *
Jeremy Hyltonaf68c872005-12-10 18:50:16 +000018PyModule_New(const char *name)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000019{
Guido van Rossumc0b618a1997-05-02 03:12:38 +000020 PyModuleObject *m;
21 PyObject *nameobj;
Neil Schemenauere83c00e2001-08-29 23:54:21 +000022 m = PyObject_GC_New(PyModuleObject, &PyModule_Type);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000023 if (m == NULL)
24 return NULL;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000025 nameobj = PyString_FromString(name);
26 m->md_dict = PyDict_New();
Guido van Rossumc45611d1993-11-17 22:58:56 +000027 if (m->md_dict == NULL || nameobj == NULL)
28 goto fail;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000029 if (PyDict_SetItemString(m->md_dict, "__name__", nameobj) != 0)
Guido van Rossumc45611d1993-11-17 22:58:56 +000030 goto fail;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000031 if (PyDict_SetItemString(m->md_dict, "__doc__", Py_None) != 0)
Guido van Rossum8b14b4c1995-01-07 11:59:29 +000032 goto fail;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000033 Py_DECREF(nameobj);
Neil Schemenauere83c00e2001-08-29 23:54:21 +000034 PyObject_GC_Track(m);
Guido van Rossumc0b618a1997-05-02 03:12:38 +000035 return (PyObject *)m;
Guido van Rossumc45611d1993-11-17 22:58:56 +000036
37 fail:
Guido van Rossumc0b618a1997-05-02 03:12:38 +000038 Py_XDECREF(nameobj);
39 Py_DECREF(m);
Guido van Rossumc45611d1993-11-17 22:58:56 +000040 return NULL;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000041}
42
Guido van Rossumc0b618a1997-05-02 03:12:38 +000043PyObject *
Fred Drakeee238b92000-07-09 06:03:25 +000044PyModule_GetDict(PyObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000045{
Guido van Rossumcd637aa2002-03-12 20:37:02 +000046 PyObject *d;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000047 if (!PyModule_Check(m)) {
48 PyErr_BadInternalCall();
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000049 return NULL;
50 }
Guido van Rossumcd637aa2002-03-12 20:37:02 +000051 d = ((PyModuleObject *)m) -> md_dict;
52 if (d == NULL)
53 ((PyModuleObject *)m) -> md_dict = d = PyDict_New();
54 return d;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000055}
56
Guido van Rossum0558a201990-10-26 15:00:11 +000057char *
Fred Drakeee238b92000-07-09 06:03:25 +000058PyModule_GetName(PyObject *m)
Guido van Rossum0558a201990-10-26 15:00:11 +000059{
Guido van Rossumcd637aa2002-03-12 20:37:02 +000060 PyObject *d;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000061 PyObject *nameobj;
Guido van Rossum572dbf82007-04-27 23:53:51 +000062 char *s;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000063 if (!PyModule_Check(m)) {
64 PyErr_BadArgument();
Guido van Rossum0558a201990-10-26 15:00:11 +000065 return NULL;
66 }
Guido van Rossumcd637aa2002-03-12 20:37:02 +000067 d = ((PyModuleObject *)m)->md_dict;
68 if (d == NULL ||
69 (nameobj = PyDict_GetItemString(d, "__name__")) == NULL ||
Guido van Rossum572dbf82007-04-27 23:53:51 +000070 !(PyString_Check(nameobj) || PyUnicode_Check(nameobj)))
Guido van Rossumcd637aa2002-03-12 20:37:02 +000071 {
Guido van Rossumc0b618a1997-05-02 03:12:38 +000072 PyErr_SetString(PyExc_SystemError, "nameless module");
Guido van Rossumc45611d1993-11-17 22:58:56 +000073 return NULL;
74 }
Guido van Rossum572dbf82007-04-27 23:53:51 +000075 if (PyUnicode_Check(nameobj))
76 nameobj = _PyUnicode_AsDefaultEncodedString(nameobj, "replace");
Guido van Rossumc0b618a1997-05-02 03:12:38 +000077 return PyString_AsString(nameobj);
Guido van Rossum0558a201990-10-26 15:00:11 +000078}
79
Guido van Rossum98cc19f1999-02-15 14:47:16 +000080char *
Fred Drakeee238b92000-07-09 06:03:25 +000081PyModule_GetFilename(PyObject *m)
Guido van Rossum98cc19f1999-02-15 14:47:16 +000082{
Guido van Rossumcd637aa2002-03-12 20:37:02 +000083 PyObject *d;
Guido van Rossum98cc19f1999-02-15 14:47:16 +000084 PyObject *fileobj;
85 if (!PyModule_Check(m)) {
86 PyErr_BadArgument();
87 return NULL;
88 }
Guido van Rossumcd637aa2002-03-12 20:37:02 +000089 d = ((PyModuleObject *)m)->md_dict;
90 if (d == NULL ||
91 (fileobj = PyDict_GetItemString(d, "__file__")) == NULL ||
92 !PyString_Check(fileobj))
93 {
Guido van Rossum98cc19f1999-02-15 14:47:16 +000094 PyErr_SetString(PyExc_SystemError, "module filename missing");
95 return NULL;
96 }
97 return PyString_AsString(fileobj);
98}
99
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000100void
Fred Drakeee238b92000-07-09 06:03:25 +0000101_PyModule_Clear(PyObject *m)
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000102{
103 /* To make the execution order of destructors for global
104 objects a bit more predictable, we first zap all objects
105 whose name starts with a single underscore, before we clear
106 the entire dictionary. We zap them by replacing them with
107 None, rather than deleting them from the dictionary, to
108 avoid rehashing the dictionary (to some extent). */
109
Martin v. Löwis18e16552006-02-15 17:27:45 +0000110 Py_ssize_t pos;
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000111 PyObject *key, *value;
112 PyObject *d;
113
114 d = ((PyModuleObject *)m)->md_dict;
Guido van Rossumcd637aa2002-03-12 20:37:02 +0000115 if (d == NULL)
116 return;
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000117
118 /* First, clear only names starting with a single underscore */
119 pos = 0;
120 while (PyDict_Next(d, &pos, &key, &value)) {
121 if (value != Py_None && PyString_Check(key)) {
122 char *s = PyString_AsString(key);
123 if (s[0] == '_' && s[1] != '_') {
124 if (Py_VerboseFlag > 1)
Guido van Rossum2f3667a1998-10-12 18:23:55 +0000125 PySys_WriteStderr("# clear[1] %s\n", s);
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000126 PyDict_SetItem(d, key, Py_None);
127 }
128 }
129 }
130
131 /* Next, clear all names except for __builtins__ */
132 pos = 0;
133 while (PyDict_Next(d, &pos, &key, &value)) {
134 if (value != Py_None && PyString_Check(key)) {
135 char *s = PyString_AsString(key);
136 if (s[0] != '_' || strcmp(s, "__builtins__") != 0) {
137 if (Py_VerboseFlag > 1)
Guido van Rossum2f3667a1998-10-12 18:23:55 +0000138 PySys_WriteStderr("# clear[2] %s\n", s);
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000139 PyDict_SetItem(d, key, Py_None);
140 }
141 }
142 }
143
144 /* Note: we leave __builtins__ in place, so that destructors
145 of non-global objects defined in this module can still use
146 builtins, in particularly 'None'. */
147
148}
149
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000150/* Methods */
151
Tim Peters6d6c1a32001-08-02 04:15:00 +0000152static int
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000153module_init(PyModuleObject *m, PyObject *args, PyObject *kwds)
Tim Peters6d6c1a32001-08-02 04:15:00 +0000154{
Martin v. Löwis15e62742006-02-27 16:46:16 +0000155 static char *kwlist[] = {"name", "doc", NULL};
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000156 PyObject *dict, *name = Py_None, *doc = Py_None;
Jeremy Hyltonaf68c872005-12-10 18:50:16 +0000157 if (!PyArg_ParseTupleAndKeywords(args, kwds, "S|O:module.__init__",
158 kwlist, &name, &doc))
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000159 return -1;
160 dict = m->md_dict;
161 if (dict == NULL) {
162 dict = PyDict_New();
163 if (dict == NULL)
164 return -1;
165 m->md_dict = dict;
166 }
167 if (PyDict_SetItemString(dict, "__name__", name) < 0)
168 return -1;
169 if (PyDict_SetItemString(dict, "__doc__", doc) < 0)
Tim Peters6d6c1a32001-08-02 04:15:00 +0000170 return -1;
171 return 0;
172}
173
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000174static void
Fred Drakeee238b92000-07-09 06:03:25 +0000175module_dealloc(PyModuleObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000176{
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000177 PyObject_GC_UnTrack(m);
Guido van Rossum27e916f1995-01-26 00:39:00 +0000178 if (m->md_dict != NULL) {
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000179 _PyModule_Clear((PyObject *)m);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000180 Py_DECREF(m->md_dict);
Guido van Rossum27e916f1995-01-26 00:39:00 +0000181 }
Guido van Rossum9475a232001-10-05 20:51:39 +0000182 m->ob_type->tp_free((PyObject *)m);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000183}
184
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000185static PyObject *
Fred Drakeee238b92000-07-09 06:03:25 +0000186module_repr(PyModuleObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000187{
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000188 char *name;
189 char *filename;
Barry Warsaw2907fe62001-08-16 20:39:24 +0000190
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000191 name = PyModule_GetName((PyObject *)m);
Guido van Rossumc45611d1993-11-17 22:58:56 +0000192 if (name == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000193 PyErr_Clear();
Guido van Rossumc45611d1993-11-17 22:58:56 +0000194 name = "?";
195 }
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000196 filename = PyModule_GetFilename((PyObject *)m);
197 if (filename == NULL) {
198 PyErr_Clear();
Barry Warsaw7ce36942001-08-24 18:34:26 +0000199 return PyString_FromFormat("<module '%s' (built-in)>", name);
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000200 }
Barry Warsaw7ce36942001-08-24 18:34:26 +0000201 return PyString_FromFormat("<module '%s' from '%s'>", name, filename);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000202}
203
Neil Schemenauer10e31cf2001-01-02 15:58:27 +0000204/* We only need a traverse function, no clear function: If the module
205 is in a cycle, md_dict will be cleared as well, which will break
206 the cycle. */
207static int
208module_traverse(PyModuleObject *m, visitproc visit, void *arg)
209{
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000210 Py_VISIT(m->md_dict);
Neil Schemenauer10e31cf2001-01-02 15:58:27 +0000211 return 0;
212}
213
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000214PyDoc_STRVAR(module_doc,
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000215"module(name[, doc])\n\
216\n\
217Create a module object.\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000218The name must be a string; the optional doc argument can have any type.");
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000219
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000220PyTypeObject PyModule_Type = {
221 PyObject_HEAD_INIT(&PyType_Type)
Tim Petersd85e1022001-05-11 21:51:48 +0000222 0, /* ob_size */
223 "module", /* tp_name */
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000224 sizeof(PyModuleObject), /* tp_size */
Tim Petersd85e1022001-05-11 21:51:48 +0000225 0, /* tp_itemsize */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000226 (destructor)module_dealloc, /* tp_dealloc */
Tim Petersd85e1022001-05-11 21:51:48 +0000227 0, /* tp_print */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000228 0, /* tp_getattr */
229 0, /* tp_setattr */
Tim Petersd85e1022001-05-11 21:51:48 +0000230 0, /* tp_compare */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000231 (reprfunc)module_repr, /* tp_repr */
Tim Petersd85e1022001-05-11 21:51:48 +0000232 0, /* tp_as_number */
233 0, /* tp_as_sequence */
234 0, /* tp_as_mapping */
235 0, /* tp_hash */
236 0, /* tp_call */
237 0, /* tp_str */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000238 PyObject_GenericGetAttr, /* tp_getattro */
Neil Schemenauer75552942003-07-16 22:04:11 +0000239 PyObject_GenericSetAttr, /* tp_setattro */
Tim Petersd85e1022001-05-11 21:51:48 +0000240 0, /* tp_as_buffer */
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000241 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC |
Tim Peters6d6c1a32001-08-02 04:15:00 +0000242 Py_TPFLAGS_BASETYPE, /* tp_flags */
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000243 module_doc, /* tp_doc */
Tim Petersd85e1022001-05-11 21:51:48 +0000244 (traverseproc)module_traverse, /* tp_traverse */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000245 0, /* tp_clear */
246 0, /* tp_richcompare */
247 0, /* tp_weaklistoffset */
248 0, /* tp_iter */
249 0, /* tp_iternext */
250 0, /* tp_methods */
251 module_members, /* tp_members */
252 0, /* tp_getset */
253 0, /* tp_base */
254 0, /* tp_dict */
255 0, /* tp_descr_get */
256 0, /* tp_descr_set */
257 offsetof(PyModuleObject, md_dict), /* tp_dictoffset */
258 (initproc)module_init, /* tp_init */
259 PyType_GenericAlloc, /* tp_alloc */
260 PyType_GenericNew, /* tp_new */
Neil Schemenauer99b5d282002-04-12 02:44:22 +0000261 PyObject_GC_Del, /* tp_free */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000262};