Cython has moved to github.
pyrex
view Tests/Runnable2/Reference/l_cfuncexport.c @ 86:da6e97bb7e6d
Multiple compilation fixed
| author | Gregory Ewing <greg.ewing@canterbury.ac.nz> |
|---|---|
| date | Sat May 24 15:50:12 2008 +1200 (4 years ago) |
| parents | 6c5f5271ebab |
| children | 3b20cb4923eb |
line source
1 /* Generated by Pyrex */
3 #define PY_SSIZE_T_CLEAN
4 #include "Python.h"
5 #include "structmember.h"
6 #ifndef PY_LONG_LONG
7 #define PY_LONG_LONG LONG_LONG
8 #endif
9 #if PY_VERSION_HEX < 0x02050000
10 typedef int Py_ssize_t;
11 #define PY_SSIZE_T_MAX INT_MAX
12 #define PY_SSIZE_T_MIN INT_MIN
13 #define PyInt_FromSsize_t(z) PyInt_FromLong(z)
14 #define PyInt_AsSsize_t(o) PyInt_AsLong(o)
15 #endif
16 #ifndef WIN32
17 #ifndef __stdcall
18 #define __stdcall
19 #endif
20 #ifndef __cdecl
21 #define __cdecl
22 #endif
23 #endif
24 #ifdef __cplusplus
25 #define __PYX_EXTERN_C extern "C"
26 #else
27 #define __PYX_EXTERN_C extern
28 #endif
29 #include <math.h>
32 typedef struct {PyObject **p; char *s;} __Pyx_InternTabEntry; /*proto*/
33 typedef struct {PyObject **p; char *s; long n;} __Pyx_StringTabEntry; /*proto*/
35 static PyObject *__pyx_m;
36 static PyObject *__pyx_b;
37 static int __pyx_lineno;
38 static char *__pyx_filename;
39 static char **__pyx_f;
41 static int __Pyx_ExportFunction(char *n, void *f, char *s); /*proto*/
43 static void __Pyx_AddTraceback(char *funcname); /*proto*/
45 /* Declarations from l_cfuncexport */
47 static int __pyx_f_13l_cfuncexport_f(int); /*proto*/
48 static int __pyx_f_13l_cfuncexport_g(int); /*proto*/
51 static __Pyx_StringTabEntry __pyx_string_tab[] = {
52 {0, 0, 0, 0}
53 };
55 /* Implementation of l_cfuncexport */
57 static int __pyx_f_13l_cfuncexport_f(int __pyx_v_x) {
58 int __pyx_r;
59 __pyx_r = (__pyx_v_x * __pyx_v_x);
60 goto __pyx_L0;
62 __pyx_r = 0;
63 __pyx_L0:;
64 return __pyx_r;
65 }
67 static int __pyx_f_13l_cfuncexport_g(int __pyx_v_x) {
68 int __pyx_r;
69 __pyx_r = (5 * __pyx_v_x);
70 goto __pyx_L0;
72 __pyx_r = 0;
73 __pyx_L0:;
74 return __pyx_r;
75 }
77 static struct PyMethodDef __pyx_methods[] = {
78 {0, 0, 0, 0}
79 };
81 static void __pyx_init_filenames(void); /*proto*/
83 PyMODINIT_FUNC initl_cfuncexport(void); /*proto*/
84 PyMODINIT_FUNC initl_cfuncexport(void) {
85 PyObject *__pyx_1 = 0;
86 __pyx_init_filenames();
87 __pyx_m = Py_InitModule4("l_cfuncexport", __pyx_methods, 0, 0, PYTHON_API_VERSION);
88 if (!__pyx_m) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
89 Py_INCREF(__pyx_m);
90 __pyx_b = PyImport_AddModule("__builtin__");
91 if (!__pyx_b) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
92 if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
93 if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
94 if (__Pyx_ExportFunction("f", (void*)__pyx_f_13l_cfuncexport_f, "int (int)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;}
95 if (__Pyx_ExportFunction("g", (void*)__pyx_f_13l_cfuncexport_g, "int (int)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;}
97 /* "/Local/Projects/D/Pyrex/Source/Tests/Runnable2/l_cfuncexport.pyx":4 */
98 return;
99 __pyx_L1:;
100 Py_XDECREF(__pyx_1);
101 __Pyx_AddTraceback("l_cfuncexport");
102 }
104 static char *__pyx_filenames[] = {
105 "l_cfuncexport.pyx",
106 };
108 /* Runtime support code */
110 static void __pyx_init_filenames(void) {
111 __pyx_f = __pyx_filenames;
112 }
114 static int __Pyx_ExportFunction(char *n, void *f, char *s) {
115 PyObject *d = 0;
116 PyObject *p = 0;
117 d = PyObject_GetAttrString(__pyx_m, "__pyx_capi__");
118 if (!d) {
119 PyErr_Clear();
120 d = PyDict_New();
121 if (!d)
122 goto bad;
123 Py_INCREF(d);
124 if (PyModule_AddObject(__pyx_m, "__pyx_capi__", d) < 0)
125 goto bad;
126 }
127 p = PyCObject_FromVoidPtrAndDesc(f, s, 0);
128 if (!p)
129 goto bad;
130 if (PyDict_SetItemString(d, n, p) < 0)
131 goto bad;
132 Py_DECREF(d);
133 return 0;
134 bad:
135 Py_XDECREF(p);
136 Py_XDECREF(d);
137 return -1;
138 }
140 #include "compile.h"
141 #include "frameobject.h"
142 #include "traceback.h"
144 static void __Pyx_AddTraceback(char *funcname) {
145 PyObject *py_srcfile = 0;
146 PyObject *py_funcname = 0;
147 PyObject *py_globals = 0;
148 PyObject *empty_tuple = 0;
149 PyObject *empty_string = 0;
150 PyCodeObject *py_code = 0;
151 PyFrameObject *py_frame = 0;
153 py_srcfile = PyString_FromString(__pyx_filename);
154 if (!py_srcfile) goto bad;
155 py_funcname = PyString_FromString(funcname);
156 if (!py_funcname) goto bad;
157 py_globals = PyModule_GetDict(__pyx_m);
158 if (!py_globals) goto bad;
159 empty_tuple = PyTuple_New(0);
160 if (!empty_tuple) goto bad;
161 empty_string = PyString_FromString("");
162 if (!empty_string) goto bad;
163 py_code = PyCode_New(
164 0, /*int argcount,*/
165 0, /*int nlocals,*/
166 0, /*int stacksize,*/
167 0, /*int flags,*/
168 empty_string, /*PyObject *code,*/
169 empty_tuple, /*PyObject *consts,*/
170 empty_tuple, /*PyObject *names,*/
171 empty_tuple, /*PyObject *varnames,*/
172 empty_tuple, /*PyObject *freevars,*/
173 empty_tuple, /*PyObject *cellvars,*/
174 py_srcfile, /*PyObject *filename,*/
175 py_funcname, /*PyObject *name,*/
176 __pyx_lineno, /*int firstlineno,*/
177 empty_string /*PyObject *lnotab*/
178 );
179 if (!py_code) goto bad;
180 py_frame = PyFrame_New(
181 PyThreadState_Get(), /*PyThreadState *tstate,*/
182 py_code, /*PyCodeObject *code,*/
183 py_globals, /*PyObject *globals,*/
184 0 /*PyObject *locals*/
185 );
186 if (!py_frame) goto bad;
187 py_frame->f_lineno = __pyx_lineno;
188 PyTraceBack_Here(py_frame);
189 bad:
190 Py_XDECREF(py_srcfile);
191 Py_XDECREF(py_funcname);
192 Py_XDECREF(empty_tuple);
193 Py_XDECREF(empty_string);
194 Py_XDECREF(py_code);
195 Py_XDECREF(py_frame);
196 }
