Cython has moved to github.

pyrex

view Tests/9/cstructreturn.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 12072e0e4fd5
children 94d46b3c5354
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; int i; char *s; long n;} __Pyx_StringTabEntry; /*proto*/
34 static PyObject *__pyx_m;
35 static PyObject *__pyx_b;
36 static int __pyx_lineno;
37 static char *__pyx_filename;
38 static char **__pyx_f;
40 static void __Pyx_WriteUnraisable(char *name); /*proto*/
42 static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
44 static void __Pyx_AddTraceback(char *funcname); /*proto*/
46 /* Declarations from cstructreturn */
49 /* Declarations from implementation of cstructreturn */
51 typedef struct {
52 int blarg;
53 } __pyx_t_13cstructreturn_Foo;
55 static __pyx_t_13cstructreturn_Foo __pyx_f_13cstructreturn_f(void); /*proto*/
60 static __Pyx_StringTabEntry __pyx_string_tab[] = {
61 {0, 0, 0, 0}
62 };
66 /* Implementation of cstructreturn */
68 static __pyx_t_13cstructreturn_Foo __pyx_f_13cstructreturn_f(void) {
69 PyObject *__pyx_v_blarg;
70 __pyx_t_13cstructreturn_Foo __pyx_r;
71 PyObject *__pyx_1 = 0;
72 __pyx_v_blarg = Py_None; Py_INCREF(Py_None);
73 __pyx_1 = PyInt_FromLong((1 + 2)); if (!__pyx_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 5; goto __pyx_L1;}
74 Py_DECREF(__pyx_v_blarg);
75 __pyx_v_blarg = __pyx_1;
76 __pyx_1 = 0;
78 goto __pyx_L0;
79 __pyx_L1:;
80 Py_XDECREF(__pyx_1);
81 __Pyx_WriteUnraisable("cstructreturn.f");
82 __pyx_L0:;
83 Py_DECREF(__pyx_v_blarg);
84 return __pyx_r;
85 }
87 static struct PyMethodDef __pyx_methods[] = {
88 {0, 0, 0, 0}
89 };
91 static void __pyx_init_filenames(void); /*proto*/
93 PyMODINIT_FUNC initcstructreturn(void); /*proto*/
94 PyMODINIT_FUNC initcstructreturn(void) {
95 __pyx_init_filenames();
96 __pyx_m = Py_InitModule4("cstructreturn", __pyx_methods, 0, 0, PYTHON_API_VERSION);
97 if (!__pyx_m) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
98 Py_INCREF(__pyx_m);
99 __pyx_b = PyImport_AddModule("__builtin__");
100 if (!__pyx_b) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
101 if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
102 if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
104 /* "/Local/Projects/D/Pyrex/Source/Tests/9/cstructreturn.pyx":4 */
105 return;
106 __pyx_L1:;
107 __Pyx_AddTraceback("cstructreturn");
108 }
110 static char *__pyx_filenames[] = {
111 "cstructreturn.pyx",
112 };
114 /* Runtime support code */
116 static void __pyx_init_filenames(void) {
117 __pyx_f = __pyx_filenames;
118 }
120 static void __Pyx_WriteUnraisable(char *name) {
121 PyObject *old_exc, *old_val, *old_tb;
122 PyObject *ctx;
123 PyErr_Fetch(&old_exc, &old_val, &old_tb);
124 ctx = PyString_FromString(name);
125 PyErr_Restore(old_exc, old_val, old_tb);
126 if (!ctx)
127 ctx = Py_None;
128 PyErr_WriteUnraisable(ctx);
129 }
131 static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
132 while (t->p) {
133 *t->p = PyString_FromStringAndSize(t->s, t->n - 1);
134 if (!*t->p)
135 return -1;
136 if (t->i)
137 PyString_InternInPlace(t->p);
138 ++t;
139 }
140 return 0;
141 }
143 #include "compile.h"
144 #include "frameobject.h"
145 #include "traceback.h"
147 static void __Pyx_AddTraceback(char *funcname) {
148 PyObject *py_srcfile = 0;
149 PyObject *py_funcname = 0;
150 PyObject *py_globals = 0;
151 PyObject *empty_tuple = 0;
152 PyObject *empty_string = 0;
153 PyCodeObject *py_code = 0;
154 PyFrameObject *py_frame = 0;
156 py_srcfile = PyString_FromString(__pyx_filename);
157 if (!py_srcfile) goto bad;
158 py_funcname = PyString_FromString(funcname);
159 if (!py_funcname) goto bad;
160 py_globals = PyModule_GetDict(__pyx_m);
161 if (!py_globals) goto bad;
162 empty_tuple = PyTuple_New(0);
163 if (!empty_tuple) goto bad;
164 empty_string = PyString_FromString("");
165 if (!empty_string) goto bad;
166 py_code = PyCode_New(
167 0, /*int argcount,*/
168 0, /*int nlocals,*/
169 0, /*int stacksize,*/
170 0, /*int flags,*/
171 empty_string, /*PyObject *code,*/
172 empty_tuple, /*PyObject *consts,*/
173 empty_tuple, /*PyObject *names,*/
174 empty_tuple, /*PyObject *varnames,*/
175 empty_tuple, /*PyObject *freevars,*/
176 empty_tuple, /*PyObject *cellvars,*/
177 py_srcfile, /*PyObject *filename,*/
178 py_funcname, /*PyObject *name,*/
179 __pyx_lineno, /*int firstlineno,*/
180 empty_string /*PyObject *lnotab*/
181 );
182 if (!py_code) goto bad;
183 py_frame = PyFrame_New(
184 PyThreadState_Get(), /*PyThreadState *tstate,*/
185 py_code, /*PyCodeObject *code,*/
186 py_globals, /*PyObject *globals,*/
187 0 /*PyObject *locals*/
188 );
189 if (!py_frame) goto bad;
190 py_frame->f_lineno = __pyx_lineno;
191 PyTraceBack_Here(py_frame);
192 bad:
193 Py_XDECREF(py_srcfile);
194 Py_XDECREF(py_funcname);
195 Py_XDECREF(empty_tuple);
196 Py_XDECREF(empty_string);
197 Py_XDECREF(py_code);
198 Py_XDECREF(py_frame);
199 }