package le1.plp.expressions1.expression;
import le1.plp.expressions1.util.Tipo;
import le1.plp.expressions1.util.TipoPrimitivo;
import le1.plp.expressions2.memory.AmbienteCompilacao;
import le1.plp.expressions2.memory.AmbienteExecucao;
/**
* Um objeto desta classe representa uma Expressao de Subtracao.
*/
public class ExpSub extends ExpBinaria {
/**
* Controi uma Expressao de Subtracao com as sub-expressoes especificadas.
* Assume-se que estas expressoes resultam em ValorInteiro
* quando avaliadas.
*
* @param esq Expressao da esquerda
* @param dir Expressao da direita
*/
public ExpSub(Expressao esq, Expressao dir) {
super(esq, dir, "-");
}
/**
* Retorna o valor da Expressao de Subtracao
*
* @param amb
* o ambiente de execu��o.
*/
public Valor avaliar(AmbienteExecucao amb) {
return new ValorInteiro(
((ValorInteiro)getEsq().avaliar(amb)).valor() -
((ValorInteiro)getDir().avaliar(amb)).valor()
);
}
/**
* Realiza a verificacao de tipos desta expressao.
*
* @param amb
* o ambiente de compila��o.
*
* @return true se os tipos da expressao sao validos;
* false caso contrario.
*/
protected boolean checaTipoElementoTerminal(AmbienteCompilacao amb) {
return (getEsq().getTipo(amb).eInteiro() && getDir().getTipo(amb).eInteiro());
}
/**
* Retorna os tipos possiveis desta expressao.
*
* @param amb
* o ambiente de compila��o.
*
* @return os tipos possiveis desta expressao.
*/
public Tipo getTipo(AmbienteCompilacao amb) {
return TipoPrimitivo.INTEIRO;
}
}