QGIS API Documentation 3.41.0-Master (45a0abf3bec)
|
A binary expression operator, which operates on two values. More...
#include <qgsexpressionnodeimpl.h>
Public Types | |
enum | BinaryOperator { boOr , boAnd , boEQ , boNE , boLE , boGE , boLT , boGT , boRegexp , boLike , boNotLike , boILike , boNotILike , boIs , boIsNot , boPlus , boMinus , boMul , boDiv , boIntDiv , boMod , boPow , boConcat } |
list of binary operators More... | |
Public Types inherited from QgsExpressionNode | |
enum | NodeType { ntUnaryOperator , ntBinaryOperator , ntInOperator , ntFunction , ntLiteral , ntColumnRef , ntCondition , ntIndexOperator , ntBetweenOperator } |
Known node types. More... | |
Public Member Functions | |
QgsExpressionNodeBinaryOperator (QgsExpressionNodeBinaryOperator::BinaryOperator op, QgsExpressionNode *opLeft, QgsExpressionNode *opRight) | |
Binary combination of the left and the right with op. | |
~QgsExpressionNodeBinaryOperator () override | |
QgsExpressionNode * | clone () const override |
Generate a clone of this node. | |
QString | dump () const override |
Dump this node into a serialized (part) of an expression. | |
QVariant | evalNode (QgsExpression *parent, const QgsExpressionContext *context) override |
Abstract virtual eval method Errors are reported to the parent. | |
bool | isStatic (QgsExpression *parent, const QgsExpressionContext *context) const override |
Returns true if this node can be evaluated for a static value. | |
bool | leftAssociative () const |
Returns true if the operator is left-associative. | |
bool | needsGeometry () const override |
Abstract virtual method which returns if the geometry is required to evaluate this expression. | |
QList< const QgsExpressionNode * > | nodes () const override |
Returns a list of all nodes which are used in this expression. | |
QgsExpressionNode::NodeType | nodeType () const override |
Gets the type of this node. | |
QgsExpressionNodeBinaryOperator::BinaryOperator | op () const |
Returns the binary operator. | |
QgsExpressionNode * | opLeft () const |
Returns the node to the left of the operator. | |
QgsExpressionNode * | opRight () const |
Returns the node to the right of the operator. | |
int | precedence () const |
Returns the precedence index for the operator. | |
bool | prepareNode (QgsExpression *parent, const QgsExpressionContext *context) override |
Abstract virtual preparation method Errors are reported to the parent. | |
QSet< QString > | referencedColumns () const override |
Abstract virtual method which returns a list of columns required to evaluate this node. | |
QSet< QString > | referencedFunctions () const override |
Returns a set of all functions which are used in this expression. | |
QSet< QString > | referencedVariables () const override |
Returns a set of all variables which are used in this expression. | |
QString | text () const |
Returns a the name of this operator without the operands. | |
Public Member Functions inherited from QgsExpressionNode | |
virtual | ~QgsExpressionNode ()=default |
QVariant | cachedStaticValue () const |
Returns the node's static cached value. | |
const QgsExpressionNode * | effectiveNode () const |
Returns a reference to the simplest node which represents this node, after any compilation optimizations have been applied. | |
QVariant | eval (QgsExpression *parent, const QgsExpressionContext *context) |
Evaluate this node with the given context and parent. | |
bool | hasCachedStaticValue () const |
Returns true if the node can be replaced by a static cached value. | |
bool | prepare (QgsExpression *parent, const QgsExpressionContext *context) |
Prepare this node for evaluation. | |
void | setCachedStaticValue (const QVariant &value) const |
Sets the cached static value for the node. | |
Additional Inherited Members | |
Public Attributes inherited from QgsExpressionNode | |
int | parserFirstColumn = 0 |
First column in the parser this node was found. | |
int | parserFirstLine = 0 |
First line in the parser this node was found. | |
int | parserLastColumn = 0 |
Last column in the parser this node was found. | |
int | parserLastLine = 0 |
Last line in the parser this node was found. | |
Protected Member Functions inherited from QgsExpressionNode | |
QgsExpressionNode ()=default | |
QgsExpressionNode (const QgsExpressionNode &other) | |
void | cloneTo (QgsExpressionNode *target) const |
Copies the members of this node to the node provided in target. | |
QgsExpressionNode & | operator= (const QgsExpressionNode &other) |
Protected Attributes inherited from QgsExpressionNode | |
QVariant | mCachedStaticValue |
Contains the static, precalculated value for the node if mHasCachedValue is true . | |
std::unique_ptr< QgsExpressionNode > | mCompiledSimplifiedNode |
Contains a compiled node which represents a simplified version of this node as a result of compilation optimizations. | |
bool | mHasCachedValue = false |
true if the node has a static, precalculated value. | |
A binary expression operator, which operates on two values.
Definition at line 99 of file qgsexpressionnodeimpl.h.
list of binary operators
Enumerator | |
---|---|
boOr | |
boAnd | |
boEQ | = |
boNE | <> |
boLE | <= |
boGE | >= |
boLT | < |
boGT |
|
boRegexp | |
boLike | |
boNotLike | |
boILike | |
boNotILike | |
boIs | |
boIsNot | |
boPlus | |
boMinus | |
boMul | |
boDiv | |
boIntDiv | |
boMod | |
boPow | |
boConcat |
Definition at line 107 of file qgsexpressionnodeimpl.h.
|
inline |
Binary combination of the left and the right with op.
Definition at line 144 of file qgsexpressionnodeimpl.h.
|
inlineoverride |
Definition at line 149 of file qgsexpressionnodeimpl.h.
|
overridevirtual |
Generate a clone of this node.
Ownership is transferred to the caller.
Implements QgsExpressionNode.
Definition at line 980 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Dump this node into a serialized (part) of an expression.
The returned expression does not necessarily literally match the original expression, it's just guaranteed to behave the same way.
Implements QgsExpressionNode.
Definition at line 918 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Abstract virtual eval method Errors are reported to the parent.
Implements QgsExpressionNode.
Definition at line 205 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Returns true
if this node can be evaluated for a static value.
This is used during the prepare() step and in case it returns true
, the value of this node will already be evaluated and the result cached (and therefore not re-evaluated in subsequent calls to eval()). In case this returns true
, prepareNode() will never be called.
Implements QgsExpressionNode.
Definition at line 987 of file qgsexpressionnodeimpl.cpp.
bool QgsExpressionNodeBinaryOperator::leftAssociative | ( | ) | const |
Returns true
if the operator is left-associative.
Definition at line 882 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Abstract virtual method which returns if the geometry is required to evaluate this expression.
This needs to call needsGeometry()
recursively on any child nodes.
true
if a geometry is required to evaluate this expression Implements QgsExpressionNode.
Definition at line 975 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Returns a list of all nodes which are used in this expression.
Implements QgsExpressionNode.
Definition at line 967 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Gets the type of this node.
Implements QgsExpressionNode.
Definition at line 690 of file qgsexpressionnodeimpl.cpp.
|
inline |
Returns the binary operator.
Definition at line 162 of file qgsexpressionnodeimpl.h.
|
inline |
Returns the node to the left of the operator.
Definition at line 168 of file qgsexpressionnodeimpl.h.
|
inline |
Returns the node to the right of the operator.
Definition at line 174 of file qgsexpressionnodeimpl.h.
int QgsExpressionNodeBinaryOperator::precedence | ( | ) | const |
Returns the precedence index for the operator.
Higher values have higher precedence.
Definition at line 836 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Abstract virtual preparation method Errors are reported to the parent.
Implements QgsExpressionNode.
Definition at line 695 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Abstract virtual method which returns a list of columns required to evaluate this node.
When reimplementing this, you need to return any column that is required to evaluate this node and in addition recursively collect all the columns required to evaluate child nodes.
Implements QgsExpressionNode.
Definition at line 949 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Returns a set of all functions which are used in this expression.
Implements QgsExpressionNode.
Definition at line 962 of file qgsexpressionnodeimpl.cpp.
|
overridevirtual |
Returns a set of all variables which are used in this expression.
Implements QgsExpressionNode.
Definition at line 957 of file qgsexpressionnodeimpl.cpp.
QString QgsExpressionNodeBinaryOperator::text | ( | ) | const |
Returns a the name of this operator without the operands.
I.e. "AND", "OR", ...
Definition at line 2143 of file qgsexpressionnodeimpl.cpp.