QGIS API Documentation 4.1.0-Master (60fea48833c)
Loading...
Searching...
No Matches
qgsprocessingprovider.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsprocessingprovider.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
20#include "qgsapplication.h"
21#include "qgsmessagelog.h"
22#include "qgsrasterfilewriter.h"
23#include "qgsvectorfilewriter.h"
24
25#include <QRegularExpressionMatch>
26#include <QString>
27
28#include "moc_qgsprocessingprovider.cpp"
29
30using namespace Qt::StringLiterals;
31
33 : QObject( parent )
34{}
35
36
38{
39 qDeleteAll( mAlgorithms );
40}
41
43{
44 return QgsApplication::getThemeIcon( "/processingAlgorithm.svg" );
45}
46
48{
49 return QgsApplication::iconPath( u"processingAlgorithm.svg"_s );
50}
51
56
58{
59 return QString();
60}
61
63{
64 return name();
65}
66
68{
69 return QString();
70}
71
73{
74 const QList<QPair<QString, QString>> formatAndExtensions = supportedOutputRasterLayerFormatAndExtensions();
75 QSet< QString > extensions;
76 QStringList res;
77 for ( const QPair<QString, QString> &formatAndExt : std::as_const( formatAndExtensions ) )
78 {
79 if ( !extensions.contains( formatAndExt.second ) )
80 {
81 extensions.insert( formatAndExt.second );
82 res << formatAndExt.second;
83 }
84 }
85 return res;
86}
87
92
94{
96 QList<QPair<QString, QString>> res;
97
98 const thread_local QRegularExpression rx( u"\\*\\.([a-zA-Z0-9]*)"_s );
99
100 for ( const QgsRasterFileWriter::FilterFormatDetails &format : formats )
101 {
102 const QString ext = format.filterString;
103 const QRegularExpressionMatch match = rx.match( ext );
104 if ( !match.hasMatch() )
105 continue;
106
107 const QString matched = match.captured( 1 );
108 res << QPair<QString, QString>( format.driverName, matched );
109 }
110
111 std::sort( res.begin(), res.end(), []( const QPair<QString, QString> &a, const QPair<QString, QString> &b ) -> bool {
112 for ( const QString &tifExt : { u"tif"_s, u"tiff"_s } )
113 {
114 if ( a.second == tifExt )
115 {
116 if ( b.second == a.second )
117 {
118 if ( a.first == "GTiff"_L1 )
119 return true;
120 else if ( b.first == "GTiff"_L1 )
121 return false;
122 return a.first.toLower().localeAwareCompare( b.first.toLower() ) < 0;
123 }
124 return true;
125 }
126 else if ( b.second == tifExt )
127 return false;
128 }
129
130 if ( a.second == "gpkg"_L1 )
131 {
132 if ( b.second == a.second )
133 return a.first.toLower().localeAwareCompare( b.first.toLower() ) < 0;
134 return true;
135 }
136 else if ( b.second == "gpkg"_L1 )
137 return false;
138
139 return a.second.toLower().localeAwareCompare( b.second.toLower() ) < 0;
140 } );
141
142 return res;
143}
144
146{
147 return QStringList();
148}
149
154
156{
157 qDeleteAll( mAlgorithms );
158 mAlgorithms.clear();
159 if ( isActive() )
160 {
162 emit algorithmsLoaded();
163 }
164}
165
166QList<const QgsProcessingAlgorithm *> QgsProcessingProvider::algorithms() const
167{
168 return mAlgorithms.values();
169}
170
172{
173 return mAlgorithms.value( name );
174}
175
177{
178 if ( !algorithm )
179 return false;
180
181 if ( mAlgorithms.contains( algorithm->name() ) )
182 {
183 QgsMessageLog::logMessage( tr( "Duplicate algorithm name %1 for provider %2" ).arg( algorithm->name(), id() ), QObject::tr( "Processing" ) );
184 return false;
185 }
186
187 // init the algorithm - this allows direct querying of the algorithm's parameters
188 // and outputs from the provider's copy
189 algorithm->initAlgorithm( QVariantMap() );
190
191 algorithm->setProvider( this );
192 mAlgorithms.insert( algorithm->name(), algorithm );
193 return true;
194}
195
200
205
206bool QgsProcessingProvider::isSupportedOutputValue( const QVariant &outputValue, const QgsProcessingDestinationParameter *parameter, QgsProcessingContext &context, QString &error ) const
207{
208 error.clear();
209 QString outputPath = QgsProcessingParameters::parameterAsOutputLayer( parameter, outputValue, context, true ).trimmed();
210
211 if ( outputPath.isEmpty() )
212 {
214 {
215 return true;
216 }
217 else
218 {
219 error = tr( "Missing parameter value %1" ).arg( parameter->description() );
220 return false;
221 }
222 }
223
225 {
226 if ( outputPath.startsWith( "memory:"_L1 ) )
227 {
229 {
230 error = tr( "This algorithm only supports disk-based outputs" );
231 return false;
232 }
233 return true;
234 }
235
236 QString providerKey;
237 QString uri;
238 QString layerName;
239 QMap<QString, QVariant> options;
240 bool useWriter = false;
241 QString format;
242 QString extension;
243 QgsProcessingUtils::parseDestinationString( outputPath, providerKey, uri, layerName, format, options, useWriter, extension );
244
245 if ( providerKey != "ogr"_L1 )
246 {
248 {
249 error = tr( "This algorithm only supports disk-based outputs" );
250 return false;
251 }
252 return true;
253 }
254
255 if ( !supportedOutputVectorLayerExtensions().contains( extension, Qt::CaseInsensitive ) )
256 {
257 error = tr( "“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
258 return false;
259 }
260 return true;
261 }
262 else if ( parameter->type() == QgsProcessingParameterRasterDestination::typeName() )
263 {
264 const QFileInfo fi( outputPath );
265 const QString extension = fi.suffix();
266 if ( !supportedOutputRasterLayerExtensions().contains( extension, Qt::CaseInsensitive ) )
267 {
268 error = tr( "“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
269 return false;
270 }
271 return true;
272 }
274 {
275 const QFileInfo fi( outputPath );
276 const QString extension = fi.completeSuffix();
277 if ( !supportedOutputPointCloudLayerExtensions().contains( extension, Qt::CaseInsensitive ) )
278 {
279 error = tr( "“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
280 return false;
281 }
282 return true;
283 }
285 {
286 const QFileInfo fi( outputPath );
287 const QString extension = fi.completeSuffix();
288 if ( !supportedOutputVectorTileLayerExtensions().contains( extension, Qt::CaseInsensitive ) )
289 {
290 error = tr( "“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
291 return false;
292 }
293 return true;
294 }
295 else
296 {
297 return true;
298 }
299}
300
302{
303 const QString userDefault = QgsProcessingUtils::defaultVectorExtension();
304
305 const QStringList supportedExtensions = supportedOutputVectorLayerExtensions();
306 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
307 {
308 // user set default is supported by provider, use that
309 return userDefault;
310 }
311 else if ( !supportedExtensions.empty() )
312 {
313 return supportedExtensions.at( 0 );
314 }
315 else
316 {
317 // who knows? provider says it has no file support at all...
318 // let's say shp. even MapInfo supports shapefiles.
319 return hasGeometry ? u"shp"_s : u"dbf"_s;
320 }
321}
322
324{
325 const QString userDefault = QgsProcessingUtils::defaultRasterFormat();
326
327 const QList<QPair<QString, QString>> formatAndExtensions = supportedOutputRasterLayerFormatAndExtensions();
328 for ( const QPair<QString, QString> &formatAndExt : std::as_const( formatAndExtensions ) )
329 {
330 if ( formatAndExt.first.compare( userDefault, Qt::CaseInsensitive ) == 0 )
331 {
332 // user set default is supported by provider, use that
333 return userDefault;
334 }
335 }
336
337 if ( !formatAndExtensions.empty() )
338 {
339 return formatAndExtensions.at( 0 ).first;
340 }
341 else
342 {
343 // who knows? provider says it has no file support at all...
344 return u"GTiff"_s;
345 }
346}
347
349{
350 QString format = defaultRasterFileFormat();
351 QStringList extensions = QgsRasterFileWriter::extensionsForFormat( format );
352 if ( !extensions.isEmpty() )
353 return extensions[0];
354
355 return u"tif"_s;
356}
357
359{
360 const QString userDefault = QgsProcessingUtils::defaultPointCloudExtension();
361
362 const QStringList supportedExtensions = supportedOutputPointCloudLayerExtensions();
363 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
364 {
365 // user set default is supported by provider, use that
366 return userDefault;
367 }
368 else if ( !supportedExtensions.empty() )
369 {
370 return supportedExtensions.at( 0 );
371 }
372 else
373 {
374 // who knows? provider says it has no file support at all...
375 return u"las"_s;
376 }
377}
378
380{
381 const QString userDefault = QgsProcessingUtils::defaultVectorTileExtension();
382
383 const QStringList supportedExtensions = supportedOutputVectorTileLayerExtensions();
384 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
385 {
386 // user set default is supported by provider, use that
387 return userDefault;
388 }
389 else if ( !supportedExtensions.empty() )
390 {
391 return supportedExtensions.at( 0 );
392 }
393 else
394 {
395 // who knows? provider says it has no file support at all...
396 return u"mbtiles"_s;
397 }
398}
399
401{
402 return true;
403}
QFlags< ProcessingProviderFlag > ProcessingProviderFlags
Flags indicating how and when an processing provider operates and should be exposed to users.
Definition qgis.h:3686
@ Optional
Parameter is optional.
Definition qgis.h:3882
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QString iconPath(const QString &iconFile)
Returns path to the desired icon file.
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::MessageLevel::Warning, bool notifyUser=true, const char *file=__builtin_FILE(), const char *function=__builtin_FUNCTION(), int line=__builtin_LINE(), Qgis::StringFormat format=Qgis::StringFormat::PlainText)
Adds a message to the log instance (and creates it if necessary).
Abstract base class for processing algorithms.
Contains information about the context in which a processing algorithm is executed.
Base class for all parameter definitions which represent file or layer destinations,...
QString description() const
Returns the description for the parameter.
virtual QString type() const =0
Unique parameter type name.
Qgis::ProcessingParameterFlags flags() const
Returns any flags associated with the parameter.
static QString typeName()
Returns the type name for the parameter class.
static QString typeName()
Returns the type name for the parameter class.
static QString typeName()
Returns the type name for the parameter class.
static QString typeName()
Returns the type name for the parameter class.
static QString typeName()
Returns the type name for the parameter class.
static QString parameterAsOutputLayer(const QgsProcessingParameterDefinition *definition, const QVariantMap &parameters, QgsProcessingContext &context)
Evaluates the parameter with matching definition to a output layer destination.
virtual QList< QPair< QString, QString > > supportedOutputRasterLayerFormatAndExtensions() const
Returns a list of (format, file extension) supported by this provider.
virtual QIcon icon() const
Returns an icon for the provider.
virtual QString defaultVectorFileExtension(bool hasGeometry=true) const
Returns the default file extension to use for vector outputs created by the provider.
virtual QString helpId() const
Returns the provider help id string, used for creating QgsHelp urls for algorithms belong to this pro...
virtual bool isSupportedOutputValue(const QVariant &outputValue, const QgsProcessingDestinationParameter *parameter, QgsProcessingContext &context, QString &error) const
Returns true if the specified outputValue is of a supported file format for the given destination par...
virtual QStringList supportedOutputTableExtensions() const
Returns a list of the table (geometry-less vector layers) file extensions supported by this provider.
const QgsProcessingAlgorithm * algorithm(const QString &name) const
Returns the matching algorithm by name, or nullptr if no matching algorithm is contained by this prov...
virtual Qgis::ProcessingProviderFlags flags() const
Returns the flags indicating how and when the provider operates and should be exposed to users.
virtual QString versionInfo() const
Returns a version information string for the provider, or an empty string if this is not applicable (...
virtual QStringList supportedOutputVectorLayerExtensions() const
Returns a list of the vector format file extensions supported by this provider.
virtual QString name() const =0
Returns the provider name, which is used to describe the provider within the GUI.
virtual QString defaultVectorTileFileExtension() const
Returns the default file extension to use for vector tile outputs created by the provider.
QStringList supportedOutputRasterLayerExtensions() const
Returns a list of the raster format file extensions supported by this provider.
virtual QStringList supportedOutputVectorTileLayerExtensions() const
Returns a list of the vector tile format file extensions supported by this provider.
QgsProcessingProvider(QObject *parent=nullptr)
Constructor for QgsProcessingProvider.
virtual bool isActive() const
Returns true if the provider is active and able to run algorithms.
virtual QStringList supportedOutputPointCloudLayerExtensions() const
Returns a list of the point cloud format file extensions supported by this provider.
QString defaultRasterFileExtension() const
Returns the default file extension to use for raster outputs created by the provider.
void algorithmsLoaded()
Emitted when the provider has loaded (or refreshed) its list of available algorithms.
virtual QString defaultRasterFileFormat() const
Returns the default file format to use for raster outputs created by the provider.
virtual QString svgIconPath() const
Returns a path to an SVG version of the provider's icon.
static QList< QPair< QString, QString > > supportedOutputRasterLayerFormatAndExtensionsDefault()
Returns a list of (format, file extension) supported by GDAL.
virtual void loadAlgorithms()=0
Loads all algorithms belonging to this provider.
void refreshAlgorithms()
Refreshes the algorithms available from the provider, causing it to re-populate with all associated a...
virtual QString longName() const
Returns the longer version of the provider name, which can include extra details such as version numb...
virtual bool supportsNonFileBasedOutput() const
Returns true if the provider supports non-file based outputs (such as memory layers or direct databas...
virtual QString defaultPointCloudFileExtension() const
Returns the default file extension to use for point cloud outputs created by the provider.
bool addAlgorithm(QgsProcessingAlgorithm *algorithm)
Adds an algorithm to the provider.
QList< const QgsProcessingAlgorithm * > algorithms() const
Returns a list of algorithms supplied by this provider.
static QString defaultVectorExtension()
Returns the default vector extension to use, in the absence of all other constraints (e....
static QString defaultRasterFormat()
Returns the default raster format to use, in the absence of all other constraints (e....
static QString defaultVectorTileExtension()
Returns the default vector tile extension to use, in the absence of all other constraints (e....
static QString defaultPointCloudExtension()
Returns the default point cloud extension to use, in the absence of all other constraints (e....
static QStringList extensionsForFormat(const QString &format)
Returns a list of known file extensions for the given GDAL driver format.
static QList< QgsRasterFileWriter::FilterFormatDetails > supportedFiltersAndFormats(RasterFormatOptions options=SortRecommended)
Returns a list or pairs, with format filter string as first element and GDAL format key as second ele...
static QStringList supportedFormatExtensions(VectorFormatOptions options=SortRecommended)
Returns a list of file extensions for supported formats, e.g "shp", "gpkg".
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:52
Details of available filters and formats.