package le2.plp.expressions2.expression;
import le2.plp.expressions1.util.Tipo;
import le2.plp.expressions1.util.TipoPrimitivo;
import le2.plp.expressions2.memory.AmbienteCompilacao;
import le2.plp.expressions2.memory.AmbienteExecucao;
import le2.plp.expressions2.memory.VariavelJaDeclaradaException;
import le2.plp.expressions2.memory.VariavelNaoDeclaradaException;
/**
* 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.
*/
public Valor avaliar(AmbienteExecucao amb) throws VariavelNaoDeclaradaException, VariavelJaDeclaradaException {
return new ValorInteiro(
((ValorInteiro)getEsq().avaliar(amb)).valor() -
((ValorInteiro)getDir().avaliar(amb)).valor()
);
}
/**
* Realiza a verificacao de tipos desta expressao.
*
* @param ambiente o ambiente de compila��o.
* @return true se os tipos da expressao sao validos;
* false caso contrario.
* @exception VariavelNaoDeclaradaException se existir um identificador
* nao declarado no ambiente.
* @exception VariavelNaoDeclaradaException se existir um identificador
* declarado mais de uma vez no mesmo bloco do ambiente.
*/
protected boolean checaTipoElementoTerminal(AmbienteCompilacao ambiente)
throws VariavelNaoDeclaradaException,VariavelJaDeclaradaException {
return (getEsq().getTipo(ambiente).eInteiro() && getDir().getTipo(ambiente).eInteiro());
}
/**
* Retorna os tipos possiveis desta expressao.
*
* @param ambiente o ambiente de compila��o.
* @return os tipos possiveis desta expressao.
*/
public Tipo getTipo(AmbienteCompilacao ambiente) {
return TipoPrimitivo.INTEIRO;
}
@Override
public ExpBinaria clone() {
return new ExpSub(esq.clone(), dir.clone());
}
}