version 1.13, 2001/09/03 07:01:10 |
version 1.15, 2001/09/20 04:08:21 |
|
|
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* |
* |
* $OpenXM: OpenXM_contrib2/asir2000/parse/eval.c,v 1.12 2001/09/03 01:04:28 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/eval.c,v 1.14 2001/09/05 09:01:28 noro Exp $ |
*/ |
*/ |
#include <ctype.h> |
#include <ctype.h> |
#include "ca.h" |
#include "ca.h" |
|
|
UP2 up2; |
UP2 up2; |
UP up; |
UP up; |
UM um; |
UM um; |
|
Obj obj; |
GF2N gf2n; |
GF2N gf2n; |
GFPN gfpn; |
GFPN gfpn; |
GFSN gfsn; |
GFSN gfsn; |
|
|
case I_PAREN: |
case I_PAREN: |
val = eval((FNODE)(FA0(f))); |
val = eval((FNODE)(FA0(f))); |
break; |
break; |
|
case I_MINUS: |
|
a1 = eval((FNODE)(FA0(f))); |
|
arf_chsgn((Obj)a1,&obj); |
|
val = (pointer)obj; |
|
break; |
case I_BOP: |
case I_BOP: |
a1 = eval((FNODE)FA1(f)); a2 = eval((FNODE)FA2(f)); |
a1 = eval((FNODE)FA1(f)); a2 = eval((FNODE)FA2(f)); |
(*((ARF)FA0(f))->fp)(CO,a1,a2,&val); |
(*((ARF)FA0(f))->fp)(CO,a1,a2,&val); |
|
|
a = eval((FNODE)FA0(f1)); ind = (NODE)FA1(f1); |
a = eval((FNODE)FA0(f1)); ind = (NODE)FA1(f1); |
evalnodebody(ind,&tn); |
evalnodebody(ind,&tn); |
putarray(a,tn,val = eval((FNODE)FA1(f))); |
putarray(a,tn,val = eval((FNODE)FA1(f))); |
|
} else { |
|
error("eval : invalid assignment"); |
} |
} |
break; |
break; |
case I_ANS: |
case I_ANS: |