QGIS API Documentation  3.16.0-Hannover (43b64b13f3)
qgscodeeditorexpression.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgscodeeditorexpressoin.cpp - An expression editor based on QScintilla
3  --------------------------------------
4  Date : 8.9.2018
5  Copyright : (C) 2018 by Matthias Kuhn
6  Email : [email protected]
7  ***************************************************************************
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  ***************************************************************************/
15 
16 #include "qgsapplication.h"
18 #include "qgssymbollayerutils.h"
19 
20 #include <QString>
21 #include <QFont>
22 
24  : QgsCodeEditor( parent )
25 {
26  if ( !parent )
27  {
28  setTitle( tr( "Expression Editor" ) );
29  }
30  setFoldingVisible( false );
31  setAutoCompletionCaseSensitivity( false );
32  QgsCodeEditorExpression::initializeLexer(); // avoid cppcheck warning by explicitly specifying namespace
33 }
34 
36 {
37  mVariables.clear();
38 
39  const QStringList variableNames = context.filteredVariableNames();
40  for ( const QString &var : variableNames )
41  {
42  mVariables << '@' + var;
43  }
44 
45  mContextFunctions = context.functionNames();
46 
47  mFunctions.clear();
48 
49  const int count = QgsExpression::functionCount();
50  for ( int i = 0; i < count; i++ )
51  {
53  if ( func->isDeprecated() ) // don't show deprecated functions
54  continue;
55  if ( func->isContextual() )
56  {
57  //don't show contextual functions by default - it's up the the QgsExpressionContext
58  //object to provide them if supported
59  continue;
60  }
61 
62  QString signature = func->name();
63  if ( !signature.startsWith( '$' ) )
64  {
65  signature += '(';
66 
67  QStringList paramNames;
68  const QgsExpressionFunction::ParameterList parameters = func->parameters();
69  for ( const QgsExpressionFunction::Parameter &param : parameters )
70  {
71  paramNames << param.name();
72  }
73 
74  // No named parameters but there should be parameteres? Show an ellipsis at least
75  if ( parameters.isEmpty() && func->params() )
76  signature += QChar( 0x2026 );
77 
78  signature += paramNames.join( ", " );
79 
80  signature += ')';
81  }
82  mFunctions << signature;
83  }
84 
85  updateApis();
86 }
87 
89 {
90  mFieldNames.clear();
91 
92  for ( const QgsField &field : fields )
93  {
94  mFieldNames << field.name();
95  }
96 
97  updateApis();
98 }
99 
101 {
102  QFont font = lexerFont();
104 
105  mSqlLexer = new QgsLexerExpression( this );
106  mSqlLexer->setDefaultFont( font );
107  mSqlLexer->setDefaultColor( defaultColor );
108  mSqlLexer->setDefaultPaper( lexerColor( QgsCodeEditorColorScheme::ColorRole::Background ) );
109  mSqlLexer->setFont( font, -1 );
110  font.setBold( true );
111  mSqlLexer->setFont( font, QsciLexerSQL::Keyword );
112 
113  font.setBold( false );
114  font.setItalic( true );
115  mSqlLexer->setFont( font, QsciLexerSQL::Comment );
116  mSqlLexer->setFont( font, QsciLexerSQL::CommentLine );
117 
118  mSqlLexer->setColor( Qt::darkYellow, QsciLexerSQL::DoubleQuotedString ); // fields
119 
120  mSqlLexer->setColor( defaultColor, QsciLexerSQL::Default );
121  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::Comment ), QsciLexerSQL::Comment );
122  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::CommentLine ), QsciLexerSQL::CommentLine );
123  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::Number ), QsciLexerSQL::Number );
124  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::Keyword ), QsciLexerSQL::Keyword );
125  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::SingleQuote ), QsciLexerSQL::SingleQuotedString );
126  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::DoubleQuote ), QsciLexerSQL::DoubleQuotedString );
127  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::Operator ), QsciLexerSQL::Operator );
128  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::Identifier ), QsciLexerSQL::Identifier );
129  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::QuotedIdentifier ), QsciLexerSQL::QuotedIdentifier );
130  mSqlLexer->setColor( lexerColor( QgsCodeEditorColorScheme::ColorRole::QuotedOperator ), QsciLexerSQL::QuotedOperator );
131 
132  setLexer( mSqlLexer );
134 }
135 
136 void QgsCodeEditorExpression::updateApis()
137 {
138  mApis = new QgsSciApisExpression( mSqlLexer );
139 
140  for ( const QString &var : qgis::as_const( mVariables ) )
141  {
142  mApis->add( var );
143  }
144 
145  for ( const QString &function : qgis::as_const( mContextFunctions ) )
146  {
147  mApis->add( function );
148  }
149 
150  for ( const QString &function : qgis::as_const( mFunctions ) )
151  {
152  mApis->add( function );
153  }
154 
155  for ( const QString &fieldName : qgis::as_const( mFieldNames ) )
156  {
157  mApis->add( fieldName );
158  }
159 
160  mApis->prepare();
161  mSqlLexer->setAPIs( mApis );
162 }
163 
165 QgsLexerExpression::QgsLexerExpression( QObject *parent )
166  : QsciLexerSQL( parent )
167 {
168 }
169 
170 const char *QgsLexerExpression::language() const
171 {
172  return "QGIS Expression";
173 }
174 
175 bool QgsLexerExpression::caseSensitive() const
176 {
177  return false;
178 }
179 
180 const char *QgsLexerExpression::wordCharacters() const
181 {
182  return "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_@";
183 }
184 
185 QgsSciApisExpression::QgsSciApisExpression( QsciLexer *lexer )
186  : QsciAPIs( lexer )
187 {
188 
189 }
190 
191 QStringList QgsSciApisExpression::callTips( const QStringList &context, int commas, QsciScintilla::CallTipsStyle style, QList<int> &shifts )
192 {
193  const QStringList originalTips = QsciAPIs::callTips( context, commas, style, shifts );
194  QStringList lowercaseTips;
195  for ( const QString &tip : originalTips )
196  lowercaseTips << tip.toLower();
197 
198  return lowercaseTips;
199 }
QgsExpressionContext
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
Definition: qgsexpressioncontext.h:370
QgsCodeEditor::lexerColor
QColor lexerColor(QgsCodeEditorColorScheme::ColorRole role) const
Returns the color to use in the lexer for the specified role.
Definition: qgscodeeditor.cpp:154
QgsCodeEditorColorScheme::ColorRole::Default
@ Default
Default text color.
QgsCodeEditorColorScheme::ColorRole::CommentLine
@ CommentLine
Line comment color.
qgssymbollayerutils.h
QgsFields
Container of fields for a vector layer.
Definition: qgsfields.h:45
QgsCodeEditor
A text editor based on QScintilla2.
Definition: qgscodeeditor.h:42
QgsCodeEditorExpression::setFields
void setFields(const QgsFields &fields)
Field names will be added to the API.
Definition: qgscodeeditorexpression.cpp:88
QgsCodeEditorColorScheme::ColorRole::Operator
@ Operator
Operator color.
field
const QgsField & field
Definition: qgsfield.h:456
QgsExpressionFunction::isContextual
bool isContextual() const
Returns whether the function is only available if provided by a QgsExpressionContext object.
Definition: qgsexpressionfunction.h:270
QgsField::name
QString name
Definition: qgsfield.h:59
QgsCodeEditorColorScheme::ColorRole::SingleQuote
@ SingleQuote
Single quote color.
QgsCodeEditor::setTitle
void setTitle(const QString &title)
Set the widget title.
Definition: qgscodeeditor.cpp:259
qgsapplication.h
QgsCodeEditorColorScheme::ColorRole::DoubleQuote
@ DoubleQuote
Double quote color.
QgsCodeEditorColorScheme::ColorRole::Comment
@ Comment
Comment color.
QgsExpressionFunction::params
int params() const
The number of parameters this function takes.
Definition: qgsexpressionfunction.h:193
QgsExpressionFunction::Parameter
Represents a single parameter passed to a function.
Definition: qgsexpressionfunction.h:55
QgsExpressionFunction::ParameterList
QList< QgsExpressionFunction::Parameter > ParameterList
List of parameters, used for function definition.
Definition: qgsexpressionfunction.h:104
QgsCodeEditorExpression::initializeLexer
void initializeLexer() override
Called when the dialect specific code lexer needs to be initialized (or reinitialized).
Definition: qgscodeeditorexpression.cpp:100
QgsCodeEditor::lexerFont
QFont lexerFont() const
Returns the font to use in the lexer.
Definition: qgscodeeditor.cpp:170
QgsCodeEditorExpression::QgsCodeEditorExpression
QgsCodeEditorExpression(QWidget *parent=nullptr)
Constructor for QgsCodeEditorExpression.
Definition: qgscodeeditorexpression.cpp:23
QgsCodeEditorExpression::setExpressionContext
void setExpressionContext(const QgsExpressionContext &context)
Variables and functions from this expression context will be added to the API.
Definition: qgscodeeditorexpression.cpp:35
QgsCodeEditor::runPostLexerConfigurationTasks
void runPostLexerConfigurationTasks()
Performs tasks which must be run after a lexer has been set for the widget.
Definition: qgscodeeditor.cpp:203
QgsExpressionFunction::isDeprecated
virtual bool isDeprecated() const
Returns true if the function is deprecated and should not be presented as a valid option to users in ...
Definition: qgsexpressionfunction.cpp:145
QgsExpression::Functions
static const QList< QgsExpressionFunction * > & Functions()
Definition: qgsexpressionfunction.cpp:6008
QgsCodeEditorColorScheme::ColorRole::Number
@ Number
Number color.
QgsCodeEditorColorScheme::ColorRole::Identifier
@ Identifier
Identifier color.
QgsCodeEditorColorScheme::ColorRole::QuotedOperator
@ QuotedOperator
Quoted operator color.
qgscodeeditorexpression.h
QgsExpressionContext::functionNames
QStringList functionNames() const
Retrieves a list of function names contained in the context.
Definition: qgsexpressioncontext.cpp:459
QgsExpressionFunction
A abstract base class for defining QgsExpression functions.
Definition: qgsexpressionfunction.h:41
QgsExpressionFunction::name
QString name() const
The name of the function.
Definition: qgsexpressionfunction.h:190
QgsCodeEditor::defaultColor
static QColor defaultColor(QgsCodeEditorColorScheme::ColorRole role, const QString &theme=QString())
Returns the default color for the specified role.
Definition: qgscodeeditor.cpp:342
QgsExpressionFunction::parameters
const QgsExpressionFunction::ParameterList & parameters() const
Returns the list of named parameters for the function, if set.
Definition: qgsexpressionfunction.h:214
QgsCodeEditorColorScheme::ColorRole::QuotedIdentifier
@ QuotedIdentifier
Quoted identifier color.
QgsCodeEditor::setFoldingVisible
void setFoldingVisible(bool folding)
Set whether the folding controls are visible in the editor.
Definition: qgscodeeditor.cpp:309
QgsExpression::functionCount
static int functionCount()
Returns the number of functions defined in the parser.
Definition: qgsexpression.cpp:140
QgsExpressionContext::filteredVariableNames
QStringList filteredVariableNames() const
Returns a filtered list of variables names set by all scopes in the context.
Definition: qgsexpressioncontext.cpp:414
QgsCodeEditorColorScheme::ColorRole::Background
@ Background
Background color.
QgsCodeEditorColorScheme::ColorRole::Keyword
@ Keyword
Keyword color.
QgsField
Encapsulate a field in an attribute table or data source.
Definition: qgsfield.h:50