/***************************************************************** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. ****************************************************************/ package org.apache.cayenne.exp.parser; import java.io.IOException; import java.util.List; import org.apache.cayenne.ObjectId; import org.apache.cayenne.Persistent; import org.apache.cayenne.exp.Expression; /** * A scalar value wrapper expression. * * @since 1.1 */ public class ASTScalar extends SimpleNode { protected Object value; /** * Constructor used by expression parser. Do not invoke directly. */ ASTScalar(int id) { super(id); } public ASTScalar() { super(ExpressionParserTreeConstants.JJTSCALAR); } public ASTScalar(Object value) { super(ExpressionParserTreeConstants.JJTSCALAR); setValue(value); } @Override protected Object evaluateNode(Object o) throws Exception { return value; } /** * Creates a copy of this expression node, without copying children. */ @Override public Expression shallowCopy() { ASTScalar copy = new ASTScalar(id); copy.value = value; return copy; } /** * @since 4.0 */ @Override public void appendAsString(Appendable out) throws IOException { SimpleNode.appendScalarAsString(out, value, '\"'); } /** * @since 4.0 */ @Override public void appendAsEJBQL(List<Object> parameterAccumulator, Appendable out, String rootId) throws IOException { // TODO: see CAY-1111 // Persistent processing is a hack for a rather special case of a single // column PK // object.. full implementation pending... // // cay1796 : change check for Persistent object by check for ObjectId Object scalar = value; if(scalar instanceof ObjectId) { ObjectId temp = (ObjectId)value; if (!temp.isTemporary() && temp.getIdSnapshot().size() == 1) { scalar = temp.getIdSnapshot().values().iterator().next(); } } SimpleNode.encodeScalarAsEJBQL(parameterAccumulator, out, scalar); } public void setValue(Object value) { if (value instanceof Persistent){ this.value = ((Persistent)value).getObjectId(); } else { this.value = value; } } public Object getValue() { return value; } @Override protected String getExpressionOperator(int index) { throw new UnsupportedOperationException("No operator for '" + ExpressionParserTreeConstants.jjtNodeName[id] + "'"); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; ASTScalar other = (ASTScalar) o; return value != null ? value.equals(other.value) : other.value == null; } @Override public int hashCode() { return value != null ? value.hashCode() : 0; } }