git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@5012 626c5289-ae23-0410-ae9c-e8d60b6d4f22
768 lines
21 KiB
Text
768 lines
21 KiB
Text
/*
|
|
* $Header$
|
|
*
|
|
* swigtcl8.swg
|
|
*/
|
|
|
|
#include <tcl.h>
|
|
#include <stdlib.h>
|
|
#include <stdarg.h>
|
|
#include <ctype.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* Constant table */
|
|
|
|
#define SWIG_TCL_INT 1
|
|
#define SWIG_TCL_FLOAT 2
|
|
#define SWIG_TCL_STRING 3
|
|
#define SWIG_TCL_POINTER 4
|
|
#define SWIG_TCL_BINARY 5
|
|
|
|
/* Flags for pointer conversion */
|
|
#define SWIG_POINTER_EXCEPTION 0x1
|
|
#define SWIG_POINTER_DISOWN 0x2
|
|
|
|
/* Swig fail macro */
|
|
|
|
#define SWIG_fail goto fail
|
|
|
|
/* Constant information structure */
|
|
typedef struct swig_const_info {
|
|
int type;
|
|
char *name;
|
|
long lvalue;
|
|
double dvalue;
|
|
void *pvalue;
|
|
swig_type_info **ptype;
|
|
} swig_const_info;
|
|
|
|
typedef int (*swig_wrapper)(ClientData, Tcl_Interp *, int, Tcl_Obj *CONST []);
|
|
typedef int (*swig_wrapper_func)(ClientData, Tcl_Interp *, int, Tcl_Obj *CONST []);
|
|
typedef char *(*swig_variable_func)(ClientData, Tcl_Interp *, char *, char *, int);
|
|
typedef void (*swig_delete_func)(ClientData);
|
|
|
|
typedef struct swig_method {
|
|
const char *name;
|
|
swig_wrapper method;
|
|
} swig_method;
|
|
|
|
typedef struct swig_attribute {
|
|
const char *name;
|
|
swig_wrapper getmethod;
|
|
swig_wrapper setmethod;
|
|
} swig_attribute;
|
|
|
|
typedef struct swig_class {
|
|
const char *name;
|
|
swig_type_info **type;
|
|
swig_wrapper constructor;
|
|
void (*destructor)(void *);
|
|
swig_method *methods;
|
|
swig_attribute *attributes;
|
|
struct swig_class **bases;
|
|
} swig_class;
|
|
|
|
typedef struct swig_instance {
|
|
Tcl_Obj *thisptr;
|
|
void *thisvalue;
|
|
swig_class *classptr;
|
|
int destroy;
|
|
Tcl_Command cmdtok;
|
|
} swig_instance;
|
|
|
|
#ifdef SWIG_NOINCLUDE
|
|
SWIGEXPORT(char *) SWIG_PackData(char *c, void *ptr, int sz);
|
|
SWIGEXPORT(char *) SWIG_UnpackData(char *c, void *ptr, int sz);
|
|
SWIGEXPORT(int) SWIG_ConvertPtrFromString(Tcl_Interp *, char *, void **, swig_type_info *,int flags);
|
|
SWIGEXPORT(int) SWIG_ConvertPtr(Tcl_Interp *, Tcl_Obj *, void **, swig_type_info *, int flags);
|
|
SWIGEXPORT(int) SWIG_ConvertPacked(Tcl_Interp *, Tcl_Obj *, void *, int sz, swig_type_info *, int flags);
|
|
SWIGEXPORT(void) SWIG_MakePtr(char *, void *, swig_type_info *, int flags);
|
|
SWIGEXPORT(Tcl_Obj *) SWIG_NewPointerObj(void *, swig_type_info *, int flags);
|
|
SWIGEXPORT(Tcl_Obj *) SWIG_NewPackedObj(void *, int sz, swig_type_info *, int flags);
|
|
SWIGEXPORT(int) SWIG_GetArgs(Tcl_Interp *, int, Tcl_Obj *CONST [], const char *, ...);
|
|
SWIGEXPORT(char *) SWIG_PointerTypeFromString(char *c);
|
|
SWIGEXPORT(void) SWIG_Acquire(void *ptr);
|
|
SWIGEXPORT(int) SWIG_Disown(void *ptr);
|
|
SWIGEXPORT(int) SWIG_Thisown(void *ptr);
|
|
SWIGEXPORT(void) SWIG_InstallConstants(Tcl_Interp *interp, struct swig_const_info constants[]);
|
|
SWIGEXPORT(Tcl_Obj *) SWIG_GetConstant(const char *key);
|
|
SWIGEXPORT(Tcl_Obj *) SWIG_NewInstanceObj(Tcl_Interp *interp, void *, swig_type_info *, int flags);
|
|
SWIGEXPORT(int) SWIG_ObjectConstructor(ClientData, Tcl_Interp *, int, Tcl_Obj *CONST objv[]);
|
|
SWIGEXPORT(int) SWIG_MethodCommand(ClientData, Tcl_Interp *, int, Tcl_Obj *CONST objv[]);
|
|
SWIGEXPORT(void) SWIG_ObjectDelete(ClientData);
|
|
#else
|
|
|
|
/* Object support */
|
|
static Tcl_HashTable swigobjectTable;
|
|
static int swigobjectTableinit = 0;
|
|
|
|
/* Acquire ownership of a pointer */
|
|
SWIGRUNTIME(void)
|
|
SWIG_Acquire(void *ptr)
|
|
{
|
|
Tcl_HashEntry *entryPtr;
|
|
int newobj;
|
|
if (!swigobjectTableinit) {
|
|
Tcl_InitHashTable(&swigobjectTable, TCL_ONE_WORD_KEYS);
|
|
swigobjectTableinit = 1;
|
|
}
|
|
entryPtr = Tcl_CreateHashEntry(&swigobjectTable, (char *) ptr, &newobj);
|
|
}
|
|
|
|
/* Disown a pointer. Returns 1 if we owned it to begin with */
|
|
SWIGRUNTIME(int)
|
|
SWIG_Disown(void *ptr)
|
|
{
|
|
Tcl_HashEntry *entryPtr;
|
|
if (!swigobjectTableinit) return 0;
|
|
entryPtr = Tcl_FindHashEntry(&swigobjectTable, (char *) ptr);
|
|
if (entryPtr) {
|
|
Tcl_DeleteHashEntry(entryPtr);
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
SWIGRUNTIME(int)
|
|
SWIG_Thisown(void *ptr) {
|
|
if (!swigobjectTableinit) return 0;
|
|
if (Tcl_FindHashEntry(&swigobjectTable, (char *) ptr)) {
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/* Pack binary data into a string */
|
|
SWIGRUNTIME(char *)
|
|
SWIG_PackData(char *c, void *ptr, int sz) {
|
|
static char hex[17] = "0123456789abcdef";
|
|
int i;
|
|
unsigned char *u = (unsigned char *) ptr;
|
|
register unsigned char uu;
|
|
for (i = 0; i < sz; i++,u++) {
|
|
uu = *u;
|
|
*(c++) = hex[(uu & 0xf0) >> 4];
|
|
*(c++) = hex[uu & 0xf];
|
|
}
|
|
return c;
|
|
}
|
|
|
|
/* Unpack binary data from a string */
|
|
SWIGRUNTIME(char *)
|
|
SWIG_UnpackData(char *c, void *ptr, int sz) {
|
|
register unsigned char uu = 0;
|
|
register int d;
|
|
unsigned char *u = (unsigned char *) ptr;
|
|
int i;
|
|
if ((int)strlen(c) < (2*sz)) return c;
|
|
for (i = 0; i < sz; i++, u++) {
|
|
d = *(c++);
|
|
if ((d >= '0') && (d <= '9'))
|
|
uu = ((d - '0') << 4);
|
|
else if ((d >= 'a') && (d <= 'f'))
|
|
uu = ((d - ('a'-10)) << 4);
|
|
d = *(c++);
|
|
if ((d >= '0') && (d <= '9'))
|
|
uu |= (d - '0');
|
|
else if ((d >= 'a') && (d <= 'f'))
|
|
uu |= (d - ('a'-10));
|
|
*u = uu;
|
|
}
|
|
return c;
|
|
}
|
|
|
|
/* Convert a pointer value */
|
|
SWIGRUNTIME(int)
|
|
SWIG_ConvertPtrFromString(Tcl_Interp *interp, char *c, void **ptr, swig_type_info *ty, int flags)
|
|
{
|
|
swig_type_info *tc;
|
|
/* Pointer values must start with leading underscore */
|
|
while (*c != '_') {
|
|
*ptr = (void *) 0;
|
|
if (strcmp(c,"NULL") == 0) return TCL_OK;
|
|
/* Hmmm. It could be an object name. */
|
|
if (Tcl_VarEval(interp,c," cget -this", (char *) NULL) == TCL_OK) {
|
|
Tcl_Obj *result = Tcl_GetObjResult(interp);
|
|
c = Tcl_GetStringFromObj(result, NULL);
|
|
continue;
|
|
}
|
|
if (flags & SWIG_POINTER_EXCEPTION)
|
|
Tcl_SetResult(interp, (char *) "Type error. Expected a pointer", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
c++;
|
|
c = SWIG_UnpackData(c,ptr,sizeof(void *));
|
|
if (ty) {
|
|
tc = SWIG_TypeCheck(c,ty);
|
|
if ((!tc) && (flags & SWIG_POINTER_EXCEPTION)) {
|
|
Tcl_SetResult(interp, (char *) "Type error. Expected ", TCL_STATIC);
|
|
Tcl_AppendElement(interp, (char *) ty->name);
|
|
return TCL_ERROR;
|
|
} else if (!tc) {
|
|
return TCL_ERROR;
|
|
}
|
|
if (flags & SWIG_POINTER_DISOWN) {
|
|
SWIG_Disown((void *) *ptr);
|
|
}
|
|
*ptr = SWIG_TypeCast(tc,(void *) *ptr);
|
|
}
|
|
return TCL_OK;
|
|
}
|
|
|
|
/* Convert a pointer value */
|
|
SWIGRUNTIME(int)
|
|
SWIG_ConvertPtr(Tcl_Interp *interp, Tcl_Obj *oc, void **ptr, swig_type_info *ty, int flags)
|
|
{
|
|
return SWIG_ConvertPtrFromString(interp, Tcl_GetStringFromObj(oc,NULL), ptr, ty, flags);
|
|
}
|
|
|
|
/* Convert a pointer value */
|
|
SWIGRUNTIME(char *)
|
|
SWIG_PointerTypeFromString(char *c) {
|
|
char d;
|
|
/* Pointer values must start with leading underscore. NULL has no type */
|
|
if (*c != '_') {
|
|
return 0;
|
|
}
|
|
c++;
|
|
/* Extract hex value from pointer */
|
|
while ((d = *c)) {
|
|
if (!(((d >= '0') && (d <= '9')) || ((d >= 'a') && (d <= 'f')))) break;
|
|
c++;
|
|
}
|
|
return c;
|
|
}
|
|
|
|
/* Convert a packed value value */
|
|
SWIGRUNTIME(int)
|
|
SWIG_ConvertPacked(Tcl_Interp *interp, Tcl_Obj *obj, void *ptr, int sz, swig_type_info *ty, int flags) {
|
|
swig_type_info *tc;
|
|
char *c;
|
|
|
|
if (!obj) goto type_error;
|
|
c = Tcl_GetStringFromObj(obj,NULL);
|
|
/* Pointer values must start with leading underscore */
|
|
if (*c != '_') goto type_error;
|
|
c++;
|
|
c = SWIG_UnpackData(c,ptr,sz);
|
|
if (ty) {
|
|
tc = SWIG_TypeCheck(c,ty);
|
|
if (!tc) goto type_error;
|
|
}
|
|
return TCL_OK;
|
|
|
|
type_error:
|
|
|
|
if (flags) {
|
|
if (ty) {
|
|
Tcl_SetResult(interp, (char *) "Type error. Expected ", TCL_STATIC);
|
|
Tcl_AppendElement(interp, (char *) ty->name);
|
|
return TCL_ERROR;
|
|
} else {
|
|
Tcl_SetResult(interp, (char *) "Expected packed data.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
}
|
|
return TCL_ERROR;
|
|
}
|
|
|
|
|
|
/* Take a pointer and convert it to a string */
|
|
SWIGRUNTIME(void)
|
|
SWIG_MakePtr(char *c, void *ptr, swig_type_info *ty, int flags) {
|
|
if (ptr) {
|
|
*(c++) = '_';
|
|
c = SWIG_PackData(c,&ptr,sizeof(void *));
|
|
strcpy(c,ty->name);
|
|
} else {
|
|
strcpy(c,(char *)"NULL");
|
|
}
|
|
flags = 0;
|
|
}
|
|
|
|
/* Create a new pointer object */
|
|
SWIGRUNTIME(Tcl_Obj *)
|
|
SWIG_NewPointerObj(void *ptr, swig_type_info *type, int flags) {
|
|
Tcl_Obj *robj;
|
|
char result[512];
|
|
SWIG_MakePtr(result,ptr,type,flags);
|
|
robj = Tcl_NewStringObj(result,-1);
|
|
return robj;
|
|
}
|
|
|
|
SWIGRUNTIME(Tcl_Obj *)
|
|
SWIG_NewPackedObj(void *ptr, int sz, swig_type_info *type, int flags) {
|
|
char result[1024];
|
|
char *r = result;
|
|
if ((2*sz + 1 + strlen(type->name)) > 1000) return 0;
|
|
*(r++) = '_';
|
|
r = SWIG_PackData(r,ptr,sz);
|
|
strcpy(r,type->name);
|
|
flags = 0;
|
|
return Tcl_NewStringObj(result,-1);
|
|
}
|
|
|
|
static Tcl_HashTable swigconstTable;
|
|
static int swigconstTableinit = 0;
|
|
|
|
/* Install Constants */
|
|
SWIGRUNTIME(void)
|
|
SWIG_InstallConstants(Tcl_Interp *interp, swig_const_info constants[]) {
|
|
int i;
|
|
Tcl_Obj *obj;
|
|
Tcl_HashEntry *entryPtr;
|
|
int newobj;
|
|
|
|
if (!swigconstTableinit) {
|
|
Tcl_InitHashTable(&swigconstTable, TCL_STRING_KEYS);
|
|
swigconstTableinit = 1;
|
|
}
|
|
for (i = 0; constants[i].type; i++) {
|
|
switch(constants[i].type) {
|
|
case SWIG_TCL_INT:
|
|
obj = Tcl_NewIntObj(constants[i].lvalue);
|
|
break;
|
|
case SWIG_TCL_FLOAT:
|
|
obj = Tcl_NewDoubleObj(constants[i].dvalue);
|
|
break;
|
|
case SWIG_TCL_STRING:
|
|
obj = Tcl_NewStringObj((char *) constants[i].pvalue,-1);
|
|
break;
|
|
case SWIG_TCL_POINTER:
|
|
obj = SWIG_NewPointerObj(constants[i].pvalue, *(constants[i]).ptype,0);
|
|
break;
|
|
case SWIG_TCL_BINARY:
|
|
obj = SWIG_NewPackedObj(constants[i].pvalue, constants[i].lvalue, *(constants[i].ptype),0);
|
|
break;
|
|
default:
|
|
obj = 0;
|
|
break;
|
|
}
|
|
if (obj) {
|
|
Tcl_ObjSetVar2(interp,Tcl_NewStringObj(constants[i].name,-1), NULL, obj, TCL_GLOBAL_ONLY);
|
|
entryPtr = Tcl_CreateHashEntry(&swigconstTable, constants[i].name, &newobj);
|
|
Tcl_SetHashValue(entryPtr, (ClientData) obj);
|
|
}
|
|
}
|
|
}
|
|
|
|
SWIGRUNTIME(Tcl_Obj *)
|
|
SWIG_GetConstant(const char *key) {
|
|
Tcl_HashEntry *entryPtr;
|
|
if (!swigconstTableinit) return 0;
|
|
entryPtr = Tcl_FindHashEntry(&swigconstTable, key);
|
|
if (entryPtr) {
|
|
return (Tcl_Obj *) Tcl_GetHashValue(entryPtr);
|
|
}
|
|
printf("Searching %s\n", key);
|
|
return 0;
|
|
}
|
|
|
|
/* Get arguments */
|
|
SWIGRUNTIME(int)
|
|
SWIG_GetArgs(Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[], const char *fmt, ...)
|
|
{
|
|
int argno = 0, opt = 0;
|
|
long tempi;
|
|
double tempd;
|
|
const char *c;
|
|
va_list ap;
|
|
void *vptr;
|
|
Tcl_Obj *obj = 0;
|
|
swig_type_info *ty;
|
|
|
|
va_start(ap,fmt);
|
|
for (c = fmt; (*c && (*c != ':') && (*c != ';')); c++,argno++) {
|
|
if (*c == '|') {
|
|
opt = 1;
|
|
c++;
|
|
}
|
|
if (argno >= (objc-1)) {
|
|
if (!opt) {
|
|
Tcl_SetResult(interp, (char *) "Wrong # args. ", TCL_STATIC);
|
|
goto argerror;
|
|
} else {
|
|
va_end(ap);
|
|
return TCL_OK;
|
|
}
|
|
}
|
|
|
|
vptr = va_arg(ap,void *);
|
|
if (vptr) {
|
|
if (isupper(*c)) {
|
|
obj = SWIG_GetConstant(Tcl_GetStringFromObj(objv[argno+1],0));
|
|
if (!obj) obj = objv[argno+1];
|
|
} else {
|
|
obj = objv[argno+1];
|
|
}
|
|
switch(*c) {
|
|
case 'i': case 'I':
|
|
case 'l': case 'L':
|
|
case 'h': case 'H':
|
|
case 'b': case 'B':
|
|
if (Tcl_GetLongFromObj(interp,obj,&tempi) != TCL_OK) goto argerror;
|
|
if ((*c == 'i') || (*c == 'I')) *((int *)vptr) = (int)tempi;
|
|
else if ((*c == 'l') || (*c == 'L')) *((long *)vptr) = (long)tempi;
|
|
else if ((*c == 'h') || (*c == 'H')) *((short*)vptr) = (short)tempi;
|
|
else if ((*c == 'b') || (*c == 'B')) *((unsigned char *)vptr) = (unsigned char)tempi;
|
|
break;
|
|
case 'f': case 'F':
|
|
case 'd': case 'D':
|
|
if (Tcl_GetDoubleFromObj(interp,obj,&tempd) != TCL_OK) goto argerror;
|
|
if ((*c == 'f') || (*c == 'F')) *((float *) vptr) = (float)tempd;
|
|
else if ((*c == 'd') || (*c == 'D')) *((double*) vptr) = tempd;
|
|
break;
|
|
case 's': case 'S':
|
|
if (*(c+1) == '#') {
|
|
int *vlptr = (int *) va_arg(ap, void *);
|
|
*((char **) vptr) = Tcl_GetStringFromObj(obj, vlptr);
|
|
c++;
|
|
} else {
|
|
*((char **)vptr) = Tcl_GetStringFromObj(obj,NULL);
|
|
}
|
|
break;
|
|
case 'c': case 'C':
|
|
*((char *)vptr) = *(Tcl_GetStringFromObj(obj,NULL));
|
|
break;
|
|
case 'p': case 'P':
|
|
ty = (swig_type_info *) va_arg(ap, void *);
|
|
if (SWIG_ConvertPtr(interp, obj, (void **) vptr, ty, SWIG_POINTER_EXCEPTION) == TCL_ERROR) goto argerror;
|
|
break;
|
|
case 'o': case 'O':
|
|
*((Tcl_Obj **)vptr) = objv[argno+1];
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ((*c != ';') && ((objc-1) > argno)) {
|
|
Tcl_SetResult(interp, (char *) "Wrong # args.", TCL_STATIC);
|
|
goto argerror;
|
|
}
|
|
va_end(ap);
|
|
return TCL_OK;
|
|
|
|
argerror:
|
|
{
|
|
char temp[32];
|
|
sprintf(temp,"%d", argno+1);
|
|
c = strchr(fmt,':');
|
|
if (!c) c = strchr(fmt,';');
|
|
if (!c) c = (char *)"";
|
|
Tcl_AppendResult(interp,c," argument ", temp, NULL);
|
|
va_end(ap);
|
|
return TCL_ERROR;
|
|
}
|
|
}
|
|
|
|
SWIGRUNTIME(void)
|
|
SWIG_ObjectDelete(ClientData clientData) {
|
|
swig_instance *si = (swig_instance *) clientData;
|
|
if ((si) && (si->destroy) && (SWIG_Disown(si->thisvalue))) {
|
|
if (si->classptr->destructor) {
|
|
(si->classptr->destructor)(si->thisvalue);
|
|
}
|
|
}
|
|
Tcl_DecrRefCount(si->thisptr);
|
|
free(si);
|
|
}
|
|
|
|
/* Function to invoke object methods given an instance */
|
|
SWIGRUNTIME(int)
|
|
SWIG_MethodCommand(ClientData clientData, Tcl_Interp *interp, int objc, Tcl_Obj *CONST _objv[])
|
|
{
|
|
char *method, *attrname;
|
|
swig_instance *inst = (swig_instance *) clientData;
|
|
swig_method *meth;
|
|
swig_attribute *attr;
|
|
Tcl_Obj *oldarg;
|
|
Tcl_Obj **objv;
|
|
int rcode;
|
|
swig_class *cls;
|
|
swig_class *cls_stack[64];
|
|
int cls_stack_bi[64];
|
|
int cls_stack_top = 0;
|
|
int numconf = 2;
|
|
int bi;
|
|
|
|
objv = (Tcl_Obj **) _objv;
|
|
if (objc < 2) {
|
|
Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
method = Tcl_GetStringFromObj(objv[1],NULL);
|
|
if (strcmp(method,"-acquire") == 0) {
|
|
inst->destroy = 1;
|
|
SWIG_Acquire(inst->thisvalue);
|
|
return TCL_OK;
|
|
}
|
|
if (strcmp(method,"-disown") == 0) {
|
|
if (inst->destroy) {
|
|
SWIG_Disown(inst->thisvalue);
|
|
}
|
|
inst->destroy = 0;
|
|
return TCL_OK;
|
|
}
|
|
if (strcmp(method,"-delete") == 0) {
|
|
Tcl_DeleteCommandFromToken(interp,inst->cmdtok);
|
|
return TCL_OK;
|
|
}
|
|
cls_stack[cls_stack_top] = inst->classptr;
|
|
cls_stack_bi[cls_stack_top] = -1;
|
|
cls = inst->classptr;
|
|
while (1) {
|
|
bi = cls_stack_bi[cls_stack_top];
|
|
cls = cls_stack[cls_stack_top];
|
|
if (bi != -1) {
|
|
cls = cls->bases[bi];
|
|
if (cls) {
|
|
cls_stack_bi[cls_stack_top]++;
|
|
cls_stack_top++;
|
|
cls_stack[cls_stack_top] = cls;
|
|
cls_stack_bi[cls_stack_top] = -1;
|
|
continue;
|
|
}
|
|
}
|
|
if (!cls) {
|
|
cls_stack_top--;
|
|
if (cls_stack_top < 0) break;
|
|
else continue;
|
|
}
|
|
cls_stack_bi[cls_stack_top]++;
|
|
|
|
meth = cls->methods;
|
|
/* Check for methods */
|
|
while (meth && meth->name) {
|
|
if (strcmp(meth->name,method) == 0) {
|
|
oldarg = objv[1];
|
|
objv[1] = inst->thisptr;
|
|
Tcl_IncrRefCount(inst->thisptr);
|
|
rcode = (*meth->method)(clientData,interp,objc,objv);
|
|
objv[1] = oldarg;
|
|
Tcl_DecrRefCount(inst->thisptr);
|
|
return rcode;
|
|
}
|
|
meth++;
|
|
}
|
|
/* Check class methods for a match */
|
|
if (strcmp(method,"cget") == 0) {
|
|
if (objc < 3) {
|
|
Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
attrname = Tcl_GetStringFromObj(objv[2],NULL);
|
|
attr = cls->attributes;
|
|
while (attr && attr->name) {
|
|
if ((strcmp(attr->name, attrname) == 0) && (attr->getmethod)) {
|
|
oldarg = objv[1];
|
|
objv[1] = inst->thisptr;
|
|
Tcl_IncrRefCount(inst->thisptr);
|
|
rcode = (*attr->getmethod)(clientData,interp,2, objv);
|
|
objv[1] = oldarg;
|
|
Tcl_DecrRefCount(inst->thisptr);
|
|
return rcode;
|
|
}
|
|
attr++;
|
|
}
|
|
if (strcmp(attrname, "-this") == 0) {
|
|
Tcl_SetObjResult(interp, Tcl_DuplicateObj(inst->thisptr));
|
|
return TCL_OK;
|
|
}
|
|
if (strcmp(attrname, "-thisown") == 0) {
|
|
if (SWIG_Thisown(inst->thisvalue)) {
|
|
Tcl_SetResult(interp,(char*)"1",TCL_STATIC);
|
|
} else {
|
|
Tcl_SetResult(interp,(char*)"0",TCL_STATIC);
|
|
}
|
|
return TCL_OK;
|
|
}
|
|
} else if (strcmp(method, "configure") == 0) {
|
|
int i;
|
|
if (objc < 4) {
|
|
Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
i = 2;
|
|
while (i < objc) {
|
|
attrname = Tcl_GetStringFromObj(objv[i],NULL);
|
|
attr = cls->attributes;
|
|
while (attr && attr->name) {
|
|
if ((strcmp(attr->name, attrname) == 0) && (attr->setmethod)) {
|
|
oldarg = objv[i];
|
|
objv[i] = inst->thisptr;
|
|
Tcl_IncrRefCount(inst->thisptr);
|
|
rcode = (*attr->setmethod)(clientData,interp,3, &objv[i-1]);
|
|
objv[i] = oldarg;
|
|
Tcl_DecrRefCount(inst->thisptr);
|
|
if (rcode != TCL_OK) return rcode;
|
|
numconf += 2;
|
|
}
|
|
attr++;
|
|
}
|
|
i+=2;
|
|
}
|
|
}
|
|
}
|
|
if (strcmp(method,"configure") == 0) {
|
|
if (numconf >= objc) {
|
|
return TCL_OK;
|
|
} else {
|
|
Tcl_SetResult(interp,(char *) "Invalid attribute name.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
}
|
|
if (strcmp(method,"cget") == 0) {
|
|
Tcl_SetResult(interp,(char *) "Invalid attribute name.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
|
|
Tcl_SetResult(interp, (char *) "Invalid method. Must be one of: configure cget -acquire -disown -delete", TCL_STATIC);
|
|
cls = inst->classptr;
|
|
bi = 0;
|
|
while (cls) {
|
|
meth = cls->methods;
|
|
while (meth && meth->name) {
|
|
char *cr = (char *) Tcl_GetStringResult(interp);
|
|
if (!strstr(strchr(cr,':'), meth->name))
|
|
Tcl_AppendElement(interp, (char *) meth->name);
|
|
meth++;
|
|
}
|
|
cls = inst->classptr->bases[bi++];
|
|
}
|
|
return TCL_ERROR;
|
|
}
|
|
|
|
/* Function to create objects */
|
|
SWIGRUNTIME(int)
|
|
SWIG_ObjectConstructor(ClientData clientData, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[])
|
|
{
|
|
Tcl_Obj *newObj = 0;
|
|
void *thisvalue = 0;
|
|
swig_instance *newinst = 0;
|
|
swig_class *classptr = (swig_class *) clientData;
|
|
swig_wrapper cons = 0;
|
|
char *name = 0;
|
|
int firstarg = 0;
|
|
int thisarg = 0;
|
|
int destroy = 1;
|
|
|
|
if (!classptr) {
|
|
Tcl_SetResult(interp, (char *) "swig: internal runtime error. No class object defined.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
cons = classptr->constructor;
|
|
if (objc > 1) {
|
|
char *s = Tcl_GetStringFromObj(objv[1],NULL);
|
|
if (strcmp(s,"-this") == 0) {
|
|
thisarg = 2;
|
|
cons = 0;
|
|
} else if (strcmp(s,"-args") == 0) {
|
|
firstarg = 1;
|
|
} else if (objc == 2) {
|
|
firstarg = 1;
|
|
name = s;
|
|
} else if (objc >= 3) {
|
|
char *s1;
|
|
name = s;
|
|
s1 = Tcl_GetStringFromObj(objv[2],NULL);
|
|
if (strcmp(s1,"-this") == 0) {
|
|
thisarg = 3;
|
|
cons = 0;
|
|
} else {
|
|
firstarg = 1;
|
|
}
|
|
}
|
|
}
|
|
if (cons) {
|
|
int result;
|
|
result = (*cons)(0, interp, objc-firstarg, &objv[firstarg]);
|
|
if (result != TCL_OK) {
|
|
return result;
|
|
}
|
|
newObj = Tcl_DuplicateObj(Tcl_GetObjResult(interp));
|
|
if (!name) name = Tcl_GetStringFromObj(newObj,NULL);
|
|
} else if (thisarg > 0) {
|
|
if (thisarg < objc) {
|
|
destroy = 0;
|
|
newObj = Tcl_DuplicateObj(objv[thisarg]);
|
|
if (!name) name = Tcl_GetStringFromObj(newObj,NULL);
|
|
} else {
|
|
Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
} else {
|
|
Tcl_SetResult(interp, (char *) "No constructor available.", TCL_STATIC);
|
|
return TCL_ERROR;
|
|
}
|
|
if (SWIG_ConvertPtr(interp,newObj, (void **) &thisvalue, *(classptr->type), SWIG_POINTER_EXCEPTION) == TCL_ERROR) {
|
|
Tcl_DecrRefCount(newObj);
|
|
return TCL_ERROR;
|
|
}
|
|
newinst = (swig_instance *) malloc(sizeof(swig_instance));
|
|
newinst->thisptr = newObj;
|
|
Tcl_IncrRefCount(newObj);
|
|
newinst->thisvalue = thisvalue;
|
|
newinst->classptr = classptr;
|
|
newinst->destroy = destroy;
|
|
if (destroy) {
|
|
SWIG_Acquire(thisvalue);
|
|
}
|
|
newinst->cmdtok = Tcl_CreateObjCommand(interp,name, (swig_wrapper) SWIG_MethodCommand, (ClientData) newinst, (swig_delete_func) SWIG_ObjectDelete);
|
|
return TCL_OK;
|
|
}
|
|
|
|
|
|
/* This function takes the current result and turns it into an object command */
|
|
SWIGRUNTIME(Tcl_Obj *)
|
|
SWIG_NewInstanceObj(Tcl_Interp *interp, void *thisvalue, swig_type_info *type, int flags) {
|
|
Tcl_Obj *robj = SWIG_NewPointerObj(thisvalue, type,0);
|
|
/* Check to see if this pointer belongs to a class or not */
|
|
if ((type->clientdata) && (interp)) {
|
|
Tcl_CmdInfo ci;
|
|
char *name;
|
|
name = Tcl_GetStringFromObj(robj,NULL);
|
|
if (!Tcl_GetCommandInfo(interp,name, &ci) || (flags)) {
|
|
swig_instance *newinst = (swig_instance *) malloc(sizeof(swig_instance));
|
|
newinst->thisptr = Tcl_DuplicateObj(robj);
|
|
Tcl_IncrRefCount(newinst->thisptr);
|
|
newinst->thisvalue = thisvalue;
|
|
newinst->classptr = (swig_class *) type->clientdata;
|
|
newinst->destroy = flags;
|
|
newinst->cmdtok = Tcl_CreateObjCommand(interp, Tcl_GetStringFromObj(robj,NULL), (swig_wrapper_func) SWIG_MethodCommand, (ClientData) newinst, (swig_delete_func) SWIG_ObjectDelete);
|
|
if (flags) {
|
|
SWIG_Acquire(thisvalue);
|
|
}
|
|
}
|
|
}
|
|
return robj;
|
|
}
|
|
|
|
#endif
|
|
|
|
/* Structure for command table */
|
|
typedef struct {
|
|
const char *name;
|
|
int (*wrapper)(ClientData, Tcl_Interp *, int, Tcl_Obj *CONST []);
|
|
ClientData clientdata;
|
|
} swig_command_info;
|
|
|
|
/* Structure for variable linking table */
|
|
typedef struct {
|
|
const char *name;
|
|
void *addr;
|
|
char * (*get)(ClientData, Tcl_Interp *, char *, char *, int);
|
|
char * (*set)(ClientData, Tcl_Interp *, char *, char *, int);
|
|
} swig_var_info;
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|
|
|
|
|