com.xdev.jadoth.sqlengine.internal.SqlFunction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xapi Show documentation
Show all versions of xapi Show documentation
XDEV Application Framework
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.dbms.DbmsDMLAssembler;
/**
* The Class SqlFunction.
*
* @author Thomas Muenz
*/
public abstract class SqlFunction extends SqlExpression
{
///////////////////////////////////////////////////////////////////////////
// instance fields //
////////////////////
/**
*
*/
private static final long serialVersionUID = 1779323673982927330L;
/** The parameters. */
protected SqlExpression[] parameters;
///////////////////////////////////////////////////////////////////////////
// constructors //
/////////////////
/**
* Instantiates a new sql function.
*
* @param functionName the function name
* @param params the params
*/
public SqlFunction(final String functionName, final Object... params) {
// (12.11.2009 TM)TODO: pseudo-static keyword getter instead
super(functionName);
this.parameters = SQL.util.parseExpressionArray(params);
}
///////////////////////////////////////////////////////////////////////////
// getters //
/////////////////////
/**
* Gets the parameters.
*
* @return the parameters
*/
public SqlExpression[] getParameters() {
return this.parameters;
}
/**
* Gets the function name.
*
* @return the function name
*/
public abstract String getFunctionName();
/**
* Sets the parameter.
*
* @param param the new parameter
*/
protected void setParameter(final Object... param) {
this.parameters = SQL.util.parseExpressionArray(param);
}
/**
* @param dmlAssembler
* @param sb
* @param indentLevel
* @param flags
* @return
* @see com.xdev.jadoth.sqlengine.internal.SqlExpression#assemble(com.xdev.jadoth.sqlengine.dbms.DbmsDMLAssembler, java.lang.StringBuilder, int, int)
*/
@Override
protected StringBuilder assemble(final DbmsDMLAssembler> dmlAssembler, final StringBuilder sb, final int indentLevel, final int flags){
return assembleFunction(this.getFunctionName(), dmlAssembler, sb, indentLevel, flags, this.parameters);
}
/**
* Assemble function.
*
* @param expression the expression
* @param dmlAssembler the dml assembler
* @param sb the sb
* @param indentLevel the indent level
* @param flags the flags
* @param parameters the parameters
* @return the string builder
*/
protected static StringBuilder assembleFunction(
final String expression,
final DbmsDMLAssembler> dmlAssembler,
final StringBuilder sb,
final int indentLevel,
final int flags,
final Object[] parameters
)
{
return sb.append(QueryPart.function(dmlAssembler, expression, flags, parameters));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy