All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.persistence.jpa.jpql.tools.model.EclipseLinkJPQLQueryBuilder Maven / Gradle / Ivy

There is a newer version: 4.0.3
Show newest version
/*******************************************************************************
 * Copyright (c) 2011, 2013 Oracle and/or its affiliates. All rights reserved.
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
 * which accompanies this distribution.
 * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 * and the Eclipse Distribution License is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * Contributors:
 *     Oracle - initial API and implementation
 *
 ******************************************************************************/
package org.eclipse.persistence.jpa.jpql.tools.model;

import org.eclipse.persistence.jpa.jpql.parser.JPQLGrammar;
import org.eclipse.persistence.jpa.jpql.tools.model.query.AbstractConditionalClauseStateObject;
import org.eclipse.persistence.jpa.jpql.tools.model.query.SelectClauseStateObject;
import org.eclipse.persistence.jpa.jpql.tools.model.query.SimpleSelectClauseStateObject;
import org.eclipse.persistence.jpa.jpql.tools.model.query.UpdateItemStateObject;

/**
 * An implementation of {@link IJPQLQueryBuilder} that provides support based on the release
 * of the Java Persistence functional specification defined in 
 * JSR-337 - Java Persistence 2.0. EclipseLink 2.1 provides additional support for 2 additional
 * JPQL identifiers: FUNC and TREAT.
 *
 * @version 2.4
 * @since 2.4
 * @author Pascal Filion
 */
@SuppressWarnings("nls")
public final class EclipseLinkJPQLQueryBuilder extends AbstractJPQLQueryBuilder {

	/**
	 * The {@link JPQLGrammar} that will be used to parse JPQL queries, which has EclipseLink support.
	 */
	private final JPQLGrammar jpqlGrammar;

	/**
	 * Creates a new EclipseLinkJPQLQueryBuilder.
	 *
	 * @param jpqlGrammar The {@link JPQLGrammar} that will be used to parse JPQL queries, which has
	 * EclipseLink support
	 */
	public EclipseLinkJPQLQueryBuilder(JPQLGrammar jpqlGrammar) {
		super();
		this.jpqlGrammar = jpqlGrammar;
	}

	/**
	 * {@inheritDoc}
	 */
	@Override
	protected EclipseLinkStateObjectBuilder buildStateObjectBuilder() {
		return new EclipseLinkStateObjectBuilder();
	}

	/**
	 * {@inheritDoc}
	 */
	public IConditionalExpressionStateObjectBuilder buildStateObjectBuilder(AbstractConditionalClauseStateObject stateObject) {
		return new EclipseLinkConditionalStateObjectBuilder(stateObject);
	}

	/**
	 * {@inheritDoc}
	 */
	public EclipseLinkSelectExpressionStateObjectBuilder buildStateObjectBuilder(SelectClauseStateObject stateObject) {
		return new EclipseLinkSelectExpressionStateObjectBuilder(stateObject);
	}

	/**
	 * {@inheritDoc}
	 */
	public EclipseLinkSimpleSelectExpressionStateObjectBuilder buildStateObjectBuilder(SimpleSelectClauseStateObject stateObject) {
		return new EclipseLinkSimpleSelectExpressionStateObjectBuilder(stateObject);
	}

	/**
	 * {@inheritDoc}
	 */
	public INewValueStateObjectBuilder buildStateObjectBuilder(UpdateItemStateObject stateObject) {
		return new DefaultNewValueStateObjectBuilder(stateObject);
	}

	/**
	 * {@inheritDoc}
	 */
	public JPQLGrammar getGrammar() {
		return jpqlGrammar;
	}

	/**
	 * {@inheritDoc}
	 */
	@Override
	public String toString() {
		return "EclipseLinkJPQLQueryBuilder using " + jpqlGrammar.toString();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy