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
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright (C) 2001 Gerwin Klein <lsf@jflex.de> *
* Copyright (C) 2001 Bernhard Rumpe <rumpe@in.tum.de> *
* All rights reserved. *
* *
* License: BSD *
* *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/**
* AST node for if-then-else expressions
*/
class Tifthenelse extends Texp implements AST {
Tboolexp boolexp; // condition
Texp exp1, exp2; // then and else branch
public Tifthenelse(Tboolexp b, Texp e1, Texp e2) {
boolexp=b;
exp1=e1;
exp2=e2;
}
public String toString() {
return "if "+boolexp+" then "+exp1+" else "+exp2+" fi";
}
public void checkcontext(SymTab st) {
boolexp.checkcontext(st);
exp1.checkcontext(st);
exp2.checkcontext(st);
}
public void prepInterp(SymTab st) {
boolexp.prepInterp(st);
exp1.prepInterp(st);
exp2.prepInterp(st);
}
public int interpret(int[] in, int[] par) {
boolean b = boolexp.interpret(in,par);
if (b)
return exp1.interpret(in,par);
else
return exp2.interpret(in,par);
}
}
|