105#include <QPainterPath>
107#include <QProgressDialog>
108#include <QRegularExpression>
110#include <QStringBuilder>
112#include <QUndoCommand>
118#include "moc_qgsvectorlayer.cpp"
120using namespace Qt::StringLiterals;
129#ifdef TESTPROVIDERLIB
135 const QString &qmlStyle,
136 const QString &sldStyle,
137 const QString &styleName,
138 const QString &styleDescription,
139 const QString &uiFileContent,
153 QStringList &descriptions,
171 const QString &baseName,
172 const QString &providerKey,
178 , mAuxiliaryLayer( nullptr )
179 , mAuxiliaryLayerKey( QString() )
181 , mRefreshRendererTimer( new QTimer( this ) )
192 mGeometryOptions = std::make_unique<QgsGeometryOptions>();
196 mStoredExpressionManager->setParent(
this );
199 mJoinBuffer->setParent(
this );
204 if ( !vectorLayerPath.isEmpty() && !
mProviderKey.isEmpty() )
215 mDataSourceReadOnly =
true;
217 setDataSource( vectorLayerPath, baseName, providerKey, providerOptions, providerFlags );
220 for (
const QgsField &field : std::as_const( mFields ) )
222 if ( !mAttributeAliasMap.contains( field.name() ) )
223 mAttributeAliasMap.insert( field.name(), QString() );
228 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities( mDataProvider->temporalCapabilities() );
229 if ( !mTemporalProperties->isActive() )
233 mTemporalProperties->guessDefaultsFromFields( mFields );
236 mElevationProperties->setDefaultsFromLayer(
this );
254 connect( mRefreshRendererTimer, &QTimer::timeout,
this, [
this] {
triggerRepaint(
true ); } );
263 delete mDataProvider;
266 delete mExpressionFieldBuffer;
268 delete mDiagramLayerSettings;
269 delete mDiagramRenderer;
274 delete mConditionalStyles;
275 delete mStoredExpressionManager;
277 if ( mFeatureCounter )
278 mFeatureCounter->cancel();
280 qDeleteAll( mRendererGenerators );
294 dataSource = mDataProvider->dataSourceUri();
295 options.transformContext = mDataProvider->transformContext();
308 layer->mXmlExtent2D = mXmlExtent2D;
309 layer->mLazyExtent2D = mLazyExtent2D;
310 layer->mValidExtent2D = mValidExtent2D;
311 layer->mXmlExtent3D = mXmlExtent3D;
312 layer->mLazyExtent3D = mLazyExtent3D;
313 layer->mValidExtent3D = mValidExtent3D;
315 QList<QgsVectorLayerJoinInfo> joins =
vectorJoins();
316 const auto constJoins = joins;
338 for (
const QgsAction &action : constActions )
375 auto constraintIt = constraints.constBegin();
376 for ( ; constraintIt != constraints.constEnd(); ++ constraintIt )
392 layer->mElevationProperties = mElevationProperties->
clone();
393 layer->mElevationProperties->setParent( layer );
395 layer->mSelectionProperties = mSelectionProperties->
clone();
396 layer->mSelectionProperties->setParent( layer );
407 return mDataProvider->storageType();
419 return mDataProvider->capabilitiesString();
428 return mDataProvider && mDataProvider->isSqlQuery();
444 return mDataProvider->dataComment();
470 mDataProvider->reloadData();
489 p.setPen( QColor( 50, 100, 120, 200 ) );
490 p.setBrush( QColor( 200, 200, 210, 120 ) );
491 p.drawEllipse( x - m, y - m, m * 2 + 1, m * 2 + 1 );
495 p.setPen( QColor( 255, 0, 0 ) );
496 p.drawLine( x - m, y + m, x + m, y - m );
497 p.drawLine( x - m, y - m, x + m, y + m );
509 mSelectedFeatureIds.insert( fid );
510 mPreviousSelectedFeatureIds.clear();
519 mSelectedFeatureIds.unite( featureIds );
520 mPreviousSelectedFeatureIds.clear();
529 mSelectedFeatureIds.remove( fid );
530 mPreviousSelectedFeatureIds.clear();
539 mSelectedFeatureIds.subtract( featureIds );
540 mPreviousSelectedFeatureIds.clear();
555 .setFilterRect( rect )
557 .setNoAttributes() );
562 newSelection << feat.
id();
575 std::optional< QgsExpressionContext > defaultContext;
579 context = &defaultContext.value();
607 newSelection << feat.
id();
615 QgsFeatureRequest request = QgsFeatureRequest().
setFilterFids( oldSelection );
622 QgsFeatureIterator features =
getFeatures( request );
627 bool matches = exp.
evaluate( context ).toBool();
631 newSelection << feat.
id();
635 newSelection << feat.
id();
656 newSelection = mSelectedFeatureIds + ids;
660 newSelection = mSelectedFeatureIds - ids;
664 newSelection = mSelectedFeatureIds.intersect( ids );
668 QgsFeatureIds deselectedFeatures = mSelectedFeatureIds - newSelection;
669 mSelectedFeatureIds = newSelection;
670 mPreviousSelectedFeatureIds.clear();
680 if ( !intersectingIds.isEmpty() )
682 QgsDebugMsgLevel( u
"Trying to select and deselect the same item at the same time. Unsure what to do. Selecting dubious items."_s, 3 );
685 mSelectedFeatureIds -= deselectIds;
686 mSelectedFeatureIds += selectIds;
687 mPreviousSelectedFeatureIds.clear();
697 ids.subtract( mSelectedFeatureIds );
716 .setFilterRect( rect )
718 .setNoAttributes() );
726 if ( mSelectedFeatureIds.contains( fet.
id() ) )
728 deselectIds << fet.
id();
732 selectIds << fet.
id();
743 if ( mSelectedFeatureIds.isEmpty() )
748 mPreviousSelectedFeatureIds = previous;
755 if ( mPreviousSelectedFeatureIds.isEmpty() || !mSelectedFeatureIds.empty() )
766 return mDataProvider;
774 return mDataProvider;
782 return mSelectionProperties;
789 return mTemporalProperties;
796 return mElevationProperties;
812 if (
isValid() && mDataProvider && mDataProvider->encoding() != encoding )
814 mDataProvider->setEncoding( encoding );
823 delete mDiagramRenderer;
824 mDiagramRenderer = r;
848 if ( !
isValid() || !
isSpatial() || mSelectedFeatureIds.isEmpty() || !mDataProvider )
860 .setFilterFids( mSelectedFeatureIds )
861 .setNoAttributes() );
874 .setNoAttributes() );
878 if ( mSelectedFeatureIds.contains( fet.
id() ) )
889 if ( retval.
width() == 0.0 || retval.
height() == 0.0 )
898 retval.
set( -1.0, -1.0, 1.0, 1.0 );
910 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
917 mLabelsEnabled = enabled;
925 if ( !mDiagramRenderer || !mDiagramLayerSettings )
928 QList<QgsDiagramSettings> settingList = mDiagramRenderer->diagramSettings();
929 if ( !settingList.isEmpty() )
931 return settingList.at( 0 ).enabled;
940 if ( !mSymbolFeatureCounted )
943 return mSymbolFeatureCountMap.value( legendKey, -1 );
950 if ( !mSymbolFeatureCounted )
953 return mSymbolFeatureIdMap.value( legendKey,
QgsFeatureIds() );
959 if ( ( mSymbolFeatureCounted || mFeatureCounter ) && !( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
960 return mFeatureCounter;
962 mSymbolFeatureCountMap.clear();
963 mSymbolFeatureIdMap.clear();
968 return mFeatureCounter;
970 if ( !mDataProvider )
973 return mFeatureCounter;
978 return mFeatureCounter;
981 if ( !mFeatureCounter || ( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
984 connect( mFeatureCounter, &
QgsTask::taskCompleted,
this, &QgsVectorLayer::onFeatureCounterCompleted, Qt::UniqueConnection );
985 connect( mFeatureCounter, &
QgsTask::taskTerminated,
this, &QgsVectorLayer::onFeatureCounterTerminated, Qt::UniqueConnection );
989 return mFeatureCounter;
997 if ( force || !mReadExtentFromXml || ( mReadExtentFromXml && mXmlExtent2D.isNull() && mXmlExtent3D.isNull() ) )
999 mValidExtent2D =
false;
1000 mValidExtent3D =
false;
1009 mValidExtent2D =
true;
1017 mValidExtent3D =
true;
1024 if ( !mDefaultValueOnUpdateFields.isEmpty() )
1029 int size = mFields.
size();
1030 for (
int idx : std::as_const( mDefaultValueOnUpdateFields ) )
1032 if ( idx < 0 || idx >= size )
1052 mLazyExtent2D =
false;
1059 updateExtent( mDataProvider->extent() );
1060 mValidExtent2D =
true;
1061 mLazyExtent2D =
false;
1065 if ( !mValidExtent2D && mLazyExtent2D && mReadExtentFromXml && !mXmlExtent2D.isNull() )
1067 updateExtent( mXmlExtent2D );
1068 mValidExtent2D =
true;
1069 mLazyExtent2D =
false;
1072 if ( !mValidExtent2D && mLazyExtent2D && mDataProvider && mDataProvider->isValid() )
1075 updateExtent( mDataProvider->extent() );
1076 mValidExtent2D =
true;
1077 mLazyExtent2D =
false;
1080 QgsDebugMsgLevel( u
"2D Extent of layer: %1"_s.arg( mExtent2D.toString() ), 3 );
1084 if ( mValidExtent2D )
1087 if ( !
isValid() || !mDataProvider )
1089 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1093 if ( !mEditBuffer ||
1094 ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) ) ||
1097 mDataProvider->updateExtents();
1101 if ( mDataProvider->featureCount() != 0 )
1107 if ( mEditBuffer && !mDataProvider->transaction() )
1109 const auto addedFeatures = mEditBuffer->addedFeatures();
1110 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1112 if ( it->hasGeometry() )
1123 .setNoAttributes() );
1136 if ( rect.xMinimum() > rect.xMaximum() && rect.yMinimum() > rect.yMaximum() )
1142 updateExtent( rect );
1143 mValidExtent2D =
true;
1156 if ( mDataProvider && mDataProvider->elevationProperties() && !mDataProvider->elevationProperties()->containsElevationData() )
1172 updateExtent( mDataProvider->extent3D() );
1173 mValidExtent3D =
true;
1174 mLazyExtent3D =
false;
1178 if ( !mValidExtent3D && mLazyExtent3D && mReadExtentFromXml && !mXmlExtent3D.isNull() )
1180 updateExtent( mXmlExtent3D );
1181 mValidExtent3D =
true;
1182 mLazyExtent3D =
false;
1185 if ( !mValidExtent3D && mLazyExtent3D && mDataProvider && mDataProvider->isValid() )
1188 updateExtent( mDataProvider->extent3D() );
1189 mValidExtent3D =
true;
1190 mLazyExtent3D =
false;
1193 QgsDebugMsgLevel( u
"3D Extent of layer: %1"_s.arg( mExtent3D.toString() ), 3 );
1197 if ( mValidExtent3D )
1200 if ( !
isValid() || !mDataProvider )
1202 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1206 if ( !mEditBuffer ||
1207 ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) ) ||
1210 mDataProvider->updateExtents();
1214 if ( mDataProvider->featureCount() != 0 )
1216 const QgsBox3D ext = mDataProvider->extent3D();
1217 extent.combineWith( ext );
1220 if ( mEditBuffer && !mDataProvider->transaction() )
1222 const auto addedFeatures = mEditBuffer->addedFeatures();
1223 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1225 if ( it->hasGeometry() )
1227 const QgsBox3D bbox = it->geometry().boundingBox3D();
1228 extent.combineWith( bbox );
1236 .setNoAttributes() );
1244 extent.combineWith( bb );
1256 mValidExtent3D =
true;
1282 if ( !
isValid() || !mDataProvider )
1284 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1287 return mDataProvider->subsetString();
1294 if ( !
isValid() || !mDataProvider )
1296 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider or while editing"_s, 3 );
1300 else if ( mEditBuffer )
1306 if ( subset == mDataProvider->subsetString() )
1309 bool res = mDataProvider->setSubsetString( subset );
1332 double maximumSimplificationScale = mSimplifyMethod.maximumScale();
1335 return !( maximumSimplificationScale > 1 && renderContext.
rendererScale() <= maximumSimplificationScale );
1344 return mConditionalStyles;
1352 if ( !
isValid() || !mDataProvider )
1364 if ( feature.isValid() )
1365 return feature.geometry();
1374 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1378 if ( mGeometryOptions->isActive() )
1381 mGeometryOptions->apply( geom );
1385 bool success = mEditBuffer->addFeature( feature );
1387 if ( success && mJoinBuffer->containsJoins() )
1389 success = mJoinBuffer->addFeature( feature );
1399 if ( !mEditBuffer || !mDataProvider )
1405 if ( currentFeature.
isValid() )
1407 bool hasChanged =
false;
1408 bool hasError =
false;
1420 QgsDebugMsgLevel( u
"geometry of feature %1 could not be changed."_s.arg( updatedFeature.
id() ), 3 );
1427 for (
int attr = 0; attr < fa.count(); ++attr )
1437 QgsDebugMsgLevel( u
"attribute %1 of feature %2 could not be changed."_s.arg( attr ).arg( updatedFeature.
id() ), 3 );
1442 if ( hasChanged && !mDefaultValueOnUpdateFields.isEmpty() && !skipDefaultValues )
1443 updateDefaultValues( updatedFeature.
id(), updatedFeature );
1449 QgsDebugMsgLevel( u
"feature %1 could not be retrieved"_s.arg( updatedFeature.
id() ), 3 );
1459 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1463 bool result = utils.
insertVertex( x, y, atFeatureId, beforeVertex );
1474 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1478 bool result = utils.
insertVertex( point, atFeatureId, beforeVertex );
1489 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1493 bool result = utils.
moveVertex( x, y, atFeatureId, atVertex );
1504 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1508 bool result = utils.
moveVertex( p, atFeatureId, atVertex );
1519 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1546 int count = mSelectedFeatureIds.size();
1559 *deletedCount = deleted;
1562 return deleted == count;
1565static const QgsPointSequence vectorPointXY2pointSequence(
const QVector<QgsPointXY> &points )
1568 pts.reserve( points.size() );
1569 QVector<QgsPointXY>::const_iterator it = points.constBegin();
1570 while ( it != points.constEnd() )
1581 return addRing( vectorPointXY2pointSequence( ring ), featureId );
1588 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1595 if ( !mSelectedFeatureIds.isEmpty() )
1597 result = utils.
addRing( ring, mSelectedFeatureIds, featureId );
1613 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1634 if ( !mSelectedFeatureIds.isEmpty() )
1636 result = utils.
addRing(
static_cast< QgsCurve *
>( ring->
clone() ), mSelectedFeatureIds, featureId );
1654 pts.reserve( points.size() );
1655 for ( QList<QgsPointXY>::const_iterator it = points.constBegin(); it != points.constEnd() ; ++it )
1666 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1671 if ( mSelectedFeatureIds.empty() )
1676 else if ( mSelectedFeatureIds.size() > 1 )
1694 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1699 if ( mSelectedFeatureIds.empty() )
1704 else if ( mSelectedFeatureIds.size() > 1 )
1723 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1738 return splitParts( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1745 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1749 return utils.
splitParts( splitLine, topologicalEditing );
1756 return splitFeatures( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1765 bool preserveCircular =
false;
1766 return splitFeatures( &splitLineString, topologyTestPoints, preserveCircular, topologicalEditing );
1773 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1777 return utils.
splitFeatures( curve, topologyTestPoints, preserveCircular, topologicalEditing );
1784 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1802 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1813 if ( !
mValid || !mEditBuffer || !mDataProvider )
1838 if ( !
isValid() || !mDataProvider )
1855 mDataProvider->enterUpdateMode();
1872 if ( mDataProvider )
1888 if ( !mRenderer->accept( visitor ) )
1892 if ( !mLabeling->accept( visitor ) )
1904 const QList<QgsAction>
actions = mActions->actions();
1907 if ( action.command().isEmpty() )
1912 switch ( action.type() )
1939 switch ( mEditFormConfig.initCodeSource() )
1943 initCode = u
"# Calling function ’%1’\n\n%2"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initCode() );
1950 if ( inputFile && inputFile->open( QFile::ReadOnly ) )
1953 QTextStream inf( inputFile );
1954 initCode = inf.readAll();
1956 initCode = u
"# Calling function ’%1’\n# From file %2\n\n"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initFilePath() ) + initCode;
1963 initCode = u
"# Calling function ’%1’\n# From environment\n\n"_s.arg( mEditFormConfig.initFunction() );
1973 if ( !initCode.isEmpty() )
1992 QDomNode pkeyNode = layer_node.namedItem( u
"provider"_s );
1994 if ( pkeyNode.isNull() )
2000 QDomElement pkeyElt = pkeyNode.toElement();
2019 const QDomElement elem = layer_node.toElement();
2033 if ( elem.hasAttribute( u
"wkbType"_s ) )
2037 QDomElement pkeyElem = pkeyNode.toElement();
2038 if ( !pkeyElem.isNull() )
2040 QString encodingString = pkeyElem.attribute( u
"encoding"_s );
2041 if ( mDataProvider && !encodingString.isEmpty() )
2043 mDataProvider->setEncoding( encodingString );
2048 mJoinBuffer->readXml( layer_node );
2053 mSetLegendFromStyle =
false;
2063 QDomNode depsNode = layer_node.namedItem( u
"dataDependencies"_s );
2064 QDomNodeList depsNodes = depsNode.childNodes();
2065 QSet<QgsMapLayerDependency> sources;
2066 for (
int i = 0; i < depsNodes.count(); i++ )
2068 QString
source = depsNodes.at( i ).toElement().attribute( u
"id"_s );
2073 if ( !mSetLegendFromStyle )
2079 mReadExtentFromXml =
true;
2081 if ( mReadExtentFromXml )
2083 const QDomNode extentNode = layer_node.namedItem( u
"extent"_s );
2084 if ( !extentNode.isNull() )
2088 const QDomNode extent3DNode = layer_node.namedItem( u
"extent3D"_s );
2089 if ( !extent3DNode.isNull() )
2096 const QDomNode asNode = layer_node.namedItem( u
"auxiliaryLayer"_s );
2097 const QDomElement asElem = asNode.toElement();
2098 if ( !asElem.isNull() )
2100 mAuxiliaryLayerKey = asElem.attribute( u
"key"_s );
2104 mServerProperties->readXml( layer_node );
2111void QgsVectorLayer::setDataSourcePrivate(
const QString &dataSource,
const QString &baseName,
const QString &provider,
2120 setDataProvider( provider, options,
flags );
2130 bool loadDefaultStyleFlag =
false;
2133 loadDefaultStyleFlag =
true;
2139 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2141 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Load layer style" ), u
"projectload"_s );
2143 bool defaultLoadedFlag =
false;
2151 mSetLegendFromStyle =
false;
2156 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
2164 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2165 if ( defaultRenderer )
2167 defaultLoadedFlag =
true;
2173 if ( !defaultLoadedFlag )
2179 if ( !mSetLegendFromStyle )
2184 std::unique_ptr< QgsAbstractVectorLayerLabeling > defaultLabeling( mDataProvider->createLabeling() );
2185 if ( defaultLabeling )
2192 styleChangedSignalBlocker.release();
2209 QStringList ids, names, descriptions;
2210 QString errorMessage;
2212 const int relatedStylesCount {
listStylesInDatabase( ids, names, descriptions, errorMessage ) };
2213 Q_ASSERT( ids.count() == names.count() );
2214 const QString currentStyleName { mStyleManager->currentStyle() };
2215 for (
int i = 0; i < relatedStylesCount; ++i )
2217 if ( names.at( i ) == currentStyleName )
2221 errorMessage.clear();
2223 if ( ! styleXml.isEmpty() && errorMessage.isEmpty() )
2229 QgsDebugMsgLevel( u
"Error retrieving style %1 from DB: %2"_s.arg( ids.at( i ), errorMessage ), 2 );
2239 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2240 if ( defaultRenderer )
2256 delete mDataProvider;
2263 if ( provider.compare(
"postgres"_L1 ) == 0 )
2265 const QString checkUnicityKey { u
"checkPrimaryKeyUnicity"_s };
2267 if ( ! uri.hasParam( checkUnicityKey ) )
2269 uri.setParam( checkUnicityKey, mReadExtentFromXml ?
"0" :
"1" );
2274 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2276 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), u
"projectload"_s );
2279 mDataProvider = qobject_cast< QgsVectorDataProvider * >(
mPreloadedProvider.release() );
2283 if ( !mDataProvider )
2290 mDataProvider->setParent(
this );
2295 setValid( mDataProvider->isValid() );
2303 profile->switchTask( tr(
"Read layer metadata" ) );
2308 QgsLayerMetadata newMetadata = mDataProvider->layerMetadata();
2310 newMetadata.
combine( &mMetadata );
2320 mWkbType = mDataProvider->wkbType();
2324 const QgsFields providerFields = mDataProvider->fields();
2325 for (
const QgsField &field : providerFields )
2328 if ( !field.editorWidgetSetup().isNull() && mFieldWidgetSetups.value( field.name() ).isNull() )
2330 mFieldWidgetSetups[ field.name() ] = field.editorWidgetSetup();
2332 if ( !field.alias().isEmpty() && mAttributeAliasMap.value( field.name() ).isEmpty() )
2334 mAttributeAliasMap[ field.name() ] = field.alias();
2336 if ( !mAttributeSplitPolicy.contains( field.name() ) )
2338 mAttributeSplitPolicy[ field.name() ] = field.splitPolicy();
2340 if ( !mAttributeDuplicatePolicy.contains( field.name() ) )
2342 mAttributeDuplicatePolicy[ field.name() ] = field.duplicatePolicy();
2344 if ( !mAttributeMergePolicy.contains( field.name() ) )
2346 mAttributeMergePolicy[ field.name() ] = field.mergePolicy();
2351 profile->switchTask( tr(
"Read layer fields" ) );
2357 mDataSource = mDataProvider->dataSourceUri(
false );
2362 const thread_local QRegularExpression reg( R
"lit("[^"]+"\."([^"] + )"( \([^)]+\))?)lit" );
2363 const QRegularExpressionMatch match = reg.match(
name() );
2364 if ( match.hasMatch() )
2366 QStringList stuff = match.capturedTexts();
2367 QString lName = stuff[1];
2371 QMap<QString, QgsMapLayer *>::const_iterator it;
2372 for ( it = layers.constBegin(); it != layers.constEnd() && ( *it )->name() != lName; ++it )
2375 if ( it != layers.constEnd() && stuff.size() > 2 )
2377 lName +=
'.' + stuff[2].mid( 2, stuff[2].length() - 3 );
2380 if ( !lName.isEmpty() )
2390 else if ( provider ==
"ogr"_L1 )
2397 else if ( provider ==
"memory"_L1 )
2402 else if ( provider ==
"hana"_L1 )
2405 mDataSource = mDataProvider->dataSourceUri(
false );
2419 QDomDocument &document,
2426 QDomElement mapLayerNode = layer_node.toElement();
2428 if ( mapLayerNode.isNull() || (
"maplayer" != mapLayerNode.nodeName() ) )
2441 if ( mDataProvider )
2443 QDomElement provider = document.createElement( u
"provider"_s );
2444 provider.setAttribute( u
"encoding"_s, mDataProvider->encoding() );
2445 QDomText providerText = document.createTextNode(
providerType() );
2446 provider.appendChild( providerText );
2447 layer_node.appendChild( provider );
2451 mJoinBuffer->writeXml( layer_node, document );
2454 QDomElement dependenciesElement = document.createElement( u
"layerDependencies"_s );
2460 QDomElement depElem = document.createElement( u
"layer"_s );
2461 depElem.setAttribute( u
"id"_s, dep.layerId() );
2462 dependenciesElement.appendChild( depElem );
2464 layer_node.appendChild( dependenciesElement );
2467 QDomElement dataDependenciesElement = document.createElement( u
"dataDependencies"_s );
2472 QDomElement depElem = document.createElement( u
"layer"_s );
2473 depElem.setAttribute( u
"id"_s, dep.layerId() );
2474 dataDependenciesElement.appendChild( depElem );
2476 layer_node.appendChild( dataDependenciesElement );
2479 mExpressionFieldBuffer->writeXml( layer_node, document );
2484 QDomElement asElem = document.createElement( u
"auxiliaryLayer"_s );
2485 if ( mAuxiliaryLayer )
2487 const QString pkField = mAuxiliaryLayer->joinInfo().targetFieldName();
2488 asElem.setAttribute( u
"key"_s, pkField );
2490 layer_node.appendChild( asElem );
2494 return writeSymbology( layer_node, document, errorMsg, context );
2524 mJoinBuffer->resolveReferences(
project );
2533 if ( categories.testFlag(
Fields ) )
2535 if ( !mExpressionFieldBuffer )
2537 mExpressionFieldBuffer->readXml( layerNode );
2547 QDomNodeList referencedLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencedLayers"_s );
2548 if ( referencedLayersNodeList.size() > 0 )
2550 const QDomNodeList relationNodes { referencedLayersNodeList.at( 0 ).childNodes() };
2551 for (
int i = 0; i < relationNodes.length(); ++i )
2553 const QDomElement relationElement = relationNodes.at( i ).toElement();
2560 QDomNodeList referencingLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencingLayers"_s );
2561 if ( referencingLayersNodeList.size() > 0 )
2563 const QDomNodeList relationNodes { referencingLayersNodeList.at( 0 ).childNodes() };
2564 for (
int i = 0; i < relationNodes.length(); ++i )
2566 const QDomElement relationElement = relationNodes.at( i ).toElement();
2572 QDomElement layerElement = layerNode.toElement();
2576 readStyle( layerNode, errorMessage, context, categories );
2578 if ( categories.testFlag(
MapTips ) )
2580 QDomElement mapTipElem = layerNode.namedItem( u
"mapTip"_s ).toElement();
2586 mDisplayExpression = layerNode.namedItem( u
"previewExpression"_s ).toElement().text();
2589 QString
displayField = layerNode.namedItem( u
"displayfield"_s ).toElement().text();
2593 if ( mMapTipTemplate.isEmpty() && categories.testFlag(
MapTips ) )
2603 if ( categories.testFlag(
Actions ) )
2604 mActions->readXml( layerNode, context );
2606 if ( categories.testFlag(
Fields ) )
2611 QDomNode aliasesNode = layerNode.namedItem( u
"aliases"_s );
2612 if ( !aliasesNode.isNull() )
2614 QDomElement aliasElem;
2616 QDomNodeList aliasNodeList = aliasesNode.toElement().elementsByTagName( u
"alias"_s );
2617 for (
int i = 0; i < aliasNodeList.size(); ++i )
2619 aliasElem = aliasNodeList.at( i ).toElement();
2622 if ( aliasElem.hasAttribute( u
"field"_s ) )
2624 field = aliasElem.attribute( u
"field"_s );
2628 int index = aliasElem.attribute( u
"index"_s ).toInt();
2630 if ( index >= 0 && index <
fields().count() )
2636 if ( !aliasElem.attribute( u
"name"_s ).isEmpty() )
2639 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), aliasElem.attribute( u
"name"_s ) );
2640 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + aliasElem.attribute( u
"name"_s ), 3 );
2645 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), field );
2646 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + field, 3 );
2648 if ( alias == aliasElem.attribute( u
"field"_s ) )
2652 QgsDebugMsgLevel(
"field " + field +
" origalias " + aliasElem.attribute( u
"name"_s ) +
" trans " + alias, 3 );
2653 mAttributeAliasMap.insert( field, alias );
2660 const QDomNode splitPoliciesNode = layerNode.namedItem( u
"splitPolicies"_s );
2661 if ( !splitPoliciesNode.isNull() )
2663 const QDomNodeList splitPolicyNodeList = splitPoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2664 for (
int i = 0; i < splitPolicyNodeList.size(); ++i )
2666 const QDomElement splitPolicyElem = splitPolicyNodeList.at( i ).toElement();
2667 const QString field = splitPolicyElem.attribute( u
"field"_s );
2669 mAttributeSplitPolicy.insert( field, policy );
2674 mAttributeDuplicatePolicy.clear();
2675 const QDomNode duplicatePoliciesNode = layerNode.namedItem( u
"duplicatePolicies"_s );
2676 if ( !duplicatePoliciesNode.isNull() )
2678 const QDomNodeList duplicatePolicyNodeList = duplicatePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2679 for (
int i = 0; i < duplicatePolicyNodeList.size(); ++i )
2681 const QDomElement duplicatePolicyElem = duplicatePolicyNodeList.at( i ).toElement();
2682 const QString field = duplicatePolicyElem.attribute( u
"field"_s );
2684 mAttributeDuplicatePolicy.insert( field, policy );
2688 const QDomNode mergePoliciesNode = layerNode.namedItem( u
"mergePolicies"_s );
2689 if ( !mergePoliciesNode.isNull() )
2691 const QDomNodeList mergePolicyNodeList = mergePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2692 for (
int i = 0; i < mergePolicyNodeList.size(); ++i )
2694 const QDomElement mergePolicyElem = mergePolicyNodeList.at( i ).toElement();
2695 const QString field = mergePolicyElem.attribute( u
"field"_s );
2697 mAttributeMergePolicy.insert( field, policy );
2702 mDefaultExpressionMap.clear();
2703 QDomNode defaultsNode = layerNode.namedItem( u
"defaults"_s );
2704 if ( !defaultsNode.isNull() )
2706 QDomNodeList defaultNodeList = defaultsNode.toElement().elementsByTagName( u
"default"_s );
2707 for (
int i = 0; i < defaultNodeList.size(); ++i )
2709 QDomElement defaultElem = defaultNodeList.at( i ).toElement();
2711 QString field = defaultElem.attribute( u
"field"_s, QString() );
2712 QString expression = defaultElem.attribute( u
"expression"_s, QString() );
2713 bool applyOnUpdate = defaultElem.attribute( u
"applyOnUpdate"_s, u
"0"_s ) ==
"1"_L1;
2714 if ( field.isEmpty() || expression.isEmpty() )
2717 mDefaultExpressionMap.insert( field,
QgsDefaultValue( expression, applyOnUpdate ) );
2722 mFieldConstraints.clear();
2723 mFieldConstraintStrength.clear();
2724 QDomNode constraintsNode = layerNode.namedItem( u
"constraints"_s );
2725 if ( !constraintsNode.isNull() )
2727 QDomNodeList constraintNodeList = constraintsNode.toElement().elementsByTagName( u
"constraint"_s );
2728 for (
int i = 0; i < constraintNodeList.size(); ++i )
2730 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2732 QString field = constraintElem.attribute( u
"field"_s, QString() );
2733 int constraints = constraintElem.attribute( u
"constraints"_s, u
"0"_s ).toInt();
2734 if ( field.isEmpty() || constraints == 0 )
2739 int uniqueStrength = constraintElem.attribute( u
"unique_strength"_s, u
"1"_s ).toInt();
2740 int notNullStrength = constraintElem.attribute( u
"notnull_strength"_s, u
"1"_s ).toInt();
2741 int expStrength = constraintElem.attribute( u
"exp_strength"_s, u
"1"_s ).toInt();
2748 mFieldConstraintExpressions.clear();
2749 QDomNode constraintExpressionsNode = layerNode.namedItem( u
"constraintExpressions"_s );
2750 if ( !constraintExpressionsNode.isNull() )
2752 QDomNodeList constraintNodeList = constraintExpressionsNode.toElement().elementsByTagName( u
"constraint"_s );
2753 for (
int i = 0; i < constraintNodeList.size(); ++i )
2755 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2757 QString field = constraintElem.attribute( u
"field"_s, QString() );
2758 QString exp = constraintElem.attribute( u
"exp"_s, QString() );
2759 QString desc = context.
projectTranslator()->
translate( u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), constraintElem.attribute( u
"desc"_s, QString() ) );
2760 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + constraintElem.attribute( u
"desc"_s, QString() ), 3 );
2761 if ( field.isEmpty() || exp.isEmpty() )
2764 mFieldConstraintExpressions.insert( field, qMakePair( exp, desc ) );
2772 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2776 QDomElement widgetsElem = layerNode.namedItem( u
"fieldConfiguration"_s ).toElement();
2777 QDomNodeList fieldConfigurationElementList = widgetsElem.elementsByTagName( u
"field"_s );
2778 for (
int i = 0; i < fieldConfigurationElementList.size(); ++i )
2780 const QDomElement fieldConfigElement = fieldConfigurationElementList.at( i ).toElement();
2781 const QDomElement fieldWidgetElement = fieldConfigElement.elementsByTagName( u
"editWidget"_s ).at( 0 ).toElement();
2783 QString fieldName = fieldConfigElement.attribute( u
"name"_s );
2785 if ( categories.testFlag(
Fields ) )
2789 if ( categories.testFlag(
Forms ) )
2791 const QString widgetType = fieldWidgetElement.attribute( u
"type"_s );
2792 const QDomElement cfgElem = fieldConfigElement.elementsByTagName( u
"config"_s ).at( 0 ).toElement();
2793 const QDomElement optionsElem = cfgElem.childNodes().at( 0 ).toElement();
2796 if ( widgetType ==
"ValueRelation"_L1 )
2798 optionsMap[ u
"Value"_s ] = context.
projectTranslator()->
translate( u
"project:layers:%1:fields:%2:valuerelationvalue"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), optionsMap[ u
"Value"_s ].toString() );
2799 optionsMap[ u
"Description"_s ] = context.
projectTranslator()->
translate( u
"project:layers:%1:fields:%2:valuerelationdescription"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), optionsMap[ u
"Description"_s ].toString() );
2801 if ( widgetType ==
"ValueMap"_L1 )
2803 if ( optionsMap[ u
"map"_s ].canConvert<QList<QVariant>>() )
2805 QList<QVariant> translatedValueList;
2806 const QList<QVariant> valueList = optionsMap[ u
"map"_s].toList();
2807 for (
int i = 0, row = 0; i < valueList.count(); i++, row++ )
2809 QMap<QString, QVariant> translatedValueMap;
2810 QString translatedKey = context.
projectTranslator()->
translate( u
"project:layers:%1:fields:%2:valuemapdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), valueList[i].toMap().constBegin().key() );
2811 translatedValueMap.insert( translatedKey, valueList[i].toMap().constBegin().value() );
2812 translatedValueList.append( translatedValueMap );
2814 optionsMap.insert( u
"map"_s, translatedValueList );
2818 mFieldWidgetSetups[fieldName] = setup;
2825 if ( categories.testFlag(
Fields ) )
2827 const QList<QPair<QString, Qgis::FieldConfigurationFlag>> legacyConfig
2832 for (
const auto &config : legacyConfig )
2834 QDomNode excludeNode = layerNode.namedItem( config.first );
2835 if ( !excludeNode.isNull() )
2837 QDomNodeList attributeNodeList = excludeNode.toElement().elementsByTagName( u
"attribute"_s );
2838 for (
int i = 0; i < attributeNodeList.size(); ++i )
2840 QString fieldName = attributeNodeList.at( i ).toElement().text();
2841 if ( !mFieldConfigurationFlags.contains( fieldName ) )
2842 mFieldConfigurationFlags[fieldName] = config.second;
2844 mFieldConfigurationFlags[fieldName].setFlag( config.second,
true );
2851 mGeometryOptions->readXml( layerNode.namedItem( u
"geometryOptions"_s ) );
2853 if ( categories.testFlag(
Forms ) )
2854 mEditFormConfig.readXml( layerNode, context );
2858 mAttributeTableConfig.readXml( layerNode );
2859 mConditionalStyles->readXml( layerNode, context );
2860 mStoredExpressionManager->readXml( layerNode );
2866 QDomElement mapLayerNode = layerNode.toElement();
2868 && mapLayerNode.attribute( u
"readOnly"_s, u
"0"_s ).toInt() == 1 )
2873 if ( categories.testFlag(
Legend ) )
2877 const QDomElement legendElem = layerNode.firstChildElement( u
"legend"_s );
2878 if ( !legendElem.isNull() )
2881 legend->readXml( legendElem, context );
2883 mSetLegendFromStyle =
true;
2913 if ( !rendererElement.isNull() )
2931 if ( mSelectionProperties )
2932 mSelectionProperties->readXml( node.toElement(), context );
2936 if ( categories.testFlag(
Labeling ) )
2940 QDomElement labelingElement = node.firstChildElement( u
"labeling"_s );
2942 if ( labelingElement.isNull() ||
2943 ( labelingElement.attribute( u
"type"_s ) ==
"simple"_L1 && labelingElement.firstChildElement( u
"settings"_s ).isNull() ) )
2951 labeling = readLabelingFromCustomProperties();
2959 if ( node.toElement().hasAttribute( u
"labelsEnabled"_s ) )
2960 mLabelsEnabled = node.toElement().attribute( u
"labelsEnabled"_s ).toInt();
2962 mLabelsEnabled =
true;
2968 QDomNode blendModeNode = node.namedItem( u
"blendMode"_s );
2969 if ( !blendModeNode.isNull() )
2971 QDomElement e = blendModeNode.toElement();
2976 QDomNode featureBlendModeNode = node.namedItem( u
"featureBlendMode"_s );
2977 if ( !featureBlendModeNode.isNull() )
2979 QDomElement e = featureBlendModeNode.toElement();
2987 QDomNode layerTransparencyNode = node.namedItem( u
"layerTransparency"_s );
2988 if ( !layerTransparencyNode.isNull() )
2990 QDomElement e = layerTransparencyNode.toElement();
2991 setOpacity( 1.0 - e.text().toInt() / 100.0 );
2993 QDomNode layerOpacityNode = node.namedItem( u
"layerOpacity"_s );
2994 if ( !layerOpacityNode.isNull() )
2996 QDomElement e = layerOpacityNode.toElement();
3000 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( u
"hasScaleBasedVisibilityFlag"_s ).nodeValue() ==
'1' };
3003 const double maxScale { node.attributes().namedItem( u
"maxScale"_s ).nodeValue().toDouble( &ok ) };
3008 const double minScale { node.attributes().namedItem( u
"minScale"_s ).nodeValue().toDouble( &ok ) };
3014 QDomElement e = node.toElement();
3019 mSimplifyMethod.setThreshold( e.attribute( u
"simplifyDrawingTol"_s, u
"1"_s ).toFloat() );
3020 mSimplifyMethod.setForceLocalOptimization( e.attribute( u
"simplifyLocal"_s, u
"1"_s ).toInt() );
3021 mSimplifyMethod.setMaximumScale( e.attribute( u
"simplifyMaxScale"_s, u
"1"_s ).toFloat() );
3024 mRenderer->setReferenceScale( e.attribute( u
"symbologyReferenceScale"_s, u
"-1"_s ).toDouble() );
3028 if ( categories.testFlag(
Diagrams ) )
3032 delete mDiagramRenderer;
3033 mDiagramRenderer =
nullptr;
3034 QDomElement singleCatDiagramElem = node.firstChildElement( u
"SingleCategoryDiagramRenderer"_s );
3035 if ( !singleCatDiagramElem.isNull() )
3038 mDiagramRenderer->readXml( singleCatDiagramElem, context );
3040 QDomElement linearDiagramElem = node.firstChildElement( u
"LinearlyInterpolatedDiagramRenderer"_s );
3041 if ( !linearDiagramElem.isNull() )
3043 if ( linearDiagramElem.hasAttribute( u
"classificationAttribute"_s ) )
3046 int idx = linearDiagramElem.attribute( u
"classificationAttribute"_s ).toInt();
3047 if ( idx >= 0 && idx < mFields.count() )
3048 linearDiagramElem.setAttribute( u
"classificationField"_s, mFields.at( idx ).name() );
3052 mDiagramRenderer->readXml( linearDiagramElem, context );
3054 QDomElement stackedDiagramElem = node.firstChildElement( u
"StackedDiagramRenderer"_s );
3055 if ( !stackedDiagramElem.isNull() )
3058 mDiagramRenderer->readXml( stackedDiagramElem, context );
3061 if ( mDiagramRenderer )
3063 QDomElement diagramSettingsElem = node.firstChildElement( u
"DiagramLayerSettings"_s );
3064 if ( !diagramSettingsElem.isNull() )
3066 bool oldXPos = diagramSettingsElem.hasAttribute( u
"xPosColumn"_s );
3067 bool oldYPos = diagramSettingsElem.hasAttribute( u
"yPosColumn"_s );
3068 bool oldShow = diagramSettingsElem.hasAttribute( u
"showColumn"_s );
3069 if ( oldXPos || oldYPos || oldShow )
3075 int xPosColumn = diagramSettingsElem.attribute( u
"xPosColumn"_s ).toInt();
3076 if ( xPosColumn >= 0 && xPosColumn < mFields.count() )
3081 int yPosColumn = diagramSettingsElem.attribute( u
"yPosColumn"_s ).toInt();
3082 if ( yPosColumn >= 0 && yPosColumn < mFields.count() )
3087 int showColumn = diagramSettingsElem.attribute( u
"showColumn"_s ).toInt();
3088 if ( showColumn >= 0 && showColumn < mFields.count() )
3091 QDomElement propertiesElem = diagramSettingsElem.ownerDocument().createElement( u
"properties"_s );
3098 ddp.
writeXml( propertiesElem, defs );
3099 diagramSettingsElem.appendChild( propertiesElem );
3102 delete mDiagramLayerSettings;
3104 mDiagramLayerSettings->readXml( diagramSettingsElem );
3110 styleChangedSignalBlocker.release();
3122 QDomElement layerElement = node.toElement();
3125 ( void )
writeStyle( node, doc, errorMessage, context, categories );
3128 mGeometryOptions->writeXml( node );
3133 if ( !legendElement.isNull() )
3134 node.appendChild( legendElement );
3143 QDomElement referencedLayersElement = doc.createElement( u
"referencedLayers"_s );
3144 node.appendChild( referencedLayersElement );
3146 const QList<QgsRelation>
referencingRelations { p->relationManager()->referencingRelations(
this ) };
3149 switch ( rel.type() )
3160 QDomElement referencingLayersElement = doc.createElement( u
"referencingLayers"_s );
3161 node.appendChild( referencingLayersElement );
3163 const QList<QgsRelation> referencedRelations { p->relationManager()->referencedRelations(
this ) };
3164 for (
const QgsRelation &rel : referencedRelations )
3166 switch ( rel.type() )
3179 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
3181 QDomElement fieldConfigurationElement;
3183 fieldConfigurationElement = doc.createElement( u
"fieldConfiguration"_s );
3184 node.appendChild( fieldConfigurationElement );
3186 for (
const QgsField &field : std::as_const( mFields ) )
3188 QDomElement fieldElement = doc.createElement( u
"field"_s );
3189 fieldElement.setAttribute( u
"name"_s, field.name() );
3190 fieldConfigurationElement.appendChild( fieldElement );
3192 if ( categories.testFlag(
Fields ) )
3194 fieldElement.setAttribute( u
"configurationFlags"_s,
qgsFlagValueToKeys( field.configurationFlags() ) );
3197 if ( categories.testFlag(
Forms ) )
3202 QDomElement editWidgetElement = doc.createElement( u
"editWidget"_s );
3203 fieldElement.appendChild( editWidgetElement );
3204 editWidgetElement.setAttribute( u
"type"_s, field.editorWidgetSetup().type() );
3205 QDomElement editWidgetConfigElement = doc.createElement( u
"config"_s );
3208 editWidgetElement.appendChild( editWidgetConfigElement );
3214 if ( categories.testFlag(
Fields ) )
3217 QDomElement aliasElem = doc.createElement( u
"aliases"_s );
3218 for (
const QgsField &field : std::as_const( mFields ) )
3220 QDomElement aliasEntryElem = doc.createElement( u
"alias"_s );
3221 aliasEntryElem.setAttribute( u
"field"_s, field.name() );
3222 aliasEntryElem.setAttribute( u
"index"_s, mFields.indexFromName( field.name() ) );
3223 aliasEntryElem.setAttribute( u
"name"_s, field.alias() );
3224 aliasElem.appendChild( aliasEntryElem );
3226 node.appendChild( aliasElem );
3230 QDomElement splitPoliciesElement = doc.createElement( u
"splitPolicies"_s );
3231 bool hasNonDefaultSplitPolicies =
false;
3232 for (
const QgsField &field : std::as_const( mFields ) )
3236 QDomElement splitPolicyElem = doc.createElement( u
"policy"_s );
3237 splitPolicyElem.setAttribute( u
"field"_s, field.name() );
3238 splitPolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.splitPolicy() ) );
3239 splitPoliciesElement.appendChild( splitPolicyElem );
3240 hasNonDefaultSplitPolicies =
true;
3243 if ( hasNonDefaultSplitPolicies )
3244 node.appendChild( splitPoliciesElement );
3249 QDomElement duplicatePoliciesElement = doc.createElement( u
"duplicatePolicies"_s );
3250 bool hasNonDefaultDuplicatePolicies =
false;
3251 for (
const QgsField &field : std::as_const( mFields ) )
3255 QDomElement duplicatePolicyElem = doc.createElement( u
"policy"_s );
3256 duplicatePolicyElem.setAttribute( u
"field"_s, field.name() );
3257 duplicatePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.duplicatePolicy() ) );
3258 duplicatePoliciesElement.appendChild( duplicatePolicyElem );
3259 hasNonDefaultDuplicatePolicies =
true;
3262 if ( hasNonDefaultDuplicatePolicies )
3263 node.appendChild( duplicatePoliciesElement );
3268 QDomElement mergePoliciesElement = doc.createElement( u
"mergePolicies"_s );
3269 bool hasNonDefaultMergePolicies =
false;
3270 for (
const QgsField &field : std::as_const( mFields ) )
3274 QDomElement mergePolicyElem = doc.createElement( u
"policy"_s );
3275 mergePolicyElem.setAttribute( u
"field"_s, field.name() );
3276 mergePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.mergePolicy() ) );
3277 mergePoliciesElement.appendChild( mergePolicyElem );
3278 hasNonDefaultMergePolicies =
true;
3281 if ( hasNonDefaultMergePolicies )
3282 node.appendChild( mergePoliciesElement );
3286 QDomElement defaultsElem = doc.createElement( u
"defaults"_s );
3287 for (
const QgsField &field : std::as_const( mFields ) )
3289 QDomElement defaultElem = doc.createElement( u
"default"_s );
3290 defaultElem.setAttribute( u
"field"_s, field.name() );
3291 defaultElem.setAttribute( u
"expression"_s, field.defaultValueDefinition().expression() );
3292 defaultElem.setAttribute( u
"applyOnUpdate"_s, field.defaultValueDefinition().applyOnUpdate() ? u
"1"_s : u
"0"_s );
3293 defaultsElem.appendChild( defaultElem );
3295 node.appendChild( defaultsElem );
3298 QDomElement constraintsElem = doc.createElement( u
"constraints"_s );
3299 for (
const QgsField &field : std::as_const( mFields ) )
3301 QDomElement constraintElem = doc.createElement( u
"constraint"_s );
3302 constraintElem.setAttribute( u
"field"_s, field.name() );
3303 constraintElem.setAttribute( u
"constraints"_s, field.constraints().constraints() );
3308 constraintsElem.appendChild( constraintElem );
3310 node.appendChild( constraintsElem );
3313 QDomElement constraintExpressionsElem = doc.createElement( u
"constraintExpressions"_s );
3314 for (
const QgsField &field : std::as_const( mFields ) )
3316 QDomElement constraintExpressionElem = doc.createElement( u
"constraint"_s );
3317 constraintExpressionElem.setAttribute( u
"field"_s, field.name() );
3318 constraintExpressionElem.setAttribute( u
"exp"_s, field.constraints().constraintExpression() );
3319 constraintExpressionElem.setAttribute( u
"desc"_s, field.constraints().constraintDescription() );
3320 constraintExpressionsElem.appendChild( constraintExpressionElem );
3322 node.appendChild( constraintExpressionsElem );
3325 if ( !mExpressionFieldBuffer )
3333 mExpressionFieldBuffer->writeXml( node, doc );
3338 if ( categories.testFlag(
Actions ) )
3339 mActions->writeXml( node );
3343 mAttributeTableConfig.writeXml( node );
3344 mConditionalStyles->writeXml( node, doc, context );
3345 mStoredExpressionManager->writeXml( node );
3348 if ( categories.testFlag(
Forms ) )
3349 mEditFormConfig.writeXml( node, context );
3353 node.toElement().setAttribute( u
"readOnly"_s, mReadOnly );
3358 QDomElement prevExpElem = doc.createElement( u
"previewExpression"_s );
3359 QDomText prevExpText = doc.createTextNode( mDisplayExpression );
3360 prevExpElem.appendChild( prevExpText );
3361 node.appendChild( prevExpElem );
3365 if ( categories.testFlag(
MapTips ) )
3367 QDomElement mapTipElem = doc.createElement( u
"mapTip"_s );
3369 QDomText mapTipText = doc.createTextNode( mMapTipTemplate );
3370 mapTipElem.appendChild( mapTipText );
3371 node.toElement().appendChild( mapTipElem );
3382 QDomElement mapLayerNode = node.toElement();
3395 QDomElement rendererElement = mRenderer->save( doc, context );
3396 node.appendChild( rendererElement );
3398 if ( mSelectionProperties )
3400 mSelectionProperties->writeXml( mapLayerNode, doc, context );
3404 if ( categories.testFlag(
Labeling ) )
3408 QDomElement labelingElement = mLabeling->save( doc, context );
3409 node.appendChild( labelingElement );
3411 mapLayerNode.setAttribute( u
"labelsEnabled"_s, mLabelsEnabled ? u
"1"_s : u
"0"_s );
3417 mapLayerNode.setAttribute( u
"simplifyDrawingHints"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyHints() ) ) );
3418 mapLayerNode.setAttribute( u
"simplifyAlgorithm"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyAlgorithm() ) ) );
3419 mapLayerNode.setAttribute( u
"simplifyDrawingTol"_s, QString::number( mSimplifyMethod.threshold() ) );
3420 mapLayerNode.setAttribute( u
"simplifyLocal"_s, mSimplifyMethod.forceLocalOptimization() ? 1 : 0 );
3421 mapLayerNode.setAttribute( u
"simplifyMaxScale"_s, QString::number( mSimplifyMethod.maximumScale() ) );
3433 QDomElement blendModeElem = doc.createElement( u
"blendMode"_s );
3435 blendModeElem.appendChild( blendModeText );
3436 node.appendChild( blendModeElem );
3439 QDomElement featureBlendModeElem = doc.createElement( u
"featureBlendMode"_s );
3441 featureBlendModeElem.appendChild( featureBlendModeText );
3442 node.appendChild( featureBlendModeElem );
3448 QDomElement layerOpacityElem = doc.createElement( u
"layerOpacity"_s );
3449 QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
3450 layerOpacityElem.appendChild( layerOpacityText );
3451 node.appendChild( layerOpacityElem );
3453 mapLayerNode.setAttribute( u
"maxScale"_s,
maximumScale() );
3454 mapLayerNode.setAttribute( u
"minScale"_s,
minimumScale() );
3456 mapLayerNode.setAttribute( u
"symbologyReferenceScale"_s, mRenderer ? mRenderer->referenceScale() : -1 );
3459 if ( categories.testFlag(
Diagrams ) && mDiagramRenderer )
3461 mDiagramRenderer->writeXml( mapLayerNode, doc, context );
3462 if ( mDiagramLayerSettings )
3463 mDiagramLayerSettings->writeXml( mapLayerNode, doc );
3474 QDomElement nameElem = node.firstChildElement( u
"Name"_s );
3475 if ( nameElem.isNull() )
3477 errorMessage = u
"Warning: Name element not found within NamedLayer while it's required."_s;
3493 readSldLabeling( node );
3495 styleChangedSignalBlocker.release();
3505 context.setExtraProperties( props );
3524 QDomElement nameNode = doc.createElement( u
"se:Name"_s );
3525 nameNode.appendChild( doc.createTextNode(
name() ) );
3526 node.appendChild( nameNode );
3528 QDomElement userStyleElem = doc.createElement( u
"UserStyle"_s );
3529 node.appendChild( userStyleElem );
3531 QDomElement nameElem = doc.createElement( u
"se:Name"_s );
3532 nameElem.appendChild( doc.createTextNode(
name() ) );
3534 userStyleElem.appendChild( nameElem );
3536 QDomElement featureTypeStyleElem = doc.createElement( u
"se:FeatureTypeStyle"_s );
3537 userStyleElem.appendChild( featureTypeStyleElem );
3539 mRenderer->toSld( doc, featureTypeStyleElem, context );
3542 mLabeling->toSld( featureTypeStyleElem, context );
3552 if ( !mEditBuffer || !mDataProvider )
3557 if ( mGeometryOptions->isActive() )
3558 mGeometryOptions->apply( geom );
3562 bool result = mEditBuffer->changeGeometry( fid, geom );
3567 if ( !skipDefaultValue && !mDefaultValueOnUpdateFields.isEmpty() )
3568 updateDefaultValues( fid );
3578 bool result =
false;
3580 switch (
fields().fieldOrigin( field ) )
3583 result = mJoinBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3592 if ( mEditBuffer && mDataProvider )
3593 result = mEditBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3601 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3619 for (
auto it = newValues.constBegin(); it != newValues.constEnd(); ++it )
3621 const int field = it.key();
3622 const QVariant newValue = it.value();
3625 if ( oldValues.contains( field ) )
3626 oldValue = oldValues[field];
3628 switch (
fields().fieldOrigin( field ) )
3631 newValuesJoin[field] = newValue;
3632 oldValuesJoin[field] = oldValue;
3639 newValuesNotJoin[field] = newValue;
3640 oldValuesNotJoin[field] = oldValue;
3649 if ( ! newValuesJoin.isEmpty() && mJoinBuffer )
3651 result = mJoinBuffer->changeAttributeValues( fid, newValuesJoin, oldValuesJoin );
3654 if ( ! newValuesNotJoin.isEmpty() )
3656 if ( mEditBuffer && mDataProvider )
3657 result &= mEditBuffer->changeAttributeValues( fid, newValuesNotJoin, oldValues );
3662 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3674 if ( !mEditBuffer || !mDataProvider )
3677 return mEditBuffer->addAttribute( field );
3684 if ( attIndex < 0 || attIndex >=
fields().count() )
3688 mFields[ attIndex ].setAlias( QString() );
3689 if ( mAttributeAliasMap.contains(
name ) )
3691 mAttributeAliasMap.remove(
name );
3693 mEditFormConfig.setFields( mFields );
3702 if ( index < 0 || index >=
fields().count() )
3705 switch ( mFields.fieldOrigin( index ) )
3709 if ( mExpressionFieldBuffer )
3711 int oi = mFields.fieldOriginIndex( index );
3712 mExpressionFieldBuffer->renameExpression( oi, newName );
3725 if ( !mEditBuffer || !mDataProvider )
3728 return mEditBuffer->renameAttribute( index, newName );
3743 if ( attIndex < 0 || attIndex >=
fields().count() )
3748 mAttributeAliasMap.insert(
name, aliasString );
3749 mFields[ attIndex ].setAlias( aliasString );
3750 mEditFormConfig.setFields( mFields );
3758 if ( index < 0 || index >=
fields().count() )
3768 if ( index >= 0 && index < mFields.count() )
3769 return mFields.at( index ).displayName();
3778 return mAttributeAliasMap;
3785 if ( index < 0 || index >=
fields().count() )
3790 mAttributeSplitPolicy.insert(
name, policy );
3791 mFields[ index ].setSplitPolicy( policy );
3792 mEditFormConfig.setFields( mFields );
3800 if ( index < 0 || index >=
fields().count() )
3805 mAttributeDuplicatePolicy.insert(
name, policy );
3806 mFields[ index ].setDuplicatePolicy( policy );
3807 mEditFormConfig.setFields( mFields );
3815 if ( index < 0 || index >=
fields().count() )
3820 mAttributeMergePolicy.insert(
name, policy );
3821 mFields[ index ].setMergePolicy( policy );
3822 mEditFormConfig.setFields( mFields );
3830 QSet<QString> excludeList;
3831 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3832 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3836 excludeList << flagsIt.key();
3846 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3847 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3858 QSet<QString> excludeList;
3859 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3860 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3864 excludeList << flagsIt.key();
3874 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3875 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3886 if ( index < 0 || index >=
fields().count() )
3895 if ( !mEditBuffer || !mDataProvider )
3898 return mEditBuffer->deleteAttribute( index );
3905 bool deleted =
false;
3908 QList<int> attrList = qgis::setToList( qgis::listToSet( attrs ) );
3910 std::sort( attrList.begin(), attrList.end(), std::greater<int>() );
3912 for (
int attr : std::as_const( attrList ) )
3930 if ( context && context->
cascade )
3933 const bool hasRelationsOrJoins = !relations.empty() || mJoinBuffer->
containsJoins();
3934 if ( hasRelationsOrJoins )
3939 if ( handledFeatureIds.contains( fid ) )
3947 handledFeatureIds << fid;
3956 for (
const QgsRelation &relation : relations )
3959 switch ( relation.strength() )
3964 QgsFeatureIterator relatedFeaturesIt = relation.getRelatedFeatures(
getFeature( fid ) );
3966 QgsFeature childFeature;
3967 while ( relatedFeaturesIt.
nextFeature( childFeature ) )
3969 childFeatureIds.insert( childFeature.
id() );
3971 if ( childFeatureIds.count() > 0 )
3973 relation.referencingLayer()->startEditing();
3974 relation.referencingLayer()->deleteFeatures( childFeatureIds, context );
3986 if ( mJoinBuffer->containsJoins() )
3987 mJoinBuffer->deleteFeature( fid, context );
3989 bool res = mEditBuffer->deleteFeature( fid );
4001 return deleteFeatureCascade( fid, context );
4010 if ( ( context && context->
cascade ) || mJoinBuffer->containsJoins() )
4014 res = deleteFeatureCascade( fid, context ) && res;
4018 res = mEditBuffer && mEditBuffer->deleteFeatures( fids );
4023 mSelectedFeatureIds.subtract( fids );
4043 if ( !mDataProvider )
4044 return pkAttributesList;
4047 for (
int i = 0; i < mFields.count(); ++i )
4050 providerIndexes.contains( mFields.fieldOriginIndex( i ) ) )
4051 pkAttributesList << i;
4054 return pkAttributesList;
4061 if ( !mDataProvider )
4063 return mDataProvider->featureCount() +
4064 ( mEditBuffer && ! mDataProvider->transaction() ? mEditBuffer->addedFeatures().size() - mEditBuffer->deletedFeatureIds().size() : 0 );
4071 const QgsFeatureIds deletedFeatures( mEditBuffer && ! mDataProvider->transaction() ? mEditBuffer->deletedFeatureIds() :
QgsFeatureIds() );
4072 const QgsFeatureMap addedFeatures( mEditBuffer && ! mDataProvider->transaction() ? mEditBuffer->addedFeatures() :
QgsFeatureMap() );
4074 if ( mEditBuffer && !deletedFeatures.empty() )
4076 if ( addedFeatures.size() > deletedFeatures.size() )
4082 if ( ( !mEditBuffer || addedFeatures.empty() ) && mDataProvider && mDataProvider->empty() )
4095 mCommitErrors.clear();
4097 if ( !mDataProvider )
4099 mCommitErrors << tr(
"ERROR: no provider" );
4105 mCommitErrors << tr(
"ERROR: layer not editable" );
4111 if ( !mAllowCommit )
4114 mCommitChangesActive =
true;
4116 bool success =
false;
4117 if ( mEditBuffer->editBufferGroup() )
4118 success = mEditBuffer->editBufferGroup()->commitChanges( mCommitErrors, stopEditing );
4120 success = mEditBuffer->commitChanges( mCommitErrors );
4122 mCommitChangesActive =
false;
4124 if ( !mDeletedFids.empty() )
4127 mDeletedFids.clear();
4148 mDataProvider->updateExtents();
4152 mDataProvider->leaveUpdateMode();
4158 if ( mFields.names() != mDataProvider->fields().names() )
4172 return mCommitErrors;
4187 if ( !mDataProvider )
4189 mCommitErrors << tr(
"ERROR: no provider" );
4193 bool rollbackExtent = !mDataProvider->transaction() && ( !mEditBuffer->deletedFeatureIds().isEmpty() ||
4194 !mEditBuffer->addedFeatures().isEmpty() ||
4195 !mEditBuffer->changedGeometries().isEmpty() );
4199 mEditBuffer->rollBack();
4215 mEditBuffer =
nullptr;
4220 if ( rollbackExtent )
4223 mDataProvider->leaveUpdateMode();
4233 return mSelectedFeatureIds.size();
4241 return mSelectedFeatureIds;
4249 features.reserve( mSelectedFeatureIds.count() );
4256 features.push_back( f );
4266 if ( mSelectedFeatureIds.isEmpty() )
4272 if ( mSelectedFeatureIds.count() == 1 )
4273 request.
setFilterFid( *mSelectedFeatureIds.constBegin() );
4284 if ( !mEditBuffer || !mDataProvider )
4287 if ( mGeometryOptions->isActive() )
4289 for (
auto feature = features.begin(); feature != features.end(); ++feature )
4292 mGeometryOptions->apply( geom );
4297 bool res = mEditBuffer->addFeatures( features );
4300 if ( res && mJoinBuffer->containsJoins() )
4301 res = mJoinBuffer->addFeatures( features );
4319 if ( exp.isField() )
4342 if ( !mDisplayExpression.isEmpty() || mFields.isEmpty() )
4344 return mDisplayExpression;
4349 if ( !candidateName.isEmpty() )
4372 return ( mEditBuffer && mDataProvider );
4384bool QgsVectorLayer::isReadOnly()
const
4388 return mDataSourceReadOnly || mReadOnly;
4396 if ( readonly && mEditBuffer )
4400 if ( !readonly && mDataSourceReadOnly )
4403 mReadOnly = readonly;
4412 if ( ! mDataProvider )
4415 if ( mDataSourceReadOnly )
4426 return mEditBuffer && mEditBuffer->isModified();
4433 bool auxiliaryField =
false;
4437 return auxiliaryField;
4444 auxiliaryField =
true;
4447 return auxiliaryField;
4463 if ( r != mRenderer )
4467 mSymbolFeatureCounted =
false;
4468 mSymbolFeatureCountMap.clear();
4469 mSymbolFeatureIdMap.clear();
4474 if ( refreshRate <= 0 )
4476 mRefreshRendererTimer->stop();
4477 mRefreshRendererTimer->setInterval( 0 );
4481 mRefreshRendererTimer->setInterval( 1000 / refreshRate );
4482 mRefreshRendererTimer->start();
4497 mRendererGenerators << generator;
4505 for (
int i = mRendererGenerators.count() - 1; i >= 0; --i )
4507 if ( mRendererGenerators.at( i )->id() ==
id )
4509 delete mRendererGenerators.at( i );
4510 mRendererGenerators.removeAt( i );
4520 QList< const QgsFeatureRendererGenerator * > res;
4530 if ( !mDataProvider )
4534 if ( mDataProvider->transaction() )
4536 QString ignoredError;
4537 mDataProvider->transaction()->createSavepoint( ignoredError );
4540 mEditCommandActive =
true;
4548 if ( !mDataProvider )
4553 mEditCommandActive =
false;
4554 if ( !mDeletedFids.isEmpty() )
4558 mSelectedFeatureIds.subtract( mDeletedFids );
4561 mDeletedFids.clear();
4570 if ( !mDataProvider )
4581 auto command = std::make_unique< QUndoCommand >();
4582 command->setObsolete(
true );
4585 mEditCommandActive =
false;
4586 mDeletedFids.clear();
4594 return mJoinBuffer->addJoin( joinInfo );
4601 return mJoinBuffer->removeJoin( joinLayerId );
4608 return mJoinBuffer->vectorJoins();
4616 mExpressionFieldBuffer->addExpression( exp, fld );
4618 int idx = mFields.indexFromName( fld.
name() );
4628 int oi = mFields.fieldOriginIndex( index );
4629 mExpressionFieldBuffer->removeExpression( oi );
4641 int oi = mFields.fieldOriginIndex( index );
4642 if ( oi < 0 || oi >= mExpressionFieldBuffer->expressions().size() )
4645 return mExpressionFieldBuffer->expressions().at( oi ).cachedExpression.expression();
4652 int oi = mFields.fieldOriginIndex( index );
4653 mExpressionFieldBuffer->updateExpression( oi, exp );
4661 if ( !mDataProvider )
4666 mFields = mDataProvider->fields();
4670 mEditBuffer->updateFields( mFields );
4673 if ( mJoinBuffer->containsJoins() )
4674 mJoinBuffer->updateFields( mFields );
4676 if ( mExpressionFieldBuffer )
4677 mExpressionFieldBuffer->updateFields( mFields );
4680 for (
auto aliasIt = mAttributeAliasMap.constBegin(); aliasIt != mAttributeAliasMap.constEnd(); ++aliasIt )
4682 int index = mFields.lookupField( aliasIt.key() );
4686 mFields[ index ].setAlias( aliasIt.value() );
4689 for (
auto splitPolicyIt = mAttributeSplitPolicy.constBegin(); splitPolicyIt != mAttributeSplitPolicy.constEnd(); ++splitPolicyIt )
4691 int index = mFields.lookupField( splitPolicyIt.key() );
4695 mFields[ index ].setSplitPolicy( splitPolicyIt.value() );
4698 for (
auto duplicatePolicyIt = mAttributeDuplicatePolicy.constBegin(); duplicatePolicyIt != mAttributeDuplicatePolicy.constEnd(); ++duplicatePolicyIt )
4700 int index = mFields.lookupField( duplicatePolicyIt.key() );
4704 mFields[ index ].setDuplicatePolicy( duplicatePolicyIt.value() );
4707 for (
auto mergePolicyIt = mAttributeMergePolicy.constBegin(); mergePolicyIt != mAttributeMergePolicy.constEnd(); ++mergePolicyIt )
4709 int index = mFields.lookupField( mergePolicyIt.key() );
4713 mFields[ index ].setMergePolicy( mergePolicyIt.value() );
4717 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.
constBegin();
4718 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
4720 int index = mFields.lookupField( flagsIt.key() );
4724 mFields[index].setConfigurationFlags( flagsIt.value() );
4728 mDefaultValueOnUpdateFields.clear();
4729 QMap< QString, QgsDefaultValue >::const_iterator defaultIt = mDefaultExpressionMap.constBegin();
4730 for ( ; defaultIt != mDefaultExpressionMap.constEnd(); ++defaultIt )
4732 int index = mFields.lookupField( defaultIt.key() );
4736 mFields[ index ].setDefaultValueDefinition( defaultIt.value() );
4737 if ( defaultIt.value().applyOnUpdate() )
4738 mDefaultValueOnUpdateFields.insert( index );
4741 QMap< QString, QgsFieldConstraints::Constraints >::const_iterator constraintIt = mFieldConstraints.constBegin();
4742 for ( ; constraintIt != mFieldConstraints.constEnd(); ++constraintIt )
4744 int index = mFields.lookupField( constraintIt.key() );
4757 mFields[ index ].setConstraints( constraints );
4760 QMap< QString, QPair< QString, QString > >::const_iterator constraintExpIt = mFieldConstraintExpressions.constBegin();
4761 for ( ; constraintExpIt != mFieldConstraintExpressions.constEnd(); ++constraintExpIt )
4763 int index = mFields.lookupField( constraintExpIt.key() );
4774 mFields[ index ].setConstraints( constraints );
4778 for ( ; constraintStrengthIt != mFieldConstraintStrength.constEnd(); ++constraintStrengthIt )
4780 int index = mFields.lookupField( constraintStrengthIt.key().first );
4790 constraints.
setConstraintStrength( constraintStrengthIt.key().second, constraintStrengthIt.value() );
4791 mFields[ index ].setConstraints( constraints );
4794 auto fieldWidgetIterator = mFieldWidgetSetups.constBegin();
4795 for ( ; fieldWidgetIterator != mFieldWidgetSetups.constEnd(); ++ fieldWidgetIterator )
4797 int index = mFields.indexOf( fieldWidgetIterator.key() );
4801 mFields[index].setEditorWidgetSetup( fieldWidgetIterator.value() );
4804 if ( oldFields != mFields )
4807 mEditFormConfig.setFields( mFields );
4816 if ( index < 0 || index >= mFields.count() || !mDataProvider )
4819 QString expression = mFields.at( index ).defaultValueDefinition().expression();
4820 if ( expression.isEmpty() )
4821 return mDataProvider->defaultValue( index );
4824 std::unique_ptr< QgsExpressionContext > tempContext;
4829 evalContext = tempContext.get();
4864 if ( index < 0 || index >= mFields.count() )
4869 mDefaultExpressionMap.insert( mFields.at( index ).name(), definition );
4873 mDefaultExpressionMap.remove( mFields.at( index ).name() );
4882 if ( index < 0 || index >= mFields.count() )
4885 return mFields.at( index ).defaultValueDefinition();
4893 if ( !mDataProvider )
4906 uniqueValues = mDataProvider->uniqueValues( index, limit );
4908 if ( mEditBuffer && ! mDataProvider->transaction() )
4912 for (
const QVariant &v : constUniqueValues )
4914 vals << v.toString();
4918 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4919 while ( addedIt.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4922 QVariant v = addedIt.value().attribute( index );
4925 QString vs = v.toString();
4926 if ( !vals.contains( vs ) )
4934 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
4935 while ( it.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4938 QVariant v = it.value().value( index );
4941 QString vs = v.toString();
4942 if ( !vals.contains( vs ) )
4956 if ( mDataProvider->transaction() || (
4957 mEditBuffer->deletedFeatureIds().isEmpty() &&
4958 mEditBuffer->addedFeatures().isEmpty() &&
4959 !mEditBuffer->deletedAttributeIds().contains( index ) &&
4960 mEditBuffer->changedAttributeValues().isEmpty() ) )
4962 uniqueValues = mDataProvider->uniqueValues( index, limit );
4975 .setSubsetOfAttributes( attList ) );
4978 QVariant currentValue;
4979 QHash<QString, QVariant> val;
4983 val.insert( currentValue.toString(), currentValue );
4984 if ( limit >= 0 && val.size() >= limit )
4990 return qgis::listToSet( val.values() );
4994 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueValues()",
"Unknown source of the field!" );
5002 QStringList results;
5003 if ( !mDataProvider )
5016 results = mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
5018 if ( mEditBuffer && ! mDataProvider->transaction() )
5021 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5022 while ( addedIt.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
5025 QVariant v = addedIt.value().attribute( index );
5028 QString vs = v.toString();
5029 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
5036 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5037 while ( it.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
5040 QVariant v = it.value().value( index );
5043 QString vs = v.toString();
5044 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
5057 if ( mDataProvider->transaction() || ( mEditBuffer->deletedFeatureIds().isEmpty() &&
5058 mEditBuffer->addedFeatures().isEmpty() &&
5059 !mEditBuffer->deletedAttributeIds().contains( index ) &&
5060 mEditBuffer->changedAttributeValues().isEmpty() ) )
5062 return mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
5075 QString fieldName = mFields.at( index ).name();
5080 QString currentValue;
5083 currentValue = f.
attribute( index ).toString();
5084 if ( !results.contains( currentValue ) )
5085 results << currentValue;
5087 if ( ( limit >= 0 && results.size() >= limit ) || ( feedback && feedback->
isCanceled() ) )
5097 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueStringsMatching()",
"Unknown source of the field!" );
5106 minimumOrMaximumValue( index, &minimum,
nullptr );
5115 minimumOrMaximumValue( index,
nullptr, &maximum );
5123 minimumOrMaximumValue( index, &minimum, &maximum );
5126void QgsVectorLayer::minimumOrMaximumValue(
int index, QVariant *minimum, QVariant *maximum )
const
5131 *minimum = QVariant();
5133 *maximum = QVariant();
5135 if ( !mDataProvider )
5152 *minimum = mDataProvider->minimumValue( index );
5154 *maximum = mDataProvider->maximumValue( index );
5155 if ( mEditBuffer && ! mDataProvider->transaction() )
5158 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5159 while ( addedIt.hasNext() )
5162 const QVariant v = addedIt.value().attribute( index );
5169 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5170 while ( it.hasNext() )
5173 const QVariant v = it.value().value( index );
5186 if ( mDataProvider->transaction() || ( mEditBuffer->deletedFeatureIds().isEmpty() &&
5187 mEditBuffer->addedFeatures().isEmpty() &&
5188 !mEditBuffer->deletedAttributeIds().contains( index ) &&
5189 mEditBuffer->changedAttributeValues().isEmpty() ) )
5192 *minimum = mDataProvider->minimumValue( index );
5194 *maximum = mDataProvider->maximumValue( index );
5207 QgsFeatureIterator fit =
getFeatures( QgsFeatureRequest()
5209 .setSubsetOfAttributes( attList ) );
5212 bool firstValue =
true;
5215 const QVariant currentValue = f.
attribute( index );
5222 *minimum = currentValue;
5224 *maximum = currentValue;
5229 if ( minimum && currentValue.isValid() &&
qgsVariantLessThan( currentValue, *minimum ) )
5230 *minimum = currentValue;
5232 *maximum = currentValue;
5239 Q_ASSERT_X(
false,
"QgsVectorLayer::minimumOrMaximumValue()",
"Unknown source of the field!" );
5242void QgsVectorLayer::createEditBuffer()
5249 if ( mDataProvider->transaction() )
5253 connect( mDataProvider->transaction(), &
QgsTransaction::dirtied,
this, &QgsVectorLayer::onDirtyTransaction, Qt::UniqueConnection );
5278void QgsVectorLayer::clearEditBuffer()
5283 mEditBuffer =
nullptr;
5298 if ( !mDataProvider )
5301 *
error = tr(
"Layer is invalid" );
5307 if ( attrIndex >= 0 )
5314 bool providerOk =
false;
5315 QVariant val = mDataProvider->aggregate(
aggregate, attrIndex, parameters, context, providerOk, fids );
5329 c.setFidsFilter( *fids );
5330 c.setParameters( parameters );
5331 bool aggregateOk =
false;
5332 const QVariant result =
c.calculate(
aggregate, fieldOrExpression, context, &aggregateOk, feedback );
5335 if ( !aggregateOk &&
error )
5358 return mFeatureBlendMode;
5361void QgsVectorLayer::readSldLabeling(
const QDomNode &node )
5368 QDomElement element = node.toElement();
5369 if ( element.isNull() )
5372 QDomElement userStyleElem = element.firstChildElement( u
"UserStyle"_s );
5373 if ( userStyleElem.isNull() )
5379 QDomElement featTypeStyleElem = userStyleElem.firstChildElement( u
"FeatureTypeStyle"_s );
5380 if ( featTypeStyleElem.isNull() )
5387 QDomElement mergedFeatTypeStyle = featTypeStyleElem.cloneNode(
false ).toElement();
5392 bool needRuleBasedLabeling =
false;
5395 while ( !featTypeStyleElem.isNull() )
5397 QDomElement ruleElem = featTypeStyleElem.firstChildElement( u
"Rule"_s );
5398 while ( !ruleElem.isNull() )
5402 bool hasTextSymbolizer =
false;
5403 bool hasRuleBased =
false;
5404 QDomElement ruleChildElem = ruleElem.firstChildElement();
5405 while ( !ruleChildElem.isNull() )
5408 if ( ruleChildElem.localName() ==
"Filter"_L1 ||
5409 ruleChildElem.localName() ==
"MinScaleDenominator"_L1 ||
5410 ruleChildElem.localName() ==
"MaxScaleDenominator"_L1 )
5412 hasRuleBased =
true;
5415 else if ( ruleChildElem.localName() ==
"TextSymbolizer"_L1 )
5418 hasTextSymbolizer =
true;
5421 ruleChildElem = ruleChildElem.nextSiblingElement();
5424 if ( hasTextSymbolizer )
5429 mergedFeatTypeStyle.appendChild( ruleElem.cloneNode().toElement() );
5433 QgsDebugMsgLevel( u
"Info: Filter or Min/MaxScaleDenominator element found: need a RuleBasedLabeling"_s, 4 );
5434 needRuleBasedLabeling =
true;
5439 if ( ruleCount > 1 )
5441 QgsDebugMsgLevel( u
"Info: More Rule elements found: need a RuleBasedLabeling"_s, 4 );
5442 needRuleBasedLabeling =
true;
5446 if ( ruleCount == 0 )
5448 needRuleBasedLabeling =
false;
5451 ruleElem = ruleElem.nextSiblingElement( u
"Rule"_s );
5453 featTypeStyleElem = featTypeStyleElem.nextSiblingElement( u
"FeatureTypeStyle"_s );
5456 if ( ruleCount == 0 )
5462 QDomElement ruleElem = mergedFeatTypeStyle.firstChildElement( u
"Rule"_s );
5464 if ( needRuleBasedLabeling )
5467 QgsRuleBasedLabeling::Rule *rootRule =
new QgsRuleBasedLabeling::Rule(
nullptr );
5468 while ( !ruleElem.isNull() )
5471 QString label, description, filterExp;
5472 int scaleMinDenom = 0, scaleMaxDenom = 0;
5473 QgsPalLayerSettings settings;
5476 QDomElement childElem = ruleElem.firstChildElement();
5477 while ( !childElem.isNull() )
5479 if ( childElem.localName() ==
"Name"_L1 )
5483 if ( label.isEmpty() )
5484 label = childElem.firstChild().nodeValue();
5486 else if ( childElem.localName() ==
"Description"_L1 )
5489 QDomElement titleElem = childElem.firstChildElement( u
"Title"_s );
5490 if ( !titleElem.isNull() )
5492 label = titleElem.firstChild().nodeValue();
5495 QDomElement abstractElem = childElem.firstChildElement( u
"Abstract"_s );
5496 if ( !abstractElem.isNull() )
5498 description = abstractElem.firstChild().nodeValue();
5501 else if ( childElem.localName() ==
"Abstract"_L1 )
5504 description = childElem.firstChild().nodeValue();
5506 else if ( childElem.localName() ==
"Title"_L1 )
5509 label = childElem.firstChild().nodeValue();
5511 else if ( childElem.localName() ==
"Filter"_L1 )
5527 else if ( childElem.localName() ==
"MinScaleDenominator"_L1 )
5530 int v = childElem.firstChild().nodeValue().toInt( &ok );
5534 else if ( childElem.localName() ==
"MaxScaleDenominator"_L1 )
5537 int v = childElem.firstChild().nodeValue().toInt( &ok );
5541 else if ( childElem.localName() ==
"TextSymbolizer"_L1 )
5543 readSldTextSymbolizer( childElem, settings );
5546 childElem = childElem.nextSiblingElement();
5549 QgsRuleBasedLabeling::Rule *ruleLabeling =
new QgsRuleBasedLabeling::Rule(
new QgsPalLayerSettings( settings ), scaleMinDenom, scaleMaxDenom, filterExp, label );
5552 ruleElem = ruleElem.nextSiblingElement();
5555 setLabeling(
new QgsRuleBasedLabeling( rootRule ) );
5562 QDomElement textSymbolizerElem = ruleElem.firstChildElement( u
"TextSymbolizer"_s );
5563 QgsPalLayerSettings s;
5564 if ( readSldTextSymbolizer( textSymbolizerElem, s ) )
5566 setLabeling(
new QgsVectorLayerSimpleLabeling( s ) );
5572bool QgsVectorLayer::readSldTextSymbolizer(
const QDomNode &node,
QgsPalLayerSettings &settings )
const
5576 if ( node.localName() !=
"TextSymbolizer"_L1 )
5578 QgsDebugMsgLevel( u
"Not a TextSymbolizer element: %1"_s.arg( node.localName() ), 3 );
5581 QDomElement textSymbolizerElem = node.toElement();
5583 QDomElement labelElem = textSymbolizerElem.firstChildElement( u
"Label"_s );
5584 if ( !labelElem.isNull() )
5586 QDomElement propertyNameElem = labelElem.firstChildElement( u
"PropertyName"_s );
5587 if ( !propertyNameElem.isNull() )
5592 QString labelAttribute = propertyNameElem.text();
5596 int fieldIndex = mFields.lookupField( labelAttribute );
5597 if ( fieldIndex == -1 )
5600 QgsExpression exp( labelAttribute );
5624 if ( textSymbolizerElem.hasAttribute( u
"uom"_s ) )
5629 QString fontFamily = u
"Sans-Serif"_s;
5630 int fontPointSize = 10;
5632 int fontWeight = -1;
5633 bool fontItalic =
false;
5634 bool fontUnderline =
false;
5637 QDomElement fontElem = textSymbolizerElem.firstChildElement( u
"Font"_s );
5638 if ( !fontElem.isNull() )
5641 for ( QgsStringMap::iterator it = fontSvgParams.begin(); it != fontSvgParams.end(); ++it )
5643 QgsDebugMsgLevel( u
"found fontSvgParams %1: %2"_s.arg( it.key(), it.value() ), 4 );
5645 if ( it.key() ==
"font-family"_L1 )
5647 fontFamily = it.value();
5649 else if ( it.key() ==
"font-style"_L1 )
5651 fontItalic = ( it.value() ==
"italic"_L1 ) || ( it.value() ==
"Italic"_L1 );
5653 else if ( it.key() ==
"font-size"_L1 )
5656 int fontSize = it.value().toInt( &ok );
5659 fontPointSize = fontSize;
5660 fontUnitSize = sldUnitSize;
5663 else if ( it.key() ==
"font-weight"_L1 )
5665 if ( ( it.value() ==
"bold"_L1 ) || ( it.value() ==
"Bold"_L1 ) )
5666 fontWeight = QFont::Bold;
5668 else if ( it.key() ==
"font-underline"_L1 )
5670 fontUnderline = ( it.value() ==
"underline"_L1 ) || ( it.value() ==
"Underline"_L1 );
5675 QgsTextFormat format;
5676 QFont font( fontFamily, fontPointSize, fontWeight, fontItalic );
5677 font.setUnderline( fontUnderline );
5679 format.
setSize( fontPointSize );
5683 QDomElement fillElem = textSymbolizerElem.firstChildElement( u
"Fill"_s );
5685 Qt::BrushStyle textBrush = Qt::SolidPattern;
5687 if ( textColor.isValid() )
5689 QgsDebugMsgLevel( u
"Info: textColor %1."_s.arg( QVariant( textColor ).toString() ), 4 );
5693 QgsTextBufferSettings bufferSettings;
5696 QDomElement haloElem = textSymbolizerElem.firstChildElement( u
"Halo"_s );
5697 if ( !haloElem.isNull() )
5702 QDomElement radiusElem = haloElem.firstChildElement( u
"Radius"_s );
5703 if ( !radiusElem.isNull() )
5706 double bufferSize = radiusElem.text().toDouble( &ok );
5709 bufferSettings.
setSize( bufferSize );
5714 QDomElement haloFillElem = haloElem.firstChildElement( u
"Fill"_s );
5716 Qt::BrushStyle bufferBrush = Qt::SolidPattern;
5718 if ( bufferColor.isValid() )
5720 QgsDebugMsgLevel( u
"Info: bufferColor %1."_s.arg( QVariant( bufferColor ).toString() ), 4 );
5721 bufferSettings.
setColor( bufferColor );
5726 QDomElement labelPlacementElem = textSymbolizerElem.firstChildElement( u
"LabelPlacement"_s );
5727 if ( !labelPlacementElem.isNull() )
5730 QDomElement pointPlacementElem = labelPlacementElem.firstChildElement( u
"PointPlacement"_s );
5731 if ( !pointPlacementElem.isNull() )
5739 QDomElement displacementElem = pointPlacementElem.firstChildElement( u
"Displacement"_s );
5740 if ( !displacementElem.isNull() )
5742 QDomElement displacementXElem = displacementElem.firstChildElement( u
"DisplacementX"_s );
5743 if ( !displacementXElem.isNull() )
5746 double xOffset = displacementXElem.text().toDouble( &ok );
5753 QDomElement displacementYElem = displacementElem.firstChildElement( u
"DisplacementY"_s );
5754 if ( !displacementYElem.isNull() )
5757 double yOffset = displacementYElem.text().toDouble( &ok );
5765 QDomElement anchorPointElem = pointPlacementElem.firstChildElement( u
"AnchorPoint"_s );
5766 if ( !anchorPointElem.isNull() )
5768 QDomElement anchorPointXElem = anchorPointElem.firstChildElement( u
"AnchorPointX"_s );
5769 if ( !anchorPointXElem.isNull() )
5772 double xOffset = anchorPointXElem.text().toDouble( &ok );
5779 QDomElement anchorPointYElem = anchorPointElem.firstChildElement( u
"AnchorPointY"_s );
5780 if ( !anchorPointYElem.isNull() )
5783 double yOffset = anchorPointYElem.text().toDouble( &ok );
5792 QDomElement rotationElem = pointPlacementElem.firstChildElement( u
"Rotation"_s );
5793 if ( !rotationElem.isNull() )
5796 double rotation = rotationElem.text().toDouble( &ok );
5806 QDomElement linePlacementElem = labelPlacementElem.firstChildElement( u
"LinePlacement"_s );
5807 if ( !linePlacementElem.isNull() )
5816 QDomElement vendorOptionElem = textSymbolizerElem.firstChildElement( u
"VendorOption"_s );
5817 while ( !vendorOptionElem.isNull() && vendorOptionElem.localName() ==
"VendorOption"_L1 )
5819 QString optionName = vendorOptionElem.attribute( u
"name"_s );
5820 QString optionValue;
5821 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::TextNode )
5823 optionValue = vendorOptionElem.firstChild().nodeValue();
5827 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::ElementNode &&
5828 vendorOptionElem.firstChild().localName() ==
"Literal"_L1 )
5831 optionValue = vendorOptionElem.firstChild().firstChild().nodeValue();
5835 QgsDebugError( u
"unexpected child of %1 named %2"_s.arg( vendorOptionElem.localName(), optionName ) );
5839 if ( !optionName.isEmpty() && !optionValue.isEmpty() )
5841 vendorOptions[ optionName ] = optionValue;
5844 vendorOptionElem = vendorOptionElem.nextSiblingElement();
5846 if ( !vendorOptions.isEmpty() )
5848 for ( QgsStringMap::iterator it = vendorOptions.begin(); it != vendorOptions.end(); ++it )
5850 if ( it.key() ==
"underlineText"_L1 && it.value() ==
"true"_L1 )
5852 font.setUnderline(
true );
5855 else if ( it.key() ==
"strikethroughText"_L1 && it.value() ==
"true"_L1 )
5857 font.setStrikeOut(
true );
5860 else if ( it.key() ==
"maxDisplacement"_L1 )
5864 else if ( it.key() ==
"followLine"_L1 && it.value() ==
"true"_L1 )
5875 else if ( it.key() ==
"maxAngleDelta"_L1 )
5878 double angle = it.value().toDouble( &ok );
5886 else if ( it.key() ==
"conflictResolution"_L1 && it.value() ==
"false"_L1 )
5890 else if ( it.key() ==
"forceLeftToRight"_L1 && it.value() ==
"false"_L1 )
5894 else if ( it.key() ==
"group"_L1 && it.value() ==
"yes"_L1 )
5898 else if ( it.key() ==
"labelAllGroup"_L1 && it.value() ==
"true"_L1 )
5914 return mEditFormConfig;
5925 mEditFormConfig.onRelationsLoaded();
5935 if ( config.isEmpty() )
5971 if ( !mDiagramLayerSettings )
5973 *mDiagramLayerSettings = s;
5981 QString myMetadata = u
"<html><head></head>\n<body>\n"_s;
5986 myMetadata += u
"<h1>"_s + tr(
"Information from provider" ) + u
"</h1>\n<hr>\n"_s;
5987 myMetadata +=
"<table class=\"list-view\">\n"_L1;
5992 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Storage" ) + u
"</td><td>"_s +
storageType() + u
"</td></tr>\n"_s;
5998 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Comment" ) + u
"</td><td>"_s +
dataComment() + u
"</td></tr>\n"_s;
6004 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Encoding" ) + u
"</td><td>"_s + provider->encoding() + u
"</td></tr>\n"_s;
6005 myMetadata += provider->htmlMetadata();
6020 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry type" ) + u
"</td><td>"_s + typeString + u
"</td></tr>\n"_s;
6026 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry column" ) + u
"</td><td>"_s + provider->geometryColumnName() + u
"</td></tr>\n"_s;
6033 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Extent" ) + u
"</td><td>"_s + extentAsStr + u
"</td></tr>\n"_s;
6037 QLocale locale = QLocale();
6038 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
6039 myMetadata += u
"<tr><td class=\"highlight\">"_s
6040 + tr(
"Feature count" ) + u
"</td><td>"_s
6042 + u
"</td></tr>\n"_s;
6045 myMetadata +=
"</table>\n<br><br>"_L1;
6054 myMetadata += u
"<h1>"_s + tr(
"Identification" ) + u
"</h1>\n<hr>\n"_s;
6055 myMetadata += htmlFormatter.identificationSectionHtml( );
6056 myMetadata +=
"<br><br>\n"_L1;
6059 myMetadata += u
"<h1>"_s + tr(
"Extent" ) + u
"</h1>\n<hr>\n"_s;
6060 myMetadata += htmlFormatter.extentSectionHtml(
isSpatial() );
6061 myMetadata +=
"<br><br>\n"_L1;
6064 myMetadata += u
"<h1>"_s + tr(
"Access" ) + u
"</h1>\n<hr>\n"_s;
6065 myMetadata += htmlFormatter.accessSectionHtml( );
6066 myMetadata +=
"<br><br>\n"_L1;
6069 myMetadata += u
"<h1>"_s + tr(
"Fields" ) + u
"</h1>\n<hr>\n<table class=\"list-view\">\n"_s;
6073 if ( !pkAttrList.isEmpty() )
6075 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Primary key attributes" ) + u
"</td><td>"_s;
6076 const auto constPkAttrList = pkAttrList;
6077 for (
int idx : constPkAttrList )
6081 myMetadata +=
"</td></tr>\n"_L1;
6087 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Count" ) + u
"</td><td>"_s + QString::number( myFields.
size() ) + u
"</td></tr>\n"_s;
6089 myMetadata +=
"</table>\n<br><table width=\"100%\" class=\"tabular-view\">\n"_L1;
6090 myMetadata +=
"<tr><th>"_L1 + tr(
"Field" ) +
"</th><th>"_L1 + tr(
"Type" ) +
"</th><th>"_L1 + tr(
"Length" ) +
"</th><th>"_L1 + tr(
"Precision" ) +
"</th><th>"_L1 + tr(
"Comment" ) +
"</th></tr>\n"_L1;
6092 for (
int i = 0; i < myFields.
size(); ++i )
6097 rowClass = u
"class=\"odd-row\""_s;
6098 myMetadata +=
"<tr "_L1 + rowClass +
"><td>"_L1 + myField.
displayNameWithAlias() +
"</td><td>"_L1 + myField.
typeName() +
"</td><td>"_L1 + QString::number( myField.
length() ) +
"</td><td>"_L1 + QString::number( myField.
precision() ) +
"</td><td>"_L1 + myField.
comment() +
"</td></tr>\n"_L1;
6102 myMetadata +=
"</table>\n<br><br>"_L1;
6105 myMetadata += u
"<h1>"_s + tr(
"Contacts" ) + u
"</h1>\n<hr>\n"_s;
6106 myMetadata += htmlFormatter.contactsSectionHtml( );
6107 myMetadata +=
"<br><br>\n"_L1;
6110 myMetadata += u
"<h1>"_s + tr(
"Links" ) + u
"</h1>\n<hr>\n"_s;
6111 myMetadata += htmlFormatter.linksSectionHtml( );
6112 myMetadata +=
"<br><br>\n"_L1;
6115 myMetadata += u
"<h1>"_s + tr(
"History" ) + u
"</h1>\n<hr>\n"_s;
6116 myMetadata += htmlFormatter.historySectionHtml( );
6117 myMetadata +=
"<br><br>\n"_L1;
6121 myMetadata +=
"\n</body>\n</html>\n"_L1;
6125void QgsVectorLayer::invalidateSymbolCountedFlag()
6129 mSymbolFeatureCounted =
false;
6132void QgsVectorLayer::onFeatureCounterCompleted()
6137 mFeatureCounter =
nullptr;
6140void QgsVectorLayer::onFeatureCounterTerminated()
6144 mFeatureCounter =
nullptr;
6147void QgsVectorLayer::onJoinedFieldsChanged()
6164void QgsVectorLayer::onFeatureDeleted(
QgsFeatureId fid )
6170 if ( mEditCommandActive || mCommitChangesActive )
6172 mDeletedFids << fid;
6176 mSelectedFeatureIds.remove( fid );
6183void QgsVectorLayer::onRelationsLoaded()
6187 mEditFormConfig.onRelationsLoaded();
6190void QgsVectorLayer::onSymbolsCounted()
6194 if ( mFeatureCounter )
6196 mSymbolFeatureCounted =
true;
6197 mSymbolFeatureCountMap = mFeatureCounter->symbolFeatureCountMap();
6198 mSymbolFeatureIdMap = mFeatureCounter->symbolFeatureIdMap();
6208 return p->relationManager()->referencingRelations(
this, idx );
6217 return mWeakRelations;
6224 mWeakRelations = relations;
6233 QString joinKey = mAuxiliaryLayerKey;
6234 if ( !key.isEmpty() )
6237 if ( storage.
isValid() && !joinKey.isEmpty() )
6262 mAuxiliaryLayerKey.clear();
6264 if ( mAuxiliaryLayer )
6277 mAuxiliaryLayer.reset( alayer );
6278 if ( mAuxiliaryLayer )
6279 mAuxiliaryLayer->setParent(
this );
6287 return mAuxiliaryLayer.get();
6294 return mAuxiliaryLayer.get();
6301 if ( mDataProvider )
6306void QgsVectorLayer::emitDataChanged()
6310 if ( mDataChangedFired )
6317 if (
QgsVectorLayer *layerWeDependUpon = qobject_cast<QgsVectorLayer *>( sender() );
6318 layerWeDependUpon && layerWeDependUpon->mCommitChangesActive )
6323 mDataChangedFired =
true;
6325 mDataChangedFired =
false;
6332 QSet<QgsMapLayerDependency> deps;
6333 const auto constODeps = oDeps;
6340 QSet<QgsMapLayerDependency> toAdd = deps -
dependencies();
6360 if ( mDataProvider )
6384 if ( ! toAdd.isEmpty() )
6394 if ( fieldIndex < 0 || fieldIndex >= mFields.count() || !mDataProvider )
6402 constraints |= mDataProvider->fieldConstraints( mFields.fieldOriginIndex( fieldIndex ) );
6412 QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > m;
6414 if ( fieldIndex < 0 || fieldIndex >= mFields.count() )
6417 QString
name = mFields.at( fieldIndex ).name();
6420 for ( ; conIt != mFieldConstraintStrength.constEnd(); ++conIt )
6422 if ( conIt.key().first ==
name )
6424 m[ conIt.key().second ] = mFieldConstraintStrength.value( conIt.key() );
6435 if ( index < 0 || index >= mFields.count() )
6438 QString
name = mFields.at( index ).name();
6442 constraints |= constraint;
6443 mFieldConstraints.insert(
name, constraints );
6445 mFieldConstraintStrength.insert( qMakePair(
name, constraint ), strength );
6454 if ( index < 0 || index >= mFields.count() )
6457 QString
name = mFields.at( index ).name();
6461 constraints &= ~constraint;
6462 mFieldConstraints.insert(
name, constraints );
6464 mFieldConstraintStrength.remove( qMakePair(
name, constraint ) );
6473 if ( index < 0 || index >= mFields.count() )
6476 return mFields.at( index ).constraints().constraintExpression();
6483 if ( index < 0 || index >= mFields.count() )
6486 return mFields.at( index ).constraints().constraintDescription();
6493 if ( index < 0 || index >= mFields.count() )
6496 if ( expression.isEmpty() )
6498 mFieldConstraintExpressions.remove( mFields.at( index ).name() );
6502 mFieldConstraintExpressions.insert( mFields.at( index ).name(), qMakePair( expression, description ) );
6511 if ( index < 0 || index >= mFields.count() )
6514 mFieldConfigurationFlags.insert( mFields.at( index ).name(),
flags );
6522 if ( index < 0 || index >= mFields.count() )
6525 flags.setFlag( flag, active );
6533 if ( index < 0 || index >= mFields.count() )
6536 return mFields.at( index ).configurationFlags();
6543 if ( index < 0 || index >= mFields.count() )
6547 mFieldWidgetSetups.remove( mFields.at( index ).name() );
6549 mFieldWidgetSetups.insert( mFields.at( index ).name(), setup );
6557 if ( index < 0 || index >= mFields.count() )
6560 return mFields.at( index ).editorWidgetSetup();
6570 if (
customProperty( u
"labeling/enabled"_s, QVariant(
false ) ).toBool() )
6574 settings.readFromLayerCustomProperties(
this );
6581 for (
const QString &key : constCustomPropertyKeys )
6583 if ( key.startsWith(
"labeling/"_L1 ) )
6595 return mAllowCommit;
6613 return mGeometryOptions.get();
6627 return mReadExtentFromXml;
6630void QgsVectorLayer::onDirtyTransaction(
const QString &sql,
const QString &name )
6635 if ( tr && mEditBuffer )
6637 qobject_cast<QgsVectorLayerEditPassthrough *>( mEditBuffer )->update( tr, sql,
name );
6643 QList<QgsVectorLayer *> layers;
6644 QMap<QgsVectorLayer *, QgsFeatureIds>::const_iterator i;
6647 if ( includeAuxiliaryLayers || !qobject_cast< QgsAuxiliaryLayer * >( i.key() ) )
6648 layers.append( i.key() );
Provides global constants and enumerations for use throughout the application.
@ Action
Expression functions.
@ FormInitCode
Map layers' action.
@ SelectAtId
Fast access to features using their ID.
@ CreateRenderer
Provider can create feature renderers using backend-specific formatting information....
@ CreateLabeling
Provider can set labeling settings using backend-specific formatting information. Since QGIS 3....
@ ReadLayerMetadata
Provider can read layer metadata from data store. Since QGIS 3.0. See QgsDataProvider::layerMetadata(...
@ DeleteFeatures
Allows deletion of features.
QFlags< VectorRenderingSimplificationFlag > VectorRenderingSimplificationFlags
Simplification flags for vector feature rendering.
@ Composition
Fix relation, related elements are part of the parent and a parent copy will copy any children or del...
@ Association
Loose relation, related elements are not part of the parent and a parent copy will not copy any child...
GeometryOperationResult
Success or failure of a geometry operation.
@ InvalidInputGeometryType
The input geometry (ring, part, split line, etc.) has not the correct geometry type.
@ Success
Operation succeeded.
@ SelectionIsEmpty
No features were selected.
@ AddRingNotInExistingFeature
The input ring doesn't have any existing ring to fit into.
@ AddRingNotClosed
The input ring is not closed.
@ SelectionIsGreaterThanOne
More than one features were selected.
@ LayerNotEditable
Cannot edit layer.
SpatialIndexPresence
Enumeration of spatial index presence states.
@ Unknown
Spatial index presence cannot be determined, index may or may not exist.
VectorRenderingSimplificationFlag
Simplification flags for vector feature rendering.
@ NoSimplification
No simplification can be applied.
@ OverPoint
Arranges candidates over a point (or centroid of a polygon), or at a preset offset from the point....
@ Curved
Arranges candidates following the curvature of a line feature. Applies to line layers only.
@ AroundPoint
Arranges candidates in a circle around a point (or centroid of a polygon). Applies to point or polygo...
@ Line
Arranges candidates parallel to a generalised line representing the feature or parallel to a polygon'...
@ Horizontal
Arranges horizontal candidates scattered throughout a polygon feature. Applies to polygon layers only...
@ PerimeterCurved
Arranges candidates following the curvature of a polygon's boundary. Applies to polygon layers only.
QFlags< VectorLayerTypeFlag > VectorLayerTypeFlags
Vector layer type flags.
VectorSimplificationAlgorithm
Simplification algorithms for vector features.
@ Distance
The simplification uses the distance between points to remove duplicate points.
@ File
Load the Python code from an external file.
@ Environment
Use the Python code available in the Python environment.
@ NoSource
Do not use Python code at all.
@ Dialog
Use the Python code provided in the dialog.
@ ExactIntersect
Use exact geometry intersection (slower) instead of bounding boxes.
@ SubsetOfAttributes
Fetch only a subset of attributes (setSubsetOfAttributes sets this flag).
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
@ FastExtent3D
Provider's 3D extent retrieval via QgsDataProvider::extent3D() is always guaranteed to be trivial/fas...
@ FastExtent2D
Provider's 2D extent retrieval via QgsDataProvider::extent() is always guaranteed to be trivial/fast ...
@ BufferedGroups
Buffered transactional editing means that all editable layers in the buffered transaction group are t...
@ OpenUrl
Open URL action.
@ SubmitUrlMultipart
POST data to an URL using "multipart/form-data".
@ Windows
Windows specific.
@ SubmitUrlEncoded
POST data to an URL, using "application/x-www-form-urlencoded" or "application/json" if the body is v...
FieldDomainMergePolicy
Merge policy for field domains.
@ UnsetField
Clears the field value so that the data provider backend will populate using any backend triggers or ...
FieldDomainSplitPolicy
Split policy for field domains.
@ Duplicate
Duplicate original value.
BlendMode
Blending modes defining the available composition modes that can be used when painting.
GeometryType
The geometry types are used to group Qgis::WkbType in a coarse way.
@ Generated
A generated relation is a child of a polymorphic relation.
@ Normal
A normal relation.
FieldDuplicatePolicy
Duplicate policy for fields.
@ Duplicate
Duplicate original value.
static const float DEFAULT_MAPTOPIXEL_THRESHOLD
Default threshold between map coordinates and device coordinates for map2pixel simplification.
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
FeatureAvailability
Possible return value for QgsFeatureSource::hasFeatures() to determine if a source is empty.
@ FeaturesMaybeAvailable
There may be features available in this source.
@ FeaturesAvailable
There is at least one feature available in this source.
@ NoFeaturesAvailable
There are certainly no features available in this source.
@ Provider
Field originates from the underlying data provider of the vector layer.
@ Edit
Field has been temporarily added in editing mode.
@ Unknown
The field origin has not been specified.
@ Expression
Field is calculated from an expression.
@ Join
Field originates from a joined layer.
RenderUnit
Rendering size units.
@ Points
Points (e.g., for font sizes).
@ LoadDefaultStyle
Reset the layer's style to the default for the datasource.
@ ForceReadOnly
Open layer in a read-only mode.
Aggregate
Available aggregates to calculate.
VertexMarkerType
Editing vertex markers, used for showing vertices during a edit operation.
@ SemiTransparentCircle
Semi-transparent circle marker.
VectorEditResult
Specifies the result of a vector layer edit operation.
@ Success
Edit operation was successful.
@ InvalidLayer
Edit failed due to invalid layer.
WkbType
The WKB type describes the number of dimensions a geometry has.
FieldConfigurationFlag
Configuration flags for fields These flags are meant to be user-configurable and are not describing a...
@ HideFromWfs
Field is not available if layer is served as WFS from QGIS server.
@ NoFlag
No flag is defined.
@ HideFromWms
Field is not available if layer is served as WMS from QGIS server.
@ AllowOverlapIfRequired
Avoids overlapping labels when possible, but permit overlaps if labels for features cannot otherwise ...
QFlags< FieldConfigurationFlag > FieldConfigurationFlags
Configuration flags for fields These flags are meant to be user-configurable and are not describing a...
@ AlwaysAllowUpsideDown
Show upside down for all labels, including dynamic ones.
SelectBehavior
Specifies how a selection should be applied.
@ SetSelection
Set selection, removing any existing selection.
@ AddToSelection
Add selection to current selection.
@ IntersectSelection
Modify current selection to include only select features which match.
@ RemoveFromSelection
Remove from current selection.
Abstract base class for objects which generate elevation profiles.
virtual bool writeXml(QDomElement &collectionElem, const QgsPropertiesDefinition &definitions) const
Writes the current state of the property collection into an XML element.
Abstract base class - its implementations define different approaches to the labeling of a vector lay...
static QgsAbstractVectorLayerLabeling * create(const QDomElement &element, const QgsReadWriteContext &context)
Try to create instance of an implementation based on the XML data.
Storage and management of actions associated with a layer.
QList< QgsAction > actions(const QString &actionScope=QString()) const
Returns a list of actions that are available in the given action scope.
QUuid addAction(Qgis::AttributeActionType type, const QString &name, const QString &command, bool capture=false)
Add an action with the given name and action details.
Utility class that encapsulates an action based on vector attributes.
Utility class for calculating aggregates for a field (or expression) over the features from a vector ...
static QgsNetworkContentFetcherRegistry * networkContentFetcherRegistry()
Returns the application's network content registry used for fetching temporary files during QGIS sess...
static QgsRuntimeProfiler * profiler()
Returns the application runtime profiler.
static QgsTaskManager * taskManager()
Returns the application's task manager, used for managing application wide background task handling.
A container for configuration of the attribute table.
void update(const QgsFields &fields)
Update the configuration with the given fields.
Allows managing the auxiliary storage for a vector layer.
QgsVectorLayerJoinInfo joinInfo() const
Returns information to use for joining with primary key and so on.
Providing some utility methods to manage auxiliary storage.
QgsAuxiliaryLayer * createAuxiliaryLayer(const QgsField &field, QgsVectorLayer *layer) const
Creates an auxiliary layer for a vector layer.
bool isValid() const
Returns the status of the auxiliary storage currently defined.
A 3-dimensional box composed of x, y, z coordinates.
QString toString(int precision=16) const
Returns a string representation of form xmin,ymin,zmin : xmax,ymax,zmax Coordinates will be truncated...
bool isEmpty() const
Returns true if the box is empty.
Holds conditional style information for a layer.
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.
Abstract base class for curved geometry type.
virtual bool isClosed() const
Returns true if the curve is closed.
QgsCurve * clone() const override=0
Clones the geometry by performing a deep copy.
void dataChanged()
Emitted whenever a change is made to the data provider which may have caused changes in the provider'...
void fullExtentCalculated()
Emitted whenever a deferred extent calculation is completed by the provider.
virtual QString dataSourceUri(bool expandAuthConfig=false) const
Gets the data source specification.
Stores the component parts of a data source URI (e.g.
bool useEstimatedMetadata() const
Returns true if estimated metadata should be used for the connection.
Provides a container for managing client side default values for fields.
bool isValid() const
Returns if this default value should be applied.
Stores the settings for rendering of all diagrams for a layer.
@ PositionX
X-coordinate data defined diagram position.
@ PositionY
Y-coordinate data defined diagram position.
@ Show
Whether to show the diagram.
Evaluates and returns the diagram settings relating to a diagram for a specific feature.
A embedded script entity for QgsObjectEntityVisitorInterface.
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 scope.
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the scope.
static QList< QgsExpressionContextScope * > globalProjectLayerScopes(const QgsMapLayer *layer)
Creates a list of three scopes: global, layer's project and layer.
static QgsExpressionContextScope * layerScope(const QgsMapLayer *layer)
Creates a new scope which contains variables and functions relating to a QgsMapLayer.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
QgsExpressionContextScope * popScope()
Removes the last scope from the expression context and return it.
void appendScope(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
Buffers information about expression fields for a vector layer.
void writeXml(QDomNode &layer_node, QDomDocument &document) const
Saves expressions to xml under the layer node.
An expression node which takes its value from a feature's field.
QString name() const
The name of the column.
Handles parsing and evaluation of expressions (formerly called "search strings").
bool prepare(const QgsExpressionContext *context)
Gets the expression ready for evaluation - find out column indexes.
QString expression() const
Returns the original, unmodified expression string.
bool hasParserError() const
Returns true if an error occurred when parsing the input expression.
QString evalErrorString() const
Returns evaluation error.
QString parserErrorString() const
Returns parser error.
QSet< QString > referencedColumns() const
Gets list of columns referenced by the expression.
static QString quotedColumnRef(QString name)
Returns a quoted column reference (in double quotes).
bool hasEvalError() const
Returns true if an error occurred when evaluating last input.
static int expressionToLayerFieldIndex(const QString &expression, const QgsVectorLayer *layer)
Attempts to resolve an expression to a field index from the given layer.
bool needsGeometry() const
Returns true if the expression uses feature geometry for some computation.
QVariant evaluate()
Evaluate the feature and return the result.
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.
bool close()
Call to end the iteration.
An interface for objects which generate feature renderers for vector layers.
Abstract base class for all 2D vector feature renderers.
static QgsFeatureRenderer * defaultRenderer(Qgis::GeometryType geomType)
Returns a new renderer - used by default in vector layers.
static QgsFeatureRenderer * load(QDomElement &symbologyElem, const QgsReadWriteContext &context)
create a renderer from XML element
static QgsFeatureRenderer * loadSld(const QDomNode &node, Qgis::GeometryType geomType, QString &errorMessage)
Create a new renderer according to the information contained in the UserStyle element of a SLD style ...
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 & setFilterFids(const QgsFeatureIds &fids)
Sets the feature IDs that should be fetched.
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
QgsFeatureRequest & setFilterExpression(const QString &expression)
Set the filter expression.
QgsFeatureRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate filter expressions.
QgsFeatureRequest & setFilterFid(QgsFeatureId fid)
Sets the feature ID that should be fetched.
virtual QgsFeatureIds allFeatureIds() const
Returns a list of all feature IDs for features present in the source.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Q_INVOKABLE bool setAttribute(int field, const QVariant &attr)
Sets an attribute's value by field index.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
bool isValid() const
Returns the validity of this feature.
Q_INVOKABLE QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
bool isCanceled() const
Tells whether the operation has been canceled already.
Stores information about constraints which may be present on a field.
ConstraintStrength
Strength of constraints.
void setConstraintStrength(Constraint constraint, ConstraintStrength strength)
Sets the strength of a constraint.
void setConstraintExpression(const QString &expression, const QString &description=QString())
Set the constraint expression for the field.
@ ConstraintOriginProvider
Constraint was set at data provider.
@ ConstraintOriginLayer
Constraint was set by layer.
ConstraintOrigin constraintOrigin(Constraint constraint) const
Returns the origin of a field constraint, or ConstraintOriginNotSet if the constraint is not present ...
Constraint
Constraints which may be present on a field.
@ ConstraintNotNull
Field may not be null.
@ ConstraintUnique
Field must have a unique value.
@ ConstraintExpression
Field has an expression constraint set. See constraintExpression().
void setConstraint(Constraint constraint, ConstraintOrigin origin=ConstraintOriginLayer)
Sets a constraint on the field.
QFlags< Constraint > Constraints
Encapsulate a field in an attribute table or data source.
QString typeName() const
Gets the field type.
QString displayNameWithAlias() const
Returns the name to use when displaying this field and adds the alias in parenthesis if it is defined...
Container of fields for a vector layer.
int size() const
Returns number of items.
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.
const_iterator constBegin() const noexcept
Returns a const STL-style iterator pointing to the first item in the list.
Contains options to automatically adjust geometries to constraints on a layer.
A geometry is the spatial representation of a feature.
QgsBox3D boundingBox3D() const
Returns the 3D bounding box of the geometry.
bool equals(const QgsGeometry &geometry) const
Test if this geometry is exactly equal to another geometry.
QgsRectangle boundingBox() const
Returns the bounding box of the geometry.
void setMergeLines(bool merge)
Sets whether connected line features with identical label text should be merged prior to generating l...
void setOverlapHandling(Qgis::LabelOverlapHandling handling)
Sets the technique used to handle overlapping labels.
Line string geometry type, with support for z-dimension and m-values.
Alters the size of rendered diagrams using linear scaling.
static void warning(const QString &msg)
Goes to qWarning.
Models dependencies with or between map layers.
Base class for storage of map layer elevation properties.
static QString typeToString(Qgis::LayerType type)
Converts a map layer type to a string value.
virtual QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const
Writes configuration to a DOM element, to be used later with readXml().
static QgsMapLayerLegend * defaultVectorLegend(QgsVectorLayer *vl)
Create new legend implementation for vector layer.
Base class for utility classes that encapsulate information necessary for rendering of map layers.
Base class for storage of map layer selection properties.
Stores style information (renderer, opacity, labeling, diagrams etc.) applicable to a map layer.
Base class for storage of map layer temporal properties.
void readStyleManager(const QDomNode &layerNode)
Read style manager's configuration (if any). To be called by subclasses.
void dependenciesChanged()
Emitted when dependencies are changed.
void writeStyleManager(QDomNode &layerNode, QDomDocument &doc) const
Write style manager's configuration (if exists). To be called by subclasses.
QgsMapLayerLegend * legend() const
Can be nullptr.
void editingStopped()
Emitted when edited changes have been successfully written to the data provider.
void recalculateExtents() const
This is used to send a request that any mapcanvas using this layer update its extents.
virtual QgsRectangle extent() const
Returns the extent of the layer.
QString source() const
Returns the source for the layer.
Q_INVOKABLE QVariant customProperty(const QString &value, const QVariant &defaultValue=QVariant()) const
Read a custom property from layer.
int mBlockStyleChangedSignal
If non-zero, the styleChanged signal should not be emitted.
QString providerType() const
Returns the provider type (provider key) for this layer.
virtual void setExtent3D(const QgsBox3D &box)
Sets the extent.
void removeCustomProperty(const QString &key)
Remove a custom property from layer.
void setBlendMode(QPainter::CompositionMode blendMode)
Set the blending mode used for rendering a layer.
void configChanged()
Emitted whenever the configuration is changed.
void setMinimumScale(double scale)
Sets the minimum map scale (i.e.
static Qgis::DataProviderReadFlags providerReadFlags(const QDomNode &layerNode, QgsMapLayer::ReadFlags layerReadFlags)
Returns provider read flag deduced from layer read flags layerReadFlags and a dom node layerNode that...
void editingStarted()
Emitted when editing on this layer has started.
QgsCoordinateReferenceSystem crs
friend class QgsVectorLayer
void writeCustomProperties(QDomNode &layerNode, QDomDocument &doc) const
Write custom properties to project file.
virtual int listStylesInDatabase(QStringList &ids, QStringList &names, QStringList &descriptions, QString &msgError)
Lists all the style in db split into related to the layer and not related to.
virtual QString loadDefaultStyle(bool &resultFlag)
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
void setDataSource(const QString &dataSource, const QString &baseName=QString(), const QString &provider=QString(), bool loadDefaultStyleFlag=false)
Updates the data source of the layer.
void triggerRepaint(bool deferredUpdate=false)
Will advise the map canvas (and any other interested party) that this layer requires to be repainted.
QString crsHtmlMetadata() const
Returns a HTML fragment containing the layer's CRS metadata, for use in the htmlMetadata() method.
void setMaximumScale(double scale)
Sets the maximum map scale (i.e.
QgsLayerMetadata metadata
QgsMapLayer(Qgis::LayerType type=Qgis::LayerType::Vector, const QString &name=QString(), const QString &source=QString())
Constructor for QgsMapLayer.
QPainter::CompositionMode blendMode() const
Returns the current blending mode for a layer.
virtual void setOpacity(double opacity)
Sets the opacity for the layer, where opacity is a value between 0 (totally transparent) and 1....
void setFlags(QgsMapLayer::LayerFlags flags)
Returns the flags for this layer.
QString publicSource(bool hidePassword=false) const
Gets a version of the internal layer definition that has sensitive bits removed (for example,...
QSet< QgsMapLayerDependency > mDependencies
List of layers that may modify this layer on modification.
void readCustomProperties(const QDomNode &layerNode, const QString &keyStartsWith=QString())
Read custom properties from project file.
virtual void setMetadata(const QgsLayerMetadata &metadata)
Sets the layer's metadata store.
QFlags< StyleCategory > StyleCategories
Q_INVOKABLE void setCustomProperty(const QString &key, const QVariant &value)
Set a custom property for layer.
QString mProviderKey
Data provider key (name of the data provider).
QgsCoordinateTransformContext transformContext() const
Returns the layer data provider coordinate transform context or a default transform context if the la...
void styleChanged()
Signal emitted whenever a change affects the layer's style.
QUndoStack * undoStack()
Returns pointer to layer's undo stack.
std::unique_ptr< QgsDataProvider > mPreloadedProvider
Optionally used when loading a project, it is released when the layer is effectively created.
void rendererChanged()
Signal emitted when renderer is changed.
virtual QgsError error() const
Gets current status error.
void setScaleBasedVisibility(bool enabled)
Sets whether scale based visibility is enabled for the layer.
void dataSourceChanged()
Emitted whenever the layer's data source has been changed.
QgsMapLayer::LayerFlags flags
bool hasScaleBasedVisibility() const
Returns whether scale based visibility is enabled for the layer.
virtual QString getStyleFromDatabase(const QString &styleId, QString &msgError)
Returns the named style corresponding to style id provided.
void emitStyleChanged()
Triggers an emission of the styleChanged() signal.
void dataChanged()
Data of layer changed.
void willBeDeleted()
Emitted in the destructor when the layer is about to be deleted, but it is still in a perfectly valid...
virtual QgsBox3D extent3D() const
Returns the 3D extent of the layer.
virtual QgsMapLayer * clone() const =0
Returns a new instance equivalent to this one except for the id which is still unique.
void setName(const QString &name)
Set the display name of the layer.
virtual void setExtent(const QgsRectangle &rect)
Sets the extent.
virtual void resolveReferences(QgsProject *project)
Resolve references to other layers (kept as layer IDs after reading XML) into layer objects.
QString mDataSource
Data source description string, varies by layer type.
void setMapTipsEnabled(bool enabled)
Enable or disable map tips for this layer.
@ FlagReadExtentFromXml
Read extent from xml and skip get extent from provider.
@ FlagForceReadOnly
Force open as read only.
@ FlagDontResolveLayers
Don't resolve layer paths or create data providers for layers.
void setValid(bool valid)
Sets whether layer is valid or not.
void readCommonStyle(const QDomElement &layerElement, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories)
Read style data common to all layer types.
QgsMapLayer::ReadFlags mReadFlags
Read flags. It's up to the subclass to respect these when restoring state from XML.
double minimumScale() const
Returns the minimum map scale (i.e.
void repaintRequested(bool deferredUpdate=false)
By emitting this signal the layer tells that either appearance or content have been changed and any v...
void setMapTipTemplate(const QString &mapTipTemplate)
The mapTip is a pretty, html representation for feature information.
Q_INVOKABLE QStringList customPropertyKeys() const
Returns list of all keys within custom properties.
QgsProject * project() const
Returns the parent project if this map layer is added to a project.
void setLegend(QgsMapLayerLegend *legend)
Assign a legend controller to the map layer.
bool mValid
Indicates if the layer is valid and can be drawn.
@ GeometryOptions
Geometry validation configuration.
@ AttributeTable
Attribute table settings: choice and order of columns, conditional styling.
@ LayerConfiguration
General configuration: identifiable, removable, searchable, display expression, read-only.
@ Rendering
Rendering: scale visibility, simplify method, opacity.
@ CustomProperties
Custom properties (by plugins for instance).
@ Fields
Aliases, widgets, WMS/WFS, expressions, constraints, virtual fields.
void layerModified()
Emitted when modifications has been done on layer.
void setProviderType(const QString &providerType)
Sets the providerType (provider key).
QString customPropertyHtmlMetadata() const
Returns an HTML fragment containing custom property information, for use in the htmlMetadata() method...
QString generalHtmlMetadata() const
Returns an HTML fragment containing general metadata information, for use in the htmlMetadata() metho...
void writeCommonStyle(QDomElement &layerElement, QDomDocument &document, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const
Write style data common to all layer types.
double maximumScale() const
Returns the maximum map scale (i.e.
bool mShouldValidateCrs
true if the layer's CRS should be validated and invalid CRSes are not permitted.
void setCrs(const QgsCoordinateReferenceSystem &srs, bool emitSignal=true)
Sets layer's spatial reference system.
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).
QFile * localFile(const QString &filePathOrUrl)
Returns a QFile from a local file or to a temporary file previously fetched by the registry.
An interface for classes which can visit various object entity (e.g.
virtual bool visitEmbeddedScript(const QgsEmbeddedScriptEntity &entity, const QgsObjectVisitorContext &context)
Called when the visitor will visit an embedded script entity.
A QgsObjectEntityVisitorInterface context object.
static QgsExpression * expressionFromOgcFilter(const QDomElement &element, QgsVectorLayer *layer=nullptr)
Parse XML with OGC filter into QGIS expression.
static Qgis::BlendMode getBlendModeEnum(QPainter::CompositionMode blendMode)
Returns a Qgis::BlendMode corresponding to a QPainter::CompositionMode.
static QPainter::CompositionMode getCompositionMode(Qgis::BlendMode blendMode)
Returns a QPainter::CompositionMode corresponding to a Qgis::BlendMode.
Contains settings for how a map layer will be labeled.
double yOffset
Vertical offset of label.
const QgsLabelPlacementSettings & placementSettings() const
Returns the label placement settings.
double maxCurvedCharAngleIn
Maximum angle between inside curved label characters (valid range 20.0 to 60.0).
void setFormat(const QgsTextFormat &format)
Sets the label text formatting settings, e.g., font settings, buffer settings, etc.
double xOffset
Horizontal offset of label.
Qgis::LabelPlacement placement
Label placement mode.
double angleOffset
Label rotation, in degrees clockwise.
double maxCurvedCharAngleOut
Maximum angle between outside curved label characters (valid range -20.0 to -95.0).
Qgis::RenderUnit offsetUnits
Units for offsets of label.
bool isExpression
true if this label is made from a expression string, e.g., FieldName || 'mm'
const QgsLabelLineSettings & lineSettings() const
Returns the label line settings, which contain settings related to how the label engine places and fo...
Qgis::UpsideDownLabelHandling upsidedownLabels
Controls whether upside down labels are displayed and how they are handled.
QString fieldName
Name of field (or an expression) to use for label text.
Point geometry type, with support for z-dimension and m-values.
Encapsulates properties and constraints relating to fetching elevation profiles from different source...
virtual QString translate(const QString &context, const QString &sourceText, const char *disambiguation=nullptr, int n=-1) const =0
Translates a string using the Qt QTranslator mechanism.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
QgsRelationManager * relationManager
bool commitChanges(QStringList &commitErrors, bool stopEditing=true, QgsVectorLayer *vectorLayer=nullptr)
Attempts to commit to the underlying data provider any buffered changes made since the last to call t...
static QgsProject * instance()
Returns the QgsProject singleton instance.
bool rollBack(QStringList &rollbackErrors, bool stopEditing=true, QgsVectorLayer *vectorLayer=nullptr)
Stops a current editing operation on vectorLayer and discards any uncommitted edits.
bool startEditing(QgsVectorLayer *vectorLayer=nullptr)
Makes the layer editable.
QMap< QString, QgsMapLayer * > mapLayers(const bool validOnly=false) const
Returns a map of all registered layers by layer ID.
A grouped map of multiple QgsProperty objects, each referenced by an integer key value.
void setProperty(int key, const QgsProperty &property)
Adds a property to the collection and takes ownership of it.
Definition for a property.
@ Double
Double value (including negative values).
static QgsProperty fromField(const QString &fieldName, bool isActive=true)
Returns a new FieldBasedProperty created from the specified field name.
QString absoluteToRelativeUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts absolute path(s) to relative path(s) in the given provider-specific URI.
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
QString relativeToAbsoluteUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts relative path(s) to absolute path(s) in the given provider-specific URI.
Allows entering a context category and takes care of leaving this category on deletion of the class.
A container for the context for various read/write operations on objects.
QgsReadWriteContextCategoryPopper enterCategory(const QString &category, const QString &details=QString()) const
Push a category to the stack.
const QgsProjectTranslator * projectTranslator() const
Returns the project translator.
QgsCoordinateTransformContext transformContext() const
Returns data provider coordinate transform context.
const QgsPathResolver & pathResolver() const
Returns path resolver for conversion between relative and absolute paths.
A rectangle specified with double values.
Q_INVOKABLE QString toString(int precision=16) const
Returns a string representation of form xmin,ymin : xmax,ymax Coordinates will be truncated to the sp...
void set(const QgsPointXY &p1, const QgsPointXY &p2, bool normalize=true)
Sets the rectangle from two QgsPoints.
void combineExtentWith(const QgsRectangle &rect)
Expands the rectangle so that it covers both the original rectangle and the given rectangle.
void normalize()
Normalize the rectangle so it has non-negative width/height.
void setNull()
Mark a rectangle as being null (holding no spatial information).
QList< QgsRelation > referencedRelations(const QgsVectorLayer *layer=nullptr) const
Gets all relations where this layer is the referenced part (i.e.
void relationsLoaded()
Emitted when the relations were loaded after reading a project.
Represents a relationship between two vector layers.
Contains information about the context of a rendering operation.
double rendererScale() const
Returns the renderer map scale.
bool useRenderingOptimization() const
Returns true if the rendering optimization (geometry simplification) can be executed.
void appendChild(QgsRuleBasedLabeling::Rule *rule)
add child rule, take ownership, sets this as parent
A boolean settings entry.
A template class for enum and flag settings entry.
static QgsSettingsTreeNode * sTreeQgis
Stores settings for use within QGIS.
Renders the diagrams for all features with the same settings.
Holds SLD export options and other information related to SLD export of a QGIS layer style.
void setExtraProperties(const QVariantMap &properties)
Sets the open ended set of properties that can drive/inform the SLD encoding.
QVariantMap extraProperties() const
Returns the open ended set of properties that can drive/inform the SLD encoding.
Renders diagrams using mixed diagram render types.
Manages stored expressions regarding creation, modification and storing in the project.
An interface for classes which can visit style entity (e.g.
static double rendererFrameRate(const QgsFeatureRenderer *renderer)
Calculates the frame rate (in frames per second) at which the given renderer must be redrawn.
static QgsStringMap getSvgParameterList(QDomElement &element)
static void mergeScaleDependencies(double mScaleMinDenom, double mScaleMaxDenom, QVariantMap &props)
Merges the local scale limits, if any, with the ones already in the map, if any.
static bool fillFromSld(QDomElement &element, Qt::BrushStyle &brushStyle, QColor &color)
static Qgis::RenderUnit decodeSldUom(const QString &str, double *scaleFactor=nullptr)
Decodes a SLD unit of measure string to a render unit.
long addTask(QgsTask *task, int priority=0)
Adds a task to the manager.
void taskCompleted()
Will be emitted by task to indicate its successful completion.
void taskTerminated()
Will be emitted by task if it has terminated for any reason other then completion (e....
void setColor(const QColor &color)
Sets the color for the buffer.
void setSizeUnit(Qgis::RenderUnit unit)
Sets the units used for the buffer size.
void setEnabled(bool enabled)
Sets whether the text buffer will be drawn.
void setSize(double size)
Sets the size of the buffer.
void setColor(const QColor &color)
Sets the color that text will be rendered in.
void setSize(double size)
Sets the size for rendered text.
void setFont(const QFont &font)
Sets the font used for rendering text.
void setSizeUnit(Qgis::RenderUnit unit)
Sets the units for the size of rendered text.
void setBuffer(const QgsTextBufferSettings &bufferSettings)
Sets the text's buffer settings.
Allows creation of a multi-layer database-side transaction.
void dirtied(const QString &sql, const QString &name)
Emitted if a sql query is executed and the underlying data is modified.
static bool isNull(const QVariant &variant, bool silenceNullWarnings=false)
Returns true if the specified variant should be considered a NULL value.
Base class for vector data providers.
static const int EditingCapabilities
Bitmask of all provider's editing capabilities.
virtual QString geometryColumnName() const
Returns the name of the column storing geometry, if applicable.
void raiseError(const QString &msg) const
Signals an error in this provider.
virtual void handlePostCloneOperations(QgsVectorDataProvider *source)
Handles any post-clone operations required after this vector data provider was cloned from the source...
virtual QgsTransaction * transaction() const
Returns the transaction this data provider is included in, if any.
void committedAttributesDeleted(const QString &layerId, const QgsAttributeList &deletedAttributes)
Emitted after attribute deletion has been committed to the layer.
void committedAttributeValuesChanges(const QString &layerId, const QgsChangedAttributesMap &changedAttributesValues)
Emitted after feature attribute value changes have been committed to the layer.
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geom)
Emitted when a feature's geometry is changed.
void committedAttributesAdded(const QString &layerId, const QList< QgsField > &addedAttributes)
Emitted after attribute addition has been committed to the layer.
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
Emitted after feature addition has been committed to the layer.
void featureDeleted(QgsFeatureId fid)
Emitted when a feature was deleted from the buffer.
void attributeAdded(int idx)
Emitted when an attribute was added to the buffer.
void committedGeometriesChanges(const QString &layerId, const QgsGeometryMap &changedGeometries)
Emitted after feature geometry changes have been committed to the layer.
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &value)
Emitted when a feature's attribute value has been changed.
void attributeDeleted(int idx)
Emitted when an attribute was deleted from the buffer.
void featureAdded(QgsFeatureId fid)
Emitted when a feature has been added to the buffer.
void layerModified()
Emitted when modifications has been done on layer.
void committedFeaturesRemoved(const QString &layerId, const QgsFeatureIds &deletedFeatureIds)
Emitted after feature removal has been committed to the layer.
Contains utility functions for editing vector layers.
int translateFeature(QgsFeatureId featureId, double dx, double dy)
Translates feature by dx, dy.
bool insertVertex(double x, double y, QgsFeatureId atFeatureId, int beforeVertex)
Insert a new vertex before the given vertex number, in the given ring, item (first number is index 0)...
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addPart(const QVector< QgsPointXY > &ring, QgsFeatureId featureId)
Adds a new part polygon to a multipart feature.
Qgis::VectorEditResult deleteVertex(QgsFeatureId featureId, int vertex)
Deletes a vertex from a feature.
int addTopologicalPoints(const QgsGeometry &geom)
Adds topological points for every vertex of the geometry.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitParts(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits parts cut by the given line.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitFeatures(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
bool moveVertex(double x, double y, QgsFeatureId atFeatureId, int atVertex)
Moves the vertex at the given position number, ring and item (first number is index 0),...
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addRing(const QVector< QgsPointXY > &ring, const QgsFeatureIds &targetFeatureIds=QgsFeatureIds(), QgsFeatureId *modifiedFeatureId=nullptr)
Adds a ring to polygon/multipolygon features.
Vector layer specific subclass of QgsMapLayerElevationProperties.
QgsVectorLayerElevationProperties * clone() const override
Creates a clone of the properties.
Counts the features in a QgsVectorLayer in task.
A feature iterator which iterates over features from a QgsVectorLayer.
Manages joined fields for a vector layer.
bool containsJoins() const
Quick way to test if there is any join at all.
void joinedFieldsChanged()
Emitted whenever the list of joined fields changes (e.g.
Defines left outer join from our vector layer to some other vector layer.
QString targetFieldName() const
Returns name of the field of our layer that will be used for join.
QString joinLayerId() const
ID of the joined layer - may be used to resolve reference to the joined layer.
Implementation of QgsAbstractProfileGenerator for vector layers.
Implementation of threaded rendering for vector layers.
Implementation of layer selection properties for vector layers.
QgsVectorLayerSelectionProperties * clone() const override
Creates a clone of the properties.
Basic implementation of the labeling interface.
Implementation of map layer temporal properties for vector layers.
Contains settings which reflect the context in which vector layer tool operations should be considere...
QgsExpressionContext * expressionContext() const
Returns the optional expression context used by the vector layer tools.
static QString guessFriendlyIdentifierField(const QgsFields &fields, bool *foundFriendly=nullptr)
Given a set of fields, attempts to pick the "most useful" field for user-friendly identification of f...
Represents a vector layer which manages a vector based dataset.
void setLabeling(QgsAbstractVectorLayerLabeling *labeling)
Sets labeling configuration.
Q_INVOKABLE QString attributeDisplayName(int index) const
Convenience function that returns the attribute alias if defined or the field name else.
bool writeSymbology(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const final
Write the style for the layer into the document provided.
QSet< QgsMapLayerDependency > dependencies() const final
Gets the list of dependencies.
int addExpressionField(const QString &exp, const QgsField &fld)
Add a new field which is calculated by the expression specified.
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
Emitted when features are added to the provider if not in transaction mode.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addPart(const QList< QgsPointXY > &ring)
Adds a new part polygon to a multipart feature.
static const QgsSettingsEntryEnumFlag< Qgis::VectorRenderingSimplificationFlags > * settingsSimplifyDrawingHints
void featureBlendModeChanged(QPainter::CompositionMode blendMode)
Signal emitted when setFeatureBlendMode() is called.
bool labelsEnabled() const
Returns whether the layer contains labels which are enabled and should be drawn.
bool isModified() const override
Returns true if the provider has been modified since the last commit.
bool isEditable() const final
Returns true if the provider is in editing mode.
void addFeatureRendererGenerator(QgsFeatureRendererGenerator *generator)
Adds a new feature renderer generator to the layer.
Q_DECL_DEPRECATED void setExcludeAttributesWfs(const QSet< QString > &att)
A set of attributes that are not advertised in WFS requests with QGIS server.
Q_INVOKABLE bool deleteSelectedFeatures(int *deletedCount=nullptr, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes the selected features.
Q_INVOKABLE void selectByRect(QgsRectangle &rect, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects features found within the search rectangle (in layer's coordinates).
Q_INVOKABLE void removeFieldAlias(int index)
Removes an alias (a display name) for attributes to display in dialogs.
void setAuxiliaryLayer(QgsAuxiliaryLayer *layer=nullptr)
Sets the current auxiliary layer.
QVariant minimumValue(int index) const final
Returns the minimum value for an attribute column or an invalid variant in case of error.
void beforeRemovingExpressionField(int idx)
Will be emitted, when an expression field is going to be deleted from this vector layer.
Q_INVOKABLE bool deleteFeatures(const QgsFeatureIds &fids, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes a set of features from the layer (but does not commit it).
void committedGeometriesChanges(const QString &layerId, const QgsGeometryMap &changedGeometries)
Emitted when geometry changes are saved to the provider if not in transaction mode.
void beforeCommitChanges(bool stopEditing)
Emitted before changes are committed to the data provider.
Q_INVOKABLE bool startEditing()
Makes the layer editable.
void setFieldConfigurationFlags(int index, Qgis::FieldConfigurationFlags flags)
Sets the configuration flags of the field at given index.
QVariant maximumValue(int index) const final
Returns the maximum value for an attribute column or an invalid variant in case of error.
QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > fieldConstraintsAndStrength(int fieldIndex) const
Returns a map of constraint with their strength for a specific field of the layer.
bool addJoin(const QgsVectorLayerJoinInfo &joinInfo)
Joins another vector layer to this layer.
QgsVectorLayer(const QString &path=QString(), const QString &baseName=QString(), const QString &providerLib="ogr", const QgsVectorLayer::LayerOptions &options=QgsVectorLayer::LayerOptions())
Constructor - creates a vector layer.
QgsMapLayerTemporalProperties * temporalProperties() override
Returns the layer's temporal properties.
QgsExpressionContext createExpressionContext() const final
This method needs to be reimplemented in all classes which implement this interface and return an exp...
Q_INVOKABLE bool changeAttributeValue(QgsFeatureId fid, int field, const QVariant &newValue, const QVariant &oldValue=QVariant(), bool skipDefaultValues=false, QgsVectorLayerToolsContext *context=nullptr)
Changes an attribute value for a feature (but does not immediately commit the changes).
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitFeatures(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
QgsDefaultValue defaultValueDefinition(int index) const
Returns the definition of the expression used when calculating the default value for a field.
QgsVectorLayerFeatureCounter * countSymbolFeatures(bool storeSymbolFids=false)
Count features for symbols.
QPainter::CompositionMode featureBlendMode() const
Returns the current blending mode for features.
QString constraintExpression(int index) const
Returns the constraint expression for for a specified field index, if set.
Q_INVOKABLE bool addAttribute(const QgsField &field)
Add an attribute field (but does not commit it) returns true if the field was added.
void attributeAdded(int idx)
Will be emitted, when a new attribute has been added to this vector layer.
QString capabilitiesString() const
Capabilities for this layer, comma separated and translated.
void deselect(QgsFeatureId featureId)
Deselects feature by its ID.
void allowCommitChanged()
Emitted whenever the allowCommit() property of this layer changes.
friend class QgsVectorLayerEditBuffer
void editCommandStarted(const QString &text)
Signal emitted when a new edit command has been started.
void updateFields()
Will regenerate the fields property of this layer by obtaining all fields from the dataProvider,...
QgsBox3D extent3D() const final
Returns the 3D extent of the layer.
const QgsDiagramLayerSettings * diagramLayerSettings() const
void setFieldConstraint(int index, QgsFieldConstraints::Constraint constraint, QgsFieldConstraints::ConstraintStrength strength=QgsFieldConstraints::ConstraintStrengthHard)
Sets a constraint for a specified field index.
bool loadAuxiliaryLayer(const QgsAuxiliaryStorage &storage, const QString &key=QString())
Loads the auxiliary layer for this vector layer.
bool insertVertex(double x, double y, QgsFeatureId atFeatureId, int beforeVertex)
Inserts a new vertex before the given vertex number, in the given ring, item (first number is index 0...
QgsAbstractProfileGenerator * createProfileGenerator(const QgsProfileRequest &request) override
Given a profile request, returns a new profile generator ready for generating elevation profiles.
bool readSymbology(const QDomNode &layerNode, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) final
Read the symbology for the current layer from the DOM node supplied.
Q_INVOKABLE QgsRectangle boundingBoxOfSelected() const
Returns the bounding box of the selected features. If there is no selection, QgsRectangle(0,...
bool isSpatial() const final
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
Q_INVOKABLE QgsFeatureList selectedFeatures() const
Returns a copy of the user-selected features.
QString expressionField(int index) const
Returns the expression used for a given expression field.
void removeFeatureRendererGenerator(const QString &id)
Removes the feature renderer with matching id from the layer.
Q_INVOKABLE bool deleteFeature(QgsFeatureId fid, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes a feature from the layer (but does not commit it).
friend class QgsVectorLayerEditPassthrough
void setSimplifyMethod(const QgsVectorSimplifyMethod &simplifyMethod)
Sets the simplification settings for fast rendering of features.
void editCommandDestroyed()
Signal emitted, when an edit command is destroyed.
QVariant aggregate(Qgis::Aggregate aggregate, const QString &fieldOrExpression, const QgsAggregateCalculator::AggregateParameters ¶meters=QgsAggregateCalculator::AggregateParameters(), QgsExpressionContext *context=nullptr, bool *ok=nullptr, QgsFeatureIds *fids=nullptr, QgsFeedback *feedback=nullptr, QString *error=nullptr) const
Calculates an aggregated value from the layer's features.
QgsRectangle sourceExtent() const final
Returns the extent of all geometries from the source.
QgsFieldConstraints::Constraints fieldConstraints(int fieldIndex) const
Returns any constraints which are present for a specified field index.
static const QgsSettingsEntryEnumFlag< Qgis::VectorSimplificationAlgorithm > * settingsSimplifyAlgorithm
Q_DECL_DEPRECATED QSet< QString > excludeAttributesWms() const
A set of attributes that are not advertised in WMS requests with QGIS server.
QgsFeatureIds symbolFeatureIds(const QString &legendKey) const
Ids of features rendered with specified legend key.
void removeFieldConstraint(int index, QgsFieldConstraints::Constraint constraint)
Removes a constraint for a specified field index.
int selectedFeatureCount() const
Returns the number of features that are selected in this layer.
void featuresDeleted(const QgsFeatureIds &fids)
Emitted when features have been deleted.
Qgis::VectorLayerTypeFlags vectorLayerTypeFlags() const
Returns the vector layer type flags.
void setLabelsEnabled(bool enabled)
Sets whether labels should be enabled for the layer.
void subsetStringChanged()
Emitted when the layer's subset string has changed.
bool setDependencies(const QSet< QgsMapLayerDependency > &layers) final
Sets the list of dependencies.
QgsAuxiliaryLayer * auxiliaryLayer()
Returns the current auxiliary layer.
void setCoordinateSystem()
Setup the coordinate system transformation for the layer.
void committedFeaturesRemoved(const QString &layerId, const QgsFeatureIds &deletedFeatureIds)
Emitted when features are deleted from the provider if not in transaction mode.
void setFieldMergePolicy(int index, Qgis::FieldDomainMergePolicy policy)
Sets a merge policy for the field with the specified index.
void updateExpressionField(int index, const QString &exp)
Changes the expression used to define an expression based (virtual) field.
Q_INVOKABLE void selectByExpression(const QString &expression, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection, QgsExpressionContext *context=nullptr)
Selects matching features using an expression.
static const QgsSettingsEntryDouble * settingsSimplifyMaxScale
void reload() final
Synchronises with changes in the datasource.
long long featureCount() const final
Returns feature count including changes which have not yet been committed If you need only the count ...
~QgsVectorLayer() override
QgsRectangle extent() const final
Returns the extent of the layer.
void endEditCommand()
Finish edit command and add it to undo/redo stack.
void destroyEditCommand()
Destroy active command and reverts all changes in it.
bool isAuxiliaryField(int index, int &srcIndex) const
Returns true if the field comes from the auxiliary layer, false otherwise.
bool hasMapTips() const final
Returns true if the layer contains map tips.
Q_INVOKABLE Qgis::WkbType wkbType() const final
Returns the WKBType or WKBUnknown in case of error.
void setExtent(const QgsRectangle &rect) final
Sets the extent.
QList< QgsRelation > referencingRelations(int idx) const
Returns the layer's relations, where the foreign key is on this layer.
Q_DECL_DEPRECATED QSet< QString > excludeAttributesWfs() const
A set of attributes that are not advertised in WFS requests with QGIS server.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitParts(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits parts cut by the given line.
void setDefaultValueDefinition(int index, const QgsDefaultValue &definition)
Sets the definition of the expression to use when calculating the default value for a field.
bool diagramsEnabled() const
Returns whether the layer contains diagrams which are enabled and should be drawn.
void setAllowCommit(bool allowCommit)
Controls, if the layer is allowed to commit changes.
QgsBox3D sourceExtent3D() const final
Returns the 3D extent of all geometries from the source.
void symbolFeatureCountMapChanged()
Emitted when the feature count for symbols on this layer has been recalculated.
Q_INVOKABLE const QgsFeatureIds & selectedFeatureIds() const
Returns a list of the selected features IDs in this layer.
Qgis::VectorEditResult deleteVertex(QgsFeatureId featureId, int vertex)
Deletes a vertex from a feature.
Qgis::FeatureAvailability hasFeatures() const final
Determines if this vector layer has features.
void setFeatureBlendMode(QPainter::CompositionMode blendMode)
Sets the blending mode used for rendering each feature.
QString constraintDescription(int index) const
Returns the descriptive name for the constraint expression for a specified field index.
void writeCustomSymbology(QDomElement &element, QDomDocument &doc, QString &errorMessage) const
Signal emitted whenever the symbology (QML-file) for this layer is being written.
const QgsAbstractVectorLayerLabeling * labeling() const
Access to const labeling configuration.
bool writeStyle(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const final
Write just the symbology information for the layer into the document.
void setProviderEncoding(const QString &encoding)
Sets the text encoding of the data provider.
Q_DECL_DEPRECATED bool writeSld(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QVariantMap &props=QVariantMap()) const
Writes the symbology of the layer into the document provided in SLD 1.1 format.
void setDisplayExpression(const QString &displayExpression)
Set the preview expression, used to create a human readable preview string.
virtual Q_INVOKABLE bool deleteAttribute(int attr)
Deletes an attribute field (but does not commit it).
static const QgsSettingsEntryBool * settingsSimplifyLocal
QString loadDefaultStyle(bool &resultFlag) final
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
bool simplifyDrawingCanbeApplied(const QgsRenderContext &renderContext, Qgis::VectorRenderingSimplificationFlag simplifyHint) const
Returns whether the VectorLayer can apply the specified simplification hint.
QString htmlMetadata() const final
Obtain a formatted HTML string containing assorted metadata for this layer.
QgsMapLayerElevationProperties * elevationProperties() override
Returns the layer's elevation properties.
bool removeJoin(const QString &joinLayerId)
Removes a vector layer join.
Q_INVOKABLE void invertSelectionInRectangle(QgsRectangle &rect)
Inverts selection of features found within the search rectangle (in layer's coordinates).
void setRenderer(QgsFeatureRenderer *r)
Sets the feature renderer which will be invoked to represent this layer in 2D map views.
Q_INVOKABLE void selectAll()
Select all the features.
QStringList commitErrors() const
Returns a list containing any error messages generated when attempting to commit changes to the layer...
QString decodedSource(const QString &source, const QString &provider, const QgsReadWriteContext &context) const final
Called by readLayerXML(), used by derived classes to decode provider's specific data source from proj...
QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
QString encodedSource(const QString &source, const QgsReadWriteContext &context) const final
Called by writeLayerXML(), used by derived classes to encode provider's specific data source to proje...
bool readExtentFromXml() const
Returns true if the extent is read from the XML document when data source has no metadata,...
QString dataComment() const
Returns a description for this layer as defined in the data provider.
bool accept(QgsStyleEntityVisitorInterface *visitor) const override
QgsExpressionContextScope * createExpressionContextScope() const final
This method needs to be reimplemented in all classes which implement this interface and return an exp...
QgsGeometryOptions * geometryOptions() const
Configuration and logic to apply automatically on any edit happening on this layer.
QgsStringMap attributeAliases() const
Returns a map of field name to attribute alias.
Q_INVOKABLE int translateFeature(QgsFeatureId featureId, double dx, double dy)
Translates feature by dx, dy.
virtual void updateExtents(bool force=false)
Update the extents for the layer.
void attributeDeleted(int idx)
Will be emitted, when an attribute has been deleted from this vector layer.
QgsFeatureRenderer * renderer()
Returns the feature renderer used for rendering the features in the layer in 2D map views.
void beforeEditingStarted()
Emitted before editing on this layer is started.
void committedAttributeValuesChanges(const QString &layerId, const QgsChangedAttributesMap &changedAttributesValues)
Emitted when attribute value changes are saved to the provider if not in transaction mode.
void committedAttributesAdded(const QString &layerId, const QList< QgsField > &addedAttributes)
Emitted when attributes are added to the provider if not in transaction mode.
void setEditFormConfig(const QgsEditFormConfig &editFormConfig)
Sets the editFormConfig (configuration) of the form used to represent this vector layer.
Qgis::FieldConfigurationFlags fieldConfigurationFlags(int index) const
Returns the configuration flags of the field at given index.
void committedAttributesDeleted(const QString &layerId, const QgsAttributeList &deletedAttributes)
Emitted when attributes are deleted from the provider if not in transaction mode.
QString displayExpression
void displayExpressionChanged()
Emitted when the display expression changes.
QgsFeatureIterator getSelectedFeatures(QgsFeatureRequest request=QgsFeatureRequest()) const
Returns an iterator of the selected features.
void setEditorWidgetSetup(int index, const QgsEditorWidgetSetup &setup)
Sets the editor widget setup for the field at the specified index.
void setConstraintExpression(int index, const QString &expression, const QString &description=QString())
Sets the constraint expression for the specified field index.
Q_INVOKABLE bool rollBack(bool deleteBuffer=true)
Stops a current editing operation and discards any uncommitted edits.
QString sourceName() const final
Returns a friendly display name for the source.
bool readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) final
Read the style for the current layer from the DOM node supplied.
Q_INVOKABLE bool updateFeature(QgsFeature &feature, bool skipDefaultValues=false)
Updates an existing feature in the layer, replacing the attributes and geometry for the feature with ...
Q_INVOKABLE bool commitChanges(bool stopEditing=true)
Attempts to commit to the underlying data provider any buffered changes made since the last to call t...
void setFieldConfigurationFlag(int index, Qgis::FieldConfigurationFlag flag, bool active)
Sets the given configuration flag for the field at given index to be active or not.
void setFieldDuplicatePolicy(int index, Qgis::FieldDuplicatePolicy policy)
Sets a duplicate policy for the field with the specified index.
bool setReadOnly(bool readonly=true)
Makes layer read-only (editing disabled) or not.
void editFormConfigChanged()
Will be emitted whenever the edit form configuration of this layer changes.
Q_INVOKABLE void modifySelection(const QgsFeatureIds &selectIds, const QgsFeatureIds &deselectIds)
Modifies the current selection on this layer.
void setWeakRelations(const QList< QgsWeakRelation > &relations)
Sets the layer's weak relations.
void resolveReferences(QgsProject *project) final
Resolves references to other layers (kept as layer IDs after reading XML) into layer objects.
void reselect()
Reselects the previous set of selected features.
void select(QgsFeatureId featureId)
Selects feature by its ID.
QgsEditorWidgetSetup editorWidgetSetup(int index) const
Returns the editor widget setup for the field at the specified index.
bool readSld(const QDomNode &node, QString &errorMessage) final
QgsMapLayerRenderer * createMapRenderer(QgsRenderContext &rendererContext) final
Returns new instance of QgsMapLayerRenderer that will be used for rendering of given context.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const final
Queries the layer for features specified in request.
void setReadExtentFromXml(bool readExtentFromXml)
Flag allowing to indicate if the extent has to be read from the XML document when data source has no ...
void afterCommitChanges()
Emitted after changes are committed to the data provider.
QgsVectorLayer * clone() const override
Returns a new instance equivalent to this one.
QgsAttributeTableConfig attributeTableConfig() const
Returns the attribute table configuration object.
QgsActionManager * actions()
Returns all layer actions defined on this layer.
Q_INVOKABLE void selectByIds(const QgsFeatureIds &ids, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects matching features using a list of feature IDs.
QStringList uniqueStringsMatching(int index, const QString &substring, int limit=-1, QgsFeedback *feedback=nullptr) const
Returns unique string values of an attribute which contain a specified subset string.
void raiseError(const QString &msg)
Signals an error related to this vector layer.
void editCommandEnded()
Signal emitted, when an edit command successfully ended.
void supportsEditingChanged()
Emitted when the read only state or the data provider of this layer is changed.
QgsCoordinateReferenceSystem sourceCrs() const final
Returns the coordinate reference system for features in the source.
void readOnlyChanged()
Emitted when the read only state of this layer is changed.
void removeExpressionField(int index)
Removes an expression field.
void setTransformContext(const QgsCoordinateTransformContext &transformContext) override
Sets the coordinate transform context to transformContext.
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &value)
Emitted whenever an attribute value change is done in the edit buffer.
static Q_DECL_DEPRECATED void drawVertexMarker(double x, double y, QPainter &p, Qgis::VertexMarkerType type, int vertexSize)
Draws a vertex symbol at (screen) coordinates x, y.
Q_INVOKABLE void setFieldAlias(int index, const QString &aliasString)
Sets an alias (a display name) for attributes to display in dialogs.
friend class QgsVectorLayerFeatureSource
void minimumAndMaximumValue(int index, QVariant &minimum, QVariant &maximum) const
Calculates both the minimum and maximum value for an attribute column.
Q_INVOKABLE Qgis::GeometryType geometryType() const
Returns point, line or polygon.
Q_DECL_DEPRECATED void setExcludeAttributesWms(const QSet< QString > &att)
A set of attributes that are not advertised in WMS requests with QGIS server.
void setAttributeTableConfig(const QgsAttributeTableConfig &attributeTableConfig)
Sets the attribute table configuration object.
virtual bool setSubsetString(const QString &subset)
Sets the string (typically sql) used to define a subset of the layer.
void afterRollBack()
Emitted after changes are rolled back.
bool writeXml(QDomNode &layer_node, QDomDocument &doc, const QgsReadWriteContext &context) const final
Writes vector layer specific state to project file Dom node.
void setDiagramLayerSettings(const QgsDiagramLayerSettings &s)
bool readXml(const QDomNode &layer_node, QgsReadWriteContext &context) final
Reads vector layer specific state from project file Dom node.
QList< QgsWeakRelation > weakRelations() const
Returns the layer's weak relations as specified in the layer's style.
const QgsVectorSimplifyMethod & simplifyMethod() const
Returns the simplification settings for fast rendering of features.
void selectionChanged(const QgsFeatureIds &selected, const QgsFeatureIds &deselected, bool clearAndSelect)
Emitted when selection was changed.
void beforeAddingExpressionField(const QString &fieldName)
Will be emitted, when an expression field is going to be added to this vector layer.
Q_INVOKABLE bool deleteAttributes(const QList< int > &attrs)
Deletes a list of attribute fields (but does not commit it).
void updatedFields()
Emitted whenever the fields available from this layer have been changed.
QVariant defaultValue(int index, const QgsFeature &feature=QgsFeature(), QgsExpressionContext *context=nullptr) const
Returns the calculated default value for the specified field index.
void featureAdded(QgsFeatureId fid)
Emitted when a new feature has been added to the layer.
Q_INVOKABLE QString attributeAlias(int index) const
Returns the alias of an attribute name or a null string if there is no alias.
void featureDeleted(QgsFeatureId fid)
Emitted when a feature has been deleted.
Q_INVOKABLE void removeSelection()
Clear selection.
bool allowCommit() const
Controls, if the layer is allowed to commit changes.
QgsConditionalLayerStyles * conditionalStyles() const
Returns the conditional styles that are set for this layer.
void readCustomSymbology(const QDomElement &element, QString &errorMessage)
Signal emitted whenever the symbology (QML-file) for this layer is being read.
void setExtent3D(const QgsBox3D &rect) final
Sets the extent.
const QList< QgsVectorLayerJoinInfo > vectorJoins() const
Q_INVOKABLE bool renameAttribute(int index, const QString &newName)
Renames an attribute field (but does not commit it).
bool isSqlQuery() const
Returns true if the layer is a query (SQL) layer.
void beforeRollBack()
Emitted before changes are rolled back.
QgsAttributeList primaryKeyAttributes() const
Returns the list of attributes which make up the layer's primary keys.
void beginEditCommand(const QString &text)
Create edit command for undo/redo operations.
QString displayField() const
This is a shorthand for accessing the displayExpression if it is a simple field.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addRing(const QVector< QgsPointXY > &ring, QgsFeatureId *featureId=nullptr)
Adds a ring to polygon/multipolygon features.
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) final
Adds a list of features to the sink.
void setDiagramRenderer(QgsDiagramRenderer *r)
Sets diagram rendering object (takes ownership).
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geometry)
Emitted whenever a geometry change is done in the edit buffer.
QgsEditFormConfig editFormConfig
QList< const QgsFeatureRendererGenerator * > featureRendererGenerators() const
Returns a list of the feature renderer generators owned by the layer.
QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const final
Calculates a list of unique values contained within an attribute in the layer.
bool moveVertex(double x, double y, QgsFeatureId atFeatureId, int atVertex)
Moves the vertex at the given position number, ring and item (first number is index 0),...
QgsGeometry getGeometry(QgsFeatureId fid) const
Queries the layer for the geometry at the given id.
int addTopologicalPoints(const QgsGeometry &geom)
Adds topological points for every vertex of the geometry.
bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) final
Adds a single feature to the sink.
void beforeModifiedCheck() const
Emitted when the layer is checked for modifications. Use for last-minute additions.
Q_INVOKABLE QgsFeature getFeature(QgsFeatureId fid) const
Queries the layer for the feature with the given id.
Q_INVOKABLE void invertSelection()
Selects not selected features and deselects selected ones.
const QgsDiagramRenderer * diagramRenderer() const
Q_INVOKABLE bool changeAttributeValues(QgsFeatureId fid, const QgsAttributeMap &newValues, const QgsAttributeMap &oldValues=QgsAttributeMap(), bool skipDefaultValues=false, QgsVectorLayerToolsContext *context=nullptr)
Changes attributes' values for a feature (but does not immediately commit the changes).
QgsMapLayerSelectionProperties * selectionProperties() override
Returns the layer's selection properties.
QgsVectorDataProvider * dataProvider() final
Returns the layer's data provider, it may be nullptr.
Q_INVOKABLE bool changeGeometry(QgsFeatureId fid, QgsGeometry &geometry, bool skipDefaultValue=false)
Changes a feature's geometry within the layer's edit buffer (but does not immediately commit the chan...
static const QgsSettingsEntryDouble * settingsSimplifyDrawingTol
Qgis::SpatialIndexPresence hasSpatialIndex() const override
void setFieldSplitPolicy(int index, Qgis::FieldDomainSplitPolicy policy)
Sets a split policy for the field with the specified index.
@ Referencing
The layer is referencing (or the "child" / "right" layer in the relationship).
@ Referenced
The layer is referenced (or the "parent" / "left" left in the relationship).
static void writeXml(const QgsVectorLayer *layer, WeakRelationType type, const QgsRelation &relation, QDomNode &node, QDomDocument &doc)
Writes a weak relation infoto an XML structure.
static QgsWeakRelation readXml(const QgsVectorLayer *layer, WeakRelationType type, const QDomNode &node, const QgsPathResolver resolver)
Returns a weak relation for the given layer.
static Qgis::GeometryType geometryType(Qgis::WkbType type)
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
static Q_INVOKABLE QString displayString(Qgis::WkbType type)
Returns a non-translated display string type for a WKB type, e.g., the geometry name used in WKT geom...
static Q_INVOKABLE QString geometryDisplayString(Qgis::GeometryType type)
Returns a display string for a geometry type.
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
static QgsBox3D readBox3D(const QDomElement &element)
Decodes a DOM element to a 3D box.
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
static QgsRectangle readRectangle(const QDomElement &element)
@ UnknownCount
Provider returned an unknown feature count.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored).
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 c
bool qgsVariantEqual(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether they are equal, two NULL values are always treated a...
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.
T qgsEnumKeyToValue(const QString &key, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given key of an enum.
QString qgsEnumValueToKey(const T &value, bool *returnOk=nullptr)
Returns the value for the given key of an enum.
QString qgsFlagValueToKeys(const T &value, bool *returnOk=nullptr)
Returns the value for the given keys of a flag.
T qgsFlagKeysToValue(const QString &keys, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given keys of a flag.
QMap< QString, QString > QgsStringMap
QVector< QgsPoint > QgsPointSequence
QMap< int, QVariant > QgsAttributeMap
QList< QgsFeature > QgsFeatureList
QSet< QgsFeatureId > QgsFeatureIds
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
#define QgsDebugMsgLevel(str, level)
#define QgsDebugError(str)
QMap< int, QgsPropertyDefinition > QgsPropertiesDefinition
Definition of available properties.
#define RENDERER_TAG_NAME
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS_NON_FATAL
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS
bool saveStyle_t(const QString &uri, const QString &qmlStyle, const QString &sldStyle, const QString &styleName, const QString &styleDescription, const QString &uiFileContent, bool useAsDefault, QString &errCause)
int listStyles_t(const QString &uri, QStringList &ids, QStringList &names, QStringList &descriptions, QString &errCause)
QString getStyleById_t(const QString &uri, QString styleID, QString &errCause)
bool deleteStyleById_t(const QString &uri, QString styleID, QString &errCause)
QString loadStyle_t(const QString &uri, QString &errCause)
QList< int > QgsAttributeList
QMap< QgsFeatureId, QgsFeature > QgsFeatureMap
A bundle of parameters controlling aggregate calculation.
Setting options for creating vector data providers.
Context for cascade delete features.
QList< QgsVectorLayer * > handledLayers(bool includeAuxiliaryLayers=true) const
Returns a list of all layers affected by the delete operation.
QMap< QgsVectorLayer *, QgsFeatureIds > mHandledFeatures
QgsFeatureIds handledFeatures(QgsVectorLayer *layer) const
Returns a list of feature IDs from the specified layer affected by the delete operation.
Setting options for loading vector layers.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool forceReadOnly
Controls whether the layer is forced to be load as Read Only.
bool loadDefaultStyle
Set to true if the default layer style should be loaded.
QgsCoordinateTransformContext transformContext
Coordinate transform context.
QgsCoordinateReferenceSystem fallbackCrs
Fallback layer coordinate reference system.
Qgis::WkbType fallbackWkbType
Fallback geometry type.
bool loadAllStoredStyles
Controls whether the stored styles will be all loaded.