45  : mName( other.mName )
 
   46  , mVariables( other.mVariables )
 
   47  , mHasFeature( other.mHasFeature )
 
   48  , mFeature( other.mFeature )
 
   49  , mHasGeometry( other.mHasGeometry )
 
   50  , mGeometry( other.mGeometry )
 
   51  , mHiddenVariables( other.mHiddenVariables )
 
   52  , mLayerStores( other.mLayerStores )
 
   54  QHash<QString, QgsScopedExpressionFunction * >::const_iterator it = other.mFunctions.constBegin();
 
   55  for ( ; it != other.mFunctions.constEnd(); ++it )
 
   57    mFunctions.insert( it.key(), it.value()->clone() );
 
 
   64  mVariables = other.mVariables;
 
   65  mHasFeature = other.mHasFeature;
 
   66  mFeature = other.mFeature;
 
   67  mHasGeometry = other.mHasGeometry;
 
   68  mGeometry = other.mGeometry;
 
   69  mHiddenVariables = other.mHiddenVariables;
 
   70  mLayerStores = other.mLayerStores;
 
   72  qDeleteAll( mFunctions );
 
   74  QHash<QString, QgsScopedExpressionFunction * >::const_iterator it = other.mFunctions.constBegin();
 
   75  for ( ; it != other.mFunctions.constEnd(); ++it )
 
   77    mFunctions.insert( it.key(), it.value()->clone() );
 
 
   85  qDeleteAll( mFunctions );
 
 
   90  auto it = mVariables.find( 
name );
 
   91  if ( it != mVariables.end() )
 
 
  109  return mVariables.remove( 
name ) > 0;
 
 
  114  return mVariables.contains( 
name );
 
 
  124  QStringList names = mVariables.keys();
 
  128    names.append( QStringLiteral( 
"feature" ) );
 
  129    names.append( QStringLiteral( 
"id" ) );
 
  130    names.append( QStringLiteral( 
"geometry" ) );
 
 
  138  return mHiddenVariables;
 
 
  148  if ( !mHiddenVariables.contains( hiddenVariable ) )
 
  149    mHiddenVariables << hiddenVariable;
 
 
  154  if ( mHiddenVariables.contains( hiddenVariable ) )
 
  155    mHiddenVariables.removeAt( mHiddenVariables.indexOf( hiddenVariable ) );
 
 
  160  mLayerStores.append( store );
 
 
  165  QList<QgsMapLayerStore *> res;
 
  166  res.reserve( mLayerStores.size() );
 
 
  176class QgsExpressionContextVariableCompare
 
  183    bool operator()( 
const QString &a, 
const QString &b )
 const 
  185      bool aReadOnly = mScope.isReadOnly( a );
 
  186      bool bReadOnly = mScope.isReadOnly( b );
 
  187      if ( aReadOnly != bReadOnly )
 
  189      return QString::localeAwareCompare( a, b ) < 0;
 
  199  QStringList allVariables = mVariables.keys();
 
  200  QStringList filtered;
 
  201  const auto constAllVariables = allVariables;
 
  202  for ( 
const QString &
variable : constAllVariables )
 
  209  QgsExpressionContextVariableCompare cmp( *
this );
 
  210  std::sort( filtered.begin(), filtered.end(), cmp );
 
 
  232  return mFunctions.contains( 
name );
 
 
  237  return mFunctions.contains( 
name ) ? mFunctions.value( 
name ) : 
nullptr;
 
 
  242  return mFunctions.keys();
 
 
  258  const QDomNodeList variablesNodeList = element.childNodes();
 
  259  for ( 
int i = 0; i < variablesNodeList.size(); ++i )
 
  261    const QDomElement variableElement = variablesNodeList.at( i ).toElement();
 
  262    const QString key = variableElement.attribute( QStringLiteral( 
"name" ) );
 
  263    if ( variableElement.tagName() == QLatin1String( 
"Variable" ) )
 
 
  276  for ( 
auto it = mVariables.constBegin(); it != mVariables.constEnd(); ++it )
 
  278    QDomElement varElem = document.createElement( QStringLiteral( 
"Variable" ) );
 
  279    varElem.setAttribute( QStringLiteral( 
"name" ), it.key() );
 
  281    varElem.appendChild( valueElem );
 
  282    element.appendChild( varElem );
 
  285  for ( QString hiddenVariable : mHiddenVariables )
 
  287    QDomElement varElem = document.createElement( QStringLiteral( 
"HiddenVariable" ) );
 
  288    varElem.setAttribute( QStringLiteral( 
"name" ), hiddenVariable );
 
  289    element.appendChild( varElem );
 
 
  301  mLoadLayerFunction = std::make_unique< LoadLayerFunction >();
 
 
  307  mLoadLayerFunction = std::make_unique< LoadLayerFunction >();
 
 
  316  mHighlightedVariables = other.mHighlightedVariables;
 
  317  mHighlightedFunctions = other.mHighlightedFunctions;
 
  318  mCachedValues = other.mCachedValues;
 
  319  mFeedback = other.mFeedback;
 
  320  mDestinationStore = other.mDestinationStore;
 
  321  mLoadLayerFunction = std::make_unique< LoadLayerFunction >();
 
 
  327  if ( 
this != &other )
 
  329    qDeleteAll( mStack );
 
  331    mStack = other.mStack;
 
  332    other.mStack.clear();
 
  334    mHighlightedVariables = other.mHighlightedVariables;
 
  335    mHighlightedFunctions = other.mHighlightedFunctions;
 
  336    mCachedValues = other.mCachedValues;
 
  337    mFeedback = other.mFeedback;
 
  338    mDestinationStore = other.mDestinationStore;
 
 
  346  if ( &other == 
this )
 
  349  qDeleteAll( mStack );
 
  355  mHighlightedVariables = other.mHighlightedVariables;
 
  356  mHighlightedFunctions = other.mHighlightedFunctions;
 
  357  mCachedValues = other.mCachedValues;
 
  358  mFeedback = other.mFeedback;
 
  359  mDestinationStore = other.mDestinationStore;
 
 
  365  qDeleteAll( mStack );
 
 
  371  const auto constMStack = mStack;
 
 
  390  const auto constNames = names;
 
  391  for ( 
const QString &name : constNames )
 
 
  400  return mHighlightedVariables.contains( name );
 
 
  405  return mHighlightedVariables;
 
 
  415  return mHighlightedFunctions.contains( name );
 
 
  420  mHighlightedFunctions = names;
 
 
  426  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  427  while ( it != mStack.constBegin() )
 
  430    if ( ( *it )->hasVariable( name ) )
 
 
  439  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  440  while ( it != mStack.constBegin() )
 
  443    if ( ( *it )->hasVariable( name ) )
 
 
  451  if ( index < 0 || index >= mStack.count() )
 
  454  return mStack.at( index );
 
 
  459  if ( mStack.count() < 1 )
 
  462  return mStack.last();
 
 
  470  return mStack.indexOf( 
scope );
 
 
  476  const auto constMStack = mStack;
 
 
  489  QSet< QString> names;
 
  494      names.insert( name );
 
  496  return QStringList( names.constBegin(), names.constEnd() );
 
 
  502  QStringList filtered;
 
  503  const auto constAllVariables = allVariables;
 
  505  QStringList hiddenVariables;
 
  510    for ( 
const QString &name : scopeHiddenVariables )
 
  511      hiddenVariables << name ;
 
  514  for ( 
const QString &
variable : constAllVariables )
 
  517         hiddenVariables.contains( 
variable ) )
 
 
  529  const auto constMStack = mStack;
 
 
  546  if ( name.compare( QLatin1String( 
"load_layer" ) ) == 0 && mDestinationStore )
 
 
  559  QSet< QString > result;
 
  564      result.insert( name );
 
  567  if ( mDestinationStore )
 
  568    result.insert( QStringLiteral( 
"load_layer" ) );
 
  570  QStringList listResult( result.constBegin(), result.constEnd() );
 
 
  577  if ( name.compare( QLatin1String( 
"load_layer" ) ) == 0 && mDestinationStore )
 
  579    return mLoadLayerFunction.get();
 
  583  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  584  while ( it != mStack.constBegin() )
 
  587    if ( ( *it )->hasFunction( name ) )
 
  588      return ( *it )->function( name );
 
 
  595  return mStack.count();
 
 
  600  mStack.append( 
scope );
 
 
  610  if ( !mStack.isEmpty() )
 
  611    return mStack.takeLast();
 
 
  618  QList<QgsExpressionContextScope *> stack = mStack;
 
 
  625  mStack.append( 
scope );
 
 
  631  if ( mStack.isEmpty() )
 
  634  mStack.last()->setFeature( 
feature );
 
 
  650  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  651  while ( it != mStack.constBegin() )
 
  654    if ( ( *it )->hasFeature() )
 
  655      return ( *it )->feature();
 
 
  662  if ( mStack.isEmpty() )
 
  665  mStack.last()->setGeometry( 
geometry );
 
 
  681  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  682  while ( it != mStack.constBegin() )
 
  685    if ( ( *it )->hasGeometry() )
 
  686      return ( *it )->geometry();
 
 
  693  if ( mStack.isEmpty() )
 
  696  mStack.last()->setFields( 
fields );
 
 
  706  if ( mStack.isEmpty() )
 
 
  715  mCachedValues.insert( key, value );
 
 
  720  return mCachedValues.contains( key );
 
 
  725  return mCachedValues.value( key, QVariant() );
 
 
  730  mCachedValues.clear();
 
 
  736  QList< QgsExpressionContextScope * >::const_iterator it = mStack.constEnd();
 
  737  QList<QgsMapLayerStore *> res;
 
  738  while ( it != mStack.constBegin() )
 
  741    res.append( ( *it )->layerStores() );
 
  744  if ( mDestinationStore && !res.contains( mDestinationStore ) )
 
  745    res.append( mDestinationStore );
 
 
  751  mDestinationStore = store;
 
 
  756  return mDestinationStore;
 
 
Single scope for storing variables and functions for use within a QgsExpressionContext.
 
void addLayerStore(QgsMapLayerStore *store)
Adds a layer store to the scope.
 
bool hasVariable(const QString &name) const
Tests whether a variable with the specified name exists in the scope.
 
void setFields(const QgsFields &fields)
Convenience function for setting a fields for the scope.
 
QString description(const QString &name) const
Returns the translated description for the variable with the specified name (if set).
 
void setHiddenVariables(const QStringList &hiddenVariables)
Sets the list of variables intended to be hidden in the expression builder dialog and widget.
 
void addHiddenVariable(const QString &hiddenVariable)
Adds the passed variable to a list of hidden variables that won't be visible in the expression builde...
 
void readXml(const QDomElement &element, const QgsReadWriteContext &context)
Reads scope variables from an XML element.
 
QStringList hiddenVariables() const
Returns the list of variables hidden within the scope.
 
bool writeXml(QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context) const
Writes scope variables to an XML element.
 
QgsExpressionFunction * function(const QString &name) const
Retrieves a function from the scope.
 
QVariant variable(const QString &name) const
Retrieves a variable's value from the scope.
 
QList< QgsMapLayerStore * > layerStores() const
Returns the list of layer stores associated with the scope.
 
void removeHiddenVariable(const QString &hiddenVariable)
Removes the passed variable from a list of hidden variables.
 
bool removeVariable(const QString &name)
Removes a variable from the context scope, if found.
 
bool isReadOnly(const QString &name) const
Tests whether the specified variable is read only and should not be editable by users.
 
void addFunction(const QString &name, QgsScopedExpressionFunction *function)
Adds a function to the scope.
 
bool hasFeature() const
Returns true if the scope has a feature associated with it.
 
bool hasFunction(const QString &name) const
Tests whether a function with the specified name exists in the scope.
 
QString name() const
Returns the friendly display name of the context scope.
 
void addVariable(const QgsExpressionContextScope::StaticVariable &variable)
Adds a variable into the context scope.
 
bool isStatic(const QString &name) const
Tests whether the variable with the specified name is static and can be cached.
 
bool hasGeometry() const
Returns true if the scope has a geometry associated with it.
 
QStringList filteredVariableNames() const
Returns a filtered and sorted list of variable names contained within the scope.
 
QStringList functionNames() const
Retrieves a list of names of functions contained in the scope.
 
void setVariable(const QString &name, const QVariant &value, bool isStatic=false)
Convenience method for setting a variable in the context scope by name name and value.
 
QgsExpressionContextScope & operator=(const QgsExpressionContextScope &other)
 
QgsExpressionContextScope(const QString &name=QString())
Constructor for QgsExpressionContextScope.
 
~QgsExpressionContextScope()
 
QStringList variableNames() const
Returns a list of variable names contained within the scope.
 
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
 
static const QString EXPR_GEOMETRY_PART_COUNT
Inbuilt variable name for geometry part count variable.
 
bool hasFunction(const QString &name) const
Checks whether a specified function is contained in the context.
 
QString description(const QString &name) const
Returns a translated description string for the variable with specified name.
 
static const QString EXPR_GEOMETRY_POINT_COUNT
Inbuilt variable name for point count variable.
 
QgsExpressionContextScope * popScope()
Removes the last scope from the expression context and return it.
 
QStringList highlightedVariables() const
Returns the current list of variables highlighted within the context.
 
static const QString EXPR_CLUSTER_SIZE
Inbuilt variable name for cluster size variable.
 
QStringList functionNames() const
Retrieves a list of function names contained in the context.
 
static const QString EXPR_GEOMETRY_POINT_NUM
Inbuilt variable name for point number variable.
 
int indexOfScope(QgsExpressionContextScope *scope) const
Returns the index of the specified scope if it exists within the context.
 
void setCachedValue(const QString &key, const QVariant &value) const
Sets a value to cache within the expression context.
 
void clearCachedValues() const
Clears all cached values from the context.
 
void setHighlightedFunctions(const QStringList &names)
Sets the list of function names intended to be highlighted to the user.
 
QgsGeometry geometry() const
Convenience function for retrieving the geometry for the context, if set.
 
bool isHighlightedFunction(const QString &name) const
Returns true if the specified function name is intended to be highlighted to the user.
 
QgsFeature feature() const
Convenience function for retrieving the feature for the context, if set.
 
void setOriginalValueVariable(const QVariant &value)
Sets the original value variable value for the context.
 
QgsExpressionContext & operator=(const QgsExpressionContext &other)
 
static const QString EXPR_FIELDS
Inbuilt variable name for fields storage.
 
QStringList filteredVariableNames() const
Returns a filtered list of variables names set by all scopes in the context.
 
QList< QgsMapLayerStore * > layerStores() const
Returns the list of layer stores associated with the context.
 
void setGeometry(const QgsGeometry &geometry)
Convenience function for setting a geometry for the context.
 
static const QString EXPR_GEOMETRY_RING_NUM
Inbuilt variable name for geometry ring number variable.
 
bool isHighlightedVariable(const QString &name) const
Returns true if the specified variable name is intended to be highlighted to the user.
 
QgsExpressionContextScope * activeScopeForVariable(const QString &name)
Returns the currently active scope from the context for a specified variable name.
 
static const QString EXPR_GEOMETRY_PART_NUM
Inbuilt variable name for geometry part number variable.
 
QgsMapLayerStore * loadedLayerStore() const
Returns the destination layer store for any layers loaded during expression evaluation.
 
static const QString EXPR_SYMBOL_COLOR
Inbuilt variable name for symbol color variable.
 
QgsExpressionContextScope * lastScope()
Returns the last scope added to the context.
 
QList< QgsExpressionContextScope * > scopes()
Returns a list of scopes contained within the stack.
 
void appendScope(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
 
bool hasVariable(const QString &name) const
Check whether a variable is specified by any scope within the context.
 
QList< QgsExpressionContextScope * > takeScopes()
Returns all scopes from this context and remove them, leaving this context without any context.
 
QgsFeedback * feedback() const
Returns the feedback object that can be queried regularly by the expression to check if evaluation sh...
 
void setFeedback(QgsFeedback *feedback)
Attach a feedback object that can be queried regularly by the expression engine to check if expressio...
 
int scopeCount() const
Returns the number of scopes contained in the context.
 
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
 
void setHighlightedVariables(const QStringList &variableNames)
Sets the list of variable names within the context intended to be highlighted to the user.
 
static const QString EXPR_SYMBOL_ANGLE
Inbuilt variable name for symbol angle variable.
 
bool isReadOnly(const QString &name) const
Returns whether a variable is read only, and should not be modifiable by users.
 
bool hasGeometry() const
Returns true if the context has a geometry associated with it.
 
QgsExpressionFunction * function(const QString &name) const
Fetches a matching function from the context.
 
void setFields(const QgsFields &fields)
Convenience function for setting a fields for the context.
 
QVariantMap variablesToMap() const
Returns a map of variable name to value representing all the expression variables contained by the co...
 
bool hasCachedValue(const QString &key) const
Returns true if the expression context contains a cached value with a matching key.
 
void setLoadedLayerStore(QgsMapLayerStore *store)
Sets the destination layer store for any layers loaded during expression evaluation.
 
void appendScopes(const QList< QgsExpressionContextScope * > &scopes)
Appends a list of scopes to the end of the context.
 
QgsExpressionContext & operator<<(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
 
static const QString EXPR_ORIGINAL_VALUE
Inbuilt variable name for value original value variable.
 
static const QString EXPR_CLUSTER_COLOR
Inbuilt variable name for cluster color variable.
 
QStringList variableNames() const
Returns a list of variables names set by all scopes in the context.
 
QgsExpressionContext()
Constructor for QgsExpressionContext.
 
QVariant variable(const QString &name) const
Fetches a matching variable from the context.
 
QgsExpressionContextScope * scope(int index)
Returns the scope at the specified index within the context.
 
QVariant cachedValue(const QString &key) const
Returns the matching cached value, if set.
 
bool hasFeature() const
Returns true if the context has a feature associated with it.
 
QgsFields fields() const
Convenience function for retrieving the fields for the context, if set.
 
A abstract base class for defining QgsExpression functions.
 
static QString variableHelpText(const QString &variableName)
Returns the help text for a specified variable.
 
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
 
Base class for feedback objects to be used for cancellation of something running in a worker thread.
 
Container of fields for a vector layer.
 
A geometry is the spatial representation of a feature.
 
A storage object for map layers, in which the layers are owned by the store and have their lifetime b...
 
The class is used as a container of context for various read/write operations on other objects.
 
Expression function for use within a QgsExpressionContextScope.
 
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
 
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
 
Single variable definition for use within a QgsExpressionContextScope.