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 Concatenacao entre * objetos ValorString */ public class ExpConcat extends ExpBinaria{ /** * Controi uma Expressao de Concatenacao com as sub-expressoes especificadas. * Estas sub-expressoes devem ser tais que a avaliacao das mesmas resulta * em ValorString * * @param esq Expressao da esquerda * @param dir Expressao da direita */ public ExpConcat(Expressao esq, Expressao dir){ super(esq, dir, "++"); } /** * Retorna o valor da Expressao de Conjuncao Logica * * @param amb o ambiente de execu��o. */ public Valor avaliar(AmbienteExecucao amb){ return new ValorString( ( (ValorString) getEsq().avaliar(amb)).valor() + ( (ValorString) 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).eString() && getDir().getTipo(amb).eString()); } /** * 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.STRING; } }