Cleanup. Replaced Parm and ParmList data structures with new implementation.

git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@606 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
Dave Beazley 2000-07-24 21:48:56 +00:00
commit 6bc7b11a9b
18 changed files with 486 additions and 724 deletions

View file

@ -96,7 +96,7 @@ typedef struct {
void *data; /* Data pointer */
int type : 4; /* Object type (max 16 -- deal with it) */
int flag_intern : 1; /* Interned object */
int flag_marked : 1; /* Mark flag */
int flag_marked : 1; /* Mark flag. Used to avoid recursive loops in places */
int flag_user : 1; /* User flag */
int flag_reserved : 1; /* Reserved flag */
int refcount : 24; /* Reference count (max 16 million) */

View file

@ -436,10 +436,10 @@ GUILE::create_function (char *name, char *iname, DataType *d, ParmList *l)
int i = 0;
int first_arg = 1;
for (p = ParmList_first(l); p != 0; ++i, p = ParmList_next(l)) {
DataType *pt = Parm_Gettype(p);
for (p = Firstitem(l); p != 0; ++i, p = Nextitem(l)) {
DataType *pt = Gettype(p);
if (Parm_Getignore(p))
if (Getignore(p))
continue;
if ((pt->type != T_VOID) || (pt->is_pointer)) {
if (!first_arg)
@ -468,19 +468,19 @@ GUILE::create_function (char *name, char *iname, DataType *d, ParmList *l)
i = 0;
int j = 0;
for (i = 0; i < pcount; ++i) {
Parm *p = ParmList_get(l,i);
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce names of source and target
sprintf(source,"s_%d",i);
sprintf(target,"%s",Parm_Getlname(p));
sprintf(target,"%s",Getlname(p));
sprintf(argnum,"%d",i);
strcpy(arg,pn);
// Handle parameter types.
if (Parm_Getignore(p))
if (Getignore(p))
Printv(f->code, "/* ", pn, " ignored... */\n", 0);
else {
++numargs;
@ -819,11 +819,11 @@ GUILE::usage_func (char *iname, DataType *d, ParmList *l, DOHString *usage)
// Now go through and print parameters
for (p = ParmList_first(l); p != 0; p = ParmList_next(l)) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
for (p = Firstitem(l); p != 0; p = Nextitem(l)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (Parm_Getignore(p))
if (Getignore(p))
continue;
// Print the type. If the parameter has been named, use that as well.
@ -868,9 +868,9 @@ GUILE::usage_returns (char *iname, DataType *d, ParmList *l, DOHString *usage)
// go through and see if any are output.
for (p = ParmList_first(l); p != 0; p = ParmList_next(l)) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
for (p = Firstitem(l); p != 0; p = Nextitem(l)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (strcmp (pn,"BOTH") && strcmp (pn,"OUTPUT"))
continue;

View file

@ -587,16 +587,16 @@ void JAVA::create_function(char *name, char *iname, DataType *t, ParmList *l)
// Now walk the function parameter list and generate code to get arguments
for (int i = 0; i < pcount ; i++) {
Parm *p = ParmList_get(l,i); // Get the ith argument
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i); // Get the ith argument
DataType *pt = Gettype(p);
char *pn = Getname(p);
char *target_copy = NULL;
char *target_length = NULL;
char *local_i = NULL;
// Produce string representation of source and target arguments
sprintf(source,"jarg%d",i);
sprintf(target,"%s", Parm_Getlname(p));
sprintf(target,"%s", Getlname(p));
char *jnitype = JavaTypeFromTypemap((char*)"jni", typemap_lang, pt, pn);
if(!jnitype) jnitype = SwigTcToJniType(pt, 0);
@ -606,7 +606,7 @@ void JAVA::create_function(char *name, char *iname, DataType *t, ParmList *l)
Printv(javaParameterSignature, JavaMethodSignature(pt, 0, 0), 0);
}
if(Parm_Getignore(p)) continue;
if(Getignore(p)) continue;
// Add to java function header
if(shadow && member_func) {
@ -1067,12 +1067,12 @@ void JAVA::cpp_member_func(char *name, char *iname, DataType *t, ParmList *l) {
}
Printv(nativecall, module, ".", Swig_name_member(shadow_classname,iname), "(_self", 0);
int pcount = l->nparms;
int pcount = Len(l);
for (int i = 0; i < pcount ; i++) {
Parm *p = ParmList_get(l,i); // Get the ith argument
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i); // Get the ith argument
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representation of source and target arguments
if(pn && *(pn))
@ -1139,13 +1139,13 @@ void JAVA::cpp_static_func(char *name, char *iname, DataType *t, ParmList *l) {
}
Printv(nativecall, module, ".", Swig_name_member(shadow_classname,iname), "(", 0);
int pcount = l->nparms;
int pcount = Len(l);
int gencomma = 0;
for (int i = 0; i < pcount ; i++) {
Parm *p = ParmList_get(l,i); // Get the ith argument
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i); // Get the ith argument
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representation of source and target arguments
if(pn && *(pn))
@ -1206,14 +1206,14 @@ void JAVA::cpp_constructor(char *name, char *iname, ParmList *l) {
else
Printv(nativecall, tab8, " _self = ", module, ".", Swig_name_construct(shadow_classname), "(", 0);
int pcount = l->nparms;
int pcount = Len(l);
if(pcount == 0) // We must have a default constructor
have_default_constructor = 1;
for (int i = 0; i < pcount ; i++) {
Parm *p = ParmList_get(l,i); // Get the ith argument
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i); // Get the ith argument
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representation of source and target arguments
if(pn && *(pn))

View file

@ -322,20 +322,20 @@ MZSCHEME::create_function (char *name, char *iname, DataType *d, ParmList *l)
int i = 0;
for (i = 0; i < pcount; ++i) {
Parm *p = ParmList_get(l,i);
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce names of source and target
sprintf(source,"argv[%d]",i);
sprintf(target,"%s", Parm_Getlname(p));
sprintf(target,"%s", Getlname(p));
sprintf(argnum,"%d",i);
strcpy(arg,pn);
// Handle parameter types.
if (Parm_Getignore(p))
if (Getignore(p))
Printv(f->code, "/* ", pn, " ignored... */\n", 0);
else {
++numargs;
@ -689,11 +689,11 @@ MZSCHEME::usage_func (char *iname, DataType *d, ParmList *l, DOHString *usage)
// Now go through and print parameters
for (p = ParmList_first(l); p != 0; p = ParmList_next(l)) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
for (p = Firstitem(l); p != 0; p = Nextitem(l)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (Parm_Getignore(p))
if (Getignore(p))
continue;
// Print the type. If the parameter has been named, use that as well.
@ -739,9 +739,9 @@ MZSCHEME::usage_returns (char *iname, DataType *d, ParmList *l, DOHString *usage
// go through and see if any are output.
for (p = ParmList_first(l); p != 0; p = ParmList_next(l)) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
for (p = Firstitem(l); p != 0; p = Nextitem(l)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (strcmp (pn,"BOTH") && strcmp (pn,"OUTPUT"))
continue;

View file

@ -778,19 +778,19 @@ void PERL5::create_function(char *name, char *iname, DataType *d, ParmList *l)
i = 0;
j = 0;
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representation of source and target arguments
sprintf(source,"ST(%d)",j);
sprintf(target,"%s", Parm_Getlname(p));
sprintf(target,"%s", Getlname(p));
sprintf(argnum,"%d",j+1);
// Check to see if this argument is being ignored
if (!Parm_Getignore(p)) {
if (!Getignore(p)) {
// If there are optional arguments, check for this
@ -909,11 +909,11 @@ void PERL5::create_function(char *name, char *iname, DataType *d, ParmList *l)
}
// If we needed a saved variable, we need to emit to emit some code for that
// This only applies if the argument actually existed (not ignore)
if ((need_save) && (!Parm_Getignore(p))) {
if ((need_save) && (!Getignore(p))) {
Printv(f->code, tab4, temp, " = ", source, ";\n", 0);
num_saved++;
}
p = ParmList_next(l);
p = Nextitem(l);
i++;
}
@ -1055,12 +1055,12 @@ void PERL5::create_function(char *name, char *iname, DataType *d, ParmList *l)
// arguments to our function correspond to other Perl objects, we
// need to extract them from a tied-hash table object.
Parm *p = ParmList_first(l);
Parm *p = Firstitem(l);
int i = 0;
while(p) {
DataType *pt = Parm_Gettype(p);
DataType *pt = Gettype(p);
if (!Parm_Getignore(p)) {
if (!Getignore(p)) {
// Look up the datatype name here
char sourceNtarget[256];
sprintf(sourceNtarget,"$args[%d]",i);
@ -1078,7 +1078,7 @@ void PERL5::create_function(char *name, char *iname, DataType *d, ParmList *l)
}
i++;
}
p = ParmList_next(l);
p = Nextitem(l);
}
Printv(func, tab4, "my $result = ", package, "::", iname, "(@args);\n", 0);
@ -1534,12 +1534,12 @@ char *PERL5::usage_func(char *iname, DataType *, ParmList *l) {
/* Now go through and print parameters */
p = ParmList_first(l);
p = Firstitem(l);
i = 0;
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
if (!Parm_Getignore(p)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (!Getignore(p)) {
/* If parameter has been named, use that. Otherwise, just print a type */
if ((pt->type != T_VOID) || (pt->is_pointer)) {
@ -1550,14 +1550,14 @@ char *PERL5::usage_func(char *iname, DataType *, ParmList *l) {
}
}
i++;
p = ParmList_next(l);
p = Nextitem(l);
if (p)
if (!Parm_Getignore(p))
if (!Getignore(p))
Putc(',',temp);
} else {
p = ParmList_next(l);
p = Nextitem(l);
if (p)
if ((i>0) && (!Parm_Getignore(p)))
if ((i>0) && (!Getignore(p)))
Putc(',',temp);
}
}
@ -1891,13 +1891,13 @@ void PERL5::cpp_member_func(char *name, char *iname, DataType *t, ParmList *l) {
// arguments to our function correspond to other Perl objects, we
// need to extract them from a tied-hash table object.
p = ParmList_first(l);
pcount = l->nparms;
p = Firstitem(l);
pcount = Len(l);
numopt = check_numopt(l);
i = 1;
while(p) {
DataType *pt = Parm_Gettype(p);
if (!Parm_Getignore(p)) {
DataType *pt = Gettype(p);
if (!Getignore(p)) {
char sourceNtarget[512];
sprintf(sourceNtarget, "$args[%d]", i);
@ -1917,7 +1917,7 @@ void PERL5::cpp_member_func(char *name, char *iname, DataType *t, ParmList *l) {
}
i++;
}
p = ParmList_next(l);
p = Nextitem(l);
}
// Okay. We've made argument adjustments, now call into the package
@ -2097,10 +2097,10 @@ void PERL5::cpp_constructor(char *name, char *iname, ParmList *l) {
// arguments to our function correspond to other Perl objects, we
// need to extract them from a tied-hash table object.
p = ParmList_first(l);
p = Firstitem(l);
i = 0;
while(p) {
DataType *pt = Parm_Gettype(p);
DataType *pt = Gettype(p);
// Look up the datatype name here
if ((Getattr(classes,pt->name)) && (pt->is_pointer <= 1)) {
@ -2108,7 +2108,7 @@ void PERL5::cpp_constructor(char *name, char *iname, ParmList *l) {
// Yep. This smells alot like an object, patch up the arguments
Printf(pcode, " $args[%d] = tied(%%{$args[%d]});\n", i, i);
}
p = ParmList_next(l);
p = Nextitem(l);
i++;
}

View file

@ -679,22 +679,22 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
j = 0;
numopt = check_numopt(l); // Get number of optional arguments
if (numopt) have_defarg = 1;
p = ParmList_first(l);
p = Firstitem(l);
Printf(kwargs,"{ ");
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
char *pv = Parm_Getvalue(p);
DataType *pt = Gettype(p);
char *pn = Getname(p);
char *pv = Getvalue(p);
// Generate source and target strings
sprintf(source,"obj%d",i);
sprintf(target,Parm_Getlname(p));
sprintf(target,Getlname(p));
sprintf(argnum,"%d",j+1);
// Only consider this argument if it's not ignored
if (!Parm_Getignore(p)) {
if (!Getignore(p)) {
Putc(',',arglist);
// Add an optional argument separator if needed
@ -782,7 +782,7 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
Putc('O',parse_args);
sprintf(source,"argo%d", i);
sprintf(target,Parm_Getlname(p));
sprintf(target,Getlname(p));
sprintf(temp,"argument %d",i+1);
Wrapper_add_localv(f,source,"PyObject *",source,"=0",0);
@ -801,7 +801,7 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
// Emit code for parameter list
if ((pt->type != T_VOID) && (pt->type != T_BOOL) && (pt->type != T_USER))
Printf(arglist,"&%s",Parm_Getlname(p));
Printf(arglist,"&%s",Getlname(p));
} else {
@ -809,7 +809,7 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
if ((pt->type == T_CHAR) && (pt->is_pointer == 1)) {
Putc('s',parse_args);
Printf(arglist,"&%s", Parm_Getlname(p));
Printf(arglist,"&%s", Getlname(p));
} else {
// Have some sort of pointer variable. Create a temporary local
@ -817,7 +817,7 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
Putc('O',parse_args);
sprintf(source,"argo%d", i);
sprintf(target,"%s",Parm_Getlname(p));
sprintf(target,"%s",Getlname(p));
sprintf(temp,"argument %d",i+1);
Wrapper_add_localv(f,source,"PyObject *",source,"=0",0);
@ -845,7 +845,7 @@ void PYTHON::create_function(char *name, char *iname, DataType *d, ParmList *l)
Replace(outarg,"$arg",source, DOH_REPLACE_ANY);
have_output++;
}
p = ParmList_next(l);
p = Nextitem(l);
i++;
}
@ -1417,11 +1417,11 @@ char *PYTHON::usage_func(char *iname, DataType *, ParmList *l) {
// You probably don't need to change this
i = 0;
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
if (!Parm_Getignore(p)) {
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (!Getignore(p)) {
i++;
/* If parameter has been named, use that. Otherwise, just print a type */
@ -1432,15 +1432,15 @@ char *PYTHON::usage_func(char *iname, DataType *, ParmList *l) {
Printf(temp,"%s", DataType_str(pt,0));
}
}
p = ParmList_next(l);
p = Nextitem(l);
if (p != 0) {
if (!Parm_Getignore(p))
if (!Getignore(p))
Putc(',',temp);
}
} else {
p = ParmList_next(l);
p = Nextitem(l);
if (p) {
if ((!Parm_Getignore(p)) && (i > 0))
if ((!Getignore(p)) && (i > 0))
Putc(',',temp);
}
}

View file

@ -443,9 +443,9 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
int numreq = 0;
int numoptreal = 0;
for (i = start; i < l->nparms; i++) {
if (!Parm_Getignore(ParmList_get(l,i))) {
if (i >= l->nparms - numopt) numoptreal++;
for (i = start; i < Len(l); i++) {
if (!Getignore(Getitem(l,i))) {
if (i >= Len(l) - numopt) numoptreal++;
else numreq++;
}
}
@ -457,8 +457,8 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
Printv(f->def, "int argc, VALUE *argv, VALUE self",0);
} else {
Printv(f->def, "VALUE self", 0);
for (i = start; i < l->nparms; i++) {
if (!Parm_Getignore(ParmList_get(l,i))) {
for (i = start; i < Len(l); i++) {
if (!Getignore(Getitem(l,i))) {
Printf(f->def,", VALUE varg%d", i);
}
}
@ -467,8 +467,8 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
// Emit all of the local variables for holding arguments.
if (vararg) {
for (i = start; i < l->nparms; i++) {
if (!Parm_Getignore(ParmList_get(l,i))) {
for (i = start; i < Len(l); i++) {
if (!Getignore(Getitem(l,i))) {
char s[256];
sprintf(s,"varg%d",i);
Wrapper_add_localv(f,s,"VALUE",s,0);
@ -497,8 +497,8 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
// Emit count to check the number of arguments
if (vararg) {
Printf(f->code," rb_scan_args(argc, argv, \"%d%d\"", (numarg-numoptreal), numoptreal);
for (i = start; i < l->nparms; i++) {
if (!Parm_Getignore(ParmList_get(l,i))) {
for (i = start; i < Len(l); i++) {
if (!Getignore(Getitem(l,i))) {
Printf(f->code,", &varg%d", i);
}
}
@ -510,9 +510,9 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
int j = 0; // Total number of non-optional arguments
for (i = 0; i < pcount ; i++) {
Parm *p = ParmList_get(l,i);
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
Parm *p = Getitem(l,i);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representation of source and target arguments
int selfp = (use_self && i == 0);
@ -521,9 +521,9 @@ void RUBY::create_function(char *name, char *iname, DataType *t, ParmList *l) {
else
sprintf(source,"varg%d",i);
sprintf(target,"%s", Parm_Getlname(p));
sprintf(target,"%s", Getlname(p));
if (!Parm_Getignore(p)) {
if (!Getignore(p)) {
char *tab = (char*)tab4;
if (j >= (pcount-numopt)) { // Check if parsing an optional argument
Printf(f->code," if (argc > %d) {\n", j - start);

View file

@ -505,19 +505,19 @@ void TCL8::create_function(char *name, char *iname, DataType *d, ParmList *l)
i = 0;
j = 0;
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Produce string representations of the source and target arguments
sprintf(source,"objv[%d]",j+1);
sprintf(target,"%s", Parm_Getlname(p));
sprintf(target,"%s", Getlname(p));
sprintf(argnum,"%d",j+1);
// See if this argument is being ignored
if (!Parm_Getignore(p)) {
if (!Getignore(p)) {
if (j == (pcount-numopt))
Putc('|',argstr);
@ -648,7 +648,7 @@ void TCL8::create_function(char *name, char *iname, DataType *d, ParmList *l)
Replace(outarg,"$arg",source, DOH_REPLACE_ANY);
}
i++;
p = ParmList_next(l); // Get next parameter and continue
p = Nextitem(l); // Get next parameter and continue
}
Printf(argstr,":%s\"",usage);
Printv(f->code,
@ -1132,13 +1132,13 @@ char * TCL8::usage_string(char *iname, DataType *, ParmList *l) {
/* Now go through and print parameters */
i = 0;
pcount = l->nparms;
pcount = Len(l);
numopt = check_numopt(l);
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
DataType *pt = Gettype(p);
char *pn = Getname(p);
// Only print an argument if not ignored
@ -1161,7 +1161,7 @@ char * TCL8::usage_string(char *iname, DataType *, ParmList *l) {
Putc(' ',temp);
i++;
}
p = ParmList_next(l);
p = Nextitem(l);
}
return Char(temp);
}
@ -1287,9 +1287,13 @@ void TCL8::cpp_close_class() {
t->is_pointer = 1;
if (have_destructor) {
Printv(code, "static void _swig_delete_", class_name, "(void *obj) {\n",
tab4, Swig_name_destroy(real_classname), "((", DataType_str(t,0), ") obj);\n",
"}\n",0);
Printv(code, "static void _swig_delete_", class_name, "(void *obj) {\n", 0);
if (CPlusPlus) {
Printv(code," delete (", DataType_str(t,0), ") obj;\n",0);
} else {
Printv(code," free((char *) obj);\n",0);
}
Printf(code,"}\n");
}
Printf(methods, " {0,0}\n};\n");

View file

@ -153,10 +153,10 @@ static void update_local_type(DataType *type) {
static void update_parms(ParmList *l) {
Parm *p;
p = ParmList_first(l);
p = Firstitem(l);
while (p) {
DataType *pt = Parm_Gettype(p);
char *pvalue = Parm_Getvalue(p);
DataType *pt = Gettype(p);
char *pvalue = Getvalue(p);
update_local_type(pt);
@ -166,10 +166,10 @@ static void update_parms(ParmList *l) {
char *s;
s = (char *) GetChar(localtypes,pvalue);
if (s) {
Parm_Setvalue(p,s);
Setvalue(p,s);
}
}
p = ParmList_next(l);
p = Nextitem(l);
}
}
@ -276,7 +276,7 @@ public:
} else {
lang->cpp_member_func(name, iname, t, l);
}
DelParmList(l);
Delete(l);
DelDataType(t);
IsVirtual = 0;
}
@ -323,7 +323,7 @@ public:
l = CopyParmList(parms);
update_parms(l);
lang->cpp_constructor(name,iname,l);
DelParmList(l);
Delete(l);
}
}
};
@ -1502,8 +1502,7 @@ void cplus_emit_member_func(char *classname, char *classtype, char *classrename,
if (!bc) bc = classname;
if (strlen(bc) == 0) bc = classname;
Printf(key,"%s+",Wrapper_Getname(w));
ParmList_print_types(l,key);
Printf(key,"%s+%s",Wrapper_Getname(w), ParmList_protostr(l));
if (!member_hash) member_hash = NewHash();
if (Getattr(member_hash,key)) {
prev_wrap = GetChar(member_hash,key);

View file

@ -43,12 +43,12 @@ int emit_args(DataType *rt, ParmList *l, Wrapper *f) {
Swig_cargs(f, l);
i = 0;
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
lname = Parm_Getlname(p);
pt = Parm_Gettype(p);
pname = Parm_Getname(p);
pvalue = Parm_Getvalue(p);
lname = Getlname(p);
pt = Gettype(p);
pname = Getname(p);
pvalue = Getvalue(p);
tm = typemap_lookup((char*)"arginit", typemap_lang, pt,pname,(char*)"",lname,f);
if (tm) {
@ -62,10 +62,10 @@ int emit_args(DataType *rt, ParmList *l, Wrapper *f) {
tm = typemap_lookup((char*)"ignore",typemap_lang,pt,pname,(char*)"",lname,f);
if (tm) {
Printv(f->code,tm,"\n",0);
Parm_Setignore(p,1);
Setignore(p,1);
}
i++;
p = ParmList_next(l);
p = Nextitem(l);
}
return(i);
}
@ -135,21 +135,20 @@ void emit_func_call(char *decl, DataType *t, ParmList *l, Wrapper *f) {
/* How to assign a C allocated string */
static char *c_str = (char *)" {\n\
static char *c_str = (char *)"\
if ($target) free($target);\n\
$target = ($rtype) malloc(strlen($source)+1);\n\
strcpy((char *)$target,$source);\n\
return $ltype $target;\n\
}\n";
return $ltype $target;\n";
/* How to assign a C allocated string */
static char *cpp_str = (char *)" {\n\
static char *cpp_str = (char *)"\
if ($target) delete [] $target;\n\
$target = ($rtype) (new char[strlen($source)+1]);\n\
strcpy((char *)$target,$source);\n\
return ($ltype) $target;\n\
}\n";
return ($ltype) $target;\n;";
void emit_set_get(char *name, char *iname, DataType *t) {

View file

@ -199,28 +199,20 @@ static void emit_extern_func(char *decl, DataType *t, ParmList *L, int extern_ty
switch(extern_type) {
case 0:
fprintf(f,"%s", DataType_str(t,0));
fprintf(f,"%s(", decl);
ParmList_print_types(L,f);
fprintf(f,");\n");
fprintf(f,"%s(%s);\n", decl, ParmList_protostr(L));
break;
case 1:
fprintf(f,"extern %s", DataType_str(t,0));
fprintf(f,"%s(", decl);
ParmList_print_types(L,f);
fprintf(f,");\n");
fprintf(f,"%s(%s);\n", decl, ParmList_protostr(L));
break;
case 2:
/* A C++ --- > C Extern */
fprintf(f,"extern \"C\" %s", DataType_str(t,0));
fprintf(f,"%s(", decl);
ParmList_print_types(L,f);
fprintf(f,");\n");
fprintf(f,"%s(%s);\n", decl, ParmList_protostr(L));
break;
case 3:
fprintf(f,"%s", DataType_str(t,0));
fprintf(f,"%s(", decl);
ParmList_print_args(L,f);
fprintf(f,")\n");
fprintf(f,"%s(%s)\n", decl, ParmList_str(L));
break;
default:
break;
@ -665,7 +657,7 @@ statement : INCLUDE STRING LBRACE {
FatalError();
} else {
if (DataType_qualifier($2)) {
if (!($2->is_pointer) && (strcmp(DataType_qualifier($2),"const") == 0)) {
if (strcmp(DataType_qualifier($2),"const") == 0) {
if ($5.type != T_ERROR)
create_constant($3.id, $2, $5.id);
} else {
@ -715,7 +707,7 @@ statement : INCLUDE STRING LBRACE {
$2->is_reference = $3.is_reference;
create_function($1, $3.id, $2, $5);
DelDataType($2);
DelParmList($5);
Delete($5);
} stail { }
/* A function declaration with code after it */
@ -726,7 +718,7 @@ statement : INCLUDE STRING LBRACE {
$2->is_reference = $3.is_reference;
create_function($1, $3.id, $2, $5);
DelDataType($2);
DelParmList($5);
Delete($5);
};
/* A function declared without any return datatype */
@ -752,7 +744,7 @@ statement : INCLUDE STRING LBRACE {
}
}
DelDataType($2);
DelParmList($5);
Delete($5);
};
/* A function with an explicit inline directive. Not safe to use inside a %inline block */
@ -773,7 +765,7 @@ statement : INCLUDE STRING LBRACE {
create_function(0, $3.id, $2, $5);
}
DelDataType($2);
DelParmList($5);
Delete($5);
};
/* A static function declaration (ignored) */
@ -781,7 +773,7 @@ statement : INCLUDE STRING LBRACE {
| STATIC type declaration LPAREN parms RPAREN cpp_const {
Active_static = 1;
DelDataType($2);
DelParmList($5);
Delete($5);
} stail {
Active_static = 0;
}
@ -856,7 +848,7 @@ statement : INCLUDE STRING LBRACE {
}
}
DelDataType($6);
DelParmList($9);
Delete($9);
}
/* %title directive */
@ -1044,7 +1036,7 @@ statement : INCLUDE STRING LBRACE {
skip_brace();
p = $7;
while (p) {
typemap_register($5,$3,Parm_Gettype(p->p),Parm_Getname(p->p),Char(CCode),p->args);
typemap_register($5,$3,Gettype(p->p),Getname(p->p),Char(CCode),p->args);
p = p->next;
}
free($3);
@ -1062,7 +1054,7 @@ statement : INCLUDE STRING LBRACE {
skip_brace();
p = $5;
while (p) {
typemap_register($3,typemap_lang,Parm_Gettype(p->p),Parm_Getname(p->p),Char(CCode),p->args);
typemap_register($3,typemap_lang,Gettype(p->p),Getname(p->p),Char(CCode),p->args);
p = p->next;
}
}
@ -1075,7 +1067,7 @@ statement : INCLUDE STRING LBRACE {
TMParm *p;
p = $7;
while (p) {
typemap_clear($5,$3,Parm_Gettype(p->p),Parm_Getname(p->p));
typemap_clear($5,$3,Gettype(p->p),Getname(p->p));
p = p->next;
}
free($3);
@ -1092,7 +1084,7 @@ statement : INCLUDE STRING LBRACE {
TMParm *p;
p = $5;
while (p) {
typemap_clear($3,typemap_lang,Parm_Gettype(p->p),Parm_Getname(p->p));
typemap_clear($3,typemap_lang,Gettype(p->p),Getname(p->p));
p = p->next;
}
}
@ -1105,12 +1097,12 @@ statement : INCLUDE STRING LBRACE {
TMParm *p;
p = $7;
while (p) {
typemap_copy($5,$3,Parm_Gettype($9->p),Parm_Getname($9->p),Parm_Gettype(p->p),Parm_Getname(p->p));
typemap_copy($5,$3,Gettype($9->p),Getname($9->p),Gettype(p->p),Getname(p->p));
p = p->next;
}
free($3);
free($5);
DelParm($9->p);
Delete($9->p);
free($9);
}
@ -1125,12 +1117,12 @@ statement : INCLUDE STRING LBRACE {
TMParm *p;
p = $5;
while (p) {
typemap_copy($3,typemap_lang,Parm_Gettype($7->p),Parm_Getname($7->p),Parm_Gettype(p->p),Parm_Getname(p->p));
typemap_copy($3,typemap_lang,Gettype($7->p),Getname($7->p),Gettype(p->p),Getname(p->p));
p = p->next;
}
}
free($3);
DelParm($7->p);
Delete($7->p);
free($7);
}
/* -----------------------------------------------------------------
@ -1141,18 +1133,18 @@ statement : INCLUDE STRING LBRACE {
TMParm *p;
p = $4;
while(p) {
typemap_apply(Parm_Gettype($2->p),Parm_Getname($2->p),Parm_Gettype(p->p),Parm_Getname(p->p));
typemap_apply(Gettype($2->p),Getname($2->p),Gettype(p->p),Getname(p->p));
p = p->next;
}
free($4);
DelParmList($2->args);
Delete($2->args);
free($2);
}
| CLEAR tm_list SEMI {
TMParm *p;
p = $2;
while (p) {
typemap_clear_apply(Parm_Gettype(p->p), Parm_Getname(p->p));
typemap_clear_apply(Gettype(p->p), Getname(p->p));
p = p->next;
}
}
@ -1275,7 +1267,7 @@ typedef_decl : TYPEDEF type declaration {
cplus_register_type($5);
DelDataType($2);
free($5);
DelParmList($8);
Delete($8);
}
/* A typedef involving function pointers again */
@ -1298,7 +1290,7 @@ typedef_decl : TYPEDEF type declaration {
cplus_register_type($6);
DelDataType($2);
free($6);
DelParmList($9);
Delete($9);
}
/* A typedef involving arrays */
@ -1410,7 +1402,7 @@ stail : SEMI { }
temp_typeptr->is_reference = $2.is_reference;
create_function(Active_extern, $2.id, temp_typeptr, $4);
DelDataType(temp_typeptr);
DelParmList($4);
Delete($4);
} stail { }
;
@ -1438,27 +1430,25 @@ func_end : cpp_const LBRACE { skip_brace(); }
------------------------------------------------------------------------------ */
parms : parm ptail {
DataType *pt = Parm_Gettype($1);
DataType *pt = Gettype($1);
if ((pt->type != T_VOID) || (pt->is_pointer))
ParmList_insert($2,$1,0);
Insert($2,0,$1);
$$ = $2;
DelParm($1);
}
| empty { $$ = NewParmList(); }
;
ptail : COMMA parm ptail {
ParmList_insert($3,$2,0);
Insert($3,0,$2);
$$ = $3;
DelParm($2);
}
| empty { $$ = NewParmList(); }
;
parm : parm_type {
$$ = $1;
if (typemap_check((char *)"ignore",typemap_lang,Parm_Gettype($$),Parm_Getname($$)))
Parm_Setignore($$,1);
if (typemap_check((char *)"ignore",typemap_lang,Gettype($$),Getname($$)))
Setignore($$,1);
}
parm_type : type pname {
@ -1468,19 +1458,19 @@ parm_type : type pname {
DataType_set_arraystr($1, Char(ArrayString));
}
$$ = NewParm($1,$2);
Parm_Setvalue($$,DefArg);
Setvalue($$,DefArg);
DelDataType($1);
free($2);
}
| type stars pname {
$$ = NewParm($1,$3);
Parm_Gettype($$)->is_pointer+=$2;
Parm_Setvalue($$,DefArg);
Gettype($$)->is_pointer+=$2;
Setvalue($$,DefArg);
if (InArray) {
Parm_Gettype($$)->is_pointer++;
Gettype($$)->is_pointer++;
// Add array string to the type
DataType_set_arraystr(Parm_Gettype($$), Char(ArrayString));
DataType_set_arraystr(Gettype($$), Char(ArrayString));
}
DelDataType($1);
free($3);
@ -1488,10 +1478,10 @@ parm_type : type pname {
| type AND pname {
$$ = NewParm($1,$3);
DataType *pt = Parm_Gettype($$);
DataType *pt = Gettype($$);
pt->is_reference = 1;
pt->is_pointer++;
Parm_Setvalue($$,DefArg);
Setvalue($$,DefArg);
if (!CPlusPlus) {
fprintf(stderr,"%s : Line %d. Warning. Use of C++ Reference detected. Use the -c++ option.\n", input_file, line_number);
}
@ -1502,20 +1492,20 @@ parm_type : type pname {
fprintf(stderr,"%s : Line %d. Error. Function pointer not allowed (remap with typedef).\n", input_file, line_number);
FatalError();
$$ = NewParm($1,$4);
DataType *pt = Parm_Gettype($$);
DataType *pt = Gettype($$);
pt->type = T_ERROR;
Parm_Setname($$,$4);
Setname($$,$4);
strcpy(pt->name,"<function ptr>");
DelDataType($1);
free($4);
DelParmList($7);
Delete($7);
}
| PERIOD PERIOD PERIOD {
fprintf(stderr,"%s : Line %d. Variable length arguments not supported (ignored).\n", input_file, line_number);
$$ = NewParm(NewDataType(T_INT),(char *) "varargs");
DataType *pt = Parm_Gettype($$);
DataType *pt = Gettype($$);
pt->type = T_ERROR;
Parm_Setname($$,(char*)"varargs");
Setname($$,(char*)"varargs");
strcpy(pt->name,"<varargs>");
FatalError();
}
@ -2292,7 +2282,7 @@ cpp_other :/* A dummy class name */
}
create_function($1, temp_name, $2, $7);
DelDataType($2);
DelParmList($7);
Delete($7);
}
/* A static C++ member data */
@ -2378,7 +2368,7 @@ cpp_member : type declaration LPAREN parms RPAREN cpp_end {
}
scanner_clear_start();
DelDataType($1);
DelParmList($4);
Delete($4);
}
/* Virtual member function */
@ -2395,7 +2385,7 @@ cpp_member : type declaration LPAREN parms RPAREN cpp_end {
}
scanner_clear_start();
DelDataType($2);
DelParmList($5);
Delete($5);
}
/* Possibly a constructor */
@ -2408,7 +2398,7 @@ cpp_member : type declaration LPAREN parms RPAREN cpp_end {
cplus_constructor($1,iname, $3);
}
scanner_clear_start();
DelParmList($3);
Delete($3);
}
/* A destructor (hopefully) */
@ -2422,7 +2412,7 @@ cpp_member : type declaration LPAREN parms RPAREN cpp_end {
cplus_destructor($2,iname);
}
scanner_clear_start();
DelParmList($4);
Delete($4);
}
/* A virtual destructor */
@ -2541,7 +2531,7 @@ cpp_member : type declaration LPAREN parms RPAREN cpp_end {
}
scanner_clear_start();
DelDataType($2);
DelParmList($5);
Delete($5);
}
/* Turn on public: mode */
@ -2915,7 +2905,7 @@ cpptype : CLASS { $$ = (char*)"class"; }
;
cpp_const : CONST {}
| THROW LPAREN parms RPAREN { DelParmList($3);}
| THROW LPAREN parms RPAREN { Delete($3);}
| empty {}
;
@ -3181,7 +3171,7 @@ objc_method : MINUS objc_ret_type ID objc_args objc_end {
scanner_clear_start();
DelDataType($2);
free($3);
DelParmList($4);
Delete($4);
}
}
| PLUS objc_ret_type ID objc_args objc_end {
@ -3199,7 +3189,7 @@ objc_method : MINUS objc_ret_type ID objc_args objc_end {
scanner_clear_start();
DelDataType($2);
free($3);
DelParmList($4);
Delete($4);
}
;
@ -3223,8 +3213,8 @@ objc_ret_type : LPAREN type RPAREN {
;
objc_arg_type : LPAREN parm RPAREN {
$$ = CopyDataType(Parm_Gettype($2));
DelParm($2);
$$ = CopyDataType(Gettype($2));
Delete($2);
}
| empty {
$$ = NewDataType(T_VOID);
@ -3238,7 +3228,7 @@ objc_args : objc_args objc_separator objc_arg_type ID {
Parm *p= NewParm($3,$4);
/* p->objc_separator = $2; */
$$ = $1;
ParmList_append($$,p);
Append($$,p);
}
| empty {
$$ = NewParmList();
@ -3333,7 +3323,7 @@ typemap_parm : type typemap_name {
| type stars typemap_name {
$$ = NewTMParm();
$$->p = NewParm($1,$3);
DataType *pt = Parm_Gettype($$->p);
DataType *pt = Gettype($$->p);
pt->is_pointer += $2;
if (InArray) {
pt->is_pointer++;
@ -3347,7 +3337,7 @@ typemap_parm : type typemap_name {
| type AND typemap_name {
$$ = NewTMParm();
$$->p = NewParm($1,$3);
DataType *pt = Parm_Gettype($$->p);
DataType *pt = Gettype($$->p);
pt->is_reference = 1;
pt->is_pointer++;
if (!CPlusPlus) {
@ -3362,14 +3352,14 @@ typemap_parm : type typemap_name {
FatalError();
$$ = NewTMParm();
$$->p = NewParm($1,$4);
DataType *pt = Parm_Gettype($$->p);
DataType *pt = Gettype($$->p);
pt->type = T_ERROR;
Parm_Setname($$->p,$4);
Setname($$->p,$4);
strcpy(pt->name,"<function ptr>");
$$->args = tm_parm;
DelDataType($1);
free($4);
DelParmList($7);
Delete($7);
}
;

View file

@ -308,16 +308,16 @@ void typemap_register(char *op, char *lang, DataType *type, char *pname,
if (args) {
Parm *p;
p = ParmList_first(tm->args);
p = Firstitem(tm->args);
while (p) {
char *pn = Parm_Getname(p);
char *pn = Getname(p);
if (pn) {
// printf(" %s %s\n", pt,pn);
} else {
fprintf(stderr,"%s:%d: Typemap error. Local variables must have a name\n",
input_file, line_number);
}
p = ParmList_next(tm->args);
p = Nextitem(tm->args);
}
}
}
@ -481,10 +481,10 @@ static void typemap_locals(DataType *t, char *pname, DOHString *s, ParmList *l,
Parm *p;
char *new_name;
p = ParmList_first(l);
p = Firstitem(l);
while (p) {
DataType *pt = Parm_Gettype(p);
char *pn = Parm_Getname(p);
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (pn) {
if (strlen(pn) > 0) {
DOHString *str;
@ -529,7 +529,7 @@ static void typemap_locals(DataType *t, char *pname, DOHString *s, ParmList *l,
Replace(s,pn,new_name,DOH_REPLACE_ID);
}
}
p = ParmList_next(l);
p = Nextitem(l);
}
// If the original datatype was an array. We're going to go through and substitute
// it's array dimensions
@ -1123,10 +1123,11 @@ int check_numopt(ParmList *l) {
int n = 0;
int state = 0;
for (int i = 0; i < l->nparms; i++) {
DataType *pt = Parm_Gettype(l->parms[i]);
char *pn = Parm_Getname(l->parms[i]);
if (Parm_Getvalue(l->parms[i])) {
for (int i = 0; i < Len(l); i++) {
Parm *p = Getitem(l,i);
DataType *pt = Gettype(p);
char *pn = Getname(p);
if (Getvalue(p)) {
n++;
state = 1;
} else if (typemap_check((char*)"default",typemap_lang,pt,pn)) {

View file

@ -6,9 +6,9 @@ srcdir = @srcdir@
VPATH = @srcdir@
SRCS = map.c wrapfunc.c naming.c tree.c stype.c scanner.c include.c getopt.c misc.c \
oldtypes.c oldparms.c cwrap.c
oldtypes.c parms.c cwrap.c
OBJS = map.o wrapfunc.o naming.o tree.o stype.o scanner.o include.o getopt.o misc.o \
oldtypes.o oldparms.o cwrap.o
oldtypes.o parms.o cwrap.o
prefix = @prefix@
exec_prefix = @exec_prefix@

View file

@ -28,8 +28,8 @@ Swig_cparm_name(Parm *p, int i) {
static char name[256];
sprintf(name,"arg%d",i);
if (p) {
Parm_Setlname(p,name);
return Parm_Getlname(p);
Setlname(p,name);
return Getlname(p);
} else {
return name;
}
@ -156,16 +156,16 @@ int Swig_cargs(Wrapper *w, ParmList *l) {
char *lname;
i = 0;
p = ParmList_first(l);
p = Firstitem(l);
while (p != 0) {
lname = Swig_cparm_name(p,i);
pt = Parm_Gettype(p);
pname = Parm_Getname(p);
pvalue = Parm_Getvalue(p);
pt = Gettype(p);
pname = Getname(p);
pvalue = Getvalue(p);
local = Swig_clocal(pt,lname,pvalue);
Wrapper_add_localv(w,lname,local,0);
i++;
p = ParmList_next(l);
p = Nextitem(l);
}
return(i);
}
@ -283,12 +283,12 @@ Swig_cfunction_call(DOHString_or_char *name, ParmList *parms) {
Printf(func,"%s(", name);
p = ParmList_first(parms);
p = Firstitem(parms);
while (p) {
pt = Parm_Gettype(p);
pt = Gettype(p);
Printf(func,"%s", Swig_clocal_deref(pt, Swig_cparm_name(p,i)));
i++;
p = ParmList_next(parms);
p = Nextitem(parms);
if (p)
Printf(func,",");
}
@ -315,17 +315,17 @@ Swig_cmethod_call(DOHString_or_char *name, ParmList *parms) {
if (!func) func = NewString("");
Clear(func);
p = ParmList_first(parms);
p = Firstitem(parms);
if (!p) return "";
Printf(func,"%s->%s(", Swig_cparm_name(p,0), name);
i++;
p = ParmList_next(parms);
p = Nextitem(parms);
while (p) {
pt = Parm_Gettype(p);
pt = Gettype(p);
Printf(func,"%s", Swig_clocal_deref(pt, Swig_cparm_name(p,i)));
i++;
p = ParmList_next(parms);
p = Nextitem(parms);
if (p)
Printf(func,",");
}
@ -373,12 +373,12 @@ Swig_cppconstructor_call(DOHString_or_char *name, ParmList *parms) {
Clear(func);
Printf(func,"new %s(", name);
p = ParmList_first(parms);
p = Firstitem(parms);
while (p) {
pt = Parm_Gettype(p);
pt = Gettype(p);
Printf(func,"%s", Swig_clocal_deref(pt, Swig_cparm_name(p,i)));
i++;
p = ParmList_next(parms);
p = Nextitem(parms);
if (p)
Printf(func,",");
}
@ -478,15 +478,15 @@ static void fix_parm_names(ParmList *l) {
int i = 0;
Parm *p;
p = ParmList_first(l);
p = Firstitem(l);
while (p) {
if (!Parm_Getname(p)) {
if (!Getname(p)) {
char temp[64];
sprintf(temp,"arg%d",i);
Parm_Setname(p,temp);
Setname(p,temp);
}
i++;
p = ParmList_next(l);
p = Nextitem(l);
}
}
@ -515,15 +515,16 @@ Swig_cfunction_wrapper(DOHString_or_char *funcname,
fix_parm_names(l);
Printf(w->def,"%s %s(%s)", DataType_str(rtype,0), funcname, ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(rtype,0), funcname, ParmList_str(l));
if (code) {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,rtype);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
return w;
}
@ -556,28 +557,25 @@ Swig_cmethod_wrapper(DOHString_or_char *classname,
strcpy(t->name,Char(classname));
t->is_pointer++;
p = NewParm(t,"self");
ParmList_insert(l,p,0);
Insert(l,0,p);
DelDataType(t);
DelParm(p);
fix_parm_names(l);
Printf(w->def,"%s %s(%s)", DataType_str(rtype,0), Swig_name_member(classname, methodname), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(rtype,0), Swig_name_member(classname, methodname), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
if ((rtype->type != T_VOID) || (rtype->is_pointer)) {
Printf(w->code,"return ");
}
Printf(w->code,"self->%s(", methodname);
p = ParmList_first(l);
p = ParmList_next(l);
p = Firstitem(l);
p = Nextitem(l);
while (p) {
Printf(w->code,"%s", Parm_Getname(p));
p = ParmList_next(l);
Printf(w->code,"%s", Getname(p));
p = Nextitem(l);
if (p)
Printf(w->code,",");
}
@ -585,10 +583,11 @@ Swig_cmethod_wrapper(DOHString_or_char *classname,
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
Printf(w->code,"}\n");
}
Wrapper_Settype(w,rtype);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
return w;
}
@ -621,19 +620,18 @@ Swig_cconstructor_wrapper(DOHString_or_char *classname,
/* Patch up the argument names */
fix_parm_names(l);
Printf(w->def,"%s %s(%s)", DataType_str(t,0), Swig_name_construct(classname), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(t,0), Swig_name_construct(classname), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"return (%s) calloc(1,sizeof(%s));\n", DataType_str(t,0), classname);
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,t);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(t);
return w;
}
@ -668,31 +666,30 @@ Swig_cppconstructor_wrapper(DOHString_or_char *classname,
/* Patch up the argument names */
fix_parm_names(l);
Printf(w->def,"%s %s(%s)", DataType_str(t,0), Swig_name_construct(classname), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(t,0), Swig_name_construct(classname), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"return new %s", DataType_str(t,0));
p = ParmList_first(l);
p = Firstitem(l);
if (p) {
Printf(w->code,"(");
while (p) {
Printf(w->code,"%s", Parm_Getname(p));
p = ParmList_next(l);
Printf(w->code,"%s", Getname(p));
p = Nextitem(l);
if (p)
Printf(w->code,",");
}
Printf(w->code,")");
}
Printf(w->code,";\n");
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,t);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(t);
return w;
}
@ -723,25 +720,23 @@ Swig_cdestructor_wrapper(DOHString_or_char *classname,
sprintf(t->name,classname);
t->is_pointer++;
p = NewParm(t,"self");
ParmList_append(l,p);
DelParm(p);
Append(l,p);
DelDataType(t);
t = NewDataType(T_VOID);
Printf(w->def,"%s %s(%s)", DataType_str(t,0), Swig_name_destroy(classname), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(t,0), Swig_name_destroy(classname), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"free((char *) self);\n");
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,t);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(t);
return w;
}
@ -772,25 +767,24 @@ Swig_cppdestructor_wrapper(DOHString_or_char *classname,
sprintf(t->name,classname);
t->is_pointer++;
p = NewParm(t,"self");
ParmList_append(l,p);
DelParm(p);
Append(l,p);
DelDataType(t);
t = NewDataType(T_VOID);
Printf(w->def,"%s %s(%s)", DataType_str(t,0), Swig_name_destroy(classname), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(t,0), Swig_name_destroy(classname), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"delete self;\n");
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,t);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(t);
return w;
}
@ -823,29 +817,26 @@ Swig_cmemberset_wrapper(DOHString_or_char *classname,
strcpy(t->name,Char(classname));
t->is_pointer++;
p = NewParm(t,"self");
ParmList_append(l,p);
Append(l,p);
DelDataType(t);
DelParm(p);
lt = Swig_clocal_type(type);
p = NewParm(lt,"value");
ParmList_append(l,p);
DelParm(p);
Append(l,p);
Printf(w->def,"%s %s(%s)", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"self->%s = %s;\n", membername, Swig_clocal_deref(lt,"value"));
Printf(w->code,"return %s self->%s;\n", Swig_clocal_assign(lt,""), membername);
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,lt);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(lt);
return w;
}
@ -879,24 +870,22 @@ Swig_cmemberget_wrapper(DOHString_or_char *classname,
strcpy(t->name,Char(classname));
t->is_pointer++;
p = NewParm(t,"self");
ParmList_append(l,p);
Append(l,p);
DelDataType(t);
DelParm(p);
lt = Swig_clocal_type(type);
Printf(w->def,"%s %s(%s)", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"return %s self->%s;", Swig_clocal_assign(lt,""), membername);
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,lt);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(lt);
return w;
}
@ -925,17 +914,14 @@ Swig_cvarset_wrapper(DOHString_or_char *varname,
l = NewParmList();
lt = Swig_clocal_type(type);
p = NewParm(lt,"value");
ParmList_append(l,p);
DelParm(p);
Append(l,p);
Printf(w->def,"%s %s(%s)", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"%s = %s;\n", varname, Swig_clocal_deref(lt,"value"));
Printf(w->code,"return %s;\n", Swig_clocal_assign(lt,varname));
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
Replace(w->code,"$target",varname, DOH_REPLACE_ANY);
@ -943,9 +929,10 @@ Swig_cvarset_wrapper(DOHString_or_char *varname,
Replace(w->code,"$ltype", DataType_str(lt,""), DOH_REPLACE_ANY);
Replace(w->code,"$rtype", DataType_str(type,""), DOH_REPLACE_ANY);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,lt);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(lt);
return w;
}
@ -974,19 +961,18 @@ Swig_cvarget_wrapper(DOHString_or_char *varname,
lt = Swig_clocal_type(type);
Printf(w->def,"%s %s(%s)", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
Printf(w->def,"%s %s(%s) {", DataType_str(lt,0), Wrapper_Getname(w), ParmList_str(l));
if (!code) {
/* No code supplied. Write a function manually */
Printf(w->def," {\n");
Printf(w->code,"return %s;", Swig_clocal_assign(type,varname));
Printf(w->code,"}\n");
} else {
Printv(w->code, code, "\n", 0);
}
Printf(w->code,"}\n");
Wrapper_Settype(w,lt);
Wrapper_Setparms(w,l);
DelParmList(l);
Delete(l);
DelDataType(lt);
return w;
}

View file

@ -1,361 +0,0 @@
/* -----------------------------------------------------------------------------
* parms.cxx
*
* Parameter list class.
*
* !!! This file is deprecated and is being replaced !!!
*
* Author(s) : David Beazley (beazley@cs.uchicago.edu)
*
* Copyright (C) 1998-2000. The University of Chicago
* Copyright (C) 1995-1998. The University of Utah and The Regents of the
* University of California.
*
* See the file LICENSE for information on usage and redistribution.
* ----------------------------------------------------------------------------- */
static char cvsroot[] = "$Header$";
#include "swig.h"
#define MAXPARMS 16
/* ------------------------------------------------------------------------
* NewParm()
*
* Create a new parameter from datatype 'type' and name 'n'.
* ------------------------------------------------------------------------ */
Parm *NewParm(DataType *type, char *n) {
Parm *p = (Parm *) malloc(sizeof(Parm));
if (type) {
p->_type = CopyDataType(type);
} else {
p->_type = 0;
}
p->_name = Swig_copy_string(n);
p->_lname = 0;
p->_defvalue = 0;
p->_ignore = 0;
return p;
}
/* ------------------------------------------------------------------------
* CopyParm()
* ------------------------------------------------------------------------ */
Parm *CopyParm(Parm *p) {
Parm *np = (Parm *) malloc(sizeof(Parm));
if (p->_type) np->_type = CopyDataType(p->_type);
np->_name = Swig_copy_string(p->_name);
np->_defvalue = Swig_copy_string(p->_defvalue);
np->_lname = Swig_copy_string(p->_lname);
np->_ignore = p->_ignore;
return np;
}
/* ------------------------------------------------------------------------
* DelParm()
* ------------------------------------------------------------------------ */
void DelParm(Parm *p) {
if (p->_type) DelDataType(p->_type);
if (p->_name) free(p->_name);
if (p->_defvalue) free(p->_defvalue);
if (p->_lname) free(p->_lname);
free(p);
}
void Parm_Settype(Parm *p, DataType *t) {
if (p->_type) DelDataType(p->_type);
p->_type = CopyDataType(t);
}
DataType *Parm_Gettype(Parm *p) {
return p->_type;
}
void Parm_Setname(Parm *p, char *n) {
if (p->_name) free(p->_name);
p->_name = Swig_copy_string(n);
}
char *Parm_Getname(Parm *p) {
return p->_name;
}
void Parm_Setlname(Parm *p, char *n) {
if (p->_lname) free(p->_lname);
p->_lname = Swig_copy_string(n);
}
char *Parm_Getlname(Parm *p) {
return p->_lname;
}
void Parm_Setvalue(Parm *p, char *v) {
if (p->_defvalue) free(p->_defvalue);
p->_defvalue = Swig_copy_string(v);
}
char *Parm_Getvalue(Parm *p) {
return p->_defvalue;
}
int Parm_Getignore(Parm *p) {
return p->_ignore;
}
void Parm_Setignore(Parm *p, int i) {
p->_ignore = i;
}
/* ------------------------------------------------------------------
* NewParmList()
* ------------------------------------------------------------------ */
ParmList *NewParmList() {
int i;
ParmList *l = (ParmList *) malloc(sizeof(ParmList));
l->nparms = 0;
l->maxparms = MAXPARMS;
l->parms = (Parm **) malloc(MAXPARMS*sizeof(Parm *));
for (i = 0; i < MAXPARMS; i++) {
l->parms[i] = 0;
}
return l;
}
/* ------------------------------------------------------------------
* CopyParmList()
* ------------------------------------------------------------------ */
ParmList *
CopyParmList(ParmList *l) {
ParmList *nl;
int i;
if (l) {
nl = (ParmList *) malloc(sizeof(ParmList));
nl->nparms = l->nparms;
nl->maxparms = l->maxparms;
nl->parms = (Parm **) malloc(l->maxparms*sizeof(Parm*));
for (i = 0; i < l->maxparms; i++) {
if (l->parms[i])
nl->parms[i] = CopyParm(l->parms[i]);
else
nl->parms[i] = 0;
}
return nl;
} else {
return NewParmList();
}
}
/* ------------------------------------------------------------------
* DelParmList()
* ------------------------------------------------------------------ */
void DelParmList(ParmList *l) {
int i;
if (NULL == l) return;
for (i = 0; i < l->maxparms; i++) {
if (l->parms[i]) DelParm(l->parms[i]);
}
free(l->parms);
free(l);
}
/* ------------------------------------------------------------------
* moreparms() - Increase memory for parameter list
* ------------------------------------------------------------------ */
static void moreparms(ParmList *l) {
Parm **newparms;
int i;
newparms = (Parm **) malloc(2*l->maxparms*sizeof(Parm *));
for (i = 0; i < 2*l->maxparms; i++)
newparms[i] = (Parm *) 0;
for (i = 0; i < l->maxparms; i++) {
newparms[i] = l->parms[i];
}
l->maxparms = 2*l->maxparms;
free(l->parms);
l->parms = newparms;
}
/* ------------------------------------------------------------------
* void ParmList_append(ParmList *l, Parm *p)
* ------------------------------------------------------------------ */
void ParmList_append(ParmList *l, Parm *p) {
if (l->nparms == l->maxparms) moreparms(l);
l->parms[l->nparms] = CopyParm(p);
l->nparms++;
}
/* ------------------------------------------------------------------
* void ParmList_insert()
* ------------------------------------------------------------------ */
void ParmList_insert(ParmList *l, Parm *p, int pos) {
int i;
/* If pos is out of range, we'd better fix it */
if (pos < 0) pos = 0;
if (pos > l->nparms) pos = l->nparms;
/* If insertion is going to need more memory, take care of that now */
if (l->nparms >= l->maxparms) moreparms(l);
/* Now shift all of the existing parms to the right */
for (i = l->nparms; i > pos; i--) {
l->parms[i] = l->parms[i-1];
}
/* Set new parameter */
l->parms[pos] = CopyParm(p);
l->nparms++;
}
/* ------------------------------------------------------------------
* void ParmList_del()
* ------------------------------------------------------------------ */
void ParmList_del(ParmList *l, int pos) {
int i;
if (l->nparms <= 0) return;
if (pos < 0) pos = 0;
if (pos >= l->nparms) pos = l->nparms-1;
/* Delete the parameter (if it exists) */
if (l->parms[pos]) DelParm(l->parms[pos]);
/* Now slide all of the parameters to the left */
for (i = pos; i < l->nparms-1; i++) {
l->parms[i] = l->parms[i+1];
}
l->nparms--;
}
/* ------------------------------------------------------------------
* Parm *ParmList_get()
* ------------------------------------------------------------------ */
Parm *ParmList_get(ParmList *l, int pos) {
if ((pos < 0) || (pos >= l->nparms)) return 0;
return l->parms[pos];
}
/* ------------------------------------------------------------------
* int ParmList_numarg()
* ------------------------------------------------------------------ */
int ParmList_numarg(ParmList *l) {
int n = 0;
int i;
for (i = 0; i < l->nparms; i++) {
if (!Parm_Getignore(l->parms[i]))
n++;
}
return n;
}
/* ---------------------------------------------------------------------
* Parm * ParmList_first()
* --------------------------------------------------------------------- */
Parm *ParmList_first(ParmList *l) {
l->current_parm = 0;
if (l->nparms > 0) return l->parms[l->current_parm++];
else return (Parm *) 0;
}
/* ----------------------------------------------------------------------
* Parm *ParmList_next()
* ---------------------------------------------------------------------- */
Parm * ParmList_next(ParmList *l) {
if (l->current_parm >= l->nparms) return 0;
else return l->parms[l->current_parm++];
}
/* ---------------------------------------------------------------------
* void ParmList_print_types(DOHFile *f)
*
* Prints a comma separated list of all of the parameter types.
* This is for generating valid C prototypes.
* ---------------------------------------------------------------------- */
void ParmList_print_types(ParmList *l, DOHFile *f) {
int pn;
DataType *t;
pn = 0;
while(pn < l->nparms) {
t = Parm_Gettype(l->parms[pn]);
Printf(f,"%s", DataType_str(t,0));
pn++;
if (pn < l->nparms)
Printf(f,",");
}
}
/* ---------------------------------------------------------------------
* void ParmList_print_args()
*
* Prints a comma separated list of all of the parameter arguments.
* ---------------------------------------------------------------------- */
void ParmList_print_args(ParmList *l, DOHFile *f) {
int pn;
DataType *t;
pn = 0;
while(pn < l->nparms) {
t = Parm_Gettype(l->parms[pn]);
Printf(f,"%s", DataType_str(t,Parm_Getname(l->parms[pn])));
pn++;
if (pn < l->nparms)
Printf(f,",");
}
}
/* ---------------------------------------------------------------------
* void ParmList_str()
*
* Generates a string of parameters
* ---------------------------------------------------------------------- */
char *ParmList_str(ParmList *l) {
static DOHString *out = 0;
int pn;
DataType *t;
if (!out) out = NewString("");
Clear(out);
pn = 0;
while(pn < l->nparms) {
t = Parm_Gettype(l->parms[pn]);
Printf(out,"%s", DataType_str(t,Parm_Getname(l->parms[pn])));
pn++;
if (pn < l->nparms)
Printf(out,",");
}
return Char(out);
}

160
SWIG/Source/Swig/parms.c Normal file
View file

@ -0,0 +1,160 @@
/* -----------------------------------------------------------------------------
* parms.cxx
*
* Parameter list class.
*
* !!! This file is deprecated and is being replaced !!!
*
* Author(s) : David Beazley (beazley@cs.uchicago.edu)
*
* Copyright (C) 1998-2000. The University of Chicago
* Copyright (C) 1995-1998. The University of Utah and The Regents of the
* University of California.
*
* See the file LICENSE for information on usage and redistribution.
* ----------------------------------------------------------------------------- */
static char cvsroot[] = "$Header$";
#include "swig.h"
#define MAXPARMS 16
/* ------------------------------------------------------------------------
* NewParm()
*
* Create a new parameter from datatype 'type' and name 'n'.
* ------------------------------------------------------------------------ */
Parm *NewParm(DataType *type, char *n) {
Parm *p = NewHash();
if (type) {
Setattr(p,"type", NewVoid(CopyDataType(type), (void (*)(void *)) DelDataType));
}
Setattr(p,"name",n);
return p;
}
/* ------------------------------------------------------------------------
* CopyParm()
* ------------------------------------------------------------------------ */
Parm *CopyParm(Parm *p) {
DataType *t;
char *name;
char *lname;
char *value;
int ignore;
Parm *np = NewHash();
t = GetVoid(p,"type");
name = GetChar(p,"name");
lname = GetChar(p,"lname");
value = GetChar(p,"value");
ignore = GetInt(p,"ignore");
Setattr(np,"type",NewVoid(CopyDataType(t), (void (*)(void *)) DelDataType));
if (name)
Setattr(np,"name",name);
if (lname)
Setattr(np,"lname", lname);
if (value)
Setattr(np,"value", value);
if (ignore)
SetInt(np,"ignore", ignore);
return np;
}
/* ------------------------------------------------------------------
* NewParmList()
* ------------------------------------------------------------------ */
ParmList *NewParmList() {
return NewList();
}
/* ------------------------------------------------------------------
* CopyParmList()
* ------------------------------------------------------------------ */
ParmList *
CopyParmList(ParmList *l) {
ParmList *nl;
int i, len;
nl = NewList();
len = Len(l);
for (i = 0; i < len; i++) {
Parm *p = Getitem(l,i);
Append(nl, CopyParm(p));
}
return nl;
}
/* ------------------------------------------------------------------
* int ParmList_numarg()
* ------------------------------------------------------------------ */
int ParmList_numarg(ParmList *l) {
int n = 0;
Parm *p;
p = Firstitem(l);
while (p) {
if (Getignore(p)) n++;
p = Nextitem(l);
}
return n;
}
/* ---------------------------------------------------------------------
* ParmList_str()
*
* Generates a string of parameters
* ---------------------------------------------------------------------- */
char *ParmList_str(ParmList *l) {
static DOHString *out = 0;
Parm *p;
DataType *t;
if (!out) out = NewString("");
Clear(out);
p = Firstitem(l);
while(p) {
t = Gettype(p);
Printf(out,"%s", DataType_str(t,Getname(p)));
p = Nextitem(l);
if (p)
Printf(out,",");
}
return Char(out);
}
/* ---------------------------------------------------------------------
* ParmList_str()
*
* Generate a prototype string.
* ---------------------------------------------------------------------- */
char *ParmList_protostr(ParmList *l) {
static DOHString *out = 0;
Parm *p;
DataType *t;
if (!out) out = NewString("");
Clear(out);
p = Firstitem(l);
while(p) {
t = Gettype(p);
Printf(out,"%s", DataType_str(t,0));
p = Nextitem(l);
if (p)
Printf(out,",");
}
return Char(out);
}

View file

@ -61,12 +61,12 @@ extern void DelDataType(DataType *type);
/* -- New type interface -- */
extern char *DataType_str(DataType *, DOHString_or_char *name); /* Exact datatype */
extern char *DataType_lstr(DataType *, DOHString_or_char *name); /* Assignable datatype */
extern char *DataType_rcaststr(DataType *, DOHString_or_char *name); /* Cast from lstr to str */
extern char *DataType_lcaststr(DataType *, DOHString_or_char *name); /* Cast from str to lstr */
extern char *DataType_manglestr(DataType *t); /* Mangled type name */
extern DataType *DataType_ltype(DataType *); /* Create local type object */
extern char *DataType_str(DataType *, DOHString_or_char *name); /* Exact datatype */
extern char *DataType_lstr(DataType *, DOHString_or_char *name); /* Assignable datatype */
extern char *DataType_rcaststr(DataType *, DOHString_or_char *name); /* Cast from lstr to str */
extern char *DataType_lcaststr(DataType *, DOHString_or_char *name); /* Cast from str to lstr */
extern char *DataType_manglestr(DataType *t); /* Mangled type name */
extern DataType *DataType_ltype(DataType *); /* Create local type object */
/* -- Old type interface -- */
@ -100,50 +100,24 @@ extern void typeeq_addtypedef(char *name, char *eqname, DataType *t);
#define STAT_REPLACETYPE 2
/* --- Deprecated parameter list structure --- */
/* --- Parameters and Parameter Lists --- */
typedef struct Parm {
DataType *_type; /* Datatype of this parameter */
char *_name; /* Name of parameter (optional) */
char *_defvalue; /* Default value (as a string) */
char *_lname; /* Local name */
int _ignore; /* Ignore flag */
} Parm;
/* Parameters are really just hidden behind a DOH object. The following
interface will probably be simplified even further. */
extern Parm *NewParm(DataType *type, char *n);
extern Parm *CopyParm(Parm *p);
extern void DelParm(Parm *p);
extern void Parm_Settype(Parm *p, DataType *t);
extern DataType *Parm_Gettype(Parm *p);
extern void Parm_Setname(Parm *p, char *name);
extern char *Parm_Getname(Parm *p);
extern void Parm_Setlname(Parm *p, char *lname);
extern char *Parm_Getlname(Parm *p);
extern void Parm_Setvalue(Parm *p, char *value);
extern char *Parm_Getvalue(Parm *p);
extern int Parm_Getignore(Parm *p);
extern void Parm_Setignore(Parm *p, int i);
typedef DOH Parm;
typedef struct ParmList {
int maxparms; /* Max parms possible in current list */
Parm **parms; /* Pointer to parms array */
int current_parm; /* Internal state for get_first,get_next */
int nparms; /* Number of parms in list */
} ParmList;
extern Parm *NewParm(DataType *type, char *n);
extern Parm *CopyParm(Parm *p);
typedef DOH ParmList;
extern ParmList *NewParmList();
extern ParmList *CopyParmList(ParmList *);
extern void DelParmList(ParmList *);
extern Parm *ParmList_get(ParmList *l, int pos);
extern void ParmList_append(ParmList *, Parm *);
extern void ParmList_insert(ParmList *, Parm *, int);
extern void ParmList_del(ParmList *, int);
extern int ParmList_numarg(ParmList *);
extern Parm *ParmList_first(ParmList *);
extern Parm *ParmList_next(ParmList *);
extern void ParmList_print_types(ParmList*,DOHFile *f);
extern void ParmList_print_args(ParmList *, DOHFile *f);
extern char *ParmList_str(ParmList *);
extern int ParmList_numarg(ParmList *);
extern char *ParmList_str(ParmList *);
extern char *ParmList_protostr(ParmList *);
/* --- File interface --- */
@ -158,11 +132,6 @@ extern int Swig_bytes_read();
#define SWIG_FILE_DELIMETER "/"
/* --- Super Strings --- */
extern DOH *NewSuperString(char *s, DOH *filename, int firstline);
extern int SuperString_check(DOH *s);
/* --- Command line parsing --- */
extern void Swig_init_args(int argc, char **argv);
@ -370,15 +339,15 @@ extern Wrapper *Swig_cdestructor_wrapper(DOHString_or_char *classname,
DOHString_or_char *code);
extern Wrapper *Swig_cppdestructor_wrapper(DOHString_or_char *classname,
DOHString_or_char *code);
DOHString_or_char *code);
extern Wrapper *Swig_cconstructor_wrapper(DOHString_or_char *classname,
ParmList *parms,
DOHString_or_char *code);
extern Wrapper *Swig_cppconstructor_wrapper(DOHString_or_char *classname,
ParmList *parms,
DOHString_or_char *code);
ParmList *parms,
DOHString_or_char *code);
extern Wrapper *Swig_cmemberset_wrapper(DOHString_or_char *classname,
@ -391,13 +360,28 @@ extern Wrapper *Swig_cmemberget_wrapper(DOHString_or_char *classname,
DataType *type,
DOHString_or_char *code);
extern Wrapper *Swig_cvarset_wrapper(DOHString_or_char *varname,
DataType *type,
DOHString_or_char *code);
extern Wrapper *Swig_cvarset_wrapper(DOHString_or_char *varname,
DataType *type,
DOHString_or_char *code);
extern Wrapper *Swig_cvarget_wrapper(DOHString_or_char *varname,
DataType *type,
DOHString_or_char *code);
extern Wrapper *Swig_cvarget_wrapper(DOHString_or_char *varname,
DataType *type,
DOHString_or_char *code);
/* --- Attribute access macros --- */
#define Gettype(x) ((DataType *) GetVoid(x,"type"))
#define Getname(x) GetChar(x,"name")
#define Getvalue(x) GetChar(x,"value")
#define Getlname(x) GetChar(x,"lname")
#define Getignore(x) GetInt(x,"ignore")
#define Settype(x,v) Setattr(x,"type",NewVoid(CopyDataType(v), (void (*)(void *)) DelDataType));
#define Setname(x,v) SetChar(x,"name",Char(v))
#define Setlname(x,v) SetChar(x,"lname",Char(v))
#define Setvalue(x,v) SetChar(x,"value", Char(v))
#define Setignore(x,v) SetInt(x,"ignore",v)
#endif

View file

@ -52,7 +52,7 @@ DelWrapper(Wrapper *w) {
Delete(w->code);
Delete(w->def);
if (w->_type) DelDataType(w->_type);
if (w->_parms) DelParmList(w->_parms);
if (w->_parms) Delete(w->_parms);
if (w->_name) Delete(w->_name);
free(w);
}
@ -291,7 +291,7 @@ Wrapper_Getparms(Wrapper *w) {
void
Wrapper_Setparms(Wrapper *w, ParmList *l) {
if (w->_parms) DelParmList(w->_parms);
if (w->_parms) Delete(w->_parms);
w->_parms = CopyParmList(l);
}