QGIS API Documentation 3.99.0-Master (8e76e220402)
Loading...
Searching...
No Matches
qgsprocessingregistry.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsprocessingregistry.cpp
3 --------------------------
4 begin : December 2016
5 copyright : (C) 2016 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
19
28#include "qgsvectorfilewriter.h"
29
30#include <QString>
31
32#include "moc_qgsprocessingregistry.cpp"
33
34using namespace Qt::StringLiterals;
35
37 : QObject( parent )
38{
79 addParameterType( new QgsProcessingParameterTypeVectorTileWriterLayers() );
80 addParameterType( new QgsProcessingParameterTypeFieldMapping() );
81 addParameterType( new QgsProcessingParameterTypeAggregate() );
82 addParameterType( new QgsProcessingParameterTypeTinInputLayers() );
83 addParameterType( new QgsProcessingParameterTypeDxfLayers() );
84 addParameterType( new QgsProcessingParameterTypeMeshDatasetGroups() );
85 addParameterType( new QgsProcessingParameterTypeMeshDatasetTime() );
91 addParameterType( new QgsProcessingParameterTypeAlignRasterLayers() );
92}
93
95{
96 const auto constMProviders = mProviders;
97 for ( QgsProcessingProvider *p : constMProviders )
98 {
99 removeProvider( p );
100 }
101
102 const auto parameterTypes = mParameterTypes.values();
103
105 {
106 removeParameterType( type );
107 }
108}
109
111{
112 if ( !provider )
113 return false;
114
115 if ( providerById( provider->id() ) )
116 {
117 QgsLogger::warning( u"Duplicate provider %1 registered"_s.arg( provider->id() ) );
118 delete provider;
119 return false;
120 }
121
122 if ( !provider->load() )
123 {
124 QgsLogger::warning( u"Provider %1 cannot load"_s.arg( provider->id() ) );
125 delete provider;
126 return false;
127 }
128
129 provider->setParent( this );
130 mProviders[ provider->id()] = provider;
131
132 mCachedInformation.clear();
133 connect( provider, &QgsProcessingProvider::algorithmsLoaded, this, [this]
134 {
135 mCachedInformation.clear();
136 } );
137
138 emit providerAdded( provider->id() );
139 return true;
140}
141
143{
144 if ( !provider )
145 return false;
146
147 const QString id = provider->id();
148
149 if ( !mProviders.contains( id ) )
150 return false;
151
152 provider->unload();
153
154 delete mProviders.take( id );
155
156 mCachedInformation.clear();
157
158 emit providerRemoved( id );
159 return true;
160}
161
162bool QgsProcessingRegistry::removeProvider( const QString &providerId )
163{
164 QgsProcessingProvider *p = providerById( providerId );
165 return removeProvider( p );
166}
167
169{
170 auto it = mProviders.constFind( id );
171 if ( it != mProviders.constEnd() )
172 return it.value();
173
174 // transparently map old references to "grass7" provider to "grass" provider
175 if ( id.compare( "grass7"_L1, Qt::CaseInsensitive ) == 0 )
176 return providerById( u"grass"_s );
177
178 return nullptr;
179}
180
181QList< const QgsProcessingAlgorithm * > QgsProcessingRegistry::algorithms() const
182{
183 QList< const QgsProcessingAlgorithm * > algs;
184 QMap<QString, QgsProcessingProvider *>::const_iterator it = mProviders.constBegin();
185 for ( ; it != mProviders.constEnd(); ++it )
186 {
187 algs.append( it.value()->algorithms() );
188 }
189 return algs;
190}
191
193{
194 const auto it = mCachedInformation.constFind( id );
195 if ( it != mCachedInformation.constEnd() )
196 return *it;
197
200 {
201 info.displayName = algorithm->displayName();
202 info.icon = algorithm->icon();
203 }
204 mCachedInformation.insert( id, info );
205 return info;
206}
207
209{
210 if ( constId.isEmpty() )
211 return nullptr;
212
213 // allow mapping of algorithm via registered algorithm aliases
214 const QString id = mAlgorithmAliases.value( constId, constId );
215
216 // try to match just the one target provider, if we can determine it from the id easily
217 static thread_local QRegularExpression reSplitProviderId( u"^(.*?):(.*)$"_s );
218 const QRegularExpressionMatch match = reSplitProviderId.match( id );
219 if ( match.hasMatch() )
220 {
221 if ( QgsProcessingProvider *provider = providerById( match.captured( 1 ) ) )
222 {
223 if ( const QgsProcessingAlgorithm *algorithm = provider->algorithm( match.captured( 2 ) ) )
224 return algorithm;
225 }
226
227 // try mapping 'qgis' algs to 'native' algs - this allows us to freely move algorithms
228 // from the python 'qgis' provider to the c++ 'native' provider without breaking API
229 // or existing models
230 if ( match.captured( 1 ) == "qgis"_L1 )
231 {
232 const QString algorithmName = id.mid( 5 );
233 if ( QgsProcessingProvider *provider = mProviders.value( u"native"_s ) )
234 {
235 if ( const QgsProcessingAlgorithm *algorithm = provider->algorithm( algorithmName ) )
236 return algorithm;
237 }
238 }
239 }
240
241 // slow: iterate through ALL providers to find a match
242 QMap<QString, QgsProcessingProvider *>::const_iterator it = mProviders.constBegin();
243 for ( ; it != mProviders.constEnd(); ++it )
244 {
245 const QList< const QgsProcessingAlgorithm * > algorithms = it.value()->algorithms();
246 for ( const QgsProcessingAlgorithm *alg : algorithms )
247 if ( alg->id() == id )
248 return alg;
249 }
250
251 return nullptr;
252}
253
254QgsProcessingAlgorithm *QgsProcessingRegistry::createAlgorithmById( const QString &id, const QVariantMap &configuration ) const
255{
256 const QgsProcessingAlgorithm *alg = algorithmById( id );
257 if ( !alg )
258 return nullptr;
259
260 std::unique_ptr< QgsProcessingAlgorithm > creation( alg->create( configuration ) );
261 return creation.release();
262}
263
264void QgsProcessingRegistry::addAlgorithmAlias( const QString &aliasId, const QString &actualId )
265{
266 mAlgorithmAliases.insert( aliasId, actualId );
267}
268
270{
271 if ( !mParameterTypes.contains( type->id() ) )
272 {
273 mParameterTypes.insert( type->id(), type );
274 emit parameterTypeAdded( type );
275 return true;
276 }
277 else
278 {
279 QgsLogger::warning( u"Duplicate parameter type %1 (\"%2\") registered"_s.arg( type->id(), type->name() ) );
280
281 if ( mParameterTypes.value( type->id() ) != type )
282 delete type;
283
284 return false;
285 }
286}
287
289{
290 mParameterTypes.remove( type->id() );
291 emit parameterTypeRemoved( type );
292 delete type;
293}
294
296{
297 return mParameterTypes.value( id );
298}
299
300QList<QgsProcessingParameterType *> QgsProcessingRegistry::parameterTypes() const
301{
302 return mParameterTypes.values();
303}
static void warning(const QString &msg)
Goes to qWarning.
Contains basic properties for a Processing algorithm.
QString displayName
Algorithm display name.
Abstract base class for processing algorithms.
QgsProcessingAlgorithm * create(const QVariantMap &configuration=QVariantMap()) const
Creates a copy of the algorithm, ready for execution.
An annotation layer parameter for processing algorithms.
An area parameter for processing algorithms.
An authentication configuration parameter for processing algorithms.
A raster band parameter for Processing algorithms.
A boolean parameter for processing algorithms.
A color parameter for Processing algorithms.
A coordinate operation parameter for Processing algorithms.
A crs parameter for processing algorithms.
A database schema name parameter for processing algorithms.
A database table name parameter for processing algorithms.
A datetime parameter for processing algorithms.
A distance parameter for processing algorithms.
A duration parameter for processing algorithms.
An enum based parameter for processing algorithms, allowing for selection from predefined values.
An expression parameter for processing algorithms.
A rectangular map extent parameter for processing algorithms.
A feature sink parameter for Processing algorithms.
An input feature source (such as vector layers) parameter for processing algorithms.
A vector layer or feature source field parameter for processing algorithms.
A generic file based destination parameter, for specifying the destination path for a file (non-map l...
An input file or folder parameter for processing algorithms.
A folder destination parameter, for specifying the destination path for a folder created by the algor...
A geometry parameter for processing algorithms.
A print layout item parameter for Processing algorithms.
A print layout parameter for Processing algorithms.
A generic map layer parameter for processing algorithms.
A map theme parameter for Processing algorithms.
A table (matrix) parameter for processing algorithms.
A mesh layer parameter for processing algorithms.
A parameter for processing algorithms which accepts multiple map layers.
A numeric parameter for processing algorithms.
A point cloud layer attribute parameter for Processing algorithms.
A pointcloud layer destination parameter, for specifying the destination path for a point cloud layer...
A point cloud layer parameter for processing algorithms.
A point parameter for processing algorithms.
A provider connection name parameter for processing algorithms.
A numeric range parameter for processing algorithms.
A raster layer destination parameter, for specifying the destination path for a raster layer created ...
A raster layer parameter for processing algorithms.
A scale parameter for processing algorithms.
A string parameter for processing algorithms.
A vector layer destination parameter, for specifying the destination path for a vector layer created ...
A vector layer parameter for processing algorithms.
A vector tile layer destination parameter, for specifying the destination path for a vector tile laye...
A volume parameter for processing algorithms.
Makes metadata of processing parameters available.
virtual QString name() const =0
A human readable and translatable short name for this parameter type.
virtual QString id() const =0
A static id for this type which will be used for storing this parameter type.
Abstract base class for processing providers.
void algorithmsLoaded()
Emitted when the provider has loaded (or refreshed) its list of available algorithms.
virtual void unload()
Unloads the provider.
virtual QString id() const =0
Returns the unique provider id, used for identifying the provider.
virtual bool load()
Loads the provider.
void removeParameterType(QgsProcessingParameterType *type)
Unregister a custom parameter type from processing.
void parameterTypeAdded(QgsProcessingParameterType *type)
Emitted when a new parameter type has been added to the registry.
QgsProcessingAlgorithm * createAlgorithmById(const QString &id, const QVariantMap &configuration=QVariantMap()) const
Creates a new instance of an algorithm by its ID.
void parameterTypeRemoved(QgsProcessingParameterType *type)
Emitted when a parameter type has been removed from the registry and is about to be deleted.
QgsProcessingAlgorithmInformation algorithmInformation(const QString &id) const
Returns basic algorithm information for the algorithm with matching ID.
QList< const QgsProcessingAlgorithm * > algorithms() const
Returns a list of all available algorithms from registered providers.
QgsProcessingParameterType * parameterType(const QString &id) const
Returns the parameter type registered for id.
bool removeProvider(QgsProcessingProvider *provider)
Removes a provider implementation from the registry (the provider object is deleted).
bool addParameterType(QgsProcessingParameterType *type)
Register a new parameter type for processing.
QgsProcessingRegistry(QObject *parent=nullptr)
Constructor for QgsProcessingRegistry.
const QgsProcessingAlgorithm * algorithmById(const QString &id) const
Finds an algorithm by its ID.
QgsProcessingProvider * providerById(const QString &id) const
Returns a matching provider by provider ID.
void providerAdded(const QString &id)
Emitted when a provider has been added to the registry.
QList< QgsProcessingParameterType * > parameterTypes() const
Returns a list with all known parameter types.
bool addProvider(QgsProcessingProvider *provider)
Add a processing provider to the registry.
void providerRemoved(const QString &id)
Emitted when a provider is removed from the registry.
void addAlgorithmAlias(const QString &aliasId, const QString &actualId)
Adds a new alias to an existing algorithm.
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into allowing algorithms to be written in pure substantial changes are required in order to port existing x Processing algorithms for QGIS x The most significant changes are outlined not GeoAlgorithm For algorithms which operate on features one by consider subclassing the QgsProcessingFeatureBasedAlgorithm class This class allows much of the boilerplate code for looping over features from a vector layer to be bypassed and instead requires implementation of a processFeature method Ensure that your algorithm(or algorithm 's parent class) implements the new pure virtual createInstance(self) call
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:53