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 "intTclEvalStr.h"
/*-----------------------------------------------------------------------------------*/
int C2F(intTclEvalStr) _PARAMS((char *fname))
{
CheckRhs(1,2);
CheckLhs(1,1);
if (GetType(1) == sci_strings)
{
char **Str=NULL;
int m1,n1,i,RET;
int m2,n2,l2;
Tcl_Interp *TCLinterpreter=NULL;
GetRhsVar(1,"S",&m1,&n1,&Str);
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;
}
for (i = 0; i<m1*n1 ;i++)
{
RET=Tcl_Eval(TCLinterpreter,Str[i]);
if (RET==TCL_ERROR)
{
if(C2F(iop).err>0)
{
Scierror(999,TCL_ERROR10,fname,i+1);
}
else
{
Scierror(999,TCL_ERROR11,fname,TCLinterpreter->result,i+1);
}
FreeRhsSVar(Str);
return 0;
}
}
FreeRhsSVar(Str);
LhsVar(1) = 0;
C2F(putlhsvar)();
}
else
{
Scierror(999,TCL_ERROR12);
return 0;
}
return 0;
}
/*-----------------------------------------------------------------------------------*/
|