File: defarg.swg

package info (click to toggle)
swig1.3 1.3.11-1
  • links: PTS
  • area: main
  • in suites: woody
  • size: 6,852 kB
  • ctags: 4,764
  • sloc: ansic: 20,489; cpp: 10,052; sh: 7,256; yacc: 2,669; makefile: 2,381; python: 873; java: 762; tcl: 686; perl: 474; lisp: 444; ruby: 370; php: 367
file content (36 lines) | stat: -rw-r--r-- 1,088 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/* This file defines an internal function for processing default arguments
   with shadow classes.

   There seems to be no straightforward way to write a shadow functions
   involving default arguments. For example :

             def foo(arg1,arg2,*args):
                     shadowc.foo(arg1,arg2,args)

   This fails because args is now a tuple and SWIG doesn't know what to
   do with it.

   This file allows a different approach :

            def foo(arg1,arg2,*args):
                    shadowc.__call_defarg(shadowc.foo,(arg1,arg2,)+args)

   Basically, we form a new tuple from the object, call this special
   __call_defarg method and it passes control to the real wrapper function.
   An ugly hack, but it works.
*/

static PyObject *swig_call_defargs(PyObject *self, PyObject *args) {
	PyObject *func;
	PyObject *parms;

	if (!PyArg_ParseTuple(args,"OO",&func,&parms))
	  return NULL;

	if (!PyCallable_Check(func)) {
             PyErr_SetString(PyExc_TypeError, "__call_defarg : Need a callable object!");
	     return NULL;
	}
	return PyEval_CallObject(func,parms);

}