summaryrefslogtreecommitdiffstats
path: root/Mac/Modules
diff options
context:
space:
mode:
authorJack Jansen <jack.jansen@cwi.nl>1999-12-03 23:35:47 (GMT)
committerJack Jansen <jack.jansen@cwi.nl>1999-12-03 23:35:47 (GMT)
commit75e62f22011caf8934b4856f0969178c3cfdcea8 (patch)
tree4bc92c31738ee37bdc9769b675d118f200217a51 /Mac/Modules
parentbf272983643776e9842cad6d1885f1b92f5eb67f (diff)
downloadcpython-75e62f22011caf8934b4856f0969178c3cfdcea8.zip
cpython-75e62f22011caf8934b4856f0969178c3cfdcea8.tar.gz
cpython-75e62f22011caf8934b4856f0969178c3cfdcea8.tar.bz2
Allow for 12 arguments max, in stead of 8. Untested.
Diffstat (limited to 'Mac/Modules')
-rw-r--r--Mac/Modules/calldll.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/Mac/Modules/calldll.c b/Mac/Modules/calldll.c
index 63c2e77..dc4d2b0 100644
--- a/Mac/Modules/calldll.c
+++ b/Mac/Modules/calldll.c
@@ -65,7 +65,7 @@ typedef anything (*anyroutine) Py_PROTO((...));
/* Other constants */
#define MAXNAME 31 /* Maximum size of names, for printing only */
-#define MAXARG 8 /* Maximum number of arguments */
+#define MAXARG 12 /* Maximum number of arguments */
/*
** Routines to convert arguments between Python and C.
@@ -666,7 +666,7 @@ cdc_call(self, args, kwargs)
{
char buf[256];
int i, pargindex;
- anything c_args[MAXARG] = {0, 0, 0, 0, 0, 0, 0, 0};
+ anything c_args[MAXARG] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
anything c_rv;
conventry *cp;
PyObject *curarg;
@@ -706,7 +706,8 @@ cdc_call(self, args, kwargs)
/* Call function */
func = self->routine->rtn;
c_rv = (*func)(c_args[0], c_args[1], c_args[2], c_args[3],
- c_args[4], c_args[5], c_args[6], c_args[7]);
+ c_args[4], c_args[5], c_args[6], c_args[7],
+ c_args[8], c_args[9], c_args[10], c_args[11]);
/* Decode return value, and store into returnvalues if needed */
pargindex = 0;
@@ -1066,17 +1067,19 @@ cdll_newcall(self, args)
PyObject *args;
{
cdrobject *routine;
- conventry *argconv[MAXARG] = {0, 0, 0, 0, 0, 0, 0, 0};
+ conventry *argconv[MAXARG] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
rv2py_converter rvconv;
int npargs, ncargs;
/* Note: the next format depends on MAXARG */
- if (!PyArg_ParseTuple(args, "O!O&|O&O&O&O&O&O&O&O&", &Cdrtype, &routine,
+ if (!PyArg_ParseTuple(args, "O!O&|O&O&O&O&O&O&O&O&O&O&O&O&", &Cdrtype, &routine,
argparse_rvconv, &rvconv,
argparse_conv, &argconv[0], argparse_conv, &argconv[1],
argparse_conv, &argconv[2], argparse_conv, &argconv[3],
argparse_conv, &argconv[4], argparse_conv, &argconv[5],
- argparse_conv, &argconv[6], argparse_conv, &argconv[7]))
+ argparse_conv, &argconv[6], argparse_conv, &argconv[7],
+ argparse_conv, &argconv[8], argparse_conv, &argconv[9],
+ argparse_conv, &argconv[10], argparse_conv, &argconv[11]))
return NULL;
npargs = 0;
for(ncargs=0; ncargs < MAXARG && argconv[ncargs]; ncargs++) {