/******************************************************************************* * * Copyright 2010 Alexandru Craciun, and individual contributors as indicated * by the @authors tag. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 3 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. ******************************************************************************/ /* Generated By:JJTree: Do not edit this line. ASTConcatExpression.java Version 4.3 */ /* JavaCCOptions:MULTI=true,NODE_USES_PARSER=false,VISITOR=false,TRACK_TOKENS=false,NODE_PREFIX=AST,NODE_EXTENDS=,NODE_FACTORY=,SUPPORT_CLASS_VISIBILITY_PUBLIC=true */ package org.netxilia.spi.impl.formula.parser; import org.netxilia.api.formula.IFormulaContext; import org.netxilia.api.value.GenericValueType; import org.netxilia.api.value.IGenericValue; import org.netxilia.api.value.StringValue; /** * An AST node representing a concatenation of 2 expressions. */ public class ASTConcatExpression extends ASTBinaryExpression { public ASTConcatExpression(int id) { super(id, "Concat"); setOperator("&"); } public ASTConcatExpression(FormulaParser p, int id) { super(p, id, "Concat"); setOperator("&"); } @Override public IGenericValue eval(IFormulaContext context) { ASTBaseNode nLeft = (ASTBaseNode) jjtGetChild(0); ASTBaseNode nRight = (ASTBaseNode) jjtGetChild(1); IGenericValue cvLeft = nLeft.eval(context); IGenericValue cvRight = nRight.eval(context); if (cvLeft.getValueType() == GenericValueType.ERROR) { return cvLeft; } if (cvRight.getValueType() == GenericValueType.ERROR) { return cvRight; } return new StringValue(cvLeft.getStringValue() + cvRight.getStringValue()); } } /* * JavaCC - OriginalChecksum=0348de459c84257de8fa6747e3dae3b8 (do not edit this * line) */