42#include <QRegularExpression>
47#include "moc_qgsprocessingutils.cpp"
49using namespace Qt::StringLiterals;
53 return compatibleMapLayers< QgsRasterLayer >( project, sort );
59 return QList<QgsVectorLayer *>();
61 QList<QgsVectorLayer *> layers;
65 if ( canUseLayer( l, geometryTypes ) )
73 return QString::localeAwareCompare( a->name(), b->name() ) < 0;
81 return compatibleMapLayers< QgsMeshLayer >( project, sort );
86 return compatibleMapLayers< QgsPluginLayer >( project, sort );
91 return compatibleMapLayers< QgsPointCloudLayer >( project, sort );
97 QList<QgsAnnotationLayer *> res = compatibleMapLayers< QgsAnnotationLayer >( project,
false );
105 return QString::localeAwareCompare( a->name(), b->name() ) < 0;
114 return compatibleMapLayers< QgsVectorTileLayer >( project, sort );
119 return compatibleMapLayers< QgsTiledSceneLayer >( project, sort );
122template<
typename T> QList<T *> QgsProcessingUtils::compatibleMapLayers(
QgsProject *project,
bool sort )
128 const auto projectLayers = project->
layers<T *>();
129 for ( T *l : projectLayers )
131 if ( canUseLayer( l ) )
137 std::sort( layers.begin(), layers.end(), [](
const T * a,
const T * b ) ->
bool
139 return QString::localeAwareCompare( a->name(), b->name() ) < 0;
148 return QList<QgsMapLayer *>();
150 QList<QgsMapLayer *> layers;
152 const auto rasterLayers = compatibleMapLayers< QgsRasterLayer >( project,
false );
160 const auto meshLayers = compatibleMapLayers< QgsMeshLayer >( project,
false );
164 const auto pointCloudLayers = compatibleMapLayers< QgsPointCloudLayer >( project,
false );
168 const auto annotationLayers = compatibleMapLayers< QgsAnnotationLayer >( project,
false );
173 const auto vectorTileLayers = compatibleMapLayers< QgsVectorTileLayer >( project,
false );
177 const auto tiledSceneLayers = compatibleMapLayers< QgsTiledSceneLayer >( project,
false );
181 const auto pluginLayers = compatibleMapLayers< QgsPluginLayer >( project,
false );
189 return QString::localeAwareCompare( a->name(), b->name() ) < 0;
197 return u
"%1://%2"_s.arg( providerKey, uri );
202 const thread_local QRegularExpression re( u
"^(\\w+?):\\/\\/(.+)$"_s );
203 const QRegularExpressionMatch match = re.match(
string );
204 if ( !match.hasMatch() )
207 providerKey = match.captured( 1 );
208 uri = match.captured( 2 );
216 if ( !store ||
string.isEmpty() )
219 QList< QgsMapLayer * > layers = store->
mapLayers().values();
221 layers.erase( std::remove_if( layers.begin(), layers.end(), [](
QgsMapLayer * layer )
223 switch ( layer->type() )
225 case Qgis::LayerType::Vector:
226 return !canUseLayer( qobject_cast< QgsVectorLayer * >( layer ) );
227 case Qgis::LayerType::Raster:
228 return !canUseLayer( qobject_cast< QgsRasterLayer * >( layer ) );
229 case Qgis::LayerType::Plugin:
230 case Qgis::LayerType::Group:
232 case Qgis::LayerType::Mesh:
233 return !canUseLayer( qobject_cast< QgsMeshLayer * >( layer ) );
234 case Qgis::LayerType::VectorTile:
235 return !canUseLayer( qobject_cast< QgsVectorTileLayer * >( layer ) );
236 case Qgis::LayerType::TiledScene:
237 return !canUseLayer( qobject_cast< QgsTiledSceneLayer * >( layer ) );
238 case Qgis::LayerType::PointCloud:
239 return !canUseLayer( qobject_cast< QgsPointCloudLayer * >( layer ) );
240 case Qgis::LayerType::Annotation:
241 return !canUseLayer( qobject_cast< QgsAnnotationLayer * >( layer ) );
246 auto isCompatibleType = [typeHint](
QgsMapLayer * l ) ->
bool
250 case LayerHint::UnknownType:
253 case LayerHint::Vector:
256 case LayerHint::Raster:
259 case LayerHint::Mesh:
262 case LayerHint::PointCloud:
265 case LayerHint::Annotation:
268 case LayerHint::VectorTile:
271 case LayerHint::TiledScene:
279 if ( isCompatibleType( l ) && l->id() ==
string )
284 if ( isCompatibleType( l ) && l->name() ==
string )
289 if ( isCompatibleType( l ) && normalizeLayerSource( l->source() ) == normalizeLayerSource(
string ) )
306 if ( providerMetadata )
309 const QVariantMap parts = providerMetadata->
decodeUri( uri );
310 const QString layerName = parts.value( u
"layerName"_s ).toString();
312 if ( !layerName.isEmpty() )
316 else if (
const QString path = parts.value( u
"path"_s ).toString(); !path.isEmpty() )
318 name = QFileInfo( path ).baseName();
323 const QStringList components = uri.split(
'|' );
324 if ( components.isEmpty() )
327 if ( QFileInfo fi( components.at( 0 ) ); fi.isFile() )
328 name = fi.baseName();
330 name = QFileInfo( uri ).baseName();
333 if ( name.isEmpty() )
335 name = QgsDataSourceUri( uri ).table();
337 if ( name.isEmpty() )
342 QList< Qgis::LayerType > candidateTypes;
347 if ( providerMetadata )
380 QgsVectorLayer::LayerOptions options { transformContext };
384 std::unique_ptr< QgsVectorLayer > layer;
385 if ( providerMetadata )
387 layer = std::make_unique<QgsVectorLayer>( uri, name, providerMetadata->
key(), options );
392 layer = std::make_unique<QgsVectorLayer>( uri, name, u
"ogr"_s, options );
394 if ( layer->isValid() )
396 return layer.release();
401 QgsRasterLayer::LayerOptions rasterOptions;
405 std::unique_ptr< QgsRasterLayer > rasterLayer;
406 if ( providerMetadata )
408 rasterLayer = std::make_unique< QgsRasterLayer >( uri, name, providerMetadata->
key(), rasterOptions );
413 rasterLayer = std::make_unique< QgsRasterLayer >( uri, name, u
"gdal"_s, rasterOptions );
416 if ( rasterLayer->isValid() )
418 return rasterLayer.release();
423 QgsMeshLayer::LayerOptions meshOptions;
426 std::unique_ptr< QgsMeshLayer > meshLayer;
427 if ( providerMetadata )
429 meshLayer = std::make_unique< QgsMeshLayer >( uri, name, providerMetadata->
key(), meshOptions );
433 meshLayer = std::make_unique< QgsMeshLayer >( uri, name, u
"mdal"_s, meshOptions );
435 if ( meshLayer->isValid() )
437 return meshLayer.release();
442 QgsPointCloudLayer::LayerOptions pointCloudOptions;
450 std::unique_ptr< QgsPointCloudLayer > pointCloudLayer;
451 if ( providerMetadata )
453 pointCloudLayer = std::make_unique< QgsPointCloudLayer >( uri, name, providerMetadata->
key(), pointCloudOptions );
458 if ( !preferredProviders.empty() )
460 pointCloudLayer = std::make_unique< QgsPointCloudLayer >( uri, name, preferredProviders.at( 0 ).metadata()->key(), pointCloudOptions );
470 pointCloudLayer = std::make_unique< QgsPointCloudLayer >( uri, name, u
"pdal"_s, pointCloudOptions );
474 if ( pointCloudLayer && pointCloudLayer->isValid() )
476 return pointCloudLayer.release();
481 QgsDataSourceUri dsUri;
482 dsUri.
setParam(
"type",
"mbtiles" );
485 std::unique_ptr< QgsVectorTileLayer > tileLayer;
486 tileLayer = std::make_unique< QgsVectorTileLayer >( dsUri.
encodedUri(), name );
488 if ( tileLayer->isValid() )
490 return tileLayer.release();
495 QgsTiledSceneLayer::LayerOptions tiledSceneOptions;
498 std::unique_ptr< QgsTiledSceneLayer > tiledSceneLayer;
499 if ( providerMetadata )
501 tiledSceneLayer = std::make_unique< QgsTiledSceneLayer >( uri, name, providerMetadata->
key(), tiledSceneOptions );
506 if ( !preferredProviders.empty() )
508 tiledSceneLayer = std::make_unique< QgsTiledSceneLayer >( uri, name, preferredProviders.at( 0 ).metadata()->key(), tiledSceneOptions );
511 if ( tiledSceneLayer && tiledSceneLayer->isValid() )
513 return tiledSceneLayer.release();
521 if (
string.isEmpty() )
529 if (
auto *lProject = context.
project() )
531 QgsMapLayer *layer = mapLayerFromStore(
string, lProject->layerStore(), typeHint );
545 if ( !allowLoadingNewLayers )
548 layer = loadMapLayerFromString(
string, context.
transformContext(), typeHint, flags );
562 QVariant val = value;
563 bool selectedFeaturesOnly =
false;
564 long long featureLimit = -1;
565 QString filterExpression;
566 bool overrideGeometryCheck =
false;
568 if ( val.userType() == qMetaTypeId<QgsProcessingFeatureSourceDefinition>() )
579 else if ( val.userType() == qMetaTypeId<QgsProcessingOutputLayerDefinition>() )
586 if (
QgsVectorLayer *layer = qobject_cast< QgsVectorLayer * >( qvariant_cast<QObject *>( val ) ) )
588 auto source = std::make_unique< QgsProcessingFeatureSource >( layer, context,
false, featureLimit, filterExpression );
589 if ( overrideGeometryCheck )
590 source->setInvalidGeometryCheck( geometryCheck );
591 return source.release();
595 if ( val.userType() == qMetaTypeId<QgsProperty>() )
599 else if ( !val.isValid() || val.toString().isEmpty() )
602 if (
QgsVectorLayer *layer = qobject_cast< QgsVectorLayer * >( qvariant_cast<QObject *>( fallbackValue ) ) )
604 auto source = std::make_unique< QgsProcessingFeatureSource >( layer, context,
false, featureLimit, filterExpression );
605 if ( overrideGeometryCheck )
606 source->setInvalidGeometryCheck( geometryCheck );
607 return source.release();
610 layerRef = fallbackValue.toString();
614 layerRef = val.toString();
617 if ( layerRef.isEmpty() )
624 std::unique_ptr< QgsProcessingFeatureSource> source;
625 if ( selectedFeaturesOnly )
631 source = std::make_unique< QgsProcessingFeatureSource >( vl, context,
false, featureLimit, filterExpression );
634 if ( overrideGeometryCheck )
635 source->setInvalidGeometryCheck( geometryCheck );
636 return source.release();
641 QVariant val = value;
643 if ( val.userType() == qMetaTypeId<QgsCoordinateReferenceSystem>() )
648 else if ( val.userType() == qMetaTypeId<QgsProcessingFeatureSourceDefinition>() )
654 else if ( val.userType() == qMetaTypeId<QgsProcessingOutputLayerDefinition>() )
667 if (
QgsMapLayer *layer = qobject_cast< QgsMapLayer * >( qvariant_cast<QObject *>( val ) ) )
670 if ( val.userType() == qMetaTypeId<QgsProperty>() )
673 if ( !val.isValid() )
679 QString crsText = val.toString();
680 if ( crsText.isEmpty() )
681 crsText = fallbackValue.toString();
683 if ( crsText.isEmpty() )
687 if ( context.
project() && crsText.compare(
"ProjectCrs"_L1, Qt::CaseInsensitive ) == 0 )
703bool QgsProcessingUtils::canUseLayer(
const QgsMeshLayer *layer )
708bool QgsProcessingUtils::canUseLayer(
const QgsPluginLayer *layer )
710 return layer && layer->
isValid();
715 return layer && layer->
isValid();
718bool QgsProcessingUtils::canUseLayer(
const QgsRasterLayer *layer )
720 return layer && layer->
isValid();
725 return layer && layer->
isValid();
730 return layer && layer->
isValid();
735 return layer && layer->
isValid();
738bool QgsProcessingUtils::canUseLayer(
const QgsVectorLayer *layer,
const QList<int> &sourceTypes )
740 return layer && layer->
isValid() &&
741 ( sourceTypes.isEmpty()
752 QString normalized = source;
753 normalized.replace(
'\\',
'/' );
754 return normalized.trimmed();
763 if ( !source.isEmpty() )
768 if ( provider.compare(
"gdal"_L1, Qt::CaseInsensitive ) == 0
769 || provider.compare(
"ogr"_L1, Qt::CaseInsensitive ) == 0
770 || provider.compare(
"mdal"_L1, Qt::CaseInsensitive ) == 0 )
773 return u
"%1://%2"_s.arg( provider, source );
786 if ( !value.isValid() )
789 if ( value.userType() == qMetaTypeId<QgsProperty>() )
791 else if ( value.userType() == qMetaTypeId<QgsCoordinateReferenceSystem>() )
794 return u
"QgsCoordinateReferenceSystem()"_s;
798 else if ( value.userType() == qMetaTypeId<QgsRectangle>() )
806 else if ( value.userType() == qMetaTypeId<QgsReferencedRectangle>() )
814 else if ( value.userType() == qMetaTypeId<QgsPointXY>() )
820 else if ( value.userType() == qMetaTypeId<QgsReferencedPointXY>() )
828 switch ( value.userType() )
830 case QMetaType::Type::Bool:
831 return value.toBool() ? u
"True"_s : u
"False"_s;
833 case QMetaType::Type::Double:
834 return QString::number( value.toDouble() );
836 case QMetaType::Type::Int:
837 case QMetaType::Type::UInt:
838 return QString::number( value.toInt() );
840 case QMetaType::Type::LongLong:
841 case QMetaType::Type::ULongLong:
842 return QString::number( value.toLongLong() );
844 case QMetaType::Type::QVariantList:
847 const QVariantList vl = value.toList();
848 for (
const QVariant &v : vl )
852 return parts.join(
',' ).prepend(
'[' ).append(
']' );
855 case QMetaType::Type::QVariantMap:
857 const QVariantMap map = value.toMap();
859 parts.reserve( map.size() );
860 for (
auto it = map.constBegin(); it != map.constEnd(); ++it )
864 return parts.join(
',' ).prepend(
'{' ).append(
'}' );
867 case QMetaType::Type::QDateTime:
869 const QDateTime dateTime = value.toDateTime();
870 return u
"QDateTime(QDate(%1, %2, %3), QTime(%4, %5, %6))"_s
871 .arg( dateTime.date().year() )
872 .arg( dateTime.date().month() )
873 .arg( dateTime.date().day() )
874 .arg( dateTime.time().hour() )
875 .arg( dateTime.time().minute() )
876 .arg( dateTime.time().second() );
889 s.replace(
'\\',
"\\\\"_L1 );
890 s.replace(
'\n',
"\\n"_L1 );
891 s.replace(
'\r',
"\\r"_L1 );
892 s.replace(
'\t',
"\\t"_L1 );
894 if ( s.contains(
'\'' ) && !s.contains(
'\"' ) )
896 s = s.prepend(
'"' ).append(
'"' );
900 s.replace(
'\'',
"\\\'"_L1 );
901 s = s.prepend(
'\'' ).append(
'\'' );
906void QgsProcessingUtils::parseDestinationString( QString &destination, QString &providerKey, QString &uri, QString &layerName, QString &format, QMap<QString, QVariant> &options,
bool &useWriter, QString &extension )
913 const thread_local QRegularExpression splitRx( u
"^(.{3,}?):(.*)$"_s );
914 QRegularExpressionMatch match = splitRx.match( destination );
915 if ( match.hasMatch() )
917 providerKey = match.captured( 1 );
918 uri = match.captured( 2 );
925 if ( providerKey ==
"postgis"_L1 )
927 providerKey = u
"postgres"_s;
929 if ( providerKey ==
"ogr"_L1 )
931 QgsDataSourceUri dsUri( uri );
934 if ( !dsUri.
table().isEmpty() )
936 layerName = dsUri.
table();
937 options.insert( u
"layerName"_s, layerName );
940 extension = QFileInfo( uri ).completeSuffix();
942 options.insert( u
"driverName"_s, format );
946 extension = QFileInfo( uri ).completeSuffix();
949 options.insert( u
"update"_s,
true );
956 providerKey = u
"ogr"_s;
958 const thread_local QRegularExpression splitRx( u
"^(.*)\\.(.*?)$"_s );
959 QRegularExpressionMatch match = splitRx.match( destination );
960 if ( match.hasMatch() )
962 extension = match.captured( 2 );
966 if ( format.isEmpty() )
969 destination = destination + u
".gpkg"_s;
972 options.insert( u
"driverName"_s, format );
979 QVariantMap options = createOptions;
980 if ( !options.contains( u
"fileEncoding"_s ) )
986 if ( destination.isEmpty() || destination.startsWith(
"memory:"_L1 ) )
989 if ( destination.startsWith(
"memory:"_L1 ) )
990 destination = destination.mid( 7 );
992 if ( destination.isEmpty() )
993 destination = u
"output"_s;
997 if ( !layer || !layer->isValid() )
1004 for (
const QgsField &field : fields )
1007 if ( !field.alias().isEmpty() )
1008 feedback->pushWarning( QObject::tr(
"%1: Aliases are not compatible with scratch layers" ).arg( field.name() ) );
1009 if ( !field.alias().isEmpty() )
1010 feedback->pushWarning( QObject::tr(
"%1: Comments are not compatible with scratch layers" ).arg( field.name() ) );
1017 destination = layer->id();
1020 auto sink = std::make_unique<QgsProcessingFeatureSink>( layer->dataProvider(), destination, context );
1023 return sink.release();
1027 QString providerKey;
1032 bool useWriter =
false;
1033 parseDestinationString( destination, providerKey, uri, layerName, format, options, useWriter, extension );
1036 if ( useWriter && providerKey ==
"ogr"_L1 )
1040 QString finalFileName;
1041 QString finalLayerName;
1043 saveOptions.
fileEncoding = options.value( u
"fileEncoding"_s ).toString();
1044 saveOptions.
layerName = !layerName.isEmpty() ? layerName : options.value( u
"layerName"_s ).toString();
1049 if ( remappingDefinition )
1053 auto vl = std::make_unique< QgsVectorLayer >( destination );
1054 if ( vl->isValid() )
1058 newFields = vl->fields();
1068 if ( writer->hasError() )
1070 throw QgsProcessingException( QObject::tr(
"Could not create layer %1: %2" ).arg( destination, writer->errorMessage() ) );
1075 for (
const QgsField &field : fields )
1078 feedback->pushWarning( QObject::tr(
"%1: Aliases are not supported by %2" ).arg( field.name(), writer->driverLongName() ) );
1080 feedback->pushWarning( QObject::tr(
"%1: Comments are not supported by %2" ).arg( field.name(), writer->driverLongName() ) );
1084 destination = finalFileName;
1085 if ( !saveOptions.
layerName.isEmpty() && !finalLayerName.isEmpty() )
1086 destination += u
"|layername=%1"_s.arg( finalLayerName );
1088 if ( remappingDefinition )
1090 auto remapSink = std::make_unique< QgsRemappingProxyFeatureSink >( *remappingDefinition, writer.release(),
true );
1101 if ( remappingDefinition )
1106 if ( !layerName.isEmpty() )
1109 parts.insert( u
"layerName"_s, layerName );
1113 auto layer = std::make_unique<QgsVectorLayer>( uri, destination, providerKey, layerOptions );
1115 destination = layer->
id();
1126 for (
const QgsField &field : fields )
1129 feedback->pushWarning( QObject::tr(
"%1: Aliases are not supported by the %2 provider" ).arg( field.name(), providerKey ) );
1131 feedback->pushWarning( QObject::tr(
"%1: Comments are not supported by the %2 provider" ).arg( field.name(), providerKey ) );
1135 auto remapSink = std::make_unique< QgsRemappingProxyFeatureSink >( *remappingDefinition, layer->
dataProvider(),
false );
1145 auto exporter = std::make_unique<QgsVectorLayerExporter>( uri, providerKey, newFields, geometryType, crs,
true, options, sinkFlags );
1148 throw QgsProcessingException( QObject::tr(
"Could not create layer %1: %2" ).arg( destination, exporter->errorMessage() ) );
1152 if ( !layerName.isEmpty() )
1154 uri += u
"|layername=%1"_s.arg( layerName );
1161 for (
const QgsField &field : fields )
1164 feedback->pushWarning( QObject::tr(
"%1: Aliases are not supported by the %2 provider" ).arg( field.name(), providerKey ) );
1166 feedback->pushWarning( QObject::tr(
"%1: Comments are not supported by the %2 provider" ).arg( field.name(), providerKey ) );
1178 *sink =
createFeatureSink( destination, context, fields, geometryType, crs, options );
1224 if ( !input.isValid() )
1225 return u
"memory:%1"_s.arg(
id.toString() );
1227 if ( input.userType() == qMetaTypeId<QgsProcessingOutputLayerDefinition>() )
1234 else if ( input.userType() == qMetaTypeId<QgsProperty>() )
1241 QString res = input.toString();
1247 else if ( res.startsWith(
"memory:"_L1 ) )
1249 return QString( res +
'_' +
id.toString() );
1255 int lastIndex = res.lastIndexOf(
'.' );
1256 return lastIndex >= 0 ? QString( res.left( lastIndex ) +
'_' +
id.toString() + res.mid( lastIndex ) ) : QString( res +
'_' +
id.toString() );
1267 static std::vector< std::unique_ptr< QTemporaryDir > > sTempFolders;
1268 static QString sFolder;
1269 static QMutex sMutex;
1270 QMutexLocker locker( &sMutex );
1275 if ( basePath.isEmpty() )
1278 if ( basePath.isEmpty() )
1281 if ( sTempFolders.empty() )
1283 const QString templatePath = u
"%1/processing_XXXXXX"_s.arg( QDir::tempPath() );
1284 auto tempFolder = std::make_unique< QTemporaryDir >( templatePath );
1286 sTempFolders.emplace_back( std::move(
tempFolder ) );
1289 else if ( sFolder.isEmpty() || !sFolder.startsWith( basePath ) || sTempFolders.empty() )
1291 if ( !QDir().exists( basePath ) )
1292 QDir().mkpath( basePath );
1294 const QString templatePath = u
"%1/processing_XXXXXX"_s.arg( basePath );
1295 auto tempFolder = std::make_unique< QTemporaryDir >( templatePath );
1297 sTempFolders.emplace_back( std::move(
tempFolder ) );
1304 QString subPath = QUuid::createUuid().toString().remove(
'-' ).remove(
'{' ).remove(
'}' );
1305 QString path =
tempFolder( context ) +
'/' + subPath;
1306 if ( !QDir( path ).exists() )
1309 tmpDir.mkdir( path );
1316 auto getText = [map](
const QString & key )->QString
1318 if ( map.contains( key ) )
1319 return map.value( key ).toString();
1324 s += u
"<html><body><p>"_s + getText( u
"ALG_DESC"_s ) + u
"</p>\n"_s;
1327 const auto parameterDefinitions =
algorithm->parameterDefinitions();
1333 if ( !getText( def->name() ).isEmpty() )
1335 inputs += u
"<h3>"_s + def->description() + u
"</h3>\n"_s;
1336 inputs += u
"<p>"_s + getText( def->name() ) + u
"</p>\n"_s;
1339 if ( !inputs.isEmpty() )
1340 s += u
"<h2>"_s + QObject::tr(
"Input parameters" ) + u
"</h2>\n"_s + inputs;
1343 const auto outputDefinitions =
algorithm->outputDefinitions();
1346 if ( !getText( def->name() ).isEmpty() )
1348 outputs += u
"<h3>"_s + def->description() + u
"</h3>\n"_s;
1349 outputs += u
"<p>"_s + getText( def->name() ) + u
"</p>\n"_s;
1352 if ( !outputs.isEmpty() )
1353 s += u
"<h2>"_s + QObject::tr(
"Outputs" ) + u
"</h2>\n"_s + outputs;
1355 if ( !map.value( u
"EXAMPLES"_s ).toString().isEmpty() )
1356 s += u
"<h2>%1</h2>\n<p>%2</p>"_s.arg( QObject::tr(
"Examples" ), getText( u
"EXAMPLES"_s ) );
1359 if ( !map.value( u
"ALG_CREATOR"_s ).toString().isEmpty() )
1360 s += u
"<p align=\"right\">"_s + QObject::tr(
"Algorithm author:" ) + u
" "_s + getText( u
"ALG_CREATOR"_s ) + u
"</p>"_s;
1361 if ( !map.value( u
"ALG_HELP_CREATOR"_s ).toString().isEmpty() )
1362 s += u
"<p align=\"right\">"_s + QObject::tr(
"Help author:" ) + u
" "_s + getText( u
"ALG_HELP_CREATOR"_s ) + u
"</p>"_s;
1363 if ( !map.value( u
"ALG_VERSION"_s ).toString().isEmpty() )
1364 s += u
"<p align=\"right\">"_s + QObject::tr(
"Algorithm version:" ) + u
" "_s + getText( u
"ALG_VERSION"_s ) + u
"</p>"_s;
1366 s +=
"</body></html>"_L1;
1375 if ( def->name().compare( name, Qt::CaseInsensitive ) == 0 )
1383 long long featureLimit,
const QString &filterExpression,
bool renameFid )
1385 bool requiresTranslation =
false;
1389 requiresTranslation = requiresTranslation || selectedFeaturesOnly;
1392 requiresTranslation = requiresTranslation || featureLimit != -1 || !filterExpression.isEmpty();
1397 requiresTranslation = requiresTranslation || vl->
providerType() !=
"ogr"_L1;
1401 requiresTranslation = requiresTranslation || !vl->
subsetString().isEmpty();
1405 requiresTranslation = requiresTranslation || vl->
source().startsWith(
"/vsi"_L1 );
1409 if ( !requiresTranslation )
1412 if ( parts.contains( u
"path"_s ) )
1414 diskPath = parts.value( u
"path"_s ).toString();
1415 QFileInfo fi( diskPath );
1416 requiresTranslation = !compatibleFormats.contains( fi.suffix(), Qt::CaseInsensitive );
1420 const QString srcLayerName = parts.value( u
"layerName"_s ).toString();
1424 *layerName = srcLayerName;
1429 requiresTranslation = requiresTranslation || ( !srcLayerName.isEmpty() && srcLayerName != fi.baseName() );
1434 requiresTranslation =
true;
1438 if ( requiresTranslation )
1448 const int fidIndex = fields.
lookupField( u
"fid"_s );
1449 if ( fidIndex >= 0 )
1450 fields.
rename( fidIndex, u
"OLD_FID"_s );
1456 if ( featureLimit != -1 )
1460 if ( !filterExpression.isEmpty() )
1465 if ( selectedFeaturesOnly )
1470 constexpr int maxErrors { 10 };
1471 unsigned long errorCounter { 0 };
1479 const QString errorMessage = writer->errorMessage();
1480 if ( !renameFid && saveOptions.
driverName ==
"GPKG"_L1 && errorMessage.contains(
"fid", Qt::CaseInsensitive ) )
1483 feedback->
reportError( QObject::tr(
"Cannot store existing FID values in temporary GeoPackage layer, these will be moved to \"OLD_FID\" instead." ),
false );
1485 featureLimit, filterExpression,
true );
1489 if ( errorCounter++ < maxErrors )
1491 errorText = QObject::tr(
"Error writing feature # %1 to output layer: %2" ).arg( QString::number( f.
id() ), errorMessage );
1497 if ( errorCounter >= maxErrors )
1499 feedback->
reportError( QObject::tr(
"There were %1 errors writing features, only the first %2 have been reported." ).arg( QString::number( errorCounter ), QString::number( maxErrors ) ) );
1511 return convertToCompatibleFormatInternal( vl, selectedFeaturesOnly, baseName, compatibleFormats, preferredFormat, context, feedback,
nullptr, featureLimit, filterExpression,
false );
1517 return convertToCompatibleFormatInternal( layer, selectedFeaturesOnly, baseName, compatibleFormats, preferredFormat, context, feedback, &layerName, featureLimit, filterExpression,
false );
1523 QSet< QString > usedNames;
1524 for (
const QgsField &f : fieldsA )
1526 usedNames.insert( f.name().toLower() );
1529 for (
const QgsField &f : fieldsB )
1532 newField.
setName( fieldsBPrefix + f.name() );
1533 if ( usedNames.contains( newField.
name().toLower() ) )
1536 QString newName = newField.
name() +
'_' + QString::number( idx );
1537 while ( usedNames.contains( newName.toLower() ) || fieldsB.
indexOf( newName ) != -1 )
1540 newName = newField.
name() +
'_' + QString::number( idx );
1543 outFields.
append( newField );
1547 outFields.
append( newField );
1549 usedNames.insert( newField.
name() );
1559 if ( !fieldNames.isEmpty() )
1561 indices.reserve( fieldNames.count() );
1562 for (
const QString &f : fieldNames )
1566 indices.append( idx );
1571 indices.reserve( fields.
count() );
1572 for (
int i = 0; i < fields.
count(); ++i )
1573 indices.append( i );
1582 for (
int i : indices )
1583 fieldsSubset.
append( fields.
at( i ) );
1584 return fieldsSubset;
1590 if ( setting.isEmpty() )
1593 if ( setting.startsWith(
'.' ) )
1594 setting = setting.mid( 1 );
1597 if ( !supportedFormats.contains( setting, Qt::CaseInsensitive ) )
1606 if ( setting.isEmpty() )
1609 const QList< QgsRasterFileWriter::FilterFormatDetails > supportedFiltersFormats =
1613 if ( detail.driverName.compare( setting, Qt::CaseInsensitive ) == 0 )
1614 return detail.driverName;
1624 if ( !extensions.isEmpty() )
1625 return extensions[0];
1637 return u
"mbtiles"_s;
1642 auto layerPointerToString = [](
QgsMapLayer * layer ) -> QString
1652 auto cleanPointerValues = [&layerPointerToString](
const QVariant & value ) -> QVariant
1654 if (
QgsMapLayer *layer = qobject_cast< QgsMapLayer * >( value.value< QObject * >() ) )
1657 return layerPointerToString( layer );
1659 else if ( value.userType() == QMetaType::type(
"QPointer< QgsMapLayer >" ) )
1662 return layerPointerToString( value.value< QPointer< QgsMapLayer > >().data() );
1671 for (
auto it = map.constBegin(); it != map.constEnd(); ++it )
1673 if ( it->userType() == QMetaType::Type::QVariantMap )
1677 else if ( it->userType() == QMetaType::Type::QVariantList )
1680 const QVariantList source = it.value().toList();
1681 dest.reserve( source.size() );
1682 for (
const QVariant &v : source )
1684 dest.append( cleanPointerValues( v ) );
1686 res.insert( it.key(), dest );
1690 res.insert( it.key(), cleanPointerValues( it.value() ) );
1700 for (
auto it = parameters.constBegin(); it != parameters.constEnd(); ++it )
1702 if ( it.value().userType() == QMetaType::Type::QVariantMap )
1704 const QVariantMap value = it.value().toMap();
1705 if ( value.value( u
"type"_s ).toString() ==
"data_defined"_L1 )
1707 const QString expression = value.value( u
"expression"_s ).toString();
1708 const QString field = value.value( u
"field"_s ).toString();
1709 if ( !expression.isEmpty() )
1713 else if ( !field.isEmpty() )
1720 error = QObject::tr(
"Invalid data defined parameter for %1, requires 'expression' or 'field' values." ).arg( it.key() );
1725 output.insert( it.key(), it.value() );
1728 else if ( it.value().userType() == QMetaType::Type::QString )
1730 const QString stringValue = it.value().toString();
1732 if ( stringValue.startsWith(
"field:"_L1 ) )
1736 else if ( stringValue.startsWith(
"expression:"_L1 ) )
1742 output.insert( it.key(), it.value() );
1747 output.insert( it.key(), it.value() );
1755 if ( ! QTextCodec::availableCodecs().contains( defaultEncoding.toLatin1() ) )
1757 const QString systemCodec = QTextCodec::codecForLocale()->name();
1758 if ( ! systemCodec.isEmpty() )
1762 return QString(
"UTF-8" );
1765 return defaultEncoding;
1773 : mSource( originalSource )
1774 , mOwnsSource( ownsOriginalSource )
1776 , mSourceFields( mSource->
fields() )
1777 , mSourceWkbType( mSource->
wkbType() )
1782 ?
Qgis::InvalidGeometryCheck::NoCheck
1784 , mInvalidGeometryCallback( context.invalidGeometryCallback( originalSource ) )
1785 , mTransformErrorCallback( context.transformErrorCallback() )
1786 , mInvalidGeometryCallbackSkip( context.defaultInvalidGeometryCallbackForCheck(
Qgis::InvalidGeometryCheck::SkipInvalid, originalSource ) )
1787 , mInvalidGeometryCallbackAbort( context.defaultInvalidGeometryCallbackForCheck(
Qgis::InvalidGeometryCheck::AbortOnInvalid, originalSource ) )
1788 , mFeatureLimit( featureLimit )
1789 , mFilterExpression( filterExpression )
1811 if ( mFeatureLimit != -1 && req.
limit() != -1 )
1812 req.
setLimit( std::min(
static_cast< long long >( req.
limit() ), mFeatureLimit ) );
1813 else if ( mFeatureLimit != -1 )
1816 if ( !mFilterExpression.isEmpty() )
1819 return mSource->getFeatures( req );
1828 return sourceAvailability;
1841 if ( mFeatureLimit != -1 && req.
limit() != -1 )
1842 req.
setLimit( std::min(
static_cast< long long >( req.
limit() ), mFeatureLimit ) );
1843 else if ( mFeatureLimit != -1 )
1846 if ( !mFilterExpression.isEmpty() )
1849 return mSource->getFeatures( req );
1859 return mSourceFields;
1864 return mSourceWkbType;
1869 if ( !mFilterExpression.isEmpty() )
1872 if ( mFeatureLimit == -1 )
1873 return mSource->featureCount();
1875 return std::min( mFeatureLimit, mSource->featureCount() );
1885 if ( mFilterExpression.isEmpty() )
1886 return mSource->uniqueValues( fieldIndex, limit );
1890 if ( fieldIndex < 0 || fieldIndex >=
fields().count() )
1891 return QSet<QVariant>();
1898 QSet<QVariant> values;
1903 values.insert( f.
attribute( fieldIndex ) );
1904 if ( limit > 0 && values.size() >= limit )
1912 if ( mFilterExpression.isEmpty() )
1913 return mSource->minimumValue( fieldIndex );
1917 if ( fieldIndex < 0 || fieldIndex >=
fields().count() )
1929 const QVariant v = f.
attribute( fieldIndex );
1940 if ( mFilterExpression.isEmpty() )
1941 return mSource->maximumValue( fieldIndex );
1945 if ( fieldIndex < 0 || fieldIndex >=
fields().count() )
1957 const QVariant v = f.
attribute( fieldIndex );
1968 return mSourceExtent;
1973 if ( mFilterExpression.isEmpty() )
1974 return mSource->allFeatureIds();
1979 .setFilterExpression( mFilterExpression ) );
1994 return mSourceSpatialIndexPresence;
2005 return expressionContextScope;
2010 mInvalidGeometryCheck = method;
2011 switch ( mInvalidGeometryCheck )
2014 mInvalidGeometryCallback =
nullptr;
2018 mInvalidGeometryCallback = mInvalidGeometryCallbackSkip;
2022 mInvalidGeometryCallback = mInvalidGeometryCallbackAbort;
2030 return mInvalidGeometryCheck;
2039 , mContext( context )
2040 , mSinkName( sinkName )
2041 , mOwnsSink( ownsOriginalSink )
2048 mContext.feedback()->reportError(
lastError() );
2069 if ( !result && mContext.feedback() )
2072 if ( !error.isEmpty() )
2073 mContext.feedback()->reportError( QObject::tr(
"Feature could not be written to %1: %2" ).arg( mSinkName, error ) );
2075 mContext.feedback()->reportError( QObject::tr(
"Feature could not be written to %1" ).arg( mSinkName ) );
2083 if ( !result && mContext.feedback() )
2086 if ( !error.isEmpty() )
2087 mContext.feedback()->reportError( QObject::tr(
"%n feature(s) could not be written to %1: %2",
nullptr, features.count() ).arg( mSinkName, error ) );
2089 mContext.feedback()->reportError( QObject::tr(
"%n feature(s) could not be written to %1",
nullptr, features.count() ).arg( mSinkName ) );
2097 if ( !result && mContext.feedback() )
2100 if ( !error.isEmpty() )
2101 mContext.feedback()->reportError( QObject::tr(
"Features could not be written to %1: %2" ).arg( mSinkName, error ) );
2103 mContext.feedback()->reportError( QObject::tr(
"Features could not be written to %1" ).arg( mSinkName ) );
Provides global constants and enumerations for use throughout the application.
@ Vector
Tables (i.e. vector layers with or without geometry). When used for a sink this indicates the sink ha...
@ VectorAnyGeometry
Any vector layer with geometry.
@ VectorPoint
Vector point layers.
@ VectorPolygon
Vector polygon layers.
@ VectorLine
Vector line layers.
@ FieldComments
Writer can support field comments.
@ FieldAliases
Writer can support field aliases.
SpatialIndexPresence
Enumeration of spatial index presence states.
@ Success
No errors were encountered.
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
FeatureAvailability
Possible return value for QgsFeatureSource::hasFeatures() to determine if a source is empty.
@ FeaturesMaybeAvailable
There may be features available in this source.
@ NoFeaturesAvailable
There are certainly no features available in this source.
@ TiledScene
Tiled scene layer. Added in QGIS 3.34.
@ Annotation
Contains freeform, georeferenced annotations. Added in QGIS 3.16.
@ VectorTile
Vector tile layer. Added in QGIS 3.14.
@ Mesh
Mesh layer. Added in QGIS 3.2.
@ PointCloud
Point cloud layer. Added in QGIS 3.18.
@ EditAlias
Allows editing aliases.
@ EditComment
Allows editing comments.
QFlags< VectorDataProviderAttributeEditCapability > VectorDataProviderAttributeEditCapabilities
Attribute editing capabilities which may be supported by vector data providers.
InvalidGeometryCheck
Methods for handling of features with invalid geometries.
@ NoCheck
No invalid geometry checking.
@ AbortOnInvalid
Close iterator on encountering any features with invalid geometry. This requires a slow geometry vali...
@ SkipInvalid
Skip any features with invalid geometry. This requires a slow geometry validity check for every featu...
@ OverrideDefaultGeometryCheck
If set, the default geometry check method (as dictated by QgsProcessingContext) will be overridden fo...
@ SkipGeometryValidityChecks
Invalid geometry checks should always be skipped. This flag can be useful for algorithms which always...
WkbType
The WKB type describes the number of dimensions a geometry has.
@ Hidden
Parameter is hidden and should not be shown to users.
@ NoSymbology
Export only data.
QFlags< ProcessingFeatureSourceFlag > ProcessingFeatureSourceFlags
Flags which control how QgsProcessingFeatureSource fetches features.
Represents a map layer containing a set of georeferenced annotations, e.g.
Represents a coordinate reference system (CRS).
bool isValid() const
Returns whether this CRS is correctly initialized and usable.
Contains information about the context in which a coordinate transform is executed.
Custom exception class for Coordinate Reference System related exceptions.
QByteArray encodedUri() const
Returns the complete encoded URI as a byte array.
QString table() const
Returns the table name stored in the URI.
void setParam(const QString &key, const QString &value)
Sets a generic parameter value on the URI.
QString database() const
Returns the database name stored in the URI.
Abstract interface for generating an expression context scope.
virtual QgsExpressionContextScope * createExpressionContextScope() const =0
This method needs to be reimplemented in all classes which implement this interface and return an exp...
Single scope for storing variables and functions for use within a QgsExpressionContext.
void setFields(const QgsFields &fields)
Convenience function for setting a fields for the context.
Wrapper for iterator of features from vector data provider or vector layer.
bool nextFeature(QgsFeature &f)
Fetch next feature and stores in f, returns true on success.
Wraps a request for features to a vector layer (or directly its vector data provider).
QgsFeatureRequest & setFlags(Qgis::FeatureRequestFlags flags)
Sets flags that affect how features will be fetched.
QgsFeatureRequest & setLimit(long long limit)
Set the maximum number of features to request.
long long limit() const
Returns the maximum number of features to request, or -1 if no limit set.
QgsFeatureRequest & combineFilterExpression(const QString &expression)
Modifies the existing filter expression to add an additional expression filter.
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
QgsFeatureRequest & setInvalidGeometryCheck(Qgis::InvalidGeometryCheck check)
Sets invalid geometry checking behavior.
QgsFeatureRequest & setFilterExpression(const QString &expression)
Set the filter expression.
QgsFeatureRequest & setInvalidGeometryCallback(const std::function< void(const QgsFeature &)> &callback)
Sets a callback function to use when encountering an invalid geometry and invalidGeometryCheck() is s...
QgsFeatureRequest & setTransformErrorCallback(const std::function< void(const QgsFeature &)> &callback)
Sets a callback function to use when encountering a transform error when iterating features and a des...
An interface for objects which accept features via addFeature(s) methods.
QFlags< SinkFlag > SinkFlags
@ FastInsert
Use faster inserts, at the cost of updating the passed features to reflect changes made at the provid...
@ RegeneratePrimaryKey
This flag indicates, that a primary key field cannot be guaranteed to be unique and the sink should i...
An interface for objects which provide features via a getFeatures method.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Q_INVOKABLE QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
bool isCanceled() const
Tells whether the operation has been canceled already.
Encapsulate a field in an attribute table or data source.
void setName(const QString &name)
Set the field name.
Container of fields for a vector layer.
bool append(const QgsField &field, Qgis::FieldOrigin origin=Qgis::FieldOrigin::Provider, int originIndex=-1)
Appends a field.
Q_INVOKABLE int indexOf(const QString &fieldName) const
Gets the field index from the field name.
QgsField at(int i) const
Returns the field at particular index (must be in range 0..N-1).
Q_INVOKABLE int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
bool rename(int fieldIdx, const QString &name)
Renames a name of field.
static QString stringToSafeFilename(const QString &string)
Converts a string to a safe filename, replacing characters which are not safe for filenames with an '...
A storage object for map layers, in which the layers are owned by the store and have their lifetime b...
QMap< QString, QgsMapLayer * > mapLayers() const
Returns a map of all layers by layer ID.
QgsMapLayer * addMapLayer(QgsMapLayer *layer, bool takeOwnership=true)
Add a layer to the store.
Base class for all map layer types.
QString source() const
Returns the source for the layer.
QString providerType() const
Returns the provider type (provider key) for this layer.
QgsCoordinateReferenceSystem crs
virtual void setTransformContext(const QgsCoordinateTransformContext &transformContext)=0
Sets the coordinate transform context to transformContext.
static QgsVectorLayer * createMemoryLayer(const QString &name, const QgsFields &fields, Qgis::WkbType geometryType=Qgis::WkbType::NoGeometry, const QgsCoordinateReferenceSystem &crs=QgsCoordinateReferenceSystem(), bool loadDefaultStyle=true) SIP_FACTORY
Creates a new memory layer using the specified parameters.
Represents a mesh layer supporting display of data on structured or unstructured meshes.
QgsMeshDataProvider * dataProvider() override
Returns the layer's data provider, it may be nullptr.
Base class for plugin layers.
Represents a map layer supporting display of point clouds.
Abstract base class for processing algorithms.
Contains information about the context in which a processing algorithm is executed.
QString defaultEncoding() const
Returns the default encoding to use for newly created files.
QgsProcessingFeedback * feedback()
Returns the associated feedback object.
QgsExpressionContext & expressionContext()
Returns the expression context.
QgsCoordinateTransformContext transformContext() const
Returns the coordinate transform context.
QgsProject * project() const
Returns the project in which the algorithm is being executed.
QgsMapLayerStore * temporaryLayerStore()
Returns a reference to the layer store used for storing temporary layers during algorithm execution.
QString temporaryFolder() const
Returns the (optional) temporary folder to use when running algorithms.
Custom exception class for processing related exceptions.
QgsProxyFeatureSink subclass which reports feature addition errors to a QgsProcessingContext.
void finalize() override
Finalizes the sink, flushing any buffered features to the destination.
~QgsProcessingFeatureSink() override
QgsProcessingFeatureSink(QgsFeatureSink *originalSink, const QString &sinkName, QgsProcessingContext &context, bool ownsOriginalSink=false)
Constructor for QgsProcessingFeatureSink, accepting an original feature sink originalSink and process...
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a list of features to the sink.
bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a single feature to the sink.
Encapsulates settings relating to a feature source input to a processing algorithm.
bool selectedFeaturesOnly
true if only selected features in the source should be used by algorithms.
QgsProperty source
Source definition.
Qgis::InvalidGeometryCheck geometryCheck
Geometry check method to apply to this source.
Qgis::ProcessingFeatureSourceDefinitionFlags flags
Flags which dictate source behavior.
long long featureLimit
If set to a value > 0, places a limit on the maximum number of features which will be read from the s...
QString filterExpression
Optional expression filter to use for filtering features which will be read from the source.
QgsFeatureSource subclass which proxies methods to an underlying QgsFeatureSource,...
QgsRectangle sourceExtent() const override
Returns the extent of all geometries from the source.
QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const override
Returns the set of unique values contained within the specified fieldIndex from this source.
QgsExpressionContextScope * createExpressionContextScope() const
Returns an expression context scope suitable for this source.
QgsProcessingFeatureSource(QgsFeatureSource *originalSource, const QgsProcessingContext &context, bool ownsOriginalSource=false, long long featureLimit=-1, const QString &filterExpression=QString())
Constructor for QgsProcessingFeatureSource, accepting an original feature source originalSource and p...
void setInvalidGeometryCheck(Qgis::InvalidGeometryCheck method)
Overrides the default geometry check method for the source.
Qgis::InvalidGeometryCheck invalidGeometryCheck() const
Returns the geometry check method for the source.
QVariant maximumValue(int fieldIndex) const override
Returns the maximum value for an attribute column or an invalid variant in case of error.
~QgsProcessingFeatureSource() override
QgsCoordinateReferenceSystem sourceCrs() const override
Returns the coordinate reference system for features in the source.
Qgis::WkbType wkbType() const override
Returns the geometry type for features returned by this source.
QVariant minimumValue(int fieldIndex) const override
Returns the minimum value for an attribute column or an invalid variant in case of error.
long long featureCount() const override
Returns the number of features contained in the source, or -1 if the feature count is unknown.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request, Qgis::ProcessingFeatureSourceFlags flags) const
Returns an iterator for the features in the source, respecting the supplied feature flags.
Qgis::FeatureAvailability hasFeatures() const override
Determines if there are any features available in the source.
QString sourceName() const override
Returns a friendly display name for the source.
QgsFeatureIds allFeatureIds() const override
Returns a list of all feature IDs for features present in the source.
Qgis::SpatialIndexPresence hasSpatialIndex() const override
Returns an enum value representing the presence of a valid spatial index on the source,...
QgsFields fields() const override
Returns the fields associated with features in the source.
Base class for providing feedback from a processing algorithm.
virtual void reportError(const QString &error, bool fatalError=false)
Reports that the algorithm encountered an error while executing.
Base class for the definition of processing outputs.
Encapsulates settings relating to a feature sink or output raster layer for a processing algorithm.
QgsProperty sink
Sink/layer definition.
Base class for the definition of processing parameters.
static QList< QgsTiledSceneLayer * > compatibleTiledSceneLayers(QgsProject *project, bool sort=true)
Returns a list of tiled scene layers from a project which are compatible with the processing framewor...
static QString stringToPythonLiteral(const QString &string)
Converts a string to a Python string literal.
static QString defaultVectorExtension()
Returns the default vector extension to use, in the absence of all other constraints (e....
static QVariant generateIteratingDestination(const QVariant &input, const QVariant &id, QgsProcessingContext &context)
Converts an input parameter value for use in source iterating mode, where one individual sink is crea...
static QgsFields indicesToFields(const QList< int > &indices, const QgsFields &fields)
Returns a subset of fields based on the indices of desired fields.
static QList< int > fieldNamesToIndices(const QStringList &fieldNames, const QgsFields &fields)
Returns a list of field indices parsed from the given list of field names.
static QString layerToStringIdentifier(const QgsMapLayer *layer, const QString &layerName=QString())
Returns a string representation of the source for a layer.
static QVariantMap preprocessQgisProcessParameters(const QVariantMap ¶meters, bool &ok, QString &error)
Pre-processes a set of parameter values for the qgis_process command.
static QList< QgsAnnotationLayer * > compatibleAnnotationLayers(QgsProject *project, bool sort=true)
Returns a list of annotation layers from a project which are compatible with the processing framework...
static QString generateTempFilename(const QString &basename, const QgsProcessingContext *context=nullptr)
Returns a temporary filename for a given file, putting it into a temporary folder (creating that fold...
static QString normalizeLayerSource(const QString &source)
Normalizes a layer source string for safe comparison across different operating system environments.
static QString formatHelpMapAsHtml(const QVariantMap &map, const QgsProcessingAlgorithm *algorithm)
Returns a HTML formatted version of the help text encoded in a variant map for a specified algorithm.
static QgsFields combineFields(const QgsFields &fieldsA, const QgsFields &fieldsB, const QString &fieldsBPrefix=QString())
Combines two field lists, avoiding duplicate field names (in a case-insensitive manner).
static QString encodeProviderKeyAndUri(const QString &providerKey, const QString &uri)
Encodes a provider key and layer uri to a single string, for use with decodeProviderKeyAndUri().
LayerHint
Layer type hints.
@ TiledScene
Tiled scene layer type, since QGIS 3.34.
@ Annotation
Annotation layer type, since QGIS 3.22.
@ Vector
Vector layer type.
@ VectorTile
Vector tile layer type, since QGIS 3.32.
@ Mesh
Mesh layer type, since QGIS 3.6.
@ Raster
Raster layer type.
@ UnknownType
Unknown layer type.
@ PointCloud
Point cloud layer type, since QGIS 3.22.
static QString defaultRasterFormat()
Returns the default raster format to use, in the absence of all other constraints (e....
static QgsProcessingFeatureSource * variantToSource(const QVariant &value, QgsProcessingContext &context, const QVariant &fallbackValue=QVariant())
Converts a variant value to a new feature source.
static QList< QgsRasterLayer * > compatibleRasterLayers(QgsProject *project, bool sort=true)
Returns a list of raster layers from a project which are compatible with the processing framework.
static int outputDefinitionIndex(const QgsProcessingAlgorithm *algorithm, const QString &name)
Returns the index of the output matching name for a specified algorithm.
static QgsRectangle combineLayerExtents(const QList< QgsMapLayer * > &layers, const QgsCoordinateReferenceSystem &crs, QgsProcessingContext &context)
Combines the extent of several map layers.
static QString resolveDefaultEncoding(const QString &defaultEncoding="System")
Returns the default encoding.
static QList< QgsPluginLayer * > compatiblePluginLayers(QgsProject *project, bool sort=true)
Returns a list of plugin layers from a project which are compatible with the processing framework.
static QString variantToPythonLiteral(const QVariant &value)
Converts a variant to a Python literal.
static QgsCoordinateReferenceSystem variantToCrs(const QVariant &value, QgsProcessingContext &context, const QVariant &fallbackValue=QVariant())
Converts a variant value to a coordinate reference system.
static QList< QgsVectorLayer * > compatibleVectorLayers(QgsProject *project, const QList< int > &sourceTypes=QList< int >(), bool sort=true)
Returns a list of vector layers from a project which are compatible with the processing framework.
static QVariantMap removePointerValuesFromMap(const QVariantMap &map)
Removes any raw pointer values from an input map, replacing them with appropriate string values where...
static bool decodeProviderKeyAndUri(const QString &string, QString &providerKey, QString &uri)
Decodes a provider key and layer uri from an encoded string, for use with encodeProviderKeyAndUri().
static void createFeatureSinkPython(QgsFeatureSink **sink, QString &destination, QgsProcessingContext &context, const QgsFields &fields, Qgis::WkbType geometryType, const QgsCoordinateReferenceSystem &crs, const QVariantMap &createOptions=QVariantMap())
Creates a feature sink ready for adding features.
static QList< QgsVectorTileLayer * > compatibleVectorTileLayers(QgsProject *project, bool sort=true)
Returns a list of vector tile layers from a project which are compatible with the processing framewor...
static QString convertToCompatibleFormatAndLayerName(const QgsVectorLayer *layer, bool selectedFeaturesOnly, const QString &baseName, const QStringList &compatibleFormats, const QString &preferredFormat, QgsProcessingContext &context, QgsProcessingFeedback *feedback, QString &layerName, long long featureLimit=-1, const QString &filterExpression=QString())
Converts a source vector layer to a file path and layer name of a vector layer of compatible format.
static QList< QgsMapLayer * > compatibleLayers(QgsProject *project, bool sort=true)
Returns a list of map layers from a project which are compatible with the processing framework.
static QString convertToCompatibleFormat(const QgsVectorLayer *layer, bool selectedFeaturesOnly, const QString &baseName, const QStringList &compatibleFormats, const QString &preferredFormat, QgsProcessingContext &context, QgsProcessingFeedback *feedback, long long featureLimit=-1, const QString &filterExpression=QString())
Converts a source vector layer to a file path of a vector layer of compatible format.
static QgsFeatureSink * createFeatureSink(QString &destination, QgsProcessingContext &context, const QgsFields &fields, Qgis::WkbType geometryType, const QgsCoordinateReferenceSystem &crs, const QVariantMap &createOptions=QVariantMap(), const QStringList &datasourceOptions=QStringList(), const QStringList &layerOptions=QStringList(), QgsFeatureSink::SinkFlags sinkFlags=QgsFeatureSink::SinkFlags(), QgsRemappingSinkDefinition *remappingDefinition=nullptr)
Creates a feature sink ready for adding features.
static QString defaultRasterExtension()
Returns the default raster extension 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 QgsMapLayer * mapLayerFromString(const QString &string, QgsProcessingContext &context, bool allowLoadingNewLayers=true, QgsProcessingUtils::LayerHint typeHint=QgsProcessingUtils::LayerHint::UnknownType, QgsProcessing::LayerOptionsFlags flags=QgsProcessing::LayerOptionsFlags())
Interprets a string as a map layer within the supplied context.
static QString defaultPointCloudExtension()
Returns the default point cloud extension to use, in the absence of all other constraints (e....
static QList< QgsPointCloudLayer * > compatiblePointCloudLayers(QgsProject *project, bool sort=true)
Returns a list of point cloud layers from a project which are compatible with the processing framewor...
static QList< QgsMeshLayer * > compatibleMeshLayers(QgsProject *project, bool sort=true)
Returns a list of mesh layers from a project which are compatible with the processing framework.
static QString tempFolder(const QgsProcessingContext *context=nullptr)
Returns a session specific processing temporary folder for use in processing algorithms.
static const QgsSettingsEntryString * settingsDefaultOutputRasterLayerFormat
Settings entry default output raster layer format.
QFlags< LayerOptionsFlag > LayerOptionsFlags
static const QgsSettingsEntryString * settingsTempPath
Settings entry temp path.
static const QString TEMPORARY_OUTPUT
Constant used to indicate that a Processing algorithm output should be a temporary layer/file.
static const QgsSettingsEntryString * settingsDefaultOutputVectorLayerExt
Settings entry default output vector layer ext.
@ SkipIndexGeneration
Do not generate index when creating a layer. Makes sense only for point cloud layers.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
QgsAnnotationLayer * mainAnnotationLayer()
Returns the main annotation layer associated with the project.
QVector< T > layers() const
Returns a list of registered map layers with a specified layer type.
QgsCoordinateReferenceSystem crs
A store for object properties.
QString asExpression() const
Returns an expression string representing the state of the property, or an empty string if the proper...
Qgis::PropertyType propertyType() const
Returns the property type.
static QgsProperty fromExpression(const QString &expression, bool isActive=true)
Returns a new ExpressionBasedProperty created from the specified expression.
static QgsProperty fromField(const QString &fieldName, bool isActive=true)
Returns a new FieldBasedProperty created from the specified field name.
static QgsProperty fromValue(const QVariant &value, bool isActive=true)
Returns a new StaticProperty created from the specified value.
QVariantMap decodeUri(const QString &providerKey, const QString &uri)
Breaks a provider data source URI into its component paths (e.g.
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
QList< QgsProviderRegistry::ProviderCandidateDetails > preferredProvidersForUri(const QString &uri) const
Returns the details for the preferred provider(s) for opening the specified uri.
QString encodeUri(const QString &providerKey, const QVariantMap &parts)
Reassembles a provider data source URI from its component paths (e.g.
QgsProviderMetadata * providerMetadata(const QString &providerKey) const
Returns metadata of the provider or nullptr if not found.
bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a single feature to the sink.
bool flushBuffer() override
Flushes any internal buffer which may exist in the sink, causing any buffered features to be added to...
QgsFeatureSink * mSink
Underlying destination sink.
QString lastError() const override
Returns the most recent error encountered by the sink, e.g.
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a list of features to the sink.
QgsProxyFeatureSink(QgsFeatureSink *sink)
Constructs a new QgsProxyFeatureSink which forwards features onto a destination sink.
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...
Represents a raster layer.
A rectangle specified with double values.
void combineExtentWith(const QgsRectangle &rect)
Expands the rectangle so that it covers both the original rectangle and the given rectangle.
QgsCoordinateReferenceSystem crs() const
Returns the associated coordinate reference system, or an invalid CRS if no reference system is set.
A QgsPointXY with associated coordinate reference system.
A QgsRectangle with associated coordinate reference system.
Defines the parameters used to remap features when creating a QgsRemappingProxyFeatureSink.
void setDestinationCrs(const QgsCoordinateReferenceSystem &destination)
Sets the destination crs used for reprojecting incoming features to the sink's destination CRS.
void setDestinationWkbType(Qgis::WkbType type)
Sets the WKB geometry type for the destination.
void setDestinationFields(const QgsFields &fields)
Sets the fields for the destination sink.
Represents a map layer supporting display of tiled scene objects.
static bool isNull(const QVariant &variant, bool silenceNullWarnings=false)
Returns true if the specified variant should be considered a NULL value.
virtual Qgis::VectorDataProviderAttributeEditCapabilities attributeEditCapabilities() const
Returns the provider's supported attribute editing capabilities.
Options to pass to QgsVectorFileWriter::writeAsVectorFormat().
QString fileEncoding
Encoding to use.
QString driverName
OGR driver to use.
QString layerName
Layer name. If let empty, it will be derived from the filename.
QStringList layerOptions
List of OGR layer creation options.
Qgis::FeatureSymbologyExport symbologyExport
Symbology to export.
QgsVectorFileWriter::ActionOnExistingFile actionOnExistingFile
Action on existing file.
QStringList datasourceOptions
List of OGR data source creation options.
static QStringList defaultLayerOptions(const QString &driverName)
Returns a list of the default layer options for a specified driver.
static QString driverForExtension(const QString &extension)
Returns the OGR driver name for a specified file extension.
static QgsVectorFileWriter * create(const QString &fileName, const QgsFields &fields, Qgis::WkbType geometryType, const QgsCoordinateReferenceSystem &srs, const QgsCoordinateTransformContext &transformContext, const QgsVectorFileWriter::SaveVectorOptions &options, QgsFeatureSink::SinkFlags sinkFlags=QgsFeatureSink::SinkFlags(), QString *newFilename=nullptr, QString *newLayer=nullptr)
Create a new vector file writer.
static QStringList defaultDatasetOptions(const QString &driverName)
Returns a list of the default dataset options for a specified driver.
static QStringList supportedFormatExtensions(VectorFormatOptions options=SortRecommended)
Returns a list of file extensions for supported formats, e.g "shp", "gpkg".
@ CreateOrOverwriteFile
Create or overwrite file.
@ AppendToLayerNoNewFields
Append features to existing layer, but do not create new fields.
QgsFeatureSource subclass for the selected features from a QgsVectorLayer.
Represents a vector layer which manages a vector based dataset.
bool isSpatial() const final
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
QgsRectangle extent() const final
Returns the extent of the layer.
Q_INVOKABLE Qgis::WkbType wkbType() const final
Returns the WKBType or WKBUnknown in case of error.
QgsFeatureIterator getSelectedFeatures(QgsFeatureRequest request=QgsFeatureRequest()) const
Returns an iterator of the selected features.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const final
Queries the layer for features specified in request.
Q_INVOKABLE Qgis::GeometryType geometryType() const
Returns point, line or polygon.
QgsVectorDataProvider * dataProvider() final
Returns the layer's data provider, it may be nullptr.
Implements a map layer that is dedicated to rendering of vector tiles.
Handles storage of information regarding WKB types and their properties.
@ UnknownCount
Provider returned an unknown feature count.
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
bool qgsVariantLessThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is less than the second.
bool qgsVariantGreaterThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is greater than the second.
QString qgsDoubleToString(double a, int precision=17)
Returns a string representation of a double.
QList< QgsFeature > QgsFeatureList
QSet< QgsFeatureId > QgsFeatureIds
QList< int > QgsAttributeList
QString convertToCompatibleFormatInternal(const QgsVectorLayer *vl, bool selectedFeaturesOnly, const QString &baseName, const QStringList &compatibleFormats, const QString &preferredFormat, QgsProcessingContext &context, QgsProcessingFeedback *feedback, QString *layerName, long long featureLimit, const QString &filterExpression, bool renameFid)
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool skipIndexGeneration
Set to true if point cloud index generation should be skipped.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool loadDefaultStyle
Sets to true if the default layer style should be loaded.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
Setting options for loading vector layers.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool loadDefaultStyle
Set to true if the default layer style should be loaded.