Cython has moved to github.

pyrex

view Tests/7/Reference/notnonearg.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_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed, char *name); /*proto*/
43 static PyTypeObject *__Pyx_ImportType(char *module_name, char *class_name, long size); /*proto*/
45 static PyObject *__Pyx_ImportModule(char *name); /*proto*/
47 static void __Pyx_AddTraceback(char *funcname); /*proto*/
49 /* Declarations from notnonearg */
51 struct Spam {
52 PyObject_HEAD
53 };
55 struct Eggs {
56 PyObject_HEAD
57 };
61 static PyTypeObject *__pyx_ptype_10notnonearg_Spam = 0;
62 static PyTypeObject *__pyx_ptype_10notnonearg_Eggs = 0;
65 static __Pyx_StringTabEntry __pyx_string_tab[] = {
66 {0, 0, 0, 0}
67 };
69 /* Implementation of notnonearg */
71 static PyObject *__pyx_f_10notnonearg_ham(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
72 static PyObject *__pyx_f_10notnonearg_ham(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
73 struct Spam *__pyx_v_s = 0;
74 struct Eggs *__pyx_v_e = 0;
75 PyObject *__pyx_r;
76 static char *__pyx_argnames[] = {"s","e",0};
77 if (!PyArg_ParseTupleAndKeywords(__pyx_args, __pyx_kwds, "OO", __pyx_argnames, &__pyx_v_s, &__pyx_v_e)) return 0;
78 Py_INCREF(__pyx_v_s);
79 Py_INCREF(__pyx_v_e);
80 if (!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_s), __pyx_ptype_10notnonearg_Spam, 1, "s")) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; goto __pyx_L1;}
81 if (!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_e), __pyx_ptype_10notnonearg_Eggs, 0, "e")) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; goto __pyx_L1;}
83 __pyx_r = Py_None; Py_INCREF(Py_None);
84 goto __pyx_L0;
85 __pyx_L1:;
86 __Pyx_AddTraceback("notnonearg.ham");
87 __pyx_r = 0;
88 __pyx_L0:;
89 Py_DECREF(__pyx_v_s);
90 Py_DECREF(__pyx_v_e);
91 return __pyx_r;
92 }
94 static struct PyMethodDef __pyx_methods[] = {
95 {"ham", (PyCFunction)__pyx_f_10notnonearg_ham, METH_VARARGS|METH_KEYWORDS, 0},
96 {0, 0, 0, 0}
97 };
99 static void __pyx_init_filenames(void); /*proto*/
101 PyMODINIT_FUNC initnotnonearg(void); /*proto*/
102 PyMODINIT_FUNC initnotnonearg(void) {
103 __pyx_init_filenames();
104 __pyx_m = Py_InitModule4("notnonearg", __pyx_methods, 0, 0, PYTHON_API_VERSION);
105 if (!__pyx_m) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
106 Py_INCREF(__pyx_m);
107 __pyx_b = PyImport_AddModule("__builtin__");
108 if (!__pyx_b) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
109 if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
110 if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;};
111 __pyx_ptype_10notnonearg_Spam = __Pyx_ImportType("external", "Spam", sizeof(struct Spam)); if (!__pyx_ptype_10notnonearg_Spam) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; goto __pyx_L1;}
112 __pyx_ptype_10notnonearg_Eggs = __Pyx_ImportType("external", "Eggs", sizeof(struct Eggs)); if (!__pyx_ptype_10notnonearg_Eggs) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; goto __pyx_L1;}
114 /* "/Local/Projects/D/Pyrex/Source/Tests/7/notnonearg.pyx":4 */
115 return;
116 __pyx_L1:;
117 __Pyx_AddTraceback("notnonearg");
118 }
120 static char *__pyx_filenames[] = {
121 "notnonearg.pyx",
122 };
124 /* Runtime support code */
126 static void __pyx_init_filenames(void) {
127 __pyx_f = __pyx_filenames;
128 }
130 static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed, char *name) {
131 if (!type) {
132 PyErr_Format(PyExc_SystemError, "Missing type object");
133 return 0;
134 }
135 if ((none_allowed && obj == Py_None) || PyObject_TypeCheck(obj, type))
136 return 1;
137 PyErr_Format(PyExc_TypeError,
138 "Argument '%s' has incorrect type (expected %s, got %s)",
139 name, type->tp_name, obj->ob_type->tp_name);
140 return 0;
141 }
143 #ifndef __PYX_HAVE_RT_ImportType
144 #define __PYX_HAVE_RT_ImportType
145 static PyTypeObject *__Pyx_ImportType(char *module_name, char *class_name,
146 long size)
147 {
148 PyObject *py_module = 0;
149 PyObject *result = 0;
151 py_module = __Pyx_ImportModule(module_name);
152 if (!py_module)
153 goto bad;
154 result = PyObject_GetAttrString(py_module, class_name);
155 if (!result)
156 goto bad;
157 if (!PyType_Check(result)) {
158 PyErr_Format(PyExc_TypeError,
159 "%s.%s is not a type object",
160 module_name, class_name);
161 goto bad;
162 }
163 if (((PyTypeObject *)result)->tp_basicsize != size) {
164 PyErr_Format(PyExc_ValueError,
165 "%s.%s does not appear to be the correct type object",
166 module_name, class_name);
167 goto bad;
168 }
169 return (PyTypeObject *)result;
170 bad:
171 Py_XDECREF(result);
172 return 0;
173 }
174 #endif
176 #ifndef __PYX_HAVE_RT_ImportModule
177 #define __PYX_HAVE_RT_ImportModule
178 static PyObject *__Pyx_ImportModule(char *name) {
179 PyObject *py_name = 0;
181 py_name = PyString_FromString(name);
182 if (!py_name)
183 goto bad;
184 return PyImport_Import(py_name);
185 bad:
186 Py_XDECREF(py_name);
187 return 0;
188 }
189 #endif
191 #include "compile.h"
192 #include "frameobject.h"
193 #include "traceback.h"
195 static void __Pyx_AddTraceback(char *funcname) {
196 PyObject *py_srcfile = 0;
197 PyObject *py_funcname = 0;
198 PyObject *py_globals = 0;
199 PyObject *empty_tuple = 0;
200 PyObject *empty_string = 0;
201 PyCodeObject *py_code = 0;
202 PyFrameObject *py_frame = 0;
204 py_srcfile = PyString_FromString(__pyx_filename);
205 if (!py_srcfile) goto bad;
206 py_funcname = PyString_FromString(funcname);
207 if (!py_funcname) goto bad;
208 py_globals = PyModule_GetDict(__pyx_m);
209 if (!py_globals) goto bad;
210 empty_tuple = PyTuple_New(0);
211 if (!empty_tuple) goto bad;
212 empty_string = PyString_FromString("");
213 if (!empty_string) goto bad;
214 py_code = PyCode_New(
215 0, /*int argcount,*/
216 0, /*int nlocals,*/
217 0, /*int stacksize,*/
218 0, /*int flags,*/
219 empty_string, /*PyObject *code,*/
220 empty_tuple, /*PyObject *consts,*/
221 empty_tuple, /*PyObject *names,*/
222 empty_tuple, /*PyObject *varnames,*/
223 empty_tuple, /*PyObject *freevars,*/
224 empty_tuple, /*PyObject *cellvars,*/
225 py_srcfile, /*PyObject *filename,*/
226 py_funcname, /*PyObject *name,*/
227 __pyx_lineno, /*int firstlineno,*/
228 empty_string /*PyObject *lnotab*/
229 );
230 if (!py_code) goto bad;
231 py_frame = PyFrame_New(
232 PyThreadState_Get(), /*PyThreadState *tstate,*/
233 py_code, /*PyCodeObject *code,*/
234 py_globals, /*PyObject *globals,*/
235 0 /*PyObject *locals*/
236 );
237 if (!py_frame) goto bad;
238 py_frame->f_lineno = __pyx_lineno;
239 PyTraceBack_Here(py_frame);
240 bad:
241 Py_XDECREF(py_srcfile);
242 Py_XDECREF(py_funcname);
243 Py_XDECREF(empty_tuple);
244 Py_XDECREF(empty_string);
245 Py_XDECREF(py_code);
246 Py_XDECREF(py_frame);
247 }