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

org.eclipse.persistence.jpa.jpql.parser.NullComparisonExpression Maven / Gradle / Ivy

There is a newer version: 5.0.0-B03
Show newest version
/*
 * Copyright (c) 2006, 2020 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 v. 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0,
 * or the Eclipse Distribution License v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
 */

// Contributors:
//     Oracle - initial API and implementation
//
package org.eclipse.persistence.jpa.jpql.parser;

import java.util.Collection;
import java.util.List;
import org.eclipse.persistence.jpa.jpql.ExpressionTools;
import org.eclipse.persistence.jpa.jpql.WordParser;

/**
 * A null comparison tests whether or not the single-valued path expression or input parameter is a
 * NULL value.
 *
 * 
BNF: null_comparison_expression ::= {single_valued_path_expression | input_parameter} IS [NOT] NULL

* * @version 2.5 * @since 2.3 * @author Pascal Filion */ public final class NullComparisonExpression extends AbstractExpression { /** * The expression tested for being null or not. */ private AbstractExpression expression; /** * The actual IS identifier found in the string representation of the JPQL query. */ private String isIdentifier; /** * The actual IS identifier found in the string representation of the JPQL query. */ private String notIdentifier; /** * The actual NULL identifier found in the string representation of the JPQL query. */ private String nullIdentifier; /** * Creates a new NullComparisonExpression. * * @param parent The parent of this expression * @param expression The expression before the identifier */ public NullComparisonExpression(AbstractExpression parent, String identifier, AbstractExpression expression) { super(parent, identifier); this.expression = expression; if (expression != null) { expression.setParent(this); } } @Override public void accept(ExpressionVisitor visitor) { visitor.visit(this); } @Override public void acceptChildren(ExpressionVisitor visitor) { getExpression().accept(visitor); } @Override protected void addChildrenTo(Collection children) { children.add(getExpression()); } @Override protected void addOrderedChildrenTo(List children) { // Expression if (hasExpression()) { children.add(expression); children.add(buildStringExpression(SPACE)); } // Identifier children.add(buildStringExpression(getIdentifier())); } @Override public JPQLQueryBNF findQueryBNF(Expression expression) { if (this.expression == expression) { return expression.getQueryBNF(); } return super.findQueryBNF(expression); } /** * Returns the actual IS found in the string representation of the JPQL query, which has * the actual case that was used. * * @return The IS identifier that was actually parsed, or an empty string if it was not * parsed */ public String getActualIsIdentifier() { return (isIdentifier != null) ? isIdentifier : ExpressionTools.EMPTY_STRING; } /** * Returns the actual Not found in the string representation of the JPQL query, which has * the actual case that was used. * * @return The NOT identifier that was actually parsed, or an empty string if it was not parsed */ public String getActualNotIdentifier() { return (notIdentifier != null) ? notIdentifier : ExpressionTools.EMPTY_STRING; } /** * Returns the actual NULL found in the string representation of the JPQL query, which has * the actual case that was used. * * @return The NULL identifier that was actually parsed */ public String getActualNullIdentifier() { return nullIdentifier; } /** * Returns the expression being tested for being null. * * @return Either the parsed expression or the null-expression */ public Expression getExpression() { if (expression == null) { expression = buildNullExpression(); } return expression; } /** * Returns the identifier for this expression that may include NOT if it was parsed. * * @return Either IS NULL or IS NOT NULL */ public String getIdentifier() { return (notIdentifier != null) ? IS_NOT_NULL : IS_NULL; } @Override public JPQLQueryBNF getQueryBNF() { return getQueryBNF(NullComparisonExpressionBNF.ID); } /** * Determines whether the expression preceding the identifier was parsed. * * @return true the expression preceding the identifier was parsed; * false otherwise */ public boolean hasExpression() { return expression != null && !expression.isNull(); } /** * Determines whether NOT is used in the query. * * @return true if NOT is present in the query; false otherwise */ public boolean hasNot() { return notIdentifier != null; } @Override protected void parse(WordParser wordParser, boolean tolerant) { // 'IS' isIdentifier = wordParser.moveForward(IS); wordParser.skipLeadingWhitespace(); // 'NOT' if (wordParser.startsWithIdentifier(NOT)) { notIdentifier = wordParser.moveForward(NOT); wordParser.skipLeadingWhitespace(); setText(IS_NOT_NULL); } else { setText(IS_NULL); } // 'NULL' nullIdentifier = wordParser.moveForward(NULL); } @Override protected void toParsedText(StringBuilder writer, boolean actual) { if (hasExpression()) { expression.toParsedText(writer, actual); writer.append(SPACE); } if (actual) { writer.append(isIdentifier); writer.append(SPACE); if (notIdentifier != null) { writer.append(notIdentifier); writer.append(SPACE); } writer.append(nullIdentifier); } else { writer.append(getIdentifier()); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy