Cython has moved to github.
pyrex
view Tests/3/assert.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 int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
42 static void __Pyx_AddTraceback(char *funcname); /*proto*/
44 /* Declarations from assert */
47 /* Declarations from implementation of assert */
53 static __Pyx_StringTabEntry __pyx_string_tab[] = {
54 {0, 0, 0, 0}
55 };
59 /* Implementation of assert */
61 static PyObject *__pyx_f_6assert_f(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
62 static PyObject *__pyx_f_6assert_f(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
63 PyObject *__pyx_v_a = 0;
64 PyObject *__pyx_v_b = 0;
65 int __pyx_v_i;
66 PyObject *__pyx_r;
67 int __pyx_1;
68 PyObject *__pyx_2 = 0;
69 static char *__pyx_argnames[] = {"a","b",0};
70 if (!PyArg_ParseTupleAndKeywords(__pyx_args, __pyx_kwds, "OO", __pyx_argnames, &__pyx_v_a, &__pyx_v_b)) return 0;
71 Py_INCREF(__pyx_v_a);
72 Py_INCREF(__pyx_v_b);
74 /* "/Local/Projects/D/Pyrex/Source/Tests/3/assert.pyx":3 */
75 #ifndef PYREX_WITHOUT_ASSERTIONS
76 __pyx_1 = PyObject_IsTrue(__pyx_v_a); if (__pyx_1 < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 3; goto __pyx_L1;}
77 if (!__pyx_1) {
78 PyErr_SetNone(PyExc_AssertionError);
79 {__pyx_filename = __pyx_f[0]; __pyx_lineno = 3; goto __pyx_L1;}
80 }
81 #endif
83 /* "/Local/Projects/D/Pyrex/Source/Tests/3/assert.pyx":4 */
84 #ifndef PYREX_WITHOUT_ASSERTIONS
85 __pyx_2 = PyNumber_Add(__pyx_v_a, __pyx_v_b); if (!__pyx_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; goto __pyx_L1;}
86 __pyx_1 = PyObject_IsTrue(__pyx_2); if (__pyx_1 < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; goto __pyx_L1;}
87 Py_DECREF(__pyx_2); __pyx_2 = 0;
88 if (!__pyx_1) {
89 PyErr_SetNone(PyExc_AssertionError);
90 {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; goto __pyx_L1;}
91 }
92 #endif
94 /* "/Local/Projects/D/Pyrex/Source/Tests/3/assert.pyx":5 */
95 #ifndef PYREX_WITHOUT_ASSERTIONS
96 if (!__pyx_v_i) {
97 PyErr_SetNone(PyExc_AssertionError);
98 {__pyx_filename = __pyx_f[0]; __pyx_lineno = 5; goto __pyx_L1;}
99 }
100 #endif
102 __pyx_r = Py_None; Py_INCREF(Py_None);
103 goto __pyx_L0;
104 __pyx_L1:;
105 Py_XDECREF(__pyx_2);
106 __Pyx_AddTraceback("assert.f");
107 __pyx_r = 0;
108 __pyx_L0:;
109 Py_DECREF(__pyx_v_a);
110 Py_DECREF(__pyx_v_b);
111 return __pyx_r;
112 }
114 static struct PyMethodDef __pyx_methods[] = {
115 {"f", (PyCFunction)__pyx_f_6assert_f, METH_VARARGS|METH_KEYWORDS, 0},
116 {0, 0, 0, 0}
117 };
119 static void __pyx_init_filenames(void); /*proto*/
121 PyMODINIT_FUNC initassert(void); /*proto*/
122 PyMODINIT_FUNC initassert(void) {
123 __pyx_init_filenames();
124 __pyx_m = Py_InitModule4("assert", __pyx_methods, 0, 0, PYTHON_API_VERSION);
125 if (!__pyx_m) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
126 Py_INCREF(__pyx_m);
127 __pyx_b = PyImport_AddModule("__builtin__");
128 if (!__pyx_b) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
129 if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
130 if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
131 return;
132 __pyx_L1:;
133 __Pyx_AddTraceback("assert");
134 }
136 static char *__pyx_filenames[] = {
137 "assert.pyx",
138 };
140 /* Runtime support code */
142 static void __pyx_init_filenames(void) {
143 __pyx_f = __pyx_filenames;
144 }
146 static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
147 while (t->p) {
148 *t->p = PyString_FromStringAndSize(t->s, t->n - 1);
149 if (!*t->p)
150 return -1;
151 if (t->i)
152 PyString_InternInPlace(t->p);
153 ++t;
154 }
155 return 0;
156 }
158 #include "compile.h"
159 #include "frameobject.h"
160 #include "traceback.h"
162 static void __Pyx_AddTraceback(char *funcname) {
163 PyObject *py_srcfile = 0;
164 PyObject *py_funcname = 0;
165 PyObject *py_globals = 0;
166 PyObject *empty_tuple = 0;
167 PyObject *empty_string = 0;
168 PyCodeObject *py_code = 0;
169 PyFrameObject *py_frame = 0;
171 py_srcfile = PyString_FromString(__pyx_filename);
172 if (!py_srcfile) goto bad;
173 py_funcname = PyString_FromString(funcname);
174 if (!py_funcname) goto bad;
175 py_globals = PyModule_GetDict(__pyx_m);
176 if (!py_globals) goto bad;
177 empty_tuple = PyTuple_New(0);
178 if (!empty_tuple) goto bad;
179 empty_string = PyString_FromString("");
180 if (!empty_string) goto bad;
181 py_code = PyCode_New(
182 0, /*int argcount,*/
183 0, /*int nlocals,*/
184 0, /*int stacksize,*/
185 0, /*int flags,*/
186 empty_string, /*PyObject *code,*/
187 empty_tuple, /*PyObject *consts,*/
188 empty_tuple, /*PyObject *names,*/
189 empty_tuple, /*PyObject *varnames,*/
190 empty_tuple, /*PyObject *freevars,*/
191 empty_tuple, /*PyObject *cellvars,*/
192 py_srcfile, /*PyObject *filename,*/
193 py_funcname, /*PyObject *name,*/
194 __pyx_lineno, /*int firstlineno,*/
195 empty_string /*PyObject *lnotab*/
196 );
197 if (!py_code) goto bad;
198 py_frame = PyFrame_New(
199 PyThreadState_Get(), /*PyThreadState *tstate,*/
200 py_code, /*PyCodeObject *code,*/
201 py_globals, /*PyObject *globals,*/
202 0 /*PyObject *locals*/
203 );
204 if (!py_frame) goto bad;
205 py_frame->f_lineno = __pyx_lineno;
206 PyTraceBack_Here(py_frame);
207 bad:
208 Py_XDECREF(py_srcfile);
209 Py_XDECREF(py_funcname);
210 Py_XDECREF(empty_tuple);
211 Py_XDECREF(empty_string);
212 Py_XDECREF(py_code);
213 Py_XDECREF(py_frame);
214 }
