summaryrefslogtreecommitdiffstats
path: root/Python/import.c
diff options
context:
space:
mode:
Diffstat (limited to 'Python/import.c')
-rw-r--r--Python/import.c552
1 files changed, 282 insertions, 270 deletions
diff --git a/Python/import.c b/Python/import.c
index 8dadc0e..64f4e29 100644
--- a/Python/import.c
+++ b/Python/import.c
@@ -31,17 +31,12 @@ PERFORMANCE OF THIS SOFTWARE.
/* Module definition and import implementation */
-#include "allobjects.h"
+#include "Python.h"
-/* XXX Some of the following are duplicate with allobjects.h... */
#include "node.h"
#include "token.h"
#include "graminit.h"
-#include "import.h"
#include "errcode.h"
-#include "sysmodule.h"
-#include "bltinmodule.h"
-#include "pythonrun.h"
#include "marshal.h"
#include "compile.h"
#include "eval.h"
@@ -57,7 +52,7 @@ PERFORMANCE OF THIS SOFTWARE.
#include <unistd.h>
#endif
-extern long getmtime(); /* In getmtime.c */
+extern long PyOS_GetLastModificationTime(); /* In getmtime.c */
/* Magic word to reject .pyc files generated by other Python versions */
/* Change for each incompatible change */
@@ -69,22 +64,22 @@ extern long getmtime(); /* In getmtime.c */
/* New way to come up with the magic number: (YEAR-1995), MONTH, DAY */
#define MAGIC (20121 | ((long)'\r'<<16) | ((long)'\n'<<24))
-object *import_modules; /* This becomes sys.modules */
+PyObject *import_modules; /* This becomes sys.modules */
/* Initialize things */
void
-initimport()
+PyImport_Init()
{
if (import_modules != NULL)
- fatal("duplicate initimport() call");
- if ((import_modules = newdictobject()) == NULL)
- fatal("no mem for dictionary of modules");
+ Py_FatalError("duplicate initimport() call");
+ if ((import_modules = PyDict_New()) == NULL)
+ Py_FatalError("no mem for dictionary of modules");
if (Py_OptimizeFlag) {
/* Replace ".pyc" with ".pyo" in import_filetab */
struct filedescr *p;
- for (p = import_filetab; p->suffix != NULL; p++) {
+ for (p = _PyImport_Filetab; p->suffix != NULL; p++) {
if (strcmp(p->suffix, ".pyc") == 0)
p->suffix = ".pyo";
}
@@ -95,19 +90,19 @@ initimport()
/* Un-initialize things, as good as we can */
void
-doneimport()
+PyImport_Cleanup()
{
if (import_modules != NULL) {
- object *tmp = import_modules;
+ PyObject *tmp = import_modules;
import_modules = NULL;
/* This deletes all modules from sys.modules.
- When a module is deallocated, it in turn clears its dictionary,
- thus hopefully breaking any circular references between modules
- and between a module's dictionary and its functions.
- Note that "import" will fail while we are cleaning up.
- */
- mappingclear(tmp);
- DECREF(tmp);
+ When a module is deallocated, it in turn clears its
+ dictionary, thus hopefully breaking any circular
+ references between modules and between a module's
+ dictionary and its functions. Note that "import"
+ will fail while we are cleaning up. */
+ PyDict_Clear(tmp);
+ Py_DECREF(tmp);
}
}
@@ -115,7 +110,7 @@ doneimport()
/* Helper for pythonrun.c -- return magic number */
long
-get_pyc_magic()
+PyImport_GetMagicNumber()
{
return MAGIC;
}
@@ -123,8 +118,8 @@ get_pyc_magic()
/* Helper for sysmodule.c -- return modules dictionary */
-object *
-get_modules()
+PyObject *
+PyImport_GetModuleDict()
{
return import_modules;
}
@@ -136,27 +131,28 @@ get_modules()
Because the former action is most common, THIS DOES NOT RETURN A
'NEW' REFERENCE! */
-object *
-add_module(name)
+PyObject *
+PyImport_AddModule(name)
char *name;
{
- object *m;
+ PyObject *m;
if (import_modules == NULL) {
- err_setstr(SystemError, "sys.modules has been deleted");
+ PyErr_SetString(PyExc_SystemError,
+ "sys.modules has been deleted");
return NULL;
}
- if ((m = dictlookup(import_modules, name)) != NULL &&
- is_moduleobject(m))
+ if ((m = PyDict_GetItemString(import_modules, name)) != NULL &&
+ PyModule_Check(m))
return m;
- m = newmoduleobject(name);
+ m = PyModule_New(name);
if (m == NULL)
return NULL;
- if (dictinsert(import_modules, name, m) != 0) {
- DECREF(m);
+ if (PyDict_SetItemString(import_modules, name, m) != 0) {
+ Py_DECREF(m);
return NULL;
}
- DECREF(m); /* Yes, it still exists, in modules! */
+ Py_DECREF(m); /* Yes, it still exists, in modules! */
return m;
}
@@ -165,29 +161,31 @@ add_module(name)
/* Execute a code object in a module and return the module object
WITH INCREMENTED REFERENCE COUNT */
-object *
-exec_code_module(name, co)
+PyObject *
+PyImport_ExecCodeModule(name, co)
char *name;
- object *co;
+ PyObject *co;
{
- object *m, *d, *v;
+ PyObject *m, *d, *v;
- m = add_module(name);
+ m = PyImport_AddModule(name);
if (m == NULL)
return NULL;
- d = getmoduledict(m);
- if (dictlookup(d, "__builtins__") == NULL) {
- if (dictinsert(d, "__builtins__", getbuiltins()) != 0)
+ d = PyModule_GetDict(m);
+ if (PyDict_GetItemString(d, "__builtins__") == NULL) {
+ if (PyDict_SetItemString(d, "__builtins__",
+ PyEval_GetBuiltins()) != 0)
return NULL;
}
/* Remember the filename as the __file__ attribute */
- if (dictinsert(d, "__file__", ((codeobject *)co)->co_filename) != 0)
- err_clear(); /* Not important enough to report */
- v = eval_code((codeobject *)co, d, d); /* XXX owner? */
+ if (PyDict_SetItemString(d, "__file__",
+ ((PyCodeObject *)co)->co_filename) != 0)
+ PyErr_Clear(); /* Not important enough to report */
+ v = PyEval_EvalCode((PyCodeObject *)co, d, d); /* XXX owner? */
if (v == NULL)
return NULL;
- DECREF(v);
- INCREF(m);
+ Py_DECREF(v);
+ Py_INCREF(m);
return m;
}
@@ -236,21 +234,21 @@ check_compiled_module(pathname, mtime, cpathname)
fp = fopen(cpathname, "rb");
if (fp == NULL)
return NULL;
- magic = rd_long(fp);
+ magic = PyMarshal_ReadLongFromFile(fp);
if (magic != MAGIC) {
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "# %s has bad magic\n", cpathname);
fclose(fp);
return NULL;
}
- pyc_mtime = rd_long(fp);
+ pyc_mtime = PyMarshal_ReadLongFromFile(fp);
if (pyc_mtime != mtime) {
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "# %s has bad mtime\n", cpathname);
fclose(fp);
return NULL;
}
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "# %s matches %s\n", cpathname, pathname);
return fp;
}
@@ -258,71 +256,72 @@ check_compiled_module(pathname, mtime, cpathname)
/* Read a code object from a file and check it for validity */
-static codeobject *
+static PyCodeObject *
read_compiled_module(fp)
FILE *fp;
{
- object *co;
+ PyObject *co;
- co = rd_object(fp);
+ co = PyMarshal_ReadObjectFromFile(fp);
/* Ugly: rd_object() may return NULL with or without error */
- if (co == NULL || !is_codeobject(co)) {
- if (!err_occurred())
- err_setstr(ImportError,
+ if (co == NULL || !PyCode_Check(co)) {
+ if (!PyErr_Occurred())
+ PyErr_SetString(PyExc_ImportError,
"Non-code object in .pyc file");
- XDECREF(co);
+ Py_XDECREF(co);
return NULL;
}
- return (codeobject *)co;
+ return (PyCodeObject *)co;
}
/* Load a module from a compiled file, execute it, and return its
module object WITH INCREMENTED REFERENCE COUNT */
-static object *
+static PyObject *
load_compiled_module(name, cpathname, fp)
char *name;
char *cpathname;
FILE *fp;
{
long magic;
- codeobject *co;
- object *m;
+ PyCodeObject *co;
+ PyObject *m;
- magic = rd_long(fp);
+ magic = PyMarshal_ReadLongFromFile(fp);
if (magic != MAGIC) {
- err_setstr(ImportError, "Bad magic number in .pyc file");
+ PyErr_SetString(PyExc_ImportError,
+ "Bad magic number in .pyc file");
return NULL;
}
- (void) rd_long(fp);
+ (void) PyMarshal_ReadLongFromFile(fp);
co = read_compiled_module(fp);
if (co == NULL)
return NULL;
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "import %s # precompiled from %s\n",
name, cpathname);
- m = exec_code_module(name, (object *)co);
- DECREF(co);
+ m = PyImport_ExecCodeModule(name, (PyObject *)co);
+ Py_DECREF(co);
return m;
}
/* Parse a source file and return the corresponding code object */
-static codeobject *
+static PyCodeObject *
parse_source_module(pathname, fp)
char *pathname;
FILE *fp;
{
- codeobject *co;
+ PyCodeObject *co;
node *n;
- n = parse_file(fp, pathname, file_input);
+ n = PyParser_SimpleParseFile(fp, pathname, file_input);
if (n == NULL)
return NULL;
- co = compile(n, pathname);
- freetree(n);
+ co = PyNode_Compile(n, pathname);
+ PyNode_Free(n);
return co;
}
@@ -335,7 +334,7 @@ parse_source_module(pathname, fp)
static void
write_compiled_module(co, cpathname, mtime)
- codeobject *co;
+ PyCodeObject *co;
char *cpathname;
long mtime;
{
@@ -343,17 +342,17 @@ write_compiled_module(co, cpathname, mtime)
fp = fopen(cpathname, "wb");
if (fp == NULL) {
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr,
"# can't create %s\n", cpathname);
return;
}
- wr_long(MAGIC, fp);
+ PyMarshal_WriteLongToFile(MAGIC, fp);
/* First write a 0 for mtime */
- wr_long(0L, fp);
- wr_object((object *)co, fp);
+ PyMarshal_WriteLongToFile(0L, fp);
+ PyMarshal_WriteObjectToFile((PyObject *)co, fp);
if (ferror(fp)) {
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "# can't write %s\n", cpathname);
/* Don't keep partial file */
fclose(fp);
@@ -362,10 +361,10 @@ write_compiled_module(co, cpathname, mtime)
}
/* Now write the true mtime */
fseek(fp, 4L, 0);
- wr_long(mtime, fp);
+ PyMarshal_WriteLongToFile(mtime, fp);
fflush(fp);
fclose(fp);
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "# wrote %s\n", cpathname);
#ifdef macintosh
setfiletype(cpathname, 'Pyth', 'PYC ');
@@ -377,7 +376,7 @@ write_compiled_module(co, cpathname, mtime)
object WITH INCREMENTED REFERENCE COUNT. If there's a matching
byte-compiled file, use that instead. */
-static object *
+static PyObject *
load_source_module(name, pathname, fp)
char *name;
char *pathname;
@@ -387,10 +386,10 @@ load_source_module(name, pathname, fp)
FILE *fpc;
char buf[MAXPATHLEN+1];
char *cpathname;
- codeobject *co;
- object *m;
+ PyCodeObject *co;
+ PyObject *m;
- mtime = getmtime(pathname);
+ mtime = PyOS_GetLastModificationTime(pathname);
cpathname = make_compiled_pathname(pathname, buf, MAXPATHLEN+1);
if (cpathname != NULL &&
(fpc = check_compiled_module(pathname, mtime, cpathname))) {
@@ -398,7 +397,7 @@ load_source_module(name, pathname, fp)
fclose(fpc);
if (co == NULL)
return NULL;
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "import %s # precompiled from %s\n",
name, cpathname);
}
@@ -406,13 +405,13 @@ load_source_module(name, pathname, fp)
co = parse_source_module(pathname, fp);
if (co == NULL)
return NULL;
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "import %s # from %s\n",
name, pathname);
write_compiled_module(co, cpathname, mtime);
}
- m = exec_code_module(name, (object *)co);
- DECREF(co);
+ m = PyImport_ExecCodeModule(name, (PyObject *)co);
+ Py_DECREF(co);
return m;
}
@@ -425,7 +424,7 @@ load_source_module(name, pathname, fp)
static struct filedescr *
find_module(name, path, buf, buflen, p_fp)
char *name;
- object *path;
+ PyObject *path;
/* Output parameters: */
char *buf;
int buflen;
@@ -445,27 +444,28 @@ find_module(name, path, buf, buflen, p_fp)
if (path == NULL)
- path = sysget("path");
- if (path == NULL || !is_listobject(path)) {
- err_setstr(ImportError,
+ path = PySys_GetObject("path");
+ if (path == NULL || !PyList_Check(path)) {
+ PyErr_SetString(PyExc_ImportError,
"sys.path must be a list of directory names");
return NULL;
}
- npath = getlistsize(path);
+ npath = PyList_Size(path);
namelen = strlen(name);
for (i = 0; i < npath; i++) {
- object *v = getlistitem(path, i);
- if (!is_stringobject(v))
+ PyObject *v = PyList_GetItem(path, i);
+ if (!PyString_Check(v))
continue;
- len = getstringsize(v);
- if (len + 2 + namelen + import_maxsuffixsize >= buflen)
+ len = PyString_Size(v);
+ if (len + 2 + namelen + _PyImport_MaxSuffixSize >= buflen)
continue; /* Too long */
- strcpy(buf, getstringvalue(v));
+ strcpy(buf, PyString_AsString(v));
if ((int)strlen(buf) != len)
continue; /* v contains '\0' */
#ifdef macintosh
if ( PyMac_FindResourceModule(name, buf) ) {
- static struct filedescr resfiledescr = { "", "", PY_RESOURCE};
+ static struct filedescr resfiledescr =
+ {"", "", PY_RESOURCE};
return &resfiledescr;
}
@@ -476,7 +476,7 @@ find_module(name, path, buf, buflen, p_fp)
/* see if we are searching in directory dos_8x3 */
if (len > 7 && !strncmp(buf + len - 8, "dos_8x3", 7)){
int j;
- char ch; /* limit name to eight lower-case characters */
+ char ch; /* limit name to 8 lower-case characters */
for (j = 0; (ch = name[j]) && j < 8; j++)
if (isupper(ch))
buf[len++] = tolower(ch);
@@ -489,9 +489,9 @@ find_module(name, path, buf, buflen, p_fp)
strcpy(buf+len, name);
len += namelen;
}
- for (fdp = import_filetab; fdp->suffix != NULL; fdp++) {
+ for (fdp = _PyImport_Filetab; fdp->suffix != NULL; fdp++) {
strcpy(buf+len, fdp->suffix);
- if (verbose > 1)
+ if (Py_VerboseFlag > 1)
fprintf(stderr, "# trying %s\n", buf);
fp = fopen(buf, fdp->mode);
if (fp != NULL)
@@ -503,7 +503,7 @@ find_module(name, path, buf, buflen, p_fp)
if (fp == NULL) {
char buf[256];
sprintf(buf, "No module named %.200s", name);
- err_setstr(ImportError, buf);
+ PyErr_SetString(PyExc_ImportError, buf);
return NULL;
}
@@ -515,16 +515,16 @@ find_module(name, path, buf, buflen, p_fp)
/* Load an external module using the default search path and return
its module object WITH INCREMENTED REFERENCE COUNT */
-static object *
+static PyObject *
load_module(name)
char *name;
{
char buf[MAXPATHLEN+1];
struct filedescr *fdp;
FILE *fp = NULL;
- object *m;
+ PyObject *m;
- fdp = find_module(name, (object *)NULL, buf, MAXPATHLEN+1, &fp);
+ fdp = find_module(name, (PyObject *)NULL, buf, MAXPATHLEN+1, &fp);
if (fdp == NULL)
return NULL;
@@ -539,7 +539,7 @@ load_module(name)
break;
case C_EXTENSION:
- m = load_dynamic_module(name, buf, fp);
+ m = _PyImport_LoadDynamicModule(name, buf, fp);
break;
#ifdef macintosh
@@ -549,7 +549,7 @@ load_module(name)
#endif
default:
- err_setstr(SystemError,
+ PyErr_SetString(PyExc_SystemError,
"find_module returned unexpected result");
m = NULL;
@@ -573,15 +573,15 @@ init_builtin(name)
for (i = 0; inittab[i].name != NULL; i++) {
if (strcmp(name, inittab[i].name) == 0) {
if (inittab[i].initfunc == NULL) {
- err_setstr(ImportError,
+ PyErr_SetString(PyExc_ImportError,
"Cannot re-init internal module");
return -1;
}
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "import %s # builtin\n",
name);
(*inittab[i].initfunc)();
- if (err_occurred())
+ if (PyErr_Occurred())
return -1;
return 1;
}
@@ -598,7 +598,7 @@ find_frozen(name)
{
struct _frozen *p;
- for (p = frozen_modules; ; p++) {
+ for (p = PyImport_FrozenModules; ; p++) {
if (p->name == NULL)
return NULL;
if (strcmp(p->name, name) == 0)
@@ -607,17 +607,17 @@ find_frozen(name)
return p;
}
-static object *
+static PyObject *
get_frozen_object(name)
char *name;
{
struct _frozen *p = find_frozen(name);
if (p == NULL) {
- err_setstr(ImportError, "No such frozen object");
+ PyErr_SetString(PyExc_ImportError, "No such frozen object");
return NULL;
}
- return rds_object((char *)p->code, p->size);
+ return PyMarshal_ReadObjectFromString((char *)p->code, p->size);
}
/* Initialize a frozen module.
@@ -626,30 +626,31 @@ get_frozen_object(name)
This function is also used from frozenmain.c */
int
-init_frozen(name)
+PyImport_ImportFrozenModule(name)
char *name;
{
struct _frozen *p = find_frozen(name);
- object *co;
- object *m;
+ PyObject *co;
+ PyObject *m;
if (p == NULL)
return 0;
- if (verbose)
+ if (Py_VerboseFlag)
fprintf(stderr, "import %s # frozen\n", name);
- co = rds_object((char *)p->code, p->size);
+ co = PyMarshal_ReadObjectFromString((char *)p->code, p->size);
if (co == NULL)
return -1;
- if (!is_codeobject(co)) {
- DECREF(co);
- err_setstr(TypeError, "frozen object is not a code object");
+ if (!PyCode_Check(co)) {
+ Py_DECREF(co);
+ PyErr_SetString(PyExc_TypeError,
+ "frozen object is not a code object");
return -1;
}
- m = exec_code_module(name, co);
- DECREF(co);
+ m = PyImport_ExecCodeModule(name, co);
+ Py_DECREF(co);
if (m == NULL)
return -1;
- DECREF(m);
+ Py_DECREF(m);
return 1;
}
@@ -657,31 +658,34 @@ init_frozen(name)
/* Import a module, either built-in, frozen, or external, and return
its module object WITH INCREMENTED REFERENCE COUNT */
-object *
-import_module(name)
+PyObject *
+PyImport_ImportModule(name)
char *name;
{
- object *m;
+ PyObject *m;
if (import_modules == NULL) {
- err_setstr(SystemError, "sys.modules has been deleted");
+ PyErr_SetString(PyExc_SystemError,
+ "sys.modules has been deleted");
return NULL;
}
- if ((m = dictlookup(import_modules, name)) != NULL) {
- INCREF(m);
+ if ((m = PyDict_GetItemString(import_modules, name)) != NULL) {
+ Py_INCREF(m);
}
else {
int i;
- if ((i = init_builtin(name)) || (i = init_frozen(name))) {
+ if ((i = init_builtin(name)) ||
+ (i = PyImport_ImportFrozenModule(name))) {
if (i < 0)
return NULL;
- if ((m = dictlookup(import_modules, name)) == NULL) {
- if (err_occurred() == NULL)
- err_setstr(SystemError,
+ if ((m = PyDict_GetItemString(import_modules,
+ name)) == NULL) {
+ if (PyErr_Occurred() == NULL)
+ PyErr_SetString(PyExc_SystemError,
"built-in module not initialized properly");
}
else
- INCREF(m);
+ Py_INCREF(m);
}
else
m = load_module(name);
@@ -694,33 +698,37 @@ import_module(name)
/* Re-import a module of any kind and return its module object, WITH
INCREMENTED REFERENCE COUNT */
-object *
-reload_module(m)
- object *m;
+PyObject *
+PyImport_ReloadModule(m)
+ PyObject *m;
{
char *name;
int i;
- if (m == NULL || !is_moduleobject(m)) {
- err_setstr(TypeError, "reload() argument must be module");
+ if (m == NULL || !PyModule_Check(m)) {
+ PyErr_SetString(PyExc_TypeError,
+ "reload() argument must be module");
return NULL;
}
- name = getmodulename(m);
+ name = PyModule_GetName(m);
if (name == NULL)
return NULL;
if (import_modules == NULL) {
- err_setstr(SystemError, "sys.modules has been deleted");
+ PyErr_SetString(PyExc_SystemError,
+ "sys.modules has been deleted");
return NULL;
}
- if (m != dictlookup(import_modules, name)) {
- err_setstr(ImportError, "reload() module not in sys.modules");
+ if (m != PyDict_GetItemString(import_modules, name)) {
+ PyErr_SetString(PyExc_ImportError,
+ "reload() module not in sys.modules");
return NULL;
}
/* Check for built-in and frozen modules */
- if ((i = init_builtin(name)) || (i = init_frozen(name))) {
+ if ((i = init_builtin(name)) ||
+ (i = PyImport_ImportFrozenModule(name))) {
if (i < 0)
return NULL;
- INCREF(m);
+ Py_INCREF(m);
}
else
m = load_module(name);
@@ -732,206 +740,208 @@ reload_module(m)
importing modules.
*/
-static object *
+static PyObject *
imp_get_magic(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char buf[4];
- if (!newgetargs(args, ""))
+ if (!PyArg_ParseTuple(args, ""))
return NULL;
buf[0] = (char) ((MAGIC >> 0) & 0xff);
buf[1] = (char) ((MAGIC >> 8) & 0xff);
buf[2] = (char) ((MAGIC >> 16) & 0xff);
buf[3] = (char) ((MAGIC >> 24) & 0xff);
- return newsizedstringobject(buf, 4);
+ return PyString_FromStringAndSize(buf, 4);
}
-static object *
+static PyObject *
imp_get_suffixes(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
- object *list;
+ PyObject *list;
struct filedescr *fdp;
- if (!newgetargs(args, ""))
+ if (!PyArg_ParseTuple(args, ""))
return NULL;
- list = newlistobject(0);
+ list = PyList_New(0);
if (list == NULL)
return NULL;
- for (fdp = import_filetab; fdp->suffix != NULL; fdp++) {
- object *item = mkvalue("ssi",
+ for (fdp = _PyImport_Filetab; fdp->suffix != NULL; fdp++) {
+ PyObject *item = Py_BuildValue("ssi",
fdp->suffix, fdp->mode, fdp->type);
if (item == NULL) {
- DECREF(list);
+ Py_DECREF(list);
return NULL;
}
- if (addlistitem(list, item) < 0) {
- DECREF(list);
- DECREF(item);
+ if (PyList_Append(list, item) < 0) {
+ Py_DECREF(list);
+ Py_DECREF(item);
return NULL;
}
- DECREF(item);
+ Py_DECREF(item);
}
return list;
}
-static object *
+static PyObject *
imp_find_module(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
- extern int fclose PROTO((FILE *));
+ extern int fclose Py_PROTO((FILE *));
char *name;
- object *path = NULL;
- object *fob, *ret;
+ PyObject *path = NULL;
+ PyObject *fob, *ret;
struct filedescr *fdp;
char pathname[MAXPATHLEN+1];
FILE *fp;
- if (!newgetargs(args, "s|O!", &name, &Listtype, &path))
+ if (!PyArg_ParseTuple(args, "s|O!", &name, &PyList_Type, &path))
return NULL;
fdp = find_module(name, path, pathname, MAXPATHLEN+1, &fp);
if (fdp == NULL)
return NULL;
- fob = newopenfileobject(fp, pathname, fdp->mode, fclose);
+ fob = PyFile_FromFile(fp, pathname, fdp->mode, fclose);
if (fob == NULL) {
fclose(fp);
return NULL;
}
- ret = mkvalue("Os(ssi)",
+ ret = Py_BuildValue("Os(ssi)",
fob, pathname, fdp->suffix, fdp->mode, fdp->type);
- DECREF(fob);
+ Py_DECREF(fob);
return ret;
}
-static object *
+static PyObject *
imp_init_builtin(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
int ret;
- object *m;
- if (!newgetargs(args, "s", &name))
+ PyObject *m;
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
ret = init_builtin(name);
if (ret < 0)
return NULL;
if (ret == 0) {
- INCREF(None);
- return None;
+ Py_INCREF(Py_None);
+ return Py_None;
}
- m = add_module(name);
- XINCREF(m);
+ m = PyImport_AddModule(name);
+ Py_XINCREF(m);
return m;
}
-static object *
+static PyObject *
imp_init_frozen(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
int ret;
- object *m;
- if (!newgetargs(args, "s", &name))
+ PyObject *m;
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
- ret = init_frozen(name);
+ ret = PyImport_ImportFrozenModule(name);
if (ret < 0)
return NULL;
if (ret == 0) {
- INCREF(None);
- return None;
+ Py_INCREF(Py_None);
+ return Py_None;
}
- m = add_module(name);
- XINCREF(m);
+ m = PyImport_AddModule(name);
+ Py_XINCREF(m);
return m;
}
-static object *
+static PyObject *
imp_get_frozen_object(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
- if (!newgetargs(args, "s", &name))
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
return get_frozen_object(name);
}
-static object *
+static PyObject *
imp_is_builtin(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
int i;
char *name;
- if (!newgetargs(args, "s", &name))
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
for (i = 0; inittab[i].name != NULL; i++) {
if (strcmp(name, inittab[i].name) == 0) {
if (inittab[i].initfunc == NULL)
- return newintobject(-1);
+ return PyInt_FromLong(-1);
else
- return newintobject(1);
+ return PyInt_FromLong(1);
}
}
- return newintobject(0);
+ return PyInt_FromLong(0);
}
-static object *
+static PyObject *
imp_is_frozen(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
struct _frozen *p;
char *name;
- if (!newgetargs(args, "s", &name))
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
- for (p = frozen_modules; ; p++) {
+ for (p = PyImport_FrozenModules; ; p++) {
if (p->name == NULL)
break;
if (strcmp(p->name, name) == 0)
- return newintobject(1);
+ return PyInt_FromLong(1);
}
- return newintobject(0);
+ return PyInt_FromLong(0);
}
static FILE *
get_file(pathname, fob, mode)
char *pathname;
- object *fob;
+ PyObject *fob;
char *mode;
{
FILE *fp;
if (fob == NULL) {
fp = fopen(pathname, mode);
if (fp == NULL)
- err_errno(IOError);
+ PyErr_SetFromErrno(PyExc_IOError);
}
else {
- fp = getfilefile(fob);
+ fp = PyFile_AsFile(fob);
if (fp == NULL)
- err_setstr(ValueError, "bad/closed file object");
+ PyErr_SetString(PyExc_ValueError,
+ "bad/closed file object");
}
return fp;
}
-static object *
+static PyObject *
imp_load_compiled(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
char *pathname;
- object *fob = NULL;
- object *m;
+ PyObject *fob = NULL;
+ PyObject *m;
FILE *fp;
- if (!newgetargs(args, "ssO!", &name, &pathname, &Filetype, &fob))
+ if (!PyArg_ParseTuple(args, "ssO!", &name, &pathname,
+ &PyFile_Type, &fob))
return NULL;
fp = get_file(pathname, fob, "rb");
if (fp == NULL)
@@ -940,35 +950,37 @@ imp_load_compiled(self, args)
return m;
}
-static object *
+static PyObject *
imp_load_dynamic(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
char *pathname;
- object *fob = NULL;
- object *m;
+ PyObject *fob = NULL;
+ PyObject *m;
FILE *fp = NULL;
- if (!newgetargs(args, "ss|O!", &name, &pathname, &Filetype, &fob))
+ if (!PyArg_ParseTuple(args, "ss|O!", &name, &pathname,
+ &PyFile_Type, &fob))
return NULL;
if (fob)
fp = get_file(pathname, fob, "r");
- m = load_dynamic_module(name, pathname, fp);
+ m = _PyImport_LoadDynamicModule(name, pathname, fp);
return m;
}
-static object *
+static PyObject *
imp_load_source(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
char *pathname;
- object *fob = NULL;
- object *m;
+ PyObject *fob = NULL;
+ PyObject *m;
FILE *fp;
- if (!newgetargs(args, "ssO!", &name, &pathname, &Filetype, &fob))
+ if (!PyArg_ParseTuple(args, "ssO!", &name, &pathname,
+ &PyFile_Type, &fob))
return NULL;
fp = get_file(pathname, fob, "r");
if (fp == NULL)
@@ -978,34 +990,34 @@ imp_load_source(self, args)
}
#ifdef macintosh
-static object *
+static PyObject *
imp_load_resource(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
char *pathname;
- object *m;
+ PyObject *m;
- if (!newgetargs(args, "ss", &name, &pathname))
+ if (!PyArg_ParseTuple(args, "ss", &name, &pathname))
return NULL;
m = PyMac_LoadResourceModule(name, pathname);
return m;
}
#endif /* macintosh */
-static object *
+static PyObject *
imp_new_module(self, args)
- object *self;
- object *args;
+ PyObject *self;
+ PyObject *args;
{
char *name;
- if (!newgetargs(args, "s", &name))
+ if (!PyArg_ParseTuple(args, "s", &name))
return NULL;
- return newmoduleobject(name);
+ return PyModule_New(name);
}
-static struct methodlist imp_methods[] = {
+static PyMethodDef imp_methods[] = {
{"get_frozen_object", imp_get_frozen_object, 1},
{"get_magic", imp_get_magic, 1},
{"get_suffixes", imp_get_suffixes, 1},
@@ -1027,34 +1039,34 @@ static struct methodlist imp_methods[] = {
void
initimp()
{
- object *m, *d, *v;
+ PyObject *m, *d, *v;
- m = initmodule("imp", imp_methods);
- d = getmoduledict(m);
+ m = Py_InitModule("imp", imp_methods);
+ d = PyModule_GetDict(m);
- v = newintobject(SEARCH_ERROR);
- dictinsert(d, "SEARCH_ERROR", v);
- XDECREF(v);
+ v = PyInt_FromLong(SEARCH_ERROR);
+ PyDict_SetItemString(d, "SEARCH_ERROR", v);
+ Py_XDECREF(v);
- v = newintobject(PY_SOURCE);
- dictinsert(d, "PY_SOURCE", v);
- XDECREF(v);
+ v = PyInt_FromLong(PY_SOURCE);
+ PyDict_SetItemString(d, "PY_SOURCE", v);
+ Py_XDECREF(v);
- v = newintobject(PY_COMPILED);
- dictinsert(d, "PY_COMPILED", v);
- XDECREF(v);
+ v = PyInt_FromLong(PY_COMPILED);
+ PyDict_SetItemString(d, "PY_COMPILED", v);
+ Py_XDECREF(v);
- v = newintobject(C_EXTENSION);
- dictinsert(d, "C_EXTENSION", v);
- XDECREF(v);
+ v = PyInt_FromLong(C_EXTENSION);
+ PyDict_SetItemString(d, "C_EXTENSION", v);
+ Py_XDECREF(v);
#ifdef macintosh
- v = newintobject(PY_RESOURCE);
- dictinsert(d, "PY_RESOURCE", v);
- XDECREF(v);
+ v = PyInt_FromLong(PY_RESOURCE);
+ PyDict_SetItemString(d, "PY_RESOURCE", v);
+ Py_XDECREF(v);
#endif
- if (err_occurred())
- fatal("imp module initialization failed");
+ if (PyErr_Occurred())
+ Py_FatalError("imp module initialization failed");
}