diff options
Diffstat (limited to 'Lib/tcl/ptrlang.i')
-rw-r--r-- | Lib/tcl/ptrlang.i | 490 |
1 files changed, 0 insertions, 490 deletions
diff --git a/Lib/tcl/ptrlang.i b/Lib/tcl/ptrlang.i deleted file mode 100644 index fbd1278c9..000000000 --- a/Lib/tcl/ptrlang.i +++ /dev/null @@ -1,490 +0,0 @@ -// -// SWIG pointer conversion and utility library -// -// Dave Beazley -// April 19, 1997 -// -// Tcl specific implementation. This file is included -// by the file ../pointer.i - - -%{ -#include <ctype.h> - -/* Types used by the library */ -static swig_type_info *SWIG_POINTER_int_p = 0; -static swig_type_info *SWIG_POINTER_short_p =0; -static swig_type_info *SWIG_POINTER_long_p = 0; -static swig_type_info *SWIG_POINTER_float_p = 0; -static swig_type_info *SWIG_POINTER_double_p = 0; -static swig_type_info *SWIG_POINTER_char_p = 0; -static swig_type_info *SWIG_POINTER_char_pp = 0; -%} - -%init %{ - SWIG_POINTER_int_p = SWIG_TypeQuery("int *"); - SWIG_POINTER_short_p = SWIG_TypeQuery("short *"); - SWIG_POINTER_long_p = SWIG_TypeQuery("long *"); - SWIG_POINTER_float_p = SWIG_TypeQuery("float *"); - SWIG_POINTER_double_p = SWIG_TypeQuery("double *"); - SWIG_POINTER_char_p = SWIG_TypeQuery("char *"); - SWIG_POINTER_char_pp = SWIG_TypeQuery("char **"); -%} - -%{ - -/*------------------------------------------------------------------ - ptrvalue(ptr,type = 0) - - Attempts to dereference a pointer value. If type is given, it - will try to use that type. Otherwise, this function will attempt - to "guess" the proper datatype by checking against all of the - builtin C datatypes. - ------------------------------------------------------------------ */ - -static int ptrvalue(Tcl_Interp *interp, char *ptrvalue, int index, char *type) { - void *ptr; - char *s; - int error = 0; - - if (type) { - if (strlen(type) == 0) type = 0; - } - s = ptrvalue; - if (SWIG_ConvertPtrFromString(interp,s,&ptr,0) != TCL_OK) { - Tcl_SetResult(interp,"Type error in ptrvalue. Argument is not a valid pointer value.", TCL_STATIC); - return TCL_ERROR; - } - - /* If no datatype was passed, try a few common datatypes first */ - if (!type) { - /* No datatype was passed. Type to figure out if it's a common one */ - if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_int_p) == TCL_OK) { - type = "int"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_double_p) == TCL_OK) { - type = "double"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_short_p) == TCL_OK) { - type = "short"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_long_p) == TCL_OK) { - type = "long"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_float_p) == TCL_OK) { - type = "float"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_char_p) == TCL_OK) { - type = "char"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_char_pp) == TCL_OK) { - type = "char *"; - } else { - type = "unknown"; - } - } - - if (!ptr) { - Tcl_SetResult(interp,"Unable to dereference NULL pointer.",TCL_STATIC); - return TCL_ERROR; - } - - /* Now we have a datatype. Try to figure out what to do about it */ - if (strcmp(type,"int") == 0) { - sprintf(interp->result,"%ld",(long) *(((int *) ptr) + index)); - } else if (strcmp(type,"double") == 0) { - Tcl_PrintDouble(interp,(double) *(((double *) ptr)+index), interp->result); - } else if (strcmp(type,"short") == 0) { - sprintf(interp->result,"%ld",(long) *(((short *) ptr) + index)); - } else if (strcmp(type,"long") == 0) { - sprintf(interp->result,"%ld",(long) *(((long *) ptr) + index)); - } else if (strcmp(type,"float") == 0) { - Tcl_PrintDouble(interp,(double) *(((float *) ptr)+index), interp->result); - } else if (strcmp(type,"char") == 0) { - Tcl_SetResult(interp,((char *) ptr) + index, TCL_VOLATILE); - } else if (strcmp(type,"char *") == 0) { - char *c = *(((char **) ptr)+index); - if (c) Tcl_SetResult(interp,(char *) c, TCL_VOLATILE); - else Tcl_SetResult(interp,"NULL", TCL_VOLATILE); - } else { - Tcl_SetResult(interp,"Unable to dereference unsupported datatype.",TCL_STATIC); - return TCL_ERROR; - } - return TCL_OK; -} - -/*------------------------------------------------------------------ - ptrcreate(type,value = 0,numelements = 1) - - Attempts to create a new object of given type. Type must be - a basic C datatype. Will not create complex objects. - ------------------------------------------------------------------ */ - -static int ptrcreate(Tcl_Interp *interp, char *type, char *ptrvalue, int numelements) { - void *ptr; - int sz; - swig_type_info *cast = 0; - char temp[40]; - - /* Check the type string against a variety of possibilities */ - - if (strcmp(type,"int") == 0) { - sz = sizeof(int)*numelements; - cast = SWIG_POINTER_int_p; - } else if (strcmp(type,"short") == 0) { - sz = sizeof(short)*numelements; - cast = SWIG_POINTER_short_p; - } else if (strcmp(type,"long") == 0) { - sz = sizeof(long)*numelements; - cast = SWIG_POINTER_long_p; - } else if (strcmp(type,"double") == 0) { - sz = sizeof(double)*numelements; - cast = SWIG_POINTER_double_p; - } else if (strcmp(type,"float") == 0) { - sz = sizeof(float)*numelements; - cast = SWIG_POINTER_float_p; - } else if (strcmp(type,"char") == 0) { - sz = sizeof(char)*numelements; - cast = SWIG_POINTER_char_p; - } else if (strcmp(type,"char *") == 0) { - sz = sizeof(char *)*(numelements+1); - cast = SWIG_POINTER_char_pp; - } else if (strcmp(type,"void") == 0) { - sz = numelements; - } else { - Tcl_SetResult(interp,"Unable to create unknown datatype.",TCL_STATIC); - return TCL_ERROR; - } - - /* Create the new object */ - - ptr = (void *) malloc(sz); - if (!ptr) { - Tcl_SetResult(interp,"Out of memory in ptrcreate.",TCL_STATIC); - return TCL_ERROR; - } - - /* Now try to set its default value */ - - if (ptrvalue) { - if (strcmp(type,"int") == 0) { - int *ip,i,ivalue; - Tcl_GetInt(interp,ptrvalue,&ivalue); - ip = (int *) ptr; - for (i = 0; i < numelements; i++) - ip[i] = ivalue; - } else if (strcmp(type,"short") == 0) { - short *ip; - int i, ivalue; - Tcl_GetInt(interp,ptrvalue,&ivalue); - ip = (short *) ptr; - for (i = 0; i < numelements; i++) - ip[i] = (short) ivalue; - } else if (strcmp(type,"long") == 0) { - long *ip; - int i, ivalue; - Tcl_GetInt(interp,ptrvalue,&ivalue); - ip = (long *) ptr; - for (i = 0; i < numelements; i++) - ip[i] = (long) ivalue; - } else if (strcmp(type,"double") == 0) { - double *ip,ivalue; - int i; - Tcl_GetDouble(interp,ptrvalue,&ivalue); - ip = (double *) ptr; - for (i = 0; i < numelements; i++) - ip[i] = ivalue; - } else if (strcmp(type,"float") == 0) { - float *ip; - double ivalue; - int i; - Tcl_GetDouble(interp,ptrvalue,&ivalue); - ip = (float *) ptr; - for (i = 0; i < numelements; i++) - ip[i] = (double) ivalue; - } else if (strcmp(type,"char") == 0) { - char *ip,*ivalue; - ivalue = (char *) ptrvalue; - ip = (char *) ptr; - strncpy(ip,ivalue,numelements-1); - } else if (strcmp(type,"char *") == 0) { - char **ip, *ivalue; - int i; - ivalue = (char *) ptrvalue; - ip = (char **) ptr; - for (i = 0; i < numelements; i++) { - if (ivalue) { - ip[i] = (char *) malloc(strlen(ivalue)+1); - strcpy(ip[i],ivalue); - } else { - ip[i] = 0; - } - } - ip[numelements] = 0; - } - } - /* Create the pointer value */ - - Tcl_SetObjResult(interp,SWIG_NewPointerObj(ptr,cast)); - return TCL_OK; -} - -/*------------------------------------------------------------------ - ptrset(ptr,value,index = 0,type = 0) - - Attempts to set the value of a pointer variable. If type is - given, we will use that type. Otherwise, we'll guess the datatype. - ------------------------------------------------------------------ */ - -static int ptrset(Tcl_Interp *interp, char *ptrvalue, char *value, int index, char *type) { - void *ptr; - char *s; - - s = ptrvalue; - if (SWIG_ConvertPtrFromString(interp,s,&ptr,0) != TCL_OK) { - Tcl_SetResult(interp,"Type error in ptrset. Argument is not a valid pointer value.", - TCL_STATIC); - return TCL_ERROR; - } - - /* If no datatype was passed, try a few common datatypes first */ - - if (!type) { - - /* No datatype was passed. Type to figure out if it's a common one */ - if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_int_p) == TCL_OK) { - type = "int"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_double_p) == TCL_OK) { - type = "double"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_short_p) == TCL_OK) { - type = "short"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_long_p) == TCL_OK) { - type = "long"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_float_p) == TCL_OK) { - type = "float"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_char_p) == TCL_OK) { - type = "char"; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_char_pp) == TCL_OK) { - type = "char *"; - } else { - type = "unknown"; - } - } - - if (!ptr) { - Tcl_SetResult(interp,"Unable to set NULL pointer.",TCL_STATIC); - return TCL_ERROR; - } - - /* Now we have a datatype. Try to figure out what to do about it */ - if (strcmp(type,"int") == 0) { - int ivalue; - Tcl_GetInt(interp,value, &ivalue); - *(((int *) ptr)+index) = ivalue; - } else if (strcmp(type,"double") == 0) { - double ivalue; - Tcl_GetDouble(interp,value, &ivalue); - *(((double *) ptr)+index) = (double) ivalue; - } else if (strcmp(type,"short") == 0) { - int ivalue; - Tcl_GetInt(interp,value, &ivalue); - *(((short *) ptr)+index) = (short) ivalue; - } else if (strcmp(type,"long") == 0) { - int ivalue; - Tcl_GetInt(interp,value, &ivalue); - *(((long *) ptr)+index) = (long) ivalue; - } else if (strcmp(type,"float") == 0) { - double ivalue; - Tcl_GetDouble(interp,value, &ivalue); - *(((float *) ptr)+index) = (float) ivalue; - } else if (strcmp(type,"char") == 0) { - char *c = value; - strcpy(((char *) ptr)+index, c); - } else if (strcmp(type,"char *") == 0) { - char *c = value; - char **ca = (char **) ptr; - if (ca[index]) free(ca[index]); - if (strcmp(c,"NULL") == 0) { - ca[index] = 0; - } else { - ca[index] = (char *) malloc(strlen(c)+1); - strcpy(ca[index],c); - } - } else { - Tcl_SetResult(interp,"Unable to set unsupported datatype.",TCL_STATIC); - return TCL_ERROR; - } - return TCL_OK; -} - -/*------------------------------------------------------------------ - ptradd(ptr,offset) - - Adds a value to an existing pointer value. Will do a type-dependent - add for basic datatypes. For other datatypes, will do a byte-add. - ------------------------------------------------------------------ */ - -static int ptradd(Tcl_Interp *interp, char *ptrvalue, int offset) { - - char *r,*s; - void *ptr,*junk; - swig_type_info *type = 0; - swig_type_info stype; - - /* Check to see what kind of object ptrvalue is */ - - s = ptrvalue; - - /* Try to handle a few common datatypes first */ - - if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_int_p) == TCL_OK) { - ptr = (void *) (((int *) ptr) + offset); - type = SWIG_POINTER_int_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_double_p) == TCL_OK) { - ptr = (void *) (((double *) ptr) + offset); - type = SWIG_POINTER_double_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_short_p) == TCL_OK) { - ptr = (void *) (((short *) ptr) + offset); - type = SWIG_POINTER_short_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_long_p) == TCL_OK) { - ptr = (void *) (((long *) ptr) + offset); - type = SWIG_POINTER_long_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_float_p) == TCL_OK) { - ptr = (void *) (((float *) ptr) + offset); - type = SWIG_POINTER_float_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,SWIG_POINTER_char_p) == TCL_OK) { - ptr = (void *) (((char *) ptr) + offset); - type = SWIG_POINTER_char_p; - } else if (SWIG_ConvertPtrFromString(interp,s,&ptr,0) == TCL_OK) { - ptr = (void *) (((char *) ptr) + offset); - stype.name = SWIG_PointerTypeFromString(s); - type = &stype; - } else { - Tcl_SetResult(interp,"Type error in ptradd. Argument is not a valid pointer value.",TCL_STATIC); - return TCL_ERROR; - } - Tcl_SetObjResult(interp,SWIG_NewPointerObj(ptr,type)); - return TCL_OK; -} - -/*------------------------------------------------------------------ - ptrfree(ptr) - - Destroys a pointer value - ------------------------------------------------------------------ */ - -int ptrfree(Tcl_Interp *interp, char *ptrvalue) { - void *ptr, *junk; - char *s; - - s = ptrvalue; - if (SWIG_ConvertPtrFromString(interp,ptrvalue,&ptr,0) != TCL_OK) { - Tcl_SetResult(interp,"Type error in ptrfree. Argument is not a valid pointer value.",TCL_STATIC); - return TCL_ERROR; - } - - /* Check to see if this pointer is a char ** */ - if (SWIG_ConvertPtrFromString(interp,ptrvalue,&junk,SWIG_POINTER_char_pp) == TCL_OK) { - char **c = (char **) ptr; - if (c) { - int i = 0; - while (c[i]) { - free(c[i]); - i++; - } - } - } - if (ptr) - free((char *) ptr); - return TCL_OK; -} -%} - -%typemap(tcl8,out) int ptrcast, - int ptrvalue, - int ptrcreate, - int ptrset, - int ptradd, - int ptrfree -{ - return $source; -} - -%typemap(tcl8,ignore) Tcl_Interp * { - $target = interp; -} - -int ptrvalue(Tcl_Interp *interp, char *ptr, int index = 0, char *type = 0); -// Returns the value that a pointer is pointing to (ie. dereferencing). -// The type is automatically inferred by the pointer type--thus, an -// integer pointer will return an integer, a double will return a double, -// and so on. The index and type fields are optional parameters. When -// an index is specified, this function returns the value of ptr[index]. -// This allows array access. When a type is specified, it overrides -// the given pointer type. Examples : -// -// ptrvalue $a # Returns the value *a -// ptrvalue $a 10 # Returns the value a[10] -// ptrvalue $a 10 double # Returns a[10] assuming a is a double * - -int ptrset(Tcl_Interp *interp, char *ptr, char *value, int index = 0, char *type = 0); -// Sets the value pointed to by a pointer. The type is automatically -// inferred from the pointer type so this function will work for -// integers, floats, doubles, etc... The index and type fields are -// optional. When an index is given, it provides array access. When -// type is specified, it overrides the given pointer type. Examples : -// -// ptrset $a 3 # Sets the value *a = 3 -// ptrset $a 3 10 # Sets a[10] = 3 -// ptrset $a 3 10 int # Sets a[10] = 3 assuming a is a int * - -int ptrcreate(Tcl_Interp *interp, char *type, char *value = 0, int nitems = 1); -// Creates a new object and returns a pointer to it. This function -// can be used to create various kinds of objects for use in C functions. -// type specifies the basic C datatype to create and value is an -// optional parameter that can be used to set the initial value of the -// object. nitems is an optional parameter that can be used to create -// an array. This function results in a memory allocation using -// malloc(). Examples : -// -// set a [ptrcreate "double"] # Create a new double, return pointer -// set a [ptrcreate int 7] # Create an integer, set value to 7 -// set a [ptrcreate int 0 1000] # Create an integer array with initial -// # values all set to zero -// -// This function only recognizes a few common C datatypes as listed below : -// -// int, short, long, float, double, char, char *, void -// -// All other datatypes will result in an error. However, other -// datatypes can be created by using the ptrcast function. For -// example: -// -// set a [ptrcast [ptrcreate int 0 100],"unsigned int *"] - -int ptrfree(Tcl_Interp *interp, char *ptr); -// Destroys the memory pointed to by ptr. This function calls free() -// and should only be used with objects created by ptrcreate(). Since -// this function calls free, it may work with other objects, but this -// is generally discouraged unless you absolutely know what you're -// doing. - -int ptradd(Tcl_Interp *interp, char *ptr, int offset); -// Adds a value to the current pointer value. For the C datatypes of -// int, short, long, float, double, and char, the offset value is the -// number of objects and works in exactly the same manner as in C. For -// example, the following code steps through the elements of an array -// -// set a [ptrcreate double 0 100] # Create an array double a[100] -// set b $a -// for {set i 0} {$i < 100} {incr i 1} { -// ptrset $b [expr{0.0025*$i}] # set *b = 0.0025*i -// set b [ptradd $b 1] # b++ (go to next double) -// } -// -// In this case, adding one to b goes to the next double. -// -// For all other datatypes (including all complex datatypes), the -// offset corresponds to bytes. This function does not perform any -// bounds checking and negative offsets are perfectly legal. - - - - - - - |