Commit ee1dc804 authored by Robert Bradshaw's avatar Robert Bradshaw

Cleanup type sharing.

parent 2fa32b3c
...@@ -533,6 +533,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -533,6 +533,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
code.putln("#else") code.putln("#else")
code.globalstate["end"].putln("#endif /* Py_PYTHON_H */") code.globalstate["end"].putln("#endif /* Py_PYTHON_H */")
from Cython import __version__
code.putln('#define CYTHON_ABI "%s"' % __version__.replace('.', '_'))
code.put(UtilityCode.load_as_string("CModulePreamble", "ModuleSetupCode.c")[1]) code.put(UtilityCode.load_as_string("CModulePreamble", "ModuleSetupCode.c")[1])
code.put(""" code.put("""
......
...@@ -6,24 +6,43 @@ static PyTypeObject* __Pyx_FetchCommonType(PyTypeObject* type); ...@@ -6,24 +6,43 @@ static PyTypeObject* __Pyx_FetchCommonType(PyTypeObject* type);
static PyTypeObject* __Pyx_FetchCommonType(PyTypeObject* type) { static PyTypeObject* __Pyx_FetchCommonType(PyTypeObject* type) {
static PyObject* fake_module = NULL; static PyObject* fake_module = NULL;
PyTypeObject* cached_type; PyObject* sys = NULL;
PyObject* sys_modules = NULL;
PyObject* args = NULL;
PyTypeObject* cached_type = NULL;
char* cython_module = "_cython_" CYTHON_ABI;
if (fake_module == NULL) { if (fake_module == NULL) {
PyObject* sys = PyImport_ImportModule("sys"); sys = PyImport_ImportModule("sys"); if (sys == NULL) goto bad;
PyObject* sys_modules = PyObject_GetAttrString(sys, "modules"); sys_modules = PyObject_GetAttrString(sys, "modules"); if (sys_modules == NULL) goto bad;
fake_module = PyDict_GetItemString(sys_modules, "_cython"); fake_module = PyDict_GetItemString(sys_modules, cython_module);
if (fake_module == NULL) { if (fake_module != NULL) {
PyObject* args = PyTuple_New(1); // borrowed
PyTuple_SET_ITEM(args, 0, __Pyx_PyStr_FromString("_cython")); Py_INCREF(fake_module);
} else {
args = PyTuple_New(1); if (args == NULL) goto bad;
PyTuple_SET_ITEM(args, 0, __Pyx_PyStr_FromString(cython_module));
if (PyTuple_GET_ITEM(args, 0) == NULL) goto bad;
fake_module = PyObject_Call((PyObject*) &PyModule_Type, args, NULL); fake_module = PyObject_Call((PyObject*) &PyModule_Type, args, NULL);
PyDict_SetItemString(sys_modules, "_cython", fake_module); if (PyDict_SetItemString(sys_modules, cython_module, fake_module) < 0)
goto bad;
} }
} }
if (PyObject_HasAttrString(fake_module, type->tp_name)) { if (PyObject_HasAttrString(fake_module, type->tp_name)) {
cached_type = (PyTypeObject*) PyObject_GetAttrString(fake_module, type->tp_name); cached_type = (PyTypeObject*) PyObject_GetAttrString(fake_module, type->tp_name);
} else { } else {
PyType_Ready(type); if (PyType_Ready(type) < 0) goto bad;
PyObject_SetAttrString(fake_module, type->tp_name, (PyObject*) type); if (PyObject_SetAttrString(fake_module, type->tp_name, (PyObject*) type) < 0)
goto bad;
cached_type = type; cached_type = type;
} }
cleanup:
Py_XDECREF(sys);
Py_XDECREF(sys_modules);
Py_XDECREF(args);
return cached_type; return cached_type;
bad:
cached_type = NULL;
goto cleanup;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment