/* * Copyright 2008 Udai Gupta, Ralf Joachim * * Licensed 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.castor.cpa.query.object; import org.castor.cpa.query.Field; import org.castor.cpa.query.Projection; /** * Final immutable class that a projection of a select query. * * @author <a href="mailto:mailtoud AT gmail DOT com">Udai Gupta</a> * @author <a href="mailto:ralf DOT joachim AT syscon DOT eu">Ralf Joachim</a> * @version $Revision: 7121 $ $Date: 2006-04-25 16:09:10 -0600 (Tue, 25 Apr 2006) $ * @since 1.3 */ public final class ProjectionImpl extends AbstractField implements Projection { //-------------------------------------------------------------------------- /** The field or schema of the projection. */ private final Field _field; /** The alias of the projection. */ private final String _alias; //-------------------------------------------------------------------------- /** * Construct projection with given field. * * @param field The field or schema of the projection. */ public ProjectionImpl(final Field field) { if (field == null) { throw new NullPointerException(); } _field = field; _alias = null; } /** * Construct projection with given field and alias. * @param field The field or schema of the projection. * @param alias The alias of the projection. */ public ProjectionImpl(final Field field, final String alias) { if (field == null) { throw new NullPointerException(); } _field = field; _alias = alias; } //-------------------------------------------------------------------------- /** * Gets the field or schema of the projection. * * @return The field of the projection. */ public Field getField() { return _field; } /** * Gets the alias of the projection. * * @return The alias of the projection. */ public String getAlias() { return _alias; } //-------------------------------------------------------------------------- /** * {@inheritDoc} */ public StringBuilder toString(final StringBuilder sb) { if (_alias != null) { sb.append(_alias); } else { _field.toString(sb); } return sb; } /** * {@inheritDoc} */ public StringBuilder toFullString(final StringBuilder sb) { _field.toString(sb); if (_alias != null) { sb.append(" AS "); sb.append(_alias); } return sb; } /** * {@inheritDoc} */ public String toFullString() { return toFullString(new StringBuilder()).toString(); } //-------------------------------------------------------------------------- }