Cython has moved to github.
pyrex
view Tests/2/delslice.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 delslice */
49 /* Declarations from implementation of delslice */
51 static void __pyx_f_8delslice_spam(void); /*proto*/
56 static __Pyx_StringTabEntry __pyx_string_tab[] = {
57 {0, 0, 0, 0}
58 };
62 /* Implementation of delslice */
64 static void __pyx_f_8delslice_spam(void) {
65 PyObject *__pyx_v_x;
66 __pyx_v_x = Py_None; Py_INCREF(Py_None);
68 /* "/Local/Projects/D/Pyrex/Source/Tests/2/delslice.pyx":3 */
69 if (PySequence_DelSlice(__pyx_v_x, 17, 42) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 3; goto __pyx_L1;}
71 goto __pyx_L0;
72 __pyx_L1:;
73 __Pyx_WriteUnraisable("delslice.spam");
74 __pyx_L0:;
75 Py_DECREF(__pyx_v_x);
76 }
78 static struct PyMethodDef __pyx_methods[] = {
79 {0, 0, 0, 0}
80 };
82 static void __pyx_init_filenames(void); /*proto*/
84 PyMODINIT_FUNC initdelslice(void); /*proto*/
85 PyMODINIT_FUNC initdelslice(void) {
86 __pyx_init_filenames();
87 __pyx_m = Py_InitModule4("delslice", __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 return;
95 __pyx_L1:;
96 __Pyx_AddTraceback("delslice");
97 }
99 static char *__pyx_filenames[] = {
100 "delslice.pyx",
101 };
103 /* Runtime support code */
105 static void __pyx_init_filenames(void) {
106 __pyx_f = __pyx_filenames;
107 }
109 static void __Pyx_WriteUnraisable(char *name) {
110 PyObject *old_exc, *old_val, *old_tb;
111 PyObject *ctx;
112 PyErr_Fetch(&old_exc, &old_val, &old_tb);
113 ctx = PyString_FromString(name);
114 PyErr_Restore(old_exc, old_val, old_tb);
115 if (!ctx)
116 ctx = Py_None;
117 PyErr_WriteUnraisable(ctx);
118 }
120 static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
121 while (t->p) {
122 *t->p = PyString_FromStringAndSize(t->s, t->n - 1);
123 if (!*t->p)
124 return -1;
125 if (t->i)
126 PyString_InternInPlace(t->p);
127 ++t;
128 }
129 return 0;
130 }
132 #include "compile.h"
133 #include "frameobject.h"
134 #include "traceback.h"
136 static void __Pyx_AddTraceback(char *funcname) {
137 PyObject *py_srcfile = 0;
138 PyObject *py_funcname = 0;
139 PyObject *py_globals = 0;
140 PyObject *empty_tuple = 0;
141 PyObject *empty_string = 0;
142 PyCodeObject *py_code = 0;
143 PyFrameObject *py_frame = 0;
145 py_srcfile = PyString_FromString(__pyx_filename);
146 if (!py_srcfile) goto bad;
147 py_funcname = PyString_FromString(funcname);
148 if (!py_funcname) goto bad;
149 py_globals = PyModule_GetDict(__pyx_m);
150 if (!py_globals) goto bad;
151 empty_tuple = PyTuple_New(0);
152 if (!empty_tuple) goto bad;
153 empty_string = PyString_FromString("");
154 if (!empty_string) goto bad;
155 py_code = PyCode_New(
156 0, /*int argcount,*/
157 0, /*int nlocals,*/
158 0, /*int stacksize,*/
159 0, /*int flags,*/
160 empty_string, /*PyObject *code,*/
161 empty_tuple, /*PyObject *consts,*/
162 empty_tuple, /*PyObject *names,*/
163 empty_tuple, /*PyObject *varnames,*/
164 empty_tuple, /*PyObject *freevars,*/
165 empty_tuple, /*PyObject *cellvars,*/
166 py_srcfile, /*PyObject *filename,*/
167 py_funcname, /*PyObject *name,*/
168 __pyx_lineno, /*int firstlineno,*/
169 empty_string /*PyObject *lnotab*/
170 );
171 if (!py_code) goto bad;
172 py_frame = PyFrame_New(
173 PyThreadState_Get(), /*PyThreadState *tstate,*/
174 py_code, /*PyCodeObject *code,*/
175 py_globals, /*PyObject *globals,*/
176 0 /*PyObject *locals*/
177 );
178 if (!py_frame) goto bad;
179 py_frame->f_lineno = __pyx_lineno;
180 PyTraceBack_Here(py_frame);
181 bad:
182 Py_XDECREF(py_srcfile);
183 Py_XDECREF(py_funcname);
184 Py_XDECREF(empty_tuple);
185 Py_XDECREF(empty_string);
186 Py_XDECREF(py_code);
187 Py_XDECREF(py_frame);
188 }
