Package org.apache.calcite.sql.type
Class SameOperandTypeChecker
- java.lang.Object
-
- org.apache.calcite.sql.type.SameOperandTypeChecker
-
- All Implemented Interfaces:
SqlOperandTypeChecker
,SqlSingleOperandTypeChecker
- Direct Known Subclasses:
ComparableOperandTypeChecker
,SameOperandTypeExceptLastOperandChecker
public class SameOperandTypeChecker extends java.lang.Object implements SqlSingleOperandTypeChecker
Parameter type-checking strategy where all operand types must be the same.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.calcite.sql.type.SqlOperandTypeChecker
SqlOperandTypeChecker.Consistency
-
-
Field Summary
Fields Modifier and Type Field Description protected int
nOperands
-
Constructor Summary
Constructors Constructor Description SameOperandTypeChecker(int nOperands)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
checkOperandTypes(SqlCallBinding callBinding, boolean throwOnFailure)
Checks the types of all operands to an operator call.boolean
checkOperandTypes(SqlOperatorBinding operatorBinding)
Similar functionality tocheckOperandTypes(SqlCallBinding, boolean)
, but not part of the interface, and cannot throw an error.protected boolean
checkOperandTypesImpl(SqlOperatorBinding operatorBinding, boolean throwOnFailure, SqlCallBinding callBinding)
boolean
checkSingleOperandType(SqlCallBinding callBinding, SqlNode operand, int iFormalOperand, boolean throwOnFailure)
Checks the type of a single operand against a particular ordinal position within a formal operator signature.java.lang.String
getAllowedSignatures(SqlOperator op, java.lang.String opName)
Returns a string describing the allowed formal signatures of a call, e.g.SqlOperandTypeChecker.Consistency
getConsistency()
Returns the strategy for making the arguments have consistency types.SqlOperandCountRange
getOperandCountRange()
protected java.util.List<java.lang.Integer>
getOperandList(int operandCount)
protected java.lang.String
getTypeName()
Override to change the behavior ofgetAllowedSignatures(SqlOperator, String)
.boolean
isOptional(int i)
Returns whether thei
th operand is optional.
-
-
-
Method Detail
-
getConsistency
public SqlOperandTypeChecker.Consistency getConsistency()
Description copied from interface:SqlOperandTypeChecker
Returns the strategy for making the arguments have consistency types.- Specified by:
getConsistency
in interfaceSqlOperandTypeChecker
-
isOptional
public boolean isOptional(int i)
Description copied from interface:SqlOperandTypeChecker
Returns whether thei
th operand is optional.- Specified by:
isOptional
in interfaceSqlOperandTypeChecker
-
checkOperandTypes
public boolean checkOperandTypes(SqlCallBinding callBinding, boolean throwOnFailure)
Description copied from interface:SqlOperandTypeChecker
Checks the types of all operands to an operator call.- Specified by:
checkOperandTypes
in interfaceSqlOperandTypeChecker
- Parameters:
callBinding
- description of the call to be checkedthrowOnFailure
- whether to throw an exception if check fails (otherwise returns false in that case)- Returns:
- whether check succeeded
-
getOperandList
protected java.util.List<java.lang.Integer> getOperandList(int operandCount)
-
checkOperandTypesImpl
protected boolean checkOperandTypesImpl(SqlOperatorBinding operatorBinding, boolean throwOnFailure, SqlCallBinding callBinding)
-
checkOperandTypes
public boolean checkOperandTypes(SqlOperatorBinding operatorBinding)
Similar functionality tocheckOperandTypes(SqlCallBinding, boolean)
, but not part of the interface, and cannot throw an error.
-
getOperandCountRange
public SqlOperandCountRange getOperandCountRange()
- Specified by:
getOperandCountRange
in interfaceSqlOperandTypeChecker
- Returns:
- range of operand counts allowed in a call
-
getAllowedSignatures
public java.lang.String getAllowedSignatures(SqlOperator op, java.lang.String opName)
Description copied from interface:SqlOperandTypeChecker
Returns a string describing the allowed formal signatures of a call, e.g. "SUBSTR(VARCHAR, INTEGER, INTEGER)".- Specified by:
getAllowedSignatures
in interfaceSqlOperandTypeChecker
- Parameters:
op
- the operator being checkedopName
- name to use for the operator in case of aliasing- Returns:
- generated string
-
getTypeName
protected java.lang.String getTypeName()
Override to change the behavior ofgetAllowedSignatures(SqlOperator, String)
.
-
checkSingleOperandType
public boolean checkSingleOperandType(SqlCallBinding callBinding, SqlNode operand, int iFormalOperand, boolean throwOnFailure)
Description copied from interface:SqlSingleOperandTypeChecker
Checks the type of a single operand against a particular ordinal position within a formal operator signature. Note that the actual ordinal position of the operand being checked may be different from the position of the formal operand.For example, when validating the actual call
C(X, Y, Z)
the strategy for validating the operand Z might involve checking its type against the formal signature OP(W). In this case,
iFormalOperand
would be zero, even though the position of Z within call C is two.- Specified by:
checkSingleOperandType
in interfaceSqlSingleOperandTypeChecker
- Parameters:
callBinding
- description of the call being checked; this is only provided for context when throwing an exception; the implementation should NOT examine the operands of the call as part of the checkoperand
- the actual operand to be checkediFormalOperand
- the 0-based formal operand ordinalthrowOnFailure
- whether to throw an exception if check fails (otherwise returns false in that case)- Returns:
- whether check succeeded
-
-