blob: f1885156ea1ef19e5046235317a316688a2db3c7 [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;
62 if (!PyModule_Check(m)) {
63 PyErr_BadArgument();
Guido van Rossum0558a201990-10-26 15:00:11 +000064 return NULL;
65 }
Guido van Rossumcd637aa2002-03-12 20:37:02 +000066 d = ((PyModuleObject *)m)->md_dict;
67 if (d == NULL ||
68 (nameobj = PyDict_GetItemString(d, "__name__")) == NULL ||
Guido van Rossum572dbf82007-04-27 23:53:51 +000069 !(PyString_Check(nameobj) || PyUnicode_Check(nameobj)))
Guido van Rossumcd637aa2002-03-12 20:37:02 +000070 {
Guido van Rossumc0b618a1997-05-02 03:12:38 +000071 PyErr_SetString(PyExc_SystemError, "nameless module");
Guido van Rossumc45611d1993-11-17 22:58:56 +000072 return NULL;
73 }
Guido van Rossumf15a29f2007-05-04 00:41:39 +000074 if (PyUnicode_Check(nameobj)) {
75 nameobj = _PyUnicode_AsDefaultEncodedString(nameobj, NULL);
76 if (nameobj == NULL)
77 return NULL;
78 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +000079 return PyString_AsString(nameobj);
Guido van Rossum0558a201990-10-26 15:00:11 +000080}
81
Guido van Rossum98cc19f1999-02-15 14:47:16 +000082char *
Fred Drakeee238b92000-07-09 06:03:25 +000083PyModule_GetFilename(PyObject *m)
Guido van Rossum98cc19f1999-02-15 14:47:16 +000084{
Guido van Rossumcd637aa2002-03-12 20:37:02 +000085 PyObject *d;
Guido van Rossum98cc19f1999-02-15 14:47:16 +000086 PyObject *fileobj;
87 if (!PyModule_Check(m)) {
88 PyErr_BadArgument();
89 return NULL;
90 }
Guido van Rossumcd637aa2002-03-12 20:37:02 +000091 d = ((PyModuleObject *)m)->md_dict;
92 if (d == NULL ||
93 (fileobj = PyDict_GetItemString(d, "__file__")) == NULL ||
94 !PyString_Check(fileobj))
95 {
Guido van Rossum98cc19f1999-02-15 14:47:16 +000096 PyErr_SetString(PyExc_SystemError, "module filename missing");
97 return NULL;
98 }
99 return PyString_AsString(fileobj);
100}
101
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000102void
Fred Drakeee238b92000-07-09 06:03:25 +0000103_PyModule_Clear(PyObject *m)
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000104{
105 /* To make the execution order of destructors for global
106 objects a bit more predictable, we first zap all objects
107 whose name starts with a single underscore, before we clear
108 the entire dictionary. We zap them by replacing them with
109 None, rather than deleting them from the dictionary, to
110 avoid rehashing the dictionary (to some extent). */
111
Martin v. Löwis18e16552006-02-15 17:27:45 +0000112 Py_ssize_t pos;
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000113 PyObject *key, *value;
114 PyObject *d;
115
116 d = ((PyModuleObject *)m)->md_dict;
Guido van Rossumcd637aa2002-03-12 20:37:02 +0000117 if (d == NULL)
118 return;
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000119
120 /* First, clear only names starting with a single underscore */
121 pos = 0;
122 while (PyDict_Next(d, &pos, &key, &value)) {
123 if (value != Py_None && PyString_Check(key)) {
124 char *s = PyString_AsString(key);
125 if (s[0] == '_' && s[1] != '_') {
126 if (Py_VerboseFlag > 1)
Guido van Rossum2f3667a1998-10-12 18:23:55 +0000127 PySys_WriteStderr("# clear[1] %s\n", s);
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000128 PyDict_SetItem(d, key, Py_None);
129 }
130 }
131 }
132
133 /* Next, clear all names except for __builtins__ */
134 pos = 0;
135 while (PyDict_Next(d, &pos, &key, &value)) {
136 if (value != Py_None && PyString_Check(key)) {
137 char *s = PyString_AsString(key);
138 if (s[0] != '_' || strcmp(s, "__builtins__") != 0) {
139 if (Py_VerboseFlag > 1)
Guido van Rossum2f3667a1998-10-12 18:23:55 +0000140 PySys_WriteStderr("# clear[2] %s\n", s);
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000141 PyDict_SetItem(d, key, Py_None);
142 }
143 }
144 }
145
146 /* Note: we leave __builtins__ in place, so that destructors
147 of non-global objects defined in this module can still use
148 builtins, in particularly 'None'. */
149
150}
151
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000152/* Methods */
153
Tim Peters6d6c1a32001-08-02 04:15:00 +0000154static int
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000155module_init(PyModuleObject *m, PyObject *args, PyObject *kwds)
Tim Peters6d6c1a32001-08-02 04:15:00 +0000156{
Martin v. Löwis15e62742006-02-27 16:46:16 +0000157 static char *kwlist[] = {"name", "doc", NULL};
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000158 PyObject *dict, *name = Py_None, *doc = Py_None;
Jeremy Hyltonaf68c872005-12-10 18:50:16 +0000159 if (!PyArg_ParseTupleAndKeywords(args, kwds, "S|O:module.__init__",
160 kwlist, &name, &doc))
Guido van Rossumc3a787e2002-06-04 05:52:47 +0000161 return -1;
162 dict = m->md_dict;
163 if (dict == NULL) {
164 dict = PyDict_New();
165 if (dict == NULL)
166 return -1;
167 m->md_dict = dict;
168 }
169 if (PyDict_SetItemString(dict, "__name__", name) < 0)
170 return -1;
171 if (PyDict_SetItemString(dict, "__doc__", doc) < 0)
Tim Peters6d6c1a32001-08-02 04:15:00 +0000172 return -1;
173 return 0;
174}
175
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000176static void
Fred Drakeee238b92000-07-09 06:03:25 +0000177module_dealloc(PyModuleObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000178{
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000179 PyObject_GC_UnTrack(m);
Guido van Rossum27e916f1995-01-26 00:39:00 +0000180 if (m->md_dict != NULL) {
Guido van Rossumf1dc0611998-02-19 20:51:52 +0000181 _PyModule_Clear((PyObject *)m);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000182 Py_DECREF(m->md_dict);
Guido van Rossum27e916f1995-01-26 00:39:00 +0000183 }
Guido van Rossum9475a232001-10-05 20:51:39 +0000184 m->ob_type->tp_free((PyObject *)m);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000185}
186
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000187static PyObject *
Fred Drakeee238b92000-07-09 06:03:25 +0000188module_repr(PyModuleObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000189{
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000190 char *name;
191 char *filename;
Barry Warsaw2907fe62001-08-16 20:39:24 +0000192
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000193 name = PyModule_GetName((PyObject *)m);
Guido van Rossumc45611d1993-11-17 22:58:56 +0000194 if (name == NULL) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000195 PyErr_Clear();
Guido van Rossumc45611d1993-11-17 22:58:56 +0000196 name = "?";
197 }
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000198 filename = PyModule_GetFilename((PyObject *)m);
199 if (filename == NULL) {
200 PyErr_Clear();
Barry Warsaw7ce36942001-08-24 18:34:26 +0000201 return PyString_FromFormat("<module '%s' (built-in)>", name);
Guido van Rossum98cc19f1999-02-15 14:47:16 +0000202 }
Barry Warsaw7ce36942001-08-24 18:34:26 +0000203 return PyString_FromFormat("<module '%s' from '%s'>", name, filename);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000204}
205
Neil Schemenauer10e31cf2001-01-02 15:58:27 +0000206/* We only need a traverse function, no clear function: If the module
207 is in a cycle, md_dict will be cleared as well, which will break
208 the cycle. */
209static int
210module_traverse(PyModuleObject *m, visitproc visit, void *arg)
211{
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000212 Py_VISIT(m->md_dict);
Neil Schemenauer10e31cf2001-01-02 15:58:27 +0000213 return 0;
214}
215
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000216PyDoc_STRVAR(module_doc,
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000217"module(name[, doc])\n\
218\n\
219Create a module object.\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000220The name must be a string; the optional doc argument can have any type.");
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000221
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000222PyTypeObject PyModule_Type = {
223 PyObject_HEAD_INIT(&PyType_Type)
Tim Petersd85e1022001-05-11 21:51:48 +0000224 0, /* ob_size */
225 "module", /* tp_name */
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000226 sizeof(PyModuleObject), /* tp_size */
Tim Petersd85e1022001-05-11 21:51:48 +0000227 0, /* tp_itemsize */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000228 (destructor)module_dealloc, /* tp_dealloc */
Tim Petersd85e1022001-05-11 21:51:48 +0000229 0, /* tp_print */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000230 0, /* tp_getattr */
231 0, /* tp_setattr */
Tim Petersd85e1022001-05-11 21:51:48 +0000232 0, /* tp_compare */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000233 (reprfunc)module_repr, /* tp_repr */
Tim Petersd85e1022001-05-11 21:51:48 +0000234 0, /* tp_as_number */
235 0, /* tp_as_sequence */
236 0, /* tp_as_mapping */
237 0, /* tp_hash */
238 0, /* tp_call */
239 0, /* tp_str */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000240 PyObject_GenericGetAttr, /* tp_getattro */
Neil Schemenauer75552942003-07-16 22:04:11 +0000241 PyObject_GenericSetAttr, /* tp_setattro */
Tim Petersd85e1022001-05-11 21:51:48 +0000242 0, /* tp_as_buffer */
Neil Schemenauere83c00e2001-08-29 23:54:21 +0000243 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC |
Tim Peters6d6c1a32001-08-02 04:15:00 +0000244 Py_TPFLAGS_BASETYPE, /* tp_flags */
Guido van Rossumed3e09f2002-06-04 06:02:35 +0000245 module_doc, /* tp_doc */
Tim Petersd85e1022001-05-11 21:51:48 +0000246 (traverseproc)module_traverse, /* tp_traverse */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000247 0, /* tp_clear */
248 0, /* tp_richcompare */
249 0, /* tp_weaklistoffset */
250 0, /* tp_iter */
251 0, /* tp_iternext */
252 0, /* tp_methods */
253 module_members, /* tp_members */
254 0, /* tp_getset */
255 0, /* tp_base */
256 0, /* tp_dict */
257 0, /* tp_descr_get */
258 0, /* tp_descr_set */
259 offsetof(PyModuleObject, md_dict), /* tp_dictoffset */
260 (initproc)module_init, /* tp_init */
261 PyType_GenericAlloc, /* tp_alloc */
262 PyType_GenericNew, /* tp_new */
Neil Schemenauer99b5d282002-04-12 02:44:22 +0000263 PyObject_GC_Del, /* tp_free */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000264};