TP-metaprogrammation-test/TP1/EvaluateurExpression.java

67 lines
1.7 KiB
Java
Raw Normal View History

2021-12-03 14:52:36 +00:00
/** Afficheur infixe, complètement parenthésé, d'une expression arithmétique.
*
* @author Xavier Crégut
* @version $Revision$
*/
import java.util.*;
public class EvaluateurExpression implements VisiteurExpression<Integer> {
private Map<String,Integer> env;
public EvaluateurExpression(Map<String,Integer> env) {
this.env = env;
}
public Integer visiterAccesVariable(AccesVariable v) {
return env.get(v.getNom());
}
public Integer visiterConstante(Constante c) {
return c.getValeur();
}
public Integer visiterExpressionBinaire(ExpressionBinaire e) {
switch (e.getOperateur().accepter(this)) {
case 0:
return e.getOperandeGauche().accepter(this) + e.getOperandeDroite().accepter(this);
case 1:
return e.getOperandeGauche().accepter(this) - e.getOperandeDroite().accepter(this);
case 2:
return e.getOperandeGauche().accepter(this) * e.getOperandeDroite().accepter(this);
default:
return 0;
}
}
public Integer visiterAddition(Addition a) {
return 0;
}
public Integer visiterSoustraction(Soustraction a) {
return 1;
}
public Integer visiterMultiplication(Multiplication m) {
return 2;
}
public Integer visiterExpressionUnaire(ExpressionUnaire e) {
switch (e.getOperateur().accepter(this)) {
case 0:
return -e.getOperande().accepter(this);
default:
return 0;
}
}
public Integer visiterNegation(Negation n) {
return 0;
}
}