com.xdev.jadoth.sqlengine.internal.ConditionClause Maven / Gradle / Ivy
package com.xdev.jadoth.sqlengine.internal;
/*-
* #%L
* XDEV Application Framework
* %%
* Copyright (C) 2003 - 2020 XDEV Software
* %%
* This program 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 program 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 General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import com.xdev.jadoth.sqlengine.SQL;
import com.xdev.jadoth.sqlengine.internal.interfaces.Conditional;
/**
* The Class ConditionClause.
*
* @param the generic type
* @author Thomas Muenz
*/
public abstract class ConditionClause> extends SqlClause
implements Conditional
{
///////////////////////////////////////////////////////////////////////////
// constants //
/////////////////////
/**
*
*/
private static final long serialVersionUID = -3642728899754205222L;
private static final SqlCondition unwrapBooleanArithmeticCondition(final SqlCondition sqlCondition)
{
if(sqlCondition instanceof SqlBooleanArithmeticCondition){
return ((SqlBooleanArithmeticCondition)sqlCondition).getCondition();
}
return sqlCondition;
}
///////////////////////////////////////////////////////////////////////////
// constructors //
/////////////////
/**
* Instantiates a new condition clause.
*/
public ConditionClause() {
super();
}
/**
* Instantiates a new condition clause.
*
* @param firstCondition the first condition
*/
public ConditionClause(final Object firstCondition) {
super(unwrapBooleanArithmeticCondition(SQL.util.parseCondition(firstCondition)));
}
protected ConditionClause(final ConditionClause copySource)
{
super(copySource);
}
/**
* @param singleLineMode
* @return
* @see com.xdev.jadoth.sqlengine.internal.SqlClause#getBodyElementSeperator(boolean)
*/
@Override
public String getBodyElementSeperator(final boolean singleLineMode) {
//AND/OR handle their trailing space by themselves
return singleLineMode?"":this.bodyElementSeperator;
}
/**
* Adds the condition.
*
* @param conditionClause the condition clause
* @return the c
*/
@SuppressWarnings("unchecked")
protected C addCondition(final SqlBooleanArithmeticCondition conditionClause)
{
/* (02.12.2009 TM)FIXME: ConditionClause.addCondition for first condition
* Refactor WHERE and HAVING to be HeadedConditionClause and handle firstCondition SpecialCase there.
* Rename "SqlBooleanArithmeticCondition"
* Make addCondition public again
*/
this.body.add(conditionClause);
return (C)this;
}
/**
* @param condition
* @return
* @see com.xdev.jadoth.sqlengine.internal.interfaces.Conditional#AND(java.lang.Object)
*/
@Override
@SuppressWarnings("unchecked")
public C AND(final Object condition)
{
if(this.body.isEmpty()){
this.body.add(SQL.util.parseCondition(condition));
return (C)this;
}
return this.addCondition((AND)(condition instanceof AND?condition:new AND(condition)));
}
/**
* @param condition
* @return
* @see com.xdev.jadoth.sqlengine.internal.interfaces.Conditional#OR(java.lang.Object)
*/
@Override
@SuppressWarnings("unchecked")
public C OR(final Object condition)
{
if(this.body.isEmpty()){
this.body.add(SQL.util.parseCondition(condition));
return (C)this;
}
return this.addCondition((OR)(condition instanceof OR?condition:new OR(condition)));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy