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 Igualdade entre Expressoes * cuja avaliacao resulta num mesmo valor primitivo. */ public class ExpEquals extends ExpBinaria { /** * Controi uma Expressao de Igualdade com as sub-expressoes especificadas. * Assume-se que estas sub-expressoes resultam num mesmo valor primitivo * quando avaliadas. * * @param esq * Expressao da esquerda * @param dir * Expressao da direita */ public ExpEquals(Expressao esq, Expressao dir) { super(esq, dir, "=="); } /** * Retorna o valor da Expressao de Igualdade * * @param amb * o ambiente de execu��o. */ public Valor avaliar(AmbienteExecucao amb) { return (new ValorBooleano( ((ValorConcreto) getEsq().avaliar(amb)) .isEquals((ValorConcreto) getDir().avaliar(amb)))); } /** * 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).eIgual(getDir().getTipo(amb))); } /** * 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.BOOLEANO; } }