25#include <QRegularExpressionMatch>
27#include "moc_qgsprocessingprovider.cpp"
36 qDeleteAll( mAlgorithms );
72 QSet< QString > extensions;
74 for (
const QPair<QString, QString> &formatAndExt : std::as_const( formatAndExtensions ) )
76 if ( !extensions.contains( formatAndExt.second ) )
78 extensions.insert( formatAndExt.second );
79 res << formatAndExt.second;
93 QList<QPair<QString, QString>> res;
95 const thread_local QRegularExpression rx( QStringLiteral(
"\\*\\.([a-zA-Z0-9]*)" ) );
99 const QString ext = format.filterString;
100 const QRegularExpressionMatch match = rx.match( ext );
101 if ( !match.hasMatch() )
104 const QString matched = match.captured( 1 );
105 res << QPair<QString, QString>( format.driverName, matched );
108 std::sort( res.begin(), res.end(), [](
const QPair<QString, QString> &a,
const QPair<QString, QString> &b ) ->
bool
110 for ( const QString &tifExt : { QStringLiteral(
"tif" ), QStringLiteral(
"tiff" ) } )
112 if ( a.second == tifExt )
114 if ( b.second == a.second )
116 if ( a.first == QLatin1String(
"GTiff" ) )
118 else if ( b.first == QLatin1String(
"GTiff" ) )
120 return a.first.toLower().localeAwareCompare( b.first.toLower() ) < 0;
124 else if ( b.second == tifExt )
128 if ( a.second == QLatin1String(
"gpkg" ) )
130 if ( b.second == a.second )
131 return a.first.toLower().localeAwareCompare( b.first.toLower() ) < 0;
134 else if ( b.second == QLatin1String(
"gpkg" ) )
137 return a.second.toLower().localeAwareCompare( b.second.toLower() ) < 0;
145 return QStringList();
155 qDeleteAll( mAlgorithms );
166 return mAlgorithms.values();
171 return mAlgorithms.value(
name );
179 if ( mAlgorithms.contains(
algorithm->name() ) )
187 algorithm->initAlgorithm( QVariantMap() );
209 if ( outputPath.isEmpty() )
217 error = tr(
"Missing parameter value %1" ).arg( parameter->
description() );
225 if ( outputPath.startsWith( QLatin1String(
"memory:" ) ) )
229 error = tr(
"This algorithm only supports disk-based outputs" );
238 QMap<QString, QVariant> options;
239 bool useWriter =
false;
242 QgsProcessingUtils::parseDestinationString( outputPath, providerKey, uri, layerName, format, options, useWriter, extension );
244 if ( providerKey != QLatin1String(
"ogr" ) )
248 error = tr(
"This algorithm only supports disk-based outputs" );
256 error = tr(
"“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
263 const QFileInfo fi( outputPath );
264 const QString extension = fi.suffix();
267 error = tr(
"“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
274 const QFileInfo fi( outputPath );
275 const QString extension = fi.completeSuffix();
278 error = tr(
"“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
285 const QFileInfo fi( outputPath );
286 const QString extension = fi.completeSuffix();
289 error = tr(
"“.%1” files are not supported as outputs for this algorithm" ).arg( extension );
305 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
310 else if ( !supportedExtensions.empty() )
312 return supportedExtensions.at( 0 );
318 return hasGeometry ? QStringLiteral(
"shp" ) : QStringLiteral(
"dbf" );
327 for (
const QPair<QString, QString> &formatAndExt : std::as_const( formatAndExtensions ) )
329 if ( formatAndExt.first.compare( userDefault, Qt::CaseInsensitive ) == 0 )
336 if ( !formatAndExtensions.empty() )
338 return formatAndExtensions.at( 0 ).first;
343 return QStringLiteral(
"GTiff" );
351 if ( !extensions.isEmpty() )
352 return extensions[0];
354 return QStringLiteral(
"tif" );
362 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
367 else if ( !supportedExtensions.empty() )
369 return supportedExtensions.at( 0 );
374 return QStringLiteral(
"las" );
383 if ( supportedExtensions.contains( userDefault, Qt::CaseInsensitive ) )
388 else if ( !supportedExtensions.empty() )
390 return supportedExtensions.at( 0 );
395 return QStringLiteral(
"mbtiles" );
QFlags< ProcessingProviderFlag > ProcessingProviderFlags
Flags indicating how and when an processing provider operates and should be exposed to users.
@ Optional
Parameter is optional.
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())
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 ¶meters, 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.
~QgsProcessingProvider() override
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".