1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
/*-----------------------------------------------------------------------------------*/
/* INRIA 2005 */
/* Allan CORNET */
/*-----------------------------------------------------------------------------------*/
#include "intTclUnsetVar.h"
/*-----------------------------------------------------------------------------------*/
int C2F(intTclUnsetVar) _PARAMS((char *fname))
{
static int l1,n1,m1;
static int l2,n2,m2;
Tcl_Interp *TCLinterpreter=NULL;
CheckRhs(1,2);
CheckLhs(1,1);
if (GetType(1) == sci_strings)
{
int *paramoutINT=(int*)MALLOC(sizeof(int));
char *VarName=NULL;
char *RetStr=NULL;
GetRhsVar(1,"c",&m1,&n1,&l1);
VarName=cstk(l1);
if (TCLinterp == NULL)
{
Scierror(999,TCL_ERROR13,fname);
return 0;
}
if (Rhs==2)
{
/* two arguments given - get a pointer on the slave interpreter */
if (GetType(2) == sci_strings)
{
GetRhsVar(2,"c",&m2,&n2,&l2)
TCLinterpreter=Tcl_GetSlave(TCLinterp,cstk(l2));
if (TCLinterpreter==NULL)
{
Scierror(999,TCL_ERROR17,fname);
return 0;
}
}
else
{
Scierror(999,TCL_ERROR14,fname);
return 0;
}
}
else
{
/* only one argument given - use the main interpreter */
TCLinterpreter=TCLinterp;
}
if (Tcl_UnsetVar(TCLinterpreter, VarName, TCL_GLOBAL_ONLY) == TCL_ERROR)
{
*paramoutINT=(int)(FALSE);
}
else
{
*paramoutINT=(int)(TRUE);
}
n1=1;
CreateVarFromPtr(1, "b", &n1, &n1, ¶moutINT);
LhsVar(1)=1;
C2F(putlhsvar)();
if (paramoutINT) {FREE(paramoutINT);paramoutINT=NULL;}
}
else
{
Scierror(999,TCL_ERROR14,fname);
return 0;
}
return 0;
}
/*-----------------------------------------------------------------------------------*/
|