104#include <QPainterPath>
106#include <QProgressDialog>
107#include <QRegularExpression>
109#include <QStringBuilder>
111#include <QUndoCommand>
117#include "moc_qgsvectorlayer.cpp"
119using namespace Qt::StringLiterals;
130#ifdef TESTPROVIDERLIB
135 const QString &uri,
const QString &qmlStyle,
const QString &sldStyle,
const QString &styleName,
const QString &styleDescription,
const QString &uiFileContent,
bool useAsDefault, QString &errCause
138typedef QString
loadStyle_t(
const QString &uri, QString &errCause );
140typedef int listStyles_t(
const QString &uri, QStringList &ids, QStringList &names, QStringList &descriptions, QString &errCause );
142typedef QString
getStyleById_t(
const QString &uri, QString styleID, QString &errCause );
152 , mAuxiliaryLayer( nullptr )
153 , mAuxiliaryLayerKey( QString() )
155 , mRefreshRendererTimer( new QTimer( this ) )
166 mGeometryOptions = std::make_unique<QgsGeometryOptions>();
170 mStoredExpressionManager->setParent(
this );
173 mJoinBuffer->setParent(
this );
178 if ( !vectorLayerPath.isEmpty() && !
mProviderKey.isEmpty() )
189 mDataSourceReadOnly =
true;
191 setDataSource( vectorLayerPath, baseName, providerKey, providerOptions, providerFlags );
194 for (
const QgsField &field : std::as_const( mFields ) )
196 if ( !mAttributeAliasMap.contains( field.name() ) )
197 mAttributeAliasMap.insert( field.name(), QString() );
202 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities( mDataProvider->temporalCapabilities() );
203 if ( !mTemporalProperties->isActive() )
207 mTemporalProperties->guessDefaultsFromFields( mFields );
210 mElevationProperties->setDefaultsFromLayer(
this );
227 connect( mRefreshRendererTimer, &QTimer::timeout,
this, [
this] {
triggerRepaint(
true ); } );
236 delete mDataProvider;
239 delete mExpressionFieldBuffer;
241 delete mDiagramLayerSettings;
242 delete mDiagramRenderer;
247 delete mConditionalStyles;
248 delete mStoredExpressionManager;
250 if ( mFeatureCounter )
251 mFeatureCounter->cancel();
253 qDeleteAll( mRendererGenerators );
267 dataSource = mDataProvider->dataSourceUri();
268 options.transformContext = mDataProvider->transformContext();
281 layer->mXmlExtent2D = mXmlExtent2D;
282 layer->mLazyExtent2D = mLazyExtent2D;
283 layer->mValidExtent2D = mValidExtent2D;
284 layer->mXmlExtent3D = mXmlExtent3D;
285 layer->mLazyExtent3D = mLazyExtent3D;
286 layer->mValidExtent3D = mValidExtent3D;
288 QList<QgsVectorLayerJoinInfo> joins =
vectorJoins();
289 const auto constJoins = joins;
310 for (
const QgsAction &action : constActions )
347 auto constraintIt = constraints.constBegin();
348 for ( ; constraintIt != constraints.constEnd(); ++constraintIt )
364 layer->mElevationProperties = mElevationProperties->
clone();
365 layer->mElevationProperties->setParent( layer );
367 layer->mSelectionProperties = mSelectionProperties->
clone();
368 layer->mSelectionProperties->setParent( layer );
379 return mDataProvider->storageType();
391 return mDataProvider->capabilitiesString();
400 return mDataProvider && mDataProvider->isSqlQuery();
416 return mDataProvider->dataComment();
442 mDataProvider->reloadData();
461 p.setPen( QColor( 50, 100, 120, 200 ) );
462 p.setBrush( QColor( 200, 200, 210, 120 ) );
463 p.drawEllipse( x - m, y - m, m * 2 + 1, m * 2 + 1 );
467 p.setPen( QColor( 255, 0, 0 ) );
468 p.drawLine( x - m, y + m, x + m, y - m );
469 p.drawLine( x - m, y - m, x + m, y + m );
481 mSelectedFeatureIds.insert( fid );
482 mPreviousSelectedFeatureIds.clear();
491 mSelectedFeatureIds.unite( featureIds );
492 mPreviousSelectedFeatureIds.clear();
501 mSelectedFeatureIds.remove( fid );
502 mPreviousSelectedFeatureIds.clear();
511 mSelectedFeatureIds.subtract( featureIds );
512 mPreviousSelectedFeatureIds.clear();
534 newSelection << feat.
id();
547 std::optional< QgsExpressionContext > defaultContext;
551 context = &defaultContext.value();
578 newSelection << feat.
id();
597 bool matches = exp.
evaluate( context ).toBool();
601 newSelection << feat.
id();
605 newSelection << feat.
id();
629 newSelection = idsToSelect;
633 newSelection = mSelectedFeatureIds + idsToSelect;
637 newSelection = mSelectedFeatureIds - idsToSelect;
641 newSelection = mSelectedFeatureIds.intersect( idsToSelect );
645 QgsFeatureIds deselectedFeatures = mSelectedFeatureIds - newSelection;
646 mSelectedFeatureIds = newSelection;
647 mPreviousSelectedFeatureIds.clear();
657 if ( !intersectingIds.isEmpty() )
659 QgsDebugMsgLevel( u
"Trying to select and deselect the same item at the same time. Unsure what to do. Selecting dubious items."_s, 3 );
662 mSelectedFeatureIds -= deselectIds;
663 mSelectedFeatureIds += selectIds;
664 mPreviousSelectedFeatureIds.clear();
674 ids.subtract( mSelectedFeatureIds );
701 if ( mSelectedFeatureIds.contains( fet.
id() ) )
703 deselectIds << fet.
id();
707 selectIds << fet.
id();
718 if ( mSelectedFeatureIds.isEmpty() )
723 mPreviousSelectedFeatureIds = previous;
730 if ( mPreviousSelectedFeatureIds.isEmpty() || !mSelectedFeatureIds.empty() )
741 return mDataProvider;
749 return mDataProvider;
757 return mSelectionProperties;
764 return mTemporalProperties;
771 return mElevationProperties;
787 if (
isValid() && mDataProvider && mDataProvider->encoding() != encoding )
789 mDataProvider->setEncoding( encoding );
798 delete mDiagramRenderer;
799 mDiagramRenderer = r;
823 if ( !
isValid() || !
isSpatial() || mSelectedFeatureIds.isEmpty() || !mDataProvider )
850 if ( mSelectedFeatureIds.contains( fet.
id() ) )
861 if ( retval.
width() == 0.0 || retval.
height() == 0.0 )
869 retval.
set( -1.0, -1.0, 1.0, 1.0 );
881 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
888 mLabelsEnabled = enabled;
896 if ( !mDiagramRenderer || !mDiagramLayerSettings )
899 QList<QgsDiagramSettings> settingList = mDiagramRenderer->diagramSettings();
900 if ( !settingList.isEmpty() )
902 return settingList.at( 0 ).enabled;
911 if ( !mSymbolFeatureCounted )
914 return mSymbolFeatureCountMap.value( legendKey, -1 );
921 if ( !mSymbolFeatureCounted )
924 return mSymbolFeatureIdMap.value( legendKey,
QgsFeatureIds() );
930 if ( ( mSymbolFeatureCounted || mFeatureCounter ) && !( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
931 return mFeatureCounter;
933 mSymbolFeatureCountMap.clear();
934 mSymbolFeatureIdMap.clear();
939 return mFeatureCounter;
941 if ( !mDataProvider )
944 return mFeatureCounter;
949 return mFeatureCounter;
952 if ( !mFeatureCounter || ( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
955 connect( mFeatureCounter, &
QgsTask::taskCompleted,
this, &QgsVectorLayer::onFeatureCounterCompleted, Qt::UniqueConnection );
956 connect( mFeatureCounter, &
QgsTask::taskTerminated,
this, &QgsVectorLayer::onFeatureCounterTerminated, Qt::UniqueConnection );
960 return mFeatureCounter;
968 if ( force || !mReadExtentFromXml || ( mReadExtentFromXml && mXmlExtent2D.isNull() && mXmlExtent3D.isNull() ) )
970 mValidExtent2D =
false;
971 mValidExtent3D =
false;
980 mValidExtent2D =
true;
988 mValidExtent3D =
true;
995 if ( !mDefaultValueOnUpdateFields.isEmpty() )
1000 int size = mFields.
size();
1001 for (
int idx : std::as_const( mDefaultValueOnUpdateFields ) )
1003 if ( idx < 0 || idx >= size )
1023 mLazyExtent2D =
false;
1030 updateExtent( mDataProvider->extent() );
1031 mValidExtent2D =
true;
1032 mLazyExtent2D =
false;
1036 if ( !mValidExtent2D && mLazyExtent2D && mReadExtentFromXml && !mXmlExtent2D.isNull() )
1038 updateExtent( mXmlExtent2D );
1039 mValidExtent2D =
true;
1040 mLazyExtent2D =
false;
1043 if ( !mValidExtent2D && mLazyExtent2D && mDataProvider && mDataProvider->isValid() )
1046 updateExtent( mDataProvider->extent() );
1047 mValidExtent2D =
true;
1048 mLazyExtent2D =
false;
1051 QgsDebugMsgLevel( u
"2D Extent of layer: %1"_s.arg( mExtent2D.toString() ), 3 );
1055 if ( mValidExtent2D )
1058 if ( !
isValid() || !mDataProvider )
1060 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1065 || ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) )
1068 mDataProvider->updateExtents();
1072 if ( mDataProvider->featureCount() != 0 )
1078 if ( mEditBuffer && !mDataProvider->transaction() )
1080 const auto addedFeatures = mEditBuffer->addedFeatures();
1081 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1083 if ( it->hasGeometry() )
1106 if ( rect.xMinimum() > rect.xMaximum() && rect.yMinimum() > rect.yMaximum() )
1112 updateExtent( rect );
1113 mValidExtent2D =
true;
1126 if ( mDataProvider && mDataProvider->elevationProperties() && !mDataProvider->elevationProperties()->containsElevationData() )
1142 updateExtent( mDataProvider->extent3D() );
1143 mValidExtent3D =
true;
1144 mLazyExtent3D =
false;
1148 if ( !mValidExtent3D && mLazyExtent3D && mReadExtentFromXml && !mXmlExtent3D.isNull() )
1150 updateExtent( mXmlExtent3D );
1151 mValidExtent3D =
true;
1152 mLazyExtent3D =
false;
1155 if ( !mValidExtent3D && mLazyExtent3D && mDataProvider && mDataProvider->isValid() )
1158 updateExtent( mDataProvider->extent3D() );
1159 mValidExtent3D =
true;
1160 mLazyExtent3D =
false;
1163 QgsDebugMsgLevel( u
"3D Extent of layer: %1"_s.arg( mExtent3D.toString() ), 3 );
1167 if ( mValidExtent3D )
1170 if ( !
isValid() || !mDataProvider )
1172 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1177 || ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) )
1180 mDataProvider->updateExtents();
1184 if ( mDataProvider->featureCount() != 0 )
1186 const QgsBox3D ext = mDataProvider->extent3D();
1187 extent.combineWith( ext );
1190 if ( mEditBuffer && !mDataProvider->transaction() )
1192 const auto addedFeatures = mEditBuffer->addedFeatures();
1193 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1195 if ( it->hasGeometry() )
1197 const QgsBox3D bbox = it->geometry().boundingBox3D();
1198 extent.combineWith( bbox );
1213 extent.combineWith( bb );
1225 mValidExtent3D =
true;
1251 if ( !
isValid() || !mDataProvider )
1253 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1256 return mDataProvider->subsetString();
1263 if ( !
isValid() || !mDataProvider )
1265 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider or while editing"_s, 3 );
1269 else if ( mEditBuffer )
1275 if ( subset == mDataProvider->subsetString() )
1278 bool res = mDataProvider->setSubsetString( subset );
1303 && ( mSimplifyMethod.simplifyHints() & simplifyHint )
1306 double maximumSimplificationScale = mSimplifyMethod.maximumScale();
1309 return !( maximumSimplificationScale > 1 && renderContext.
rendererScale() <= maximumSimplificationScale );
1318 return mConditionalStyles;
1326 if ( !
isValid() || !mDataProvider )
1338 if ( feature.isValid() )
1339 return feature.geometry();
1348 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1352 if ( mGeometryOptions->isActive() )
1355 mGeometryOptions->apply( geom );
1359 bool success = mEditBuffer->addFeature( feature );
1361 if ( success && mJoinBuffer->containsJoins() )
1363 success = mJoinBuffer->addFeature( feature );
1373 if ( !mEditBuffer || !mDataProvider )
1379 if ( currentFeature.
isValid() )
1381 bool hasChanged =
false;
1382 bool hasError =
false;
1394 QgsDebugMsgLevel( u
"geometry of feature %1 could not be changed."_s.arg( updatedFeature.
id() ), 3 );
1401 for (
int attr = 0; attr < fa.count(); ++attr )
1411 QgsDebugMsgLevel( u
"attribute %1 of feature %2 could not be changed."_s.arg( attr ).arg( updatedFeature.
id() ), 3 );
1416 if ( hasChanged && !mDefaultValueOnUpdateFields.isEmpty() && !skipDefaultValues )
1417 updateDefaultValues( updatedFeature.
id(), updatedFeature );
1423 QgsDebugMsgLevel( u
"feature %1 could not be retrieved"_s.arg( updatedFeature.
id() ), 3 );
1433 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1437 bool result = utils.
insertVertex( x, y, atFeatureId, beforeVertex );
1448 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1452 bool result = utils.
insertVertex( point, atFeatureId, beforeVertex );
1463 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1467 bool result = utils.
moveVertex( x, y, atFeatureId, atVertex );
1478 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1482 bool result = utils.
moveVertex( p, atFeatureId, atVertex );
1493 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1508 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1534 int count = mSelectedFeatureIds.size();
1547 *deletedCount = deleted;
1550 return deleted == count;
1553static const QgsPointSequence vectorPointXY2pointSequence(
const QVector<QgsPointXY> &points )
1556 pts.reserve( points.size() );
1557 QVector<QgsPointXY>::const_iterator it = points.constBegin();
1558 while ( it != points.constEnd() )
1569 return addRing( vectorPointXY2pointSequence( ring ), featureId );
1576 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1583 if ( !mSelectedFeatureIds.isEmpty() )
1585 result = utils.
addRing( ring, mSelectedFeatureIds, featureId );
1601 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1622 if ( !mSelectedFeatureIds.isEmpty() )
1624 result = utils.
addRing(
static_cast< QgsCurve *
>( ring->
clone() ), mSelectedFeatureIds, featureId );
1642 pts.reserve( points.size() );
1643 for ( QList<QgsPointXY>::const_iterator it = points.constBegin(); it != points.constEnd(); ++it )
1654 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1659 if ( mSelectedFeatureIds.empty() )
1664 else if ( mSelectedFeatureIds.size() > 1 )
1682 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1687 if ( mSelectedFeatureIds.empty() )
1692 else if ( mSelectedFeatureIds.size() > 1 )
1711 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1726 return splitParts( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1733 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1737 return utils.
splitParts( splitLine, topologicalEditing );
1744 return splitFeatures( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1753 bool preserveCircular =
false;
1754 return splitFeatures( &splitLineString, topologyTestPoints, preserveCircular, topologicalEditing );
1761 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1765 return utils.
splitFeatures( curve, topologyTestPoints, preserveCircular, topologicalEditing );
1772 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1790 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1801 if ( !
mValid || !mEditBuffer || !mDataProvider )
1826 if ( !
isValid() || !mDataProvider )
1843 mDataProvider->enterUpdateMode();
1860 if ( mDataProvider )
1876 if ( !mRenderer->accept( visitor ) )
1880 if ( !mLabeling->accept( visitor ) )
1892 const QList<QgsAction>
actions = mActions->actions();
1895 if ( action.command().isEmpty() )
1900 switch ( action.type() )
1927 switch ( mEditFormConfig.initCodeSource() )
1931 initCode = u
"# Calling function ’%1’\n\n%2"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initCode() );
1938 if ( inputFile && inputFile->open( QFile::ReadOnly ) )
1941 QTextStream inf( inputFile );
1942 initCode = inf.readAll();
1944 initCode = u
"# Calling function ’%1’\n# From file %2\n\n"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initFilePath() ) + initCode;
1951 initCode = u
"# Calling function ’%1’\n# From environment\n\n"_s.arg( mEditFormConfig.initFunction() );
1961 if ( !initCode.isEmpty() )
1980 QDomNode pkeyNode = layer_node.namedItem( u
"provider"_s );
1982 if ( pkeyNode.isNull() )
1988 QDomElement pkeyElt = pkeyNode.toElement();
2007 const QDomElement elem = layer_node.toElement();
2021 if ( elem.hasAttribute( u
"wkbType"_s ) )
2025 QDomElement pkeyElem = pkeyNode.toElement();
2026 if ( !pkeyElem.isNull() )
2028 QString encodingString = pkeyElem.attribute( u
"encoding"_s );
2029 if ( mDataProvider && !encodingString.isEmpty() )
2031 mDataProvider->setEncoding( encodingString );
2036 mJoinBuffer->readXml( layer_node );
2041 mSetLegendFromStyle =
false;
2051 QDomNode depsNode = layer_node.namedItem( u
"dataDependencies"_s );
2052 QDomNodeList depsNodes = depsNode.childNodes();
2053 QSet<QgsMapLayerDependency> sources;
2054 for (
int i = 0; i < depsNodes.count(); i++ )
2056 QString
source = depsNodes.at( i ).toElement().attribute( u
"id"_s );
2061 if ( !mSetLegendFromStyle )
2067 mReadExtentFromXml =
true;
2069 if ( mReadExtentFromXml )
2071 const QDomNode extentNode = layer_node.namedItem( u
"extent"_s );
2072 if ( !extentNode.isNull() )
2076 const QDomNode extent3DNode = layer_node.namedItem( u
"extent3D"_s );
2077 if ( !extent3DNode.isNull() )
2084 const QDomNode asNode = layer_node.namedItem( u
"auxiliaryLayer"_s );
2085 const QDomElement asElem = asNode.toElement();
2086 if ( !asElem.isNull() )
2088 mAuxiliaryLayerKey = asElem.attribute( u
"key"_s );
2092 mServerProperties->readXml( layer_node );
2107 setDataProvider( provider, options,
flags );
2117 bool loadDefaultStyleFlag =
false;
2120 loadDefaultStyleFlag =
true;
2126 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2128 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Load layer style" ), u
"projectload"_s );
2130 bool defaultLoadedFlag =
false;
2138 mSetLegendFromStyle =
false;
2143 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
2151 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2152 if ( defaultRenderer )
2154 defaultLoadedFlag =
true;
2160 if ( !defaultLoadedFlag )
2166 if ( !mSetLegendFromStyle )
2171 std::unique_ptr< QgsAbstractVectorLayerLabeling > defaultLabeling( mDataProvider->createLabeling() );
2172 if ( defaultLabeling )
2179 styleChangedSignalBlocker.release();
2196 QStringList ids, names, descriptions;
2197 QString errorMessage;
2199 const int relatedStylesCount {
listStylesInDatabase( ids, names, descriptions, errorMessage ) };
2200 Q_ASSERT( ids.count() == names.count() );
2201 const QString currentStyleName { mStyleManager->currentStyle() };
2202 for (
int i = 0; i < relatedStylesCount; ++i )
2204 if ( names.at( i ) == currentStyleName )
2208 errorMessage.clear();
2210 if ( !styleXml.isEmpty() && errorMessage.isEmpty() )
2216 QgsDebugMsgLevel( u
"Error retrieving style %1 from DB: %2"_s.arg( ids.at( i ), errorMessage ), 2 );
2226 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2227 if ( defaultRenderer )
2243 delete mDataProvider;
2250 if ( provider.compare(
"postgres"_L1 ) == 0 )
2252 const QString checkUnicityKey { u
"checkPrimaryKeyUnicity"_s };
2254 if ( !uri.hasParam( checkUnicityKey ) )
2256 uri.setParam( checkUnicityKey, mReadExtentFromXml ?
"0" :
"1" );
2261 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2263 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), u
"projectload"_s );
2268 mDataProvider = qobject_cast< QgsVectorDataProvider * >(
mPreloadedProvider.release() );
2275 if ( !mDataProvider )
2282 mDataProvider->setParent(
this );
2287 setValid( mDataProvider->isValid() );
2295 profile->switchTask( tr(
"Read layer metadata" ) );
2300 QgsLayerMetadata newMetadata = mDataProvider->layerMetadata();
2302 newMetadata.
combine( &mMetadata );
2312 mWkbType = mDataProvider->wkbType();
2316 const QgsFields providerFields = mDataProvider->fields();
2317 for (
const QgsField &field : providerFields )
2320 if ( !field.editorWidgetSetup().isNull() && mFieldWidgetSetups.value( field.name() ).isNull() )
2322 mFieldWidgetSetups[field.name()] = field.editorWidgetSetup();
2324 if ( !field.alias().isEmpty() && mAttributeAliasMap.value( field.name() ).isEmpty() )
2326 mAttributeAliasMap[field.name()] = field.alias();
2328 if ( !mAttributeSplitPolicy.contains( field.name() ) )
2330 mAttributeSplitPolicy[field.name()] = field.splitPolicy();
2332 if ( !mAttributeDuplicatePolicy.contains( field.name() ) )
2334 mAttributeDuplicatePolicy[field.name()] = field.duplicatePolicy();
2336 if ( !mAttributeMergePolicy.contains( field.name() ) )
2338 mAttributeMergePolicy[field.name()] = field.mergePolicy();
2343 profile->switchTask( tr(
"Read layer fields" ) );
2349 mDataSource = mDataProvider->dataSourceUri(
false );
2354 const thread_local QRegularExpression reg( R
"lit("[^"]+"\."([^"] + )"( \([^)]+\))?)lit" );
2355 const QRegularExpressionMatch match = reg.match(
name() );
2356 if ( match.hasMatch() )
2358 QStringList stuff = match.capturedTexts();
2359 QString lName = stuff[1];
2363 QMap<QString, QgsMapLayer *>::const_iterator it;
2364 for ( it = layers.constBegin(); it != layers.constEnd() && ( *it )->name() != lName; ++it )
2367 if ( it != layers.constEnd() && stuff.size() > 2 )
2369 lName +=
'.' + stuff[2].mid( 2, stuff[2].length() - 3 );
2372 if ( !lName.isEmpty() )
2382 else if ( provider ==
"ogr"_L1 )
2389 else if ( provider ==
"memory"_L1 )
2394 else if ( provider ==
"hana"_L1 )
2397 mDataSource = mDataProvider->dataSourceUri(
false );
2414 QDomElement mapLayerNode = layer_node.toElement();
2416 if ( mapLayerNode.isNull() || (
"maplayer" != mapLayerNode.nodeName() ) )
2429 if ( mDataProvider )
2431 QDomElement provider = document.createElement( u
"provider"_s );
2432 provider.setAttribute( u
"encoding"_s, mDataProvider->encoding() );
2433 QDomText providerText = document.createTextNode(
providerType() );
2434 provider.appendChild( providerText );
2435 layer_node.appendChild( provider );
2439 mJoinBuffer->writeXml( layer_node, document );
2442 QDomElement dependenciesElement = document.createElement( u
"layerDependencies"_s );
2448 QDomElement depElem = document.createElement( u
"layer"_s );
2449 depElem.setAttribute( u
"id"_s, dep.layerId() );
2450 dependenciesElement.appendChild( depElem );
2452 layer_node.appendChild( dependenciesElement );
2455 QDomElement dataDependenciesElement = document.createElement( u
"dataDependencies"_s );
2460 QDomElement depElem = document.createElement( u
"layer"_s );
2461 depElem.setAttribute( u
"id"_s, dep.layerId() );
2462 dataDependenciesElement.appendChild( depElem );
2464 layer_node.appendChild( dataDependenciesElement );
2467 mExpressionFieldBuffer->writeXml( layer_node, document );
2472 QDomElement asElem = document.createElement( u
"auxiliaryLayer"_s );
2473 if ( mAuxiliaryLayer )
2475 const QString pkField = mAuxiliaryLayer->joinInfo().targetFieldName();
2476 asElem.setAttribute( u
"key"_s, pkField );
2478 layer_node.appendChild( asElem );
2482 return writeSymbology( layer_node, document, errorMsg, context );
2511 mJoinBuffer->resolveReferences(
project );
2519 if ( categories.testFlag(
Fields ) )
2521 if ( !mExpressionFieldBuffer )
2523 mExpressionFieldBuffer->readXml( layerNode );
2533 QDomNodeList referencedLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencedLayers"_s );
2534 if ( referencedLayersNodeList.size() > 0 )
2536 const QDomNodeList relationNodes { referencedLayersNodeList.at( 0 ).childNodes() };
2537 for (
int i = 0; i < relationNodes.length(); ++i )
2539 const QDomElement relationElement = relationNodes.at( i ).toElement();
2546 QDomNodeList referencingLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencingLayers"_s );
2547 if ( referencingLayersNodeList.size() > 0 )
2549 const QDomNodeList relationNodes { referencingLayersNodeList.at( 0 ).childNodes() };
2550 for (
int i = 0; i < relationNodes.length(); ++i )
2552 const QDomElement relationElement = relationNodes.at( i ).toElement();
2558 QDomElement layerElement = layerNode.toElement();
2562 readStyle( layerNode, errorMessage, context, categories );
2564 if ( categories.testFlag(
MapTips ) )
2566 QDomElement mapTipElem = layerNode.namedItem( u
"mapTip"_s ).toElement();
2572 mDisplayExpression = layerNode.namedItem( u
"previewExpression"_s ).toElement().text();
2575 QString
displayField = layerNode.namedItem( u
"displayfield"_s ).toElement().text();
2579 if ( mMapTipTemplate.isEmpty() && categories.testFlag(
MapTips ) )
2589 if ( categories.testFlag(
Actions ) )
2590 mActions->readXml( layerNode, context );
2592 if ( categories.testFlag(
Fields ) )
2597 QDomNode aliasesNode = layerNode.namedItem( u
"aliases"_s );
2598 if ( !aliasesNode.isNull() )
2600 QDomElement aliasElem;
2602 QDomNodeList aliasNodeList = aliasesNode.toElement().elementsByTagName( u
"alias"_s );
2603 for (
int i = 0; i < aliasNodeList.size(); ++i )
2605 aliasElem = aliasNodeList.at( i ).toElement();
2608 if ( aliasElem.hasAttribute( u
"field"_s ) )
2610 field = aliasElem.attribute( u
"field"_s );
2614 int index = aliasElem.attribute( u
"index"_s ).toInt();
2616 if ( index >= 0 && index <
fields().count() )
2622 if ( !aliasElem.attribute( u
"name"_s ).isEmpty() )
2625 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), aliasElem.attribute( u
"name"_s ) );
2626 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + aliasElem.attribute( u
"name"_s ), 3 );
2631 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), field );
2632 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + field, 3 );
2634 if ( alias == aliasElem.attribute( u
"field"_s ) )
2638 QgsDebugMsgLevel(
"field " + field +
" origalias " + aliasElem.attribute( u
"name"_s ) +
" trans " + alias, 3 );
2639 mAttributeAliasMap.insert( field, alias );
2645 mAttributeCustomCommentMap.clear();
2646 QDomNode customCommentsNode = layerNode.namedItem( u
"customComments"_s );
2647 if ( !customCommentsNode.isNull() )
2649 QDomElement customCommentEntryElem;
2651 QDomNodeList customCommentNodeList = customCommentsNode.toElement().elementsByTagName( u
"customComment"_s );
2652 for (
int i = 0; i < customCommentNodeList.size(); ++i )
2654 customCommentEntryElem = customCommentNodeList.at( i ).toElement();
2656 const QString field = customCommentEntryElem.attribute( u
"field"_s );
2659 const QString customComment = customCommentEntryElem.attribute( u
"value"_s );
2661 if (
fields().lookupField( field ) < 0 )
2663 QgsDebugMsgLevel( u
"Warning: Field %1 not found in layer %2 to load custom comment from setting "_s.arg( field,
name() ), 2 );
2666 mAttributeCustomCommentMap.insert( field, customComment );
2673 const QDomNode splitPoliciesNode = layerNode.namedItem( u
"splitPolicies"_s );
2674 if ( !splitPoliciesNode.isNull() )
2676 const QDomNodeList splitPolicyNodeList = splitPoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2677 for (
int i = 0; i < splitPolicyNodeList.size(); ++i )
2679 const QDomElement splitPolicyElem = splitPolicyNodeList.at( i ).toElement();
2680 const QString field = splitPolicyElem.attribute( u
"field"_s );
2682 mAttributeSplitPolicy.insert( field, policy );
2687 mAttributeDuplicatePolicy.clear();
2688 const QDomNode duplicatePoliciesNode = layerNode.namedItem( u
"duplicatePolicies"_s );
2689 if ( !duplicatePoliciesNode.isNull() )
2691 const QDomNodeList duplicatePolicyNodeList = duplicatePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2692 for (
int i = 0; i < duplicatePolicyNodeList.size(); ++i )
2694 const QDomElement duplicatePolicyElem = duplicatePolicyNodeList.at( i ).toElement();
2695 const QString field = duplicatePolicyElem.attribute( u
"field"_s );
2697 mAttributeDuplicatePolicy.insert( field, policy );
2701 const QDomNode mergePoliciesNode = layerNode.namedItem( u
"mergePolicies"_s );
2702 if ( !mergePoliciesNode.isNull() )
2704 const QDomNodeList mergePolicyNodeList = mergePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2705 for (
int i = 0; i < mergePolicyNodeList.size(); ++i )
2707 const QDomElement mergePolicyElem = mergePolicyNodeList.at( i ).toElement();
2708 const QString field = mergePolicyElem.attribute( u
"field"_s );
2710 mAttributeMergePolicy.insert( field, policy );
2715 mDefaultExpressionMap.clear();
2716 QDomNode defaultsNode = layerNode.namedItem( u
"defaults"_s );
2717 if ( !defaultsNode.isNull() )
2719 QDomNodeList defaultNodeList = defaultsNode.toElement().elementsByTagName( u
"default"_s );
2720 for (
int i = 0; i < defaultNodeList.size(); ++i )
2722 QDomElement defaultElem = defaultNodeList.at( i ).toElement();
2724 QString field = defaultElem.attribute( u
"field"_s, QString() );
2725 QString expression = defaultElem.attribute( u
"expression"_s, QString() );
2726 bool applyOnUpdate = defaultElem.attribute( u
"applyOnUpdate"_s, u
"0"_s ) ==
"1"_L1;
2727 if ( field.isEmpty() || expression.isEmpty() )
2730 mDefaultExpressionMap.insert( field,
QgsDefaultValue( expression, applyOnUpdate ) );
2735 mFieldConstraints.clear();
2736 mFieldConstraintStrength.clear();
2737 QDomNode constraintsNode = layerNode.namedItem( u
"constraints"_s );
2738 if ( !constraintsNode.isNull() )
2740 QDomNodeList constraintNodeList = constraintsNode.toElement().elementsByTagName( u
"constraint"_s );
2741 for (
int i = 0; i < constraintNodeList.size(); ++i )
2743 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2745 QString field = constraintElem.attribute( u
"field"_s, QString() );
2746 int constraints = constraintElem.attribute( u
"constraints"_s, u
"0"_s ).toInt();
2747 if ( field.isEmpty() || constraints == 0 )
2752 int uniqueStrength = constraintElem.attribute( u
"unique_strength"_s, u
"1"_s ).toInt();
2753 int notNullStrength = constraintElem.attribute( u
"notnull_strength"_s, u
"1"_s ).toInt();
2754 int expStrength = constraintElem.attribute( u
"exp_strength"_s, u
"1"_s ).toInt();
2761 mFieldConstraintExpressions.clear();
2762 QDomNode constraintExpressionsNode = layerNode.namedItem( u
"constraintExpressions"_s );
2763 if ( !constraintExpressionsNode.isNull() )
2765 QDomNodeList constraintNodeList = constraintExpressionsNode.toElement().elementsByTagName( u
"constraint"_s );
2766 for (
int i = 0; i < constraintNodeList.size(); ++i )
2768 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2770 QString field = constraintElem.attribute( u
"field"_s, QString() );
2771 QString exp = constraintElem.attribute( u
"exp"_s, QString() );
2773 = context.
projectTranslator()->
translate( u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), constraintElem.attribute( u
"desc"_s, QString() ) );
2774 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + constraintElem.attribute( u
"desc"_s, QString() ), 3 );
2775 if ( field.isEmpty() || exp.isEmpty() )
2778 mFieldConstraintExpressions.insert( field, qMakePair( exp, desc ) );
2786 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2790 QDomElement widgetsElem = layerNode.namedItem( u
"fieldConfiguration"_s ).toElement();
2791 QDomNodeList fieldConfigurationElementList = widgetsElem.elementsByTagName( u
"field"_s );
2792 for (
int i = 0; i < fieldConfigurationElementList.size(); ++i )
2794 const QDomElement fieldConfigElement = fieldConfigurationElementList.at( i ).toElement();
2795 const QDomElement fieldWidgetElement = fieldConfigElement.elementsByTagName( u
"editWidget"_s ).at( 0 ).toElement();
2797 QString fieldName = fieldConfigElement.attribute( u
"name"_s );
2799 if ( categories.testFlag(
Fields ) )
2803 if ( categories.testFlag(
Forms ) )
2805 const QString widgetType = fieldWidgetElement.attribute( u
"type"_s );
2806 const QDomElement cfgElem = fieldConfigElement.elementsByTagName( u
"config"_s ).at( 0 ).toElement();
2807 const QDomElement optionsElem = cfgElem.childNodes().at( 0 ).toElement();
2810 if ( widgetType ==
"ValueRelation"_L1 )
2812 optionsMap[u
"Value"_s]
2813 = 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() );
2814 optionsMap[u
"Description"_s]
2816 ->
translate( u
"project:layers:%1:fields:%2:valuerelationdescription"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), optionsMap[u
"Description"_s].toString() );
2818 if ( widgetType ==
"ValueMap"_L1 )
2820 if ( optionsMap[u
"map"_s].canConvert<QList<QVariant>>() )
2822 QList<QVariant> translatedValueList;
2823 const QList<QVariant> valueList = optionsMap[u
"map"_s].toList();
2824 for (
int i = 0; i < valueList.count(); i++ )
2826 QMap<QString, QVariant> translatedValueMap;
2827 QString translatedKey
2829 ->
translate( u
"project:layers:%1:fields:%2:valuemapdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), valueList[i].toMap().constBegin().key() );
2830 translatedValueMap.insert( translatedKey, valueList[i].toMap().constBegin().value() );
2831 translatedValueList.append( translatedValueMap );
2833 optionsMap.insert( u
"map"_s, translatedValueList );
2837 mFieldWidgetSetups[fieldName] = setup;
2844 if ( categories.testFlag(
Fields ) )
2846 const QList<QPair<QString, Qgis::FieldConfigurationFlag>>
2848 for (
const auto &config : legacyConfig )
2850 QDomNode excludeNode = layerNode.namedItem( config.first );
2851 if ( !excludeNode.isNull() )
2853 QDomNodeList attributeNodeList = excludeNode.toElement().elementsByTagName( u
"attribute"_s );
2854 for (
int i = 0; i < attributeNodeList.size(); ++i )
2856 QString fieldName = attributeNodeList.at( i ).toElement().text();
2857 if ( !mFieldConfigurationFlags.contains( fieldName ) )
2858 mFieldConfigurationFlags[fieldName] = config.second;
2860 mFieldConfigurationFlags[fieldName].setFlag( config.second,
true );
2867 mGeometryOptions->readXml( layerNode.namedItem( u
"geometryOptions"_s ) );
2869 if ( categories.testFlag(
Forms ) )
2870 mEditFormConfig.readXml( layerNode, context );
2874 mAttributeTableConfig.readXml( layerNode );
2875 mConditionalStyles->readXml( layerNode, context );
2876 mStoredExpressionManager->readXml( layerNode );
2882 QDomElement mapLayerNode = layerNode.toElement();
2883 if ( categories.testFlag(
LayerConfiguration ) && mapLayerNode.attribute( u
"readOnly"_s, u
"0"_s ).toInt() == 1 )
2888 if ( categories.testFlag(
Legend ) )
2892 const QDomElement legendElem = layerNode.firstChildElement( u
"legend"_s );
2893 if ( !legendElem.isNull() )
2896 legend->readXml( legendElem, context );
2898 mSetLegendFromStyle =
true;
2927 if ( !rendererElement.isNull() )
2945 if ( mSelectionProperties )
2946 mSelectionProperties->readXml( node.toElement(), context );
2950 if ( categories.testFlag(
Labeling ) )
2954 QDomElement labelingElement = node.firstChildElement( u
"labeling"_s );
2956 if ( labelingElement.isNull() || ( labelingElement.attribute( u
"type"_s ) ==
"simple"_L1 && labelingElement.firstChildElement( u
"settings"_s ).isNull() ) )
2964 labeling = readLabelingFromCustomProperties();
2972 if ( node.toElement().hasAttribute( u
"labelsEnabled"_s ) )
2973 mLabelsEnabled = node.toElement().attribute( u
"labelsEnabled"_s ).toInt();
2975 mLabelsEnabled =
true;
2981 QDomNode blendModeNode = node.namedItem( u
"blendMode"_s );
2982 if ( !blendModeNode.isNull() )
2984 QDomElement e = blendModeNode.toElement();
2989 QDomNode featureBlendModeNode = node.namedItem( u
"featureBlendMode"_s );
2990 if ( !featureBlendModeNode.isNull() )
2992 QDomElement e = featureBlendModeNode.toElement();
3000 QDomNode layerTransparencyNode = node.namedItem( u
"layerTransparency"_s );
3001 if ( !layerTransparencyNode.isNull() )
3003 QDomElement e = layerTransparencyNode.toElement();
3004 setOpacity( 1.0 - e.text().toInt() / 100.0 );
3006 QDomNode layerOpacityNode = node.namedItem( u
"layerOpacity"_s );
3007 if ( !layerOpacityNode.isNull() )
3009 QDomElement e = layerOpacityNode.toElement();
3013 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( u
"hasScaleBasedVisibilityFlag"_s ).nodeValue() ==
'1' };
3016 const double maxScale { node.attributes().namedItem( u
"maxScale"_s ).nodeValue().toDouble( &ok ) };
3021 const double minScale { node.attributes().namedItem( u
"minScale"_s ).nodeValue().toDouble( &ok ) };
3027 QDomElement e = node.toElement();
3032 mSimplifyMethod.setThreshold( e.attribute( u
"simplifyDrawingTol"_s, u
"1"_s ).toFloat() );
3033 mSimplifyMethod.setForceLocalOptimization( e.attribute( u
"simplifyLocal"_s, u
"1"_s ).toInt() );
3034 mSimplifyMethod.setMaximumScale( e.attribute( u
"simplifyMaxScale"_s, u
"1"_s ).toFloat() );
3037 mRenderer->setReferenceScale( e.attribute( u
"symbologyReferenceScale"_s, u
"-1"_s ).toDouble() );
3041 if ( categories.testFlag(
Diagrams ) )
3045 delete mDiagramRenderer;
3046 mDiagramRenderer =
nullptr;
3047 QDomElement singleCatDiagramElem = node.firstChildElement( u
"SingleCategoryDiagramRenderer"_s );
3048 if ( !singleCatDiagramElem.isNull() )
3051 mDiagramRenderer->readXml( singleCatDiagramElem, context );
3053 QDomElement linearDiagramElem = node.firstChildElement( u
"LinearlyInterpolatedDiagramRenderer"_s );
3054 if ( !linearDiagramElem.isNull() )
3056 if ( linearDiagramElem.hasAttribute( u
"classificationAttribute"_s ) )
3059 int idx = linearDiagramElem.attribute( u
"classificationAttribute"_s ).toInt();
3060 if ( idx >= 0 && idx < mFields.count() )
3061 linearDiagramElem.setAttribute( u
"classificationField"_s, mFields.at( idx ).name() );
3065 mDiagramRenderer->readXml( linearDiagramElem, context );
3067 QDomElement stackedDiagramElem = node.firstChildElement( u
"StackedDiagramRenderer"_s );
3068 if ( !stackedDiagramElem.isNull() )
3071 mDiagramRenderer->readXml( stackedDiagramElem, context );
3074 if ( mDiagramRenderer )
3076 QDomElement diagramSettingsElem = node.firstChildElement( u
"DiagramLayerSettings"_s );
3077 if ( !diagramSettingsElem.isNull() )
3079 bool oldXPos = diagramSettingsElem.hasAttribute( u
"xPosColumn"_s );
3080 bool oldYPos = diagramSettingsElem.hasAttribute( u
"yPosColumn"_s );
3081 bool oldShow = diagramSettingsElem.hasAttribute( u
"showColumn"_s );
3082 if ( oldXPos || oldYPos || oldShow )
3088 int xPosColumn = diagramSettingsElem.attribute( u
"xPosColumn"_s ).toInt();
3089 if ( xPosColumn >= 0 && xPosColumn < mFields.count() )
3094 int yPosColumn = diagramSettingsElem.attribute( u
"yPosColumn"_s ).toInt();
3095 if ( yPosColumn >= 0 && yPosColumn < mFields.count() )
3100 int showColumn = diagramSettingsElem.attribute( u
"showColumn"_s ).toInt();
3101 if ( showColumn >= 0 && showColumn < mFields.count() )
3104 QDomElement propertiesElem = diagramSettingsElem.ownerDocument().createElement( u
"properties"_s );
3110 ddp.
writeXml( propertiesElem, defs );
3111 diagramSettingsElem.appendChild( propertiesElem );
3114 delete mDiagramLayerSettings;
3116 mDiagramLayerSettings->readXml( diagramSettingsElem );
3122 styleChangedSignalBlocker.release();
3133 QDomElement layerElement = node.toElement();
3136 ( void )
writeStyle( node, doc, errorMessage, context, categories );
3139 mGeometryOptions->writeXml( node );
3144 if ( !legendElement.isNull() )
3145 node.appendChild( legendElement );
3154 QDomElement referencedLayersElement = doc.createElement( u
"referencedLayers"_s );
3155 node.appendChild( referencedLayersElement );
3157 const QList<QgsRelation>
referencingRelations { p->relationManager()->referencingRelations(
this ) };
3160 switch ( rel.type() )
3171 QDomElement referencingLayersElement = doc.createElement( u
"referencingLayers"_s );
3172 node.appendChild( referencingLayersElement );
3174 const QList<QgsRelation> referencedRelations { p->relationManager()->referencedRelations(
this ) };
3175 for (
const QgsRelation &rel : referencedRelations )
3177 switch ( rel.type() )
3190 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
3192 QDomElement fieldConfigurationElement;
3194 fieldConfigurationElement = doc.createElement( u
"fieldConfiguration"_s );
3195 node.appendChild( fieldConfigurationElement );
3197 for (
const QgsField &field : std::as_const( mFields ) )
3199 QDomElement fieldElement = doc.createElement( u
"field"_s );
3200 fieldElement.setAttribute( u
"name"_s, field.name() );
3201 fieldConfigurationElement.appendChild( fieldElement );
3203 if ( categories.testFlag(
Fields ) )
3205 fieldElement.setAttribute( u
"configurationFlags"_s,
qgsFlagValueToKeys( field.configurationFlags() ) );
3208 if ( categories.testFlag(
Forms ) )
3213 QDomElement editWidgetElement = doc.createElement( u
"editWidget"_s );
3214 fieldElement.appendChild( editWidgetElement );
3215 editWidgetElement.setAttribute( u
"type"_s, field.editorWidgetSetup().type() );
3216 QDomElement editWidgetConfigElement = doc.createElement( u
"config"_s );
3219 editWidgetElement.appendChild( editWidgetConfigElement );
3225 if ( categories.testFlag(
Fields ) )
3228 QDomElement aliasElem = doc.createElement( u
"aliases"_s );
3229 for (
const QgsField &field : std::as_const( mFields ) )
3231 QDomElement aliasEntryElem = doc.createElement( u
"alias"_s );
3232 aliasEntryElem.setAttribute( u
"field"_s, field.name() );
3233 aliasEntryElem.setAttribute( u
"index"_s, mFields.indexFromName( field.name() ) );
3234 aliasEntryElem.setAttribute( u
"name"_s, field.alias() );
3235 aliasElem.appendChild( aliasEntryElem );
3237 node.appendChild( aliasElem );
3240 QDomElement customCommentElem = doc.createElement( u
"customComments"_s );
3241 bool hasCustomComments =
false;
3242 for (
const QgsField &field : std::as_const( mFields ) )
3245 const QString customComment = field.customComment();
3246 if ( customComment.isNull() )
3249 hasCustomComments =
true;
3250 QDomElement customCommentEntryElem = doc.createElement( u
"customComment"_s );
3251 customCommentEntryElem.setAttribute( u
"field"_s, field.name() );
3252 customCommentEntryElem.setAttribute( u
"value"_s, customComment );
3253 customCommentElem.appendChild( customCommentEntryElem );
3255 if ( hasCustomComments )
3257 node.appendChild( customCommentElem );
3262 QDomElement splitPoliciesElement = doc.createElement( u
"splitPolicies"_s );
3263 bool hasNonDefaultSplitPolicies =
false;
3264 for (
const QgsField &field : std::as_const( mFields ) )
3268 QDomElement splitPolicyElem = doc.createElement( u
"policy"_s );
3269 splitPolicyElem.setAttribute( u
"field"_s, field.name() );
3270 splitPolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.splitPolicy() ) );
3271 splitPoliciesElement.appendChild( splitPolicyElem );
3272 hasNonDefaultSplitPolicies =
true;
3275 if ( hasNonDefaultSplitPolicies )
3276 node.appendChild( splitPoliciesElement );
3281 QDomElement duplicatePoliciesElement = doc.createElement( u
"duplicatePolicies"_s );
3282 bool hasNonDefaultDuplicatePolicies =
false;
3283 for (
const QgsField &field : std::as_const( mFields ) )
3287 QDomElement duplicatePolicyElem = doc.createElement( u
"policy"_s );
3288 duplicatePolicyElem.setAttribute( u
"field"_s, field.name() );
3289 duplicatePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.duplicatePolicy() ) );
3290 duplicatePoliciesElement.appendChild( duplicatePolicyElem );
3291 hasNonDefaultDuplicatePolicies =
true;
3294 if ( hasNonDefaultDuplicatePolicies )
3295 node.appendChild( duplicatePoliciesElement );
3300 QDomElement mergePoliciesElement = doc.createElement( u
"mergePolicies"_s );
3301 bool hasNonDefaultMergePolicies =
false;
3302 for (
const QgsField &field : std::as_const( mFields ) )
3306 QDomElement mergePolicyElem = doc.createElement( u
"policy"_s );
3307 mergePolicyElem.setAttribute( u
"field"_s, field.name() );
3308 mergePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.mergePolicy() ) );
3309 mergePoliciesElement.appendChild( mergePolicyElem );
3310 hasNonDefaultMergePolicies =
true;
3313 if ( hasNonDefaultMergePolicies )
3314 node.appendChild( mergePoliciesElement );
3318 QDomElement defaultsElem = doc.createElement( u
"defaults"_s );
3319 for (
const QgsField &field : std::as_const( mFields ) )
3321 QDomElement defaultElem = doc.createElement( u
"default"_s );
3322 defaultElem.setAttribute( u
"field"_s, field.name() );
3323 defaultElem.setAttribute( u
"expression"_s, field.defaultValueDefinition().expression() );
3324 defaultElem.setAttribute( u
"applyOnUpdate"_s, field.defaultValueDefinition().applyOnUpdate() ? u
"1"_s : u
"0"_s );
3325 defaultsElem.appendChild( defaultElem );
3327 node.appendChild( defaultsElem );
3330 QDomElement constraintsElem = doc.createElement( u
"constraints"_s );
3331 for (
const QgsField &field : std::as_const( mFields ) )
3333 QDomElement constraintElem = doc.createElement( u
"constraint"_s );
3334 constraintElem.setAttribute( u
"field"_s, field.name() );
3335 constraintElem.setAttribute( u
"constraints"_s, field.constraints().constraints() );
3340 constraintsElem.appendChild( constraintElem );
3342 node.appendChild( constraintsElem );
3345 QDomElement constraintExpressionsElem = doc.createElement( u
"constraintExpressions"_s );
3346 for (
const QgsField &field : std::as_const( mFields ) )
3348 QDomElement constraintExpressionElem = doc.createElement( u
"constraint"_s );
3349 constraintExpressionElem.setAttribute( u
"field"_s, field.name() );
3350 constraintExpressionElem.setAttribute( u
"exp"_s, field.constraints().constraintExpression() );
3351 constraintExpressionElem.setAttribute( u
"desc"_s, field.constraints().constraintDescription() );
3352 constraintExpressionsElem.appendChild( constraintExpressionElem );
3354 node.appendChild( constraintExpressionsElem );
3357 if ( !mExpressionFieldBuffer )
3365 mExpressionFieldBuffer->writeXml( node, doc );
3370 if ( categories.testFlag(
Actions ) )
3371 mActions->writeXml( node );
3375 mAttributeTableConfig.writeXml( node );
3376 mConditionalStyles->writeXml( node, doc, context );
3377 mStoredExpressionManager->writeXml( node );
3380 if ( categories.testFlag(
Forms ) )
3381 mEditFormConfig.writeXml( node, context );
3385 node.toElement().setAttribute( u
"readOnly"_s, mReadOnly );
3390 QDomElement prevExpElem = doc.createElement( u
"previewExpression"_s );
3391 QDomText prevExpText = doc.createTextNode( mDisplayExpression );
3392 prevExpElem.appendChild( prevExpText );
3393 node.appendChild( prevExpElem );
3397 if ( categories.testFlag(
MapTips ) )
3399 QDomElement mapTipElem = doc.createElement( u
"mapTip"_s );
3401 QDomText mapTipText = doc.createTextNode( mMapTipTemplate );
3402 mapTipElem.appendChild( mapTipText );
3403 node.toElement().appendChild( mapTipElem );
3413 QDomElement mapLayerNode = node.toElement();
3426 QDomElement rendererElement = mRenderer->save( doc, context );
3427 node.appendChild( rendererElement );
3429 if ( mSelectionProperties )
3431 mSelectionProperties->writeXml( mapLayerNode, doc, context );
3435 if ( categories.testFlag(
Labeling ) )
3439 QDomElement labelingElement = mLabeling->save( doc, context );
3440 node.appendChild( labelingElement );
3442 mapLayerNode.setAttribute( u
"labelsEnabled"_s, mLabelsEnabled ? u
"1"_s : u
"0"_s );
3448 mapLayerNode.setAttribute( u
"simplifyDrawingHints"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyHints() ) ) );
3449 mapLayerNode.setAttribute( u
"simplifyAlgorithm"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyAlgorithm() ) ) );
3450 mapLayerNode.setAttribute( u
"simplifyDrawingTol"_s, QString::number( mSimplifyMethod.threshold() ) );
3451 mapLayerNode.setAttribute( u
"simplifyLocal"_s, mSimplifyMethod.forceLocalOptimization() ? 1 : 0 );
3452 mapLayerNode.setAttribute( u
"simplifyMaxScale"_s, QString::number( mSimplifyMethod.maximumScale() ) );
3464 QDomElement blendModeElem = doc.createElement( u
"blendMode"_s );
3466 blendModeElem.appendChild( blendModeText );
3467 node.appendChild( blendModeElem );
3470 QDomElement featureBlendModeElem = doc.createElement( u
"featureBlendMode"_s );
3472 featureBlendModeElem.appendChild( featureBlendModeText );
3473 node.appendChild( featureBlendModeElem );
3479 QDomElement layerOpacityElem = doc.createElement( u
"layerOpacity"_s );
3480 QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
3481 layerOpacityElem.appendChild( layerOpacityText );
3482 node.appendChild( layerOpacityElem );
3484 mapLayerNode.setAttribute( u
"maxScale"_s,
maximumScale() );
3485 mapLayerNode.setAttribute( u
"minScale"_s,
minimumScale() );
3487 mapLayerNode.setAttribute( u
"symbologyReferenceScale"_s, mRenderer ? mRenderer->referenceScale() : -1 );
3490 if ( categories.testFlag(
Diagrams ) && mDiagramRenderer )
3492 mDiagramRenderer->writeXml( mapLayerNode, doc, context );
3493 if ( mDiagramLayerSettings )
3494 mDiagramLayerSettings->writeXml( mapLayerNode, doc );
3505 QDomElement nameElem = node.firstChildElement( u
"Name"_s );
3506 if ( nameElem.isNull() )
3508 errorMessage = u
"Warning: Name element not found within NamedLayer while it's required."_s;
3524 readSldLabeling( node );
3526 styleChangedSignalBlocker.release();
3536 context.setExtraProperties( props );
3555 QDomElement nameNode = doc.createElement( u
"se:Name"_s );
3556 nameNode.appendChild( doc.createTextNode(
name() ) );
3557 node.appendChild( nameNode );
3559 QDomElement userStyleElem = doc.createElement( u
"UserStyle"_s );
3560 node.appendChild( userStyleElem );
3562 QDomElement nameElem = doc.createElement( u
"se:Name"_s );
3563 nameElem.appendChild( doc.createTextNode(
name() ) );
3565 userStyleElem.appendChild( nameElem );
3567 QDomElement featureTypeStyleElem = doc.createElement( u
"se:FeatureTypeStyle"_s );
3568 userStyleElem.appendChild( featureTypeStyleElem );
3570 mRenderer->toSld( doc, featureTypeStyleElem, context );
3573 mLabeling->toSld( featureTypeStyleElem, context );
3583 if ( !mEditBuffer || !mDataProvider )
3588 if ( mGeometryOptions->isActive() )
3589 mGeometryOptions->apply( geom );
3593 bool result = mEditBuffer->changeGeometry( fid, geom );
3598 if ( !skipDefaultValue && !mDefaultValueOnUpdateFields.isEmpty() )
3599 updateDefaultValues( fid );
3609 bool result =
false;
3611 switch (
fields().fieldOrigin( field ) )
3614 result = mJoinBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3623 if ( mEditBuffer && mDataProvider )
3624 result = mEditBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3632 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3650 for (
auto it = newValues.constBegin(); it != newValues.constEnd(); ++it )
3652 const int field = it.key();
3653 const QVariant newValue = it.value();
3656 if ( oldValues.contains( field ) )
3657 oldValue = oldValues[field];
3659 switch (
fields().fieldOrigin( field ) )
3662 newValuesJoin[field] = newValue;
3663 oldValuesJoin[field] = oldValue;
3670 newValuesNotJoin[field] = newValue;
3671 oldValuesNotJoin[field] = oldValue;
3680 if ( !newValuesJoin.isEmpty() && mJoinBuffer )
3682 result = mJoinBuffer->changeAttributeValues( fid, newValuesJoin, oldValuesJoin );
3685 if ( !newValuesNotJoin.isEmpty() )
3687 if ( mEditBuffer && mDataProvider )
3688 result &= mEditBuffer->changeAttributeValues( fid, newValuesNotJoin, oldValues );
3693 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3705 if ( !mEditBuffer || !mDataProvider )
3708 return mEditBuffer->addAttribute( field );
3715 if ( attIndex < 0 || attIndex >=
fields().count() )
3719 mFields[attIndex].setAlias( QString() );
3720 if ( mAttributeAliasMap.contains(
name ) )
3722 mAttributeAliasMap.remove(
name );
3724 mEditFormConfig.setFields( mFields );
3733 if ( index < 0 || index >=
fields().count() )
3736 switch ( mFields.fieldOrigin( index ) )
3740 if ( mExpressionFieldBuffer )
3742 int oi = mFields.fieldOriginIndex( index );
3743 mExpressionFieldBuffer->renameExpression( oi, newName );
3756 if ( !mEditBuffer || !mDataProvider )
3759 return mEditBuffer->renameAttribute( index, newName );
3773 if ( attIndex < 0 || attIndex >=
fields().count() )
3778 mAttributeAliasMap.insert(
name, aliasString );
3779 mFields[attIndex].setAlias( aliasString );
3780 mEditFormConfig.setFields( mFields );
3788 if ( index < 0 || index >=
fields().count() )
3798 if ( attIndex < 0 || attIndex >=
fields().count() )
3803 mAttributeCustomCommentMap.insert(
name, customCommentString );
3804 mFields[attIndex].setCustomComment( customCommentString );
3805 mEditFormConfig.setFields( mFields );
3813 if ( attIndex < 0 || attIndex >=
fields().count() )
3817 mFields[attIndex].setCustomComment( QString() );
3818 if ( mAttributeCustomCommentMap.contains(
name ) )
3820 mAttributeCustomCommentMap.remove(
name );
3822 mEditFormConfig.setFields( mFields );
3831 if ( index < 0 || index >=
fields().count() )
3841 return mAttributeCustomCommentMap;
3848 if ( index >= 0 && index < mFields.count() )
3849 return mFields.at( index ).displayName();
3858 return mAttributeAliasMap;
3865 if ( index < 0 || index >=
fields().count() )
3870 mAttributeSplitPolicy.insert(
name, policy );
3871 mFields[index].setSplitPolicy( policy );
3872 mEditFormConfig.setFields( mFields );
3880 if ( index < 0 || index >=
fields().count() )
3885 mAttributeDuplicatePolicy.insert(
name, policy );
3886 mFields[index].setDuplicatePolicy( policy );
3887 mEditFormConfig.setFields( mFields );
3895 if ( index < 0 || index >=
fields().count() )
3900 mAttributeMergePolicy.insert(
name, policy );
3901 mFields[index].setMergePolicy( policy );
3902 mEditFormConfig.setFields( mFields );
3910 QSet<QString> excludeList;
3911 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3912 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3916 excludeList << flagsIt.key();
3926 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3927 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3938 QSet<QString> excludeList;
3939 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3940 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3944 excludeList << flagsIt.key();
3954 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3955 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3966 if ( index < 0 || index >=
fields().count() )
3975 if ( !mEditBuffer || !mDataProvider )
3978 return mEditBuffer->deleteAttribute( index );
3985 bool deleted =
false;
3988 QList<int> attrList = qgis::setToList( qgis::listToSet( attrs ) );
3990 std::sort( attrList.begin(), attrList.end(), std::greater<int>() );
3992 for (
int attr : std::as_const( attrList ) )
4010 if ( context && context->
cascade )
4013 const bool hasRelationsOrJoins = !relations.empty() || mJoinBuffer->
containsJoins();
4014 if ( hasRelationsOrJoins )
4019 if ( handledFeatureIds.contains( fid ) )
4027 handledFeatureIds << fid;
4036 for (
const QgsRelation &relation : relations )
4039 switch ( relation.strength() )
4044 QgsFeatureIterator relatedFeaturesIt = relation.getRelatedFeatures(
getFeature( fid ) );
4046 QgsFeature childFeature;
4047 while ( relatedFeaturesIt.
nextFeature( childFeature ) )
4049 childFeatureIds.insert( childFeature.
id() );
4051 if ( childFeatureIds.count() > 0 )
4053 relation.referencingLayer()->startEditing();
4054 relation.referencingLayer()->deleteFeatures( childFeatureIds, context );
4066 if ( mJoinBuffer->containsJoins() )
4067 mJoinBuffer->deleteFeature( fid, context );
4069 bool res = mEditBuffer->deleteFeature( fid );
4081 return deleteFeatureCascade( fid, context );
4090 if ( ( context && context->
cascade ) || mJoinBuffer->containsJoins() )
4094 res = deleteFeatureCascade( fid, context ) && res;
4098 res = mEditBuffer && mEditBuffer->deleteFeatures( fids );
4103 mSelectedFeatureIds.subtract( fids );
4123 if ( !mDataProvider )
4124 return pkAttributesList;
4127 for (
int i = 0; i < mFields.count(); ++i )
4130 pkAttributesList << i;
4133 return pkAttributesList;
4140 if ( !mDataProvider )
4142 return mDataProvider->featureCount() + ( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->addedFeatures().size() - mEditBuffer->deletedFeatureIds().size() : 0 );
4149 const QgsFeatureIds deletedFeatures( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->deletedFeatureIds() :
QgsFeatureIds() );
4150 const QgsFeatureMap addedFeatures( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->addedFeatures() :
QgsFeatureMap() );
4152 if ( mEditBuffer && !deletedFeatures.empty() )
4154 if ( addedFeatures.size() > deletedFeatures.size() )
4160 if ( ( !mEditBuffer || addedFeatures.empty() ) && mDataProvider && mDataProvider->empty() )
4173 mCommitErrors.clear();
4175 if ( !mDataProvider )
4177 mCommitErrors << tr(
"ERROR: no provider" );
4183 mCommitErrors << tr(
"ERROR: layer not editable" );
4189 if ( !mAllowCommit )
4192 mCommitChangesActive =
true;
4194 bool success =
false;
4195 if ( mEditBuffer->editBufferGroup() )
4196 success = mEditBuffer->editBufferGroup()->commitChanges( mCommitErrors, stopEditing );
4198 success = mEditBuffer->commitChanges( mCommitErrors );
4200 mCommitChangesActive =
false;
4202 if ( !mDeletedFids.empty() )
4205 mDeletedFids.clear();
4226 mDataProvider->updateExtents();
4230 mDataProvider->leaveUpdateMode();
4236 if ( mFields.names() != mDataProvider->fields().names() )
4250 return mCommitErrors;
4265 if ( !mDataProvider )
4267 mCommitErrors << tr(
"ERROR: no provider" );
4271 bool rollbackExtent = !mDataProvider->transaction() && ( !mEditBuffer->deletedFeatureIds().isEmpty() || !mEditBuffer->addedFeatures().isEmpty() || !mEditBuffer->changedGeometries().isEmpty() );
4275 mEditBuffer->rollBack();
4291 mEditBuffer =
nullptr;
4296 if ( rollbackExtent )
4299 mDataProvider->leaveUpdateMode();
4309 return mSelectedFeatureIds.size();
4317 return mSelectedFeatureIds;
4325 features.reserve( mSelectedFeatureIds.count() );
4332 features.push_back( f );
4342 if ( mSelectedFeatureIds.isEmpty() )
4348 if ( mSelectedFeatureIds.count() == 1 )
4349 request.
setFilterFid( *mSelectedFeatureIds.constBegin() );
4360 if ( !mEditBuffer || !mDataProvider )
4363 if ( mGeometryOptions->isActive() )
4365 for (
auto feature = features.begin(); feature != features.end(); ++feature )
4368 mGeometryOptions->apply( geom );
4373 bool res = mEditBuffer->addFeatures( features );
4376 if ( res && mJoinBuffer->containsJoins() )
4377 res = mJoinBuffer->addFeatures( features );
4395 if ( exp.isField() )
4418 if ( !mDisplayExpression.isEmpty() || mFields.isEmpty() )
4420 return mDisplayExpression;
4425 if ( !candidateName.isEmpty() )
4448 return ( mEditBuffer && mDataProvider );
4460bool QgsVectorLayer::isReadOnly()
const
4464 return mDataSourceReadOnly || mReadOnly;
4472 if ( readonly && mEditBuffer )
4476 if ( !readonly && mDataSourceReadOnly )
4479 mReadOnly = readonly;
4488 if ( !mDataProvider )
4491 if ( mDataSourceReadOnly )
4502 return mEditBuffer && mEditBuffer->isModified();
4509 bool auxiliaryField =
false;
4513 return auxiliaryField;
4520 auxiliaryField =
true;
4523 return auxiliaryField;
4539 if ( r != mRenderer )
4543 mSymbolFeatureCounted =
false;
4544 mSymbolFeatureCountMap.clear();
4545 mSymbolFeatureIdMap.clear();
4550 if ( refreshRate <= 0 )
4552 mRefreshRendererTimer->stop();
4553 mRefreshRendererTimer->setInterval( 0 );
4557 mRefreshRendererTimer->setInterval( 1000 / refreshRate );
4558 mRefreshRendererTimer->start();
4573 mRendererGenerators << generator;
4581 for (
int i = mRendererGenerators.count() - 1; i >= 0; --i )
4583 if ( mRendererGenerators.at( i )->id() ==
id )
4585 delete mRendererGenerators.at( i );
4586 mRendererGenerators.removeAt( i );
4596 QList< const QgsFeatureRendererGenerator * > res;
4606 if ( !mDataProvider )
4610 if ( mDataProvider->transaction() )
4612 QString ignoredError;
4613 mDataProvider->transaction()->createSavepoint( ignoredError );
4616 mEditCommandActive =
true;
4624 if ( !mDataProvider )
4629 mEditCommandActive =
false;
4630 if ( !mDeletedFids.isEmpty() )
4634 mSelectedFeatureIds.subtract( mDeletedFids );
4637 mDeletedFids.clear();
4646 if ( !mDataProvider )
4657 auto command = std::make_unique< QUndoCommand >();
4658 command->setObsolete(
true );
4661 mEditCommandActive =
false;
4662 mDeletedFids.clear();
4670 return mJoinBuffer->addJoin( joinInfo );
4677 return mJoinBuffer->removeJoin( joinLayerId );
4684 return mJoinBuffer->vectorJoins();
4692 mExpressionFieldBuffer->addExpression( exp, fld );
4694 int idx = mFields.indexFromName( fld.
name() );
4704 int oi = mFields.fieldOriginIndex( index );
4705 mExpressionFieldBuffer->removeExpression( oi );
4717 int oi = mFields.fieldOriginIndex( index );
4718 if ( oi < 0 || oi >= mExpressionFieldBuffer->expressions().size() )
4721 return mExpressionFieldBuffer->expressions().at( oi ).cachedExpression.expression();
4728 int oi = mFields.fieldOriginIndex( index );
4729 mExpressionFieldBuffer->updateExpression( oi, exp );
4737 if ( !mDataProvider )
4742 mFields = mDataProvider->fields();
4746 mEditBuffer->updateFields( mFields );
4749 if ( mJoinBuffer->containsJoins() )
4750 mJoinBuffer->updateFields( mFields );
4752 if ( mExpressionFieldBuffer )
4753 mExpressionFieldBuffer->updateFields( mFields );
4756 for (
auto aliasIt = mAttributeAliasMap.constBegin(); aliasIt != mAttributeAliasMap.constEnd(); ++aliasIt )
4758 int index = mFields.lookupField( aliasIt.key() );
4762 mFields[index].setAlias( aliasIt.value() );
4766 for (
auto customCommentIt = mAttributeCustomCommentMap.constBegin(); customCommentIt != mAttributeCustomCommentMap.constEnd(); ++customCommentIt )
4768 int index = mFields.lookupField( customCommentIt.key() );
4772 mFields[index].setCustomComment( customCommentIt.value() );
4775 for (
auto splitPolicyIt = mAttributeSplitPolicy.constBegin(); splitPolicyIt != mAttributeSplitPolicy.constEnd(); ++splitPolicyIt )
4777 int index = mFields.lookupField( splitPolicyIt.key() );
4781 mFields[index].setSplitPolicy( splitPolicyIt.value() );
4784 for (
auto duplicatePolicyIt = mAttributeDuplicatePolicy.constBegin(); duplicatePolicyIt != mAttributeDuplicatePolicy.constEnd(); ++duplicatePolicyIt )
4786 int index = mFields.lookupField( duplicatePolicyIt.key() );
4790 mFields[index].setDuplicatePolicy( duplicatePolicyIt.value() );
4793 for (
auto mergePolicyIt = mAttributeMergePolicy.constBegin(); mergePolicyIt != mAttributeMergePolicy.constEnd(); ++mergePolicyIt )
4795 int index = mFields.lookupField( mergePolicyIt.key() );
4799 mFields[index].setMergePolicy( mergePolicyIt.value() );
4803 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.
constBegin();
4804 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
4806 int index = mFields.lookupField( flagsIt.key() );
4810 mFields[index].setConfigurationFlags( flagsIt.value() );
4814 mDefaultValueOnUpdateFields.clear();
4815 QMap< QString, QgsDefaultValue >::const_iterator defaultIt = mDefaultExpressionMap.constBegin();
4816 for ( ; defaultIt != mDefaultExpressionMap.constEnd(); ++defaultIt )
4818 int index = mFields.lookupField( defaultIt.key() );
4822 mFields[index].setDefaultValueDefinition( defaultIt.value() );
4823 if ( defaultIt.value().applyOnUpdate() )
4824 mDefaultValueOnUpdateFields.insert( index );
4827 QMap< QString, QgsFieldConstraints::Constraints >::const_iterator constraintIt = mFieldConstraints.constBegin();
4828 for ( ; constraintIt != mFieldConstraints.constEnd(); ++constraintIt )
4830 int index = mFields.lookupField( constraintIt.key() );
4843 mFields[index].setConstraints( constraints );
4846 QMap< QString, QPair< QString, QString > >::const_iterator constraintExpIt = mFieldConstraintExpressions.constBegin();
4847 for ( ; constraintExpIt != mFieldConstraintExpressions.constEnd(); ++constraintExpIt )
4849 int index = mFields.lookupField( constraintExpIt.key() );
4860 mFields[index].setConstraints( constraints );
4864 for ( ; constraintStrengthIt != mFieldConstraintStrength.constEnd(); ++constraintStrengthIt )
4866 int index = mFields.lookupField( constraintStrengthIt.key().first );
4876 constraints.
setConstraintStrength( constraintStrengthIt.key().second, constraintStrengthIt.value() );
4877 mFields[index].setConstraints( constraints );
4880 auto fieldWidgetIterator = mFieldWidgetSetups.constBegin();
4881 for ( ; fieldWidgetIterator != mFieldWidgetSetups.constEnd(); ++fieldWidgetIterator )
4883 int index = mFields.indexOf( fieldWidgetIterator.key() );
4887 mFields[index].setEditorWidgetSetup( fieldWidgetIterator.value() );
4890 if ( oldFields != mFields )
4893 mEditFormConfig.setFields( mFields );
4901 if ( index < 0 || index >= mFields.count() || !mDataProvider )
4904 QString expression = mFields.at( index ).defaultValueDefinition().expression();
4905 if ( expression.isEmpty() )
4906 return mDataProvider->defaultValue( index );
4909 std::unique_ptr< QgsExpressionContext > tempContext;
4914 evalContext = tempContext.get();
4949 if ( index < 0 || index >= mFields.count() )
4954 mDefaultExpressionMap.insert( mFields.at( index ).name(), definition );
4958 mDefaultExpressionMap.remove( mFields.at( index ).name() );
4967 if ( index < 0 || index >= mFields.count() )
4970 return mFields.at( index ).defaultValueDefinition();
4978 if ( !mDataProvider )
4991 uniqueValues = mDataProvider->uniqueValues( index, limit );
4993 if ( mEditBuffer && !mDataProvider->transaction() )
4997 for (
const QVariant &v : constUniqueValues )
4999 vals << v.toString();
5003 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5004 while ( addedIt.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
5007 QVariant v = addedIt.value().attribute( index );
5010 QString vs = v.toString();
5011 if ( !vals.contains( vs ) )
5019 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5020 while ( it.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
5023 QVariant v = it.value().value( index );
5026 QString vs = v.toString();
5027 if ( !vals.contains( vs ) )
5041 if ( mDataProvider->transaction()
5042 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
5044 uniqueValues = mDataProvider->uniqueValues( index, limit );
5058 QVariant currentValue;
5059 QHash<QString, QVariant> val;
5063 val.insert( currentValue.toString(), currentValue );
5064 if ( limit >= 0 && val.size() >= limit )
5070 return qgis::listToSet( val.values() );
5074 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueValues()",
"Unknown source of the field!" );
5082 QStringList results;
5083 if ( !mDataProvider )
5096 results = mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
5098 if ( mEditBuffer && !mDataProvider->transaction() )
5101 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5102 while ( addedIt.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
5105 QVariant v = addedIt.value().attribute( index );
5108 QString vs = v.toString();
5109 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
5116 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5117 while ( it.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
5120 QVariant v = it.value().value( index );
5123 QString vs = v.toString();
5124 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
5137 if ( mDataProvider->transaction()
5138 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
5140 return mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
5153 QString fieldName = mFields.at( index ).name();
5158 QString currentValue;
5161 currentValue = f.
attribute( index ).toString();
5162 if ( !results.contains( currentValue ) )
5163 results << currentValue;
5165 if ( ( limit >= 0 && results.size() >= limit ) || ( feedback && feedback->
isCanceled() ) )
5175 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueStringsMatching()",
"Unknown source of the field!" );
5184 minimumOrMaximumValue( index, &minimum,
nullptr );
5193 minimumOrMaximumValue( index,
nullptr, &maximum );
5201 minimumOrMaximumValue( index, &minimum, &maximum );
5204void QgsVectorLayer::minimumOrMaximumValue(
int index, QVariant *minimum, QVariant *maximum )
const
5209 *minimum = QVariant();
5211 *maximum = QVariant();
5213 if ( !mDataProvider )
5230 *minimum = mDataProvider->minimumValue( index );
5232 *maximum = mDataProvider->maximumValue( index );
5233 if ( mEditBuffer && !mDataProvider->transaction() )
5236 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5237 while ( addedIt.hasNext() )
5240 const QVariant v = addedIt.value().attribute( index );
5247 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5248 while ( it.hasNext() )
5251 const QVariant v = it.value().value( index );
5264 if ( mDataProvider->transaction()
5265 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
5268 *minimum = mDataProvider->minimumValue( index );
5270 *maximum = mDataProvider->maximumValue( index );
5286 bool firstValue =
true;
5289 const QVariant currentValue = f.
attribute( index );
5296 *minimum = currentValue;
5298 *maximum = currentValue;
5303 if ( minimum && currentValue.isValid() &&
qgsVariantLessThan( currentValue, *minimum ) )
5304 *minimum = currentValue;
5306 *maximum = currentValue;
5313 Q_ASSERT_X(
false,
"QgsVectorLayer::minimumOrMaximumValue()",
"Unknown source of the field!" );
5316void QgsVectorLayer::createEditBuffer()
5323 if ( mDataProvider->transaction() )
5327 connect( mDataProvider->transaction(), &
QgsTransaction::dirtied,
this, &QgsVectorLayer::onDirtyTransaction, Qt::UniqueConnection );
5351void QgsVectorLayer::clearEditBuffer()
5356 mEditBuffer =
nullptr;
5361 const QString &fieldOrExpression,
5378 if ( !mDataProvider )
5381 *
error = tr(
"Layer is invalid" );
5387 if ( attrIndex >= 0 )
5394 bool providerOk =
false;
5395 QVariant val = mDataProvider->aggregate(
aggregate, attrIndex, parameters, context, providerOk, fids );
5409 c.setFidsFilter( *fids );
5410 c.setParameters( parameters );
5411 bool aggregateOk =
false;
5412 const QVariant result =
c.calculate(
aggregate, fieldOrExpression, context, &aggregateOk, feedback );
5415 if ( !aggregateOk &&
error )
5438 return mFeatureBlendMode;
5441void QgsVectorLayer::readSldLabeling(
const QDomNode &node )
5448 QDomElement element = node.toElement();
5449 if ( element.isNull() )
5452 QDomElement userStyleElem = element.firstChildElement( u
"UserStyle"_s );
5453 if ( userStyleElem.isNull() )
5459 QDomElement featTypeStyleElem = userStyleElem.firstChildElement( u
"FeatureTypeStyle"_s );
5460 if ( featTypeStyleElem.isNull() )
5467 QDomElement mergedFeatTypeStyle = featTypeStyleElem.cloneNode(
false ).toElement();
5472 bool needRuleBasedLabeling =
false;
5475 while ( !featTypeStyleElem.isNull() )
5477 QDomElement ruleElem = featTypeStyleElem.firstChildElement( u
"Rule"_s );
5478 while ( !ruleElem.isNull() )
5482 bool hasTextSymbolizer =
false;
5483 bool hasRuleBased =
false;
5484 QDomElement ruleChildElem = ruleElem.firstChildElement();
5485 while ( !ruleChildElem.isNull() )
5488 if ( ruleChildElem.localName() ==
"Filter"_L1 || ruleChildElem.localName() ==
"MinScaleDenominator"_L1 || ruleChildElem.localName() ==
"MaxScaleDenominator"_L1 )
5490 hasRuleBased =
true;
5493 else if ( ruleChildElem.localName() ==
"TextSymbolizer"_L1 )
5496 hasTextSymbolizer =
true;
5499 ruleChildElem = ruleChildElem.nextSiblingElement();
5502 if ( hasTextSymbolizer )
5507 mergedFeatTypeStyle.appendChild( ruleElem.cloneNode().toElement() );
5511 QgsDebugMsgLevel( u
"Info: Filter or Min/MaxScaleDenominator element found: need a RuleBasedLabeling"_s, 4 );
5512 needRuleBasedLabeling =
true;
5517 if ( ruleCount > 1 )
5519 QgsDebugMsgLevel( u
"Info: More Rule elements found: need a RuleBasedLabeling"_s, 4 );
5520 needRuleBasedLabeling =
true;
5524 if ( ruleCount == 0 )
5526 needRuleBasedLabeling =
false;
5529 ruleElem = ruleElem.nextSiblingElement( u
"Rule"_s );
5531 featTypeStyleElem = featTypeStyleElem.nextSiblingElement( u
"FeatureTypeStyle"_s );
5534 if ( ruleCount == 0 )
5540 QDomElement ruleElem = mergedFeatTypeStyle.firstChildElement( u
"Rule"_s );
5542 if ( needRuleBasedLabeling )
5545 QgsRuleBasedLabeling::Rule *rootRule =
new QgsRuleBasedLabeling::Rule(
nullptr );
5546 while ( !ruleElem.isNull() )
5548 QString label, description, filterExp;
5549 int scaleMinDenom = 0, scaleMaxDenom = 0;
5550 QgsPalLayerSettings settings;
5553 QDomElement childElem = ruleElem.firstChildElement();
5554 while ( !childElem.isNull() )
5556 if ( childElem.localName() ==
"Name"_L1 )
5560 if ( label.isEmpty() )
5561 label = childElem.firstChild().nodeValue();
5563 else if ( childElem.localName() ==
"Description"_L1 )
5566 QDomElement titleElem = childElem.firstChildElement( u
"Title"_s );
5567 if ( !titleElem.isNull() )
5569 label = titleElem.firstChild().nodeValue();
5572 QDomElement abstractElem = childElem.firstChildElement( u
"Abstract"_s );
5573 if ( !abstractElem.isNull() )
5575 description = abstractElem.firstChild().nodeValue();
5578 else if ( childElem.localName() ==
"Abstract"_L1 )
5581 description = childElem.firstChild().nodeValue();
5583 else if ( childElem.localName() ==
"Title"_L1 )
5586 label = childElem.firstChild().nodeValue();
5588 else if ( childElem.localName() ==
"Filter"_L1 )
5604 else if ( childElem.localName() ==
"MinScaleDenominator"_L1 )
5607 int v = childElem.firstChild().nodeValue().toInt( &ok );
5611 else if ( childElem.localName() ==
"MaxScaleDenominator"_L1 )
5614 int v = childElem.firstChild().nodeValue().toInt( &ok );
5618 else if ( childElem.localName() ==
"TextSymbolizer"_L1 )
5620 readSldTextSymbolizer( childElem, settings );
5623 childElem = childElem.nextSiblingElement();
5626 QgsRuleBasedLabeling::Rule *ruleLabeling =
new QgsRuleBasedLabeling::Rule(
new QgsPalLayerSettings( settings ), scaleMinDenom, scaleMaxDenom, filterExp, label );
5629 ruleElem = ruleElem.nextSiblingElement();
5632 setLabeling(
new QgsRuleBasedLabeling( rootRule ) );
5639 QDomElement textSymbolizerElem = ruleElem.firstChildElement( u
"TextSymbolizer"_s );
5640 QgsPalLayerSettings s;
5641 if ( readSldTextSymbolizer( textSymbolizerElem, s ) )
5643 setLabeling(
new QgsVectorLayerSimpleLabeling( s ) );
5649bool QgsVectorLayer::readSldTextSymbolizer(
const QDomNode &node,
QgsPalLayerSettings &settings )
const
5653 if ( node.localName() !=
"TextSymbolizer"_L1 )
5655 QgsDebugMsgLevel( u
"Not a TextSymbolizer element: %1"_s.arg( node.localName() ), 3 );
5658 QDomElement textSymbolizerElem = node.toElement();
5660 QDomElement labelElem = textSymbolizerElem.firstChildElement( u
"Label"_s );
5661 if ( !labelElem.isNull() )
5663 QDomElement propertyNameElem = labelElem.firstChildElement( u
"PropertyName"_s );
5664 if ( !propertyNameElem.isNull() )
5669 QString labelAttribute = propertyNameElem.text();
5673 int fieldIndex = mFields.lookupField( labelAttribute );
5674 if ( fieldIndex == -1 )
5677 QgsExpression exp( labelAttribute );
5678 if ( !exp.hasEvalError() )
5684 QgsDebugMsgLevel( u
"SLD label attribute error: %1"_s.arg( exp.evalErrorString() ), 3 );
5701 if ( textSymbolizerElem.hasAttribute( u
"uom"_s ) )
5706 QString fontFamily = u
"Sans-Serif"_s;
5707 double fontPointSize = 10;
5709 int fontWeight = -1;
5710 bool fontItalic =
false;
5711 bool fontUnderline =
false;
5714 QDomElement fontElem = textSymbolizerElem.firstChildElement( u
"Font"_s );
5715 if ( !fontElem.isNull() )
5718 for ( QgsStringMap::iterator it = fontSvgParams.begin(); it != fontSvgParams.end(); ++it )
5720 QgsDebugMsgLevel( u
"found fontSvgParams %1: %2"_s.arg( it.key(), it.value() ), 4 );
5722 if ( it.key() ==
"font-family"_L1 )
5724 fontFamily = it.value();
5726 else if ( it.key() ==
"font-style"_L1 )
5728 fontItalic = ( it.value() ==
"italic"_L1 ) || ( it.value() ==
"Italic"_L1 );
5730 else if ( it.key() ==
"font-size"_L1 )
5733 double fontSize = it.value().toDouble( &ok );
5736 fontPointSize = fontSize;
5737 fontUnitSize = sldUnitSize;
5740 else if ( it.key() ==
"font-weight"_L1 )
5742 if ( ( it.value() ==
"bold"_L1 ) || ( it.value() ==
"Bold"_L1 ) )
5743 fontWeight = QFont::Bold;
5745 else if ( it.key() ==
"font-underline"_L1 )
5747 fontUnderline = ( it.value() ==
"underline"_L1 ) || ( it.value() ==
"Underline"_L1 );
5752 QgsTextFormat format;
5753 QFont font( fontFamily, 1, fontWeight, fontItalic );
5754 font.setUnderline( fontUnderline );
5756 format.
setSize( fontPointSize );
5760 QDomElement fillElem = textSymbolizerElem.firstChildElement( u
"Fill"_s );
5762 Qt::BrushStyle textBrush = Qt::SolidPattern;
5764 if ( textColor.isValid() )
5766 QgsDebugMsgLevel( u
"Info: textColor %1."_s.arg( QVariant( textColor ).toString() ), 4 );
5770 QgsTextBufferSettings bufferSettings;
5773 QDomElement haloElem = textSymbolizerElem.firstChildElement( u
"Halo"_s );
5774 if ( !haloElem.isNull() )
5779 QDomElement radiusElem = haloElem.firstChildElement( u
"Radius"_s );
5780 if ( !radiusElem.isNull() )
5783 double bufferSize = radiusElem.text().toDouble( &ok );
5786 bufferSettings.
setSize( bufferSize );
5791 QDomElement haloFillElem = haloElem.firstChildElement( u
"Fill"_s );
5793 Qt::BrushStyle bufferBrush = Qt::SolidPattern;
5795 if ( bufferColor.isValid() )
5797 QgsDebugMsgLevel( u
"Info: bufferColor %1."_s.arg( QVariant( bufferColor ).toString() ), 4 );
5798 bufferSettings.
setColor( bufferColor );
5803 QDomElement labelPlacementElem = textSymbolizerElem.firstChildElement( u
"LabelPlacement"_s );
5804 if ( !labelPlacementElem.isNull() )
5807 QDomElement pointPlacementElem = labelPlacementElem.firstChildElement( u
"PointPlacement"_s );
5808 if ( !pointPlacementElem.isNull() )
5816 QDomElement displacementElem = pointPlacementElem.firstChildElement( u
"Displacement"_s );
5817 if ( !displacementElem.isNull() )
5819 QDomElement displacementXElem = displacementElem.firstChildElement( u
"DisplacementX"_s );
5820 if ( !displacementXElem.isNull() )
5823 double xOffset = displacementXElem.text().toDouble( &ok );
5830 QDomElement displacementYElem = displacementElem.firstChildElement( u
"DisplacementY"_s );
5831 if ( !displacementYElem.isNull() )
5834 double yOffset = displacementYElem.text().toDouble( &ok );
5842 QDomElement anchorPointElem = pointPlacementElem.firstChildElement( u
"AnchorPoint"_s );
5843 if ( !anchorPointElem.isNull() )
5845 QDomElement anchorPointXElem = anchorPointElem.firstChildElement( u
"AnchorPointX"_s );
5846 if ( !anchorPointXElem.isNull() )
5849 double xOffset = anchorPointXElem.text().toDouble( &ok );
5856 QDomElement anchorPointYElem = anchorPointElem.firstChildElement( u
"AnchorPointY"_s );
5857 if ( !anchorPointYElem.isNull() )
5860 double yOffset = anchorPointYElem.text().toDouble( &ok );
5869 QDomElement rotationElem = pointPlacementElem.firstChildElement( u
"Rotation"_s );
5870 if ( !rotationElem.isNull() )
5873 double rotation = rotationElem.text().toDouble( &ok );
5883 QDomElement linePlacementElem = labelPlacementElem.firstChildElement( u
"LinePlacement"_s );
5884 if ( !linePlacementElem.isNull() )
5893 QDomElement vendorOptionElem = textSymbolizerElem.firstChildElement( u
"VendorOption"_s );
5894 while ( !vendorOptionElem.isNull() && vendorOptionElem.localName() ==
"VendorOption"_L1 )
5896 QString optionName = vendorOptionElem.attribute( u
"name"_s );
5897 QString optionValue;
5898 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::TextNode )
5900 optionValue = vendorOptionElem.firstChild().nodeValue();
5904 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::ElementNode && vendorOptionElem.firstChild().localName() ==
"Literal"_L1 )
5907 optionValue = vendorOptionElem.firstChild().firstChild().nodeValue();
5911 QgsDebugError( u
"unexpected child of %1 named %2"_s.arg( vendorOptionElem.localName(), optionName ) );
5915 if ( !optionName.isEmpty() && !optionValue.isEmpty() )
5917 vendorOptions[optionName] = optionValue;
5920 vendorOptionElem = vendorOptionElem.nextSiblingElement();
5922 if ( !vendorOptions.isEmpty() )
5924 for ( QgsStringMap::iterator it = vendorOptions.begin(); it != vendorOptions.end(); ++it )
5926 if ( it.key() ==
"underlineText"_L1 && it.value() ==
"true"_L1 )
5928 font.setUnderline(
true );
5931 else if ( it.key() ==
"strikethroughText"_L1 && it.value() ==
"true"_L1 )
5933 font.setStrikeOut(
true );
5936 else if ( it.key() ==
"maxDisplacement"_L1 )
5940 else if ( it.key() ==
"followLine"_L1 && it.value() ==
"true"_L1 )
5951 else if ( it.key() ==
"maxAngleDelta"_L1 )
5954 double angle = it.value().toDouble( &ok );
5962 else if ( it.key() ==
"conflictResolution"_L1 && it.value() ==
"false"_L1 )
5966 else if ( it.key() ==
"forceLeftToRight"_L1 && it.value() ==
"false"_L1 )
5970 else if ( it.key() ==
"group"_L1 && it.value() ==
"yes"_L1 )
5974 else if ( it.key() ==
"labelAllGroup"_L1 && it.value() ==
"true"_L1 )
5990 return mEditFormConfig;
6001 mEditFormConfig.onRelationsLoaded();
6011 if ( config.isEmpty() )
6047 if ( !mDiagramLayerSettings )
6049 *mDiagramLayerSettings = s;
6057 QString myMetadata = u
"<html><head></head>\n<body>\n"_s;
6062 myMetadata += u
"<h1>"_s + tr(
"Information from provider" ) + u
"</h1>\n<hr>\n"_s;
6063 myMetadata +=
"<table class=\"list-view\">\n"_L1;
6068 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Storage" ) + u
"</td><td>"_s +
storageType() + u
"</td></tr>\n"_s;
6074 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Comment" ) + u
"</td><td>"_s +
dataComment() + u
"</td></tr>\n"_s;
6080 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Encoding" ) + u
"</td><td>"_s + provider->encoding() + u
"</td></tr>\n"_s;
6081 myMetadata += provider->htmlMetadata();
6095 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry type" ) + u
"</td><td>"_s + typeString + u
"</td></tr>\n"_s;
6101 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry column" ) + u
"</td><td>"_s + provider->geometryColumnName() + u
"</td></tr>\n"_s;
6108 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Extent" ) + u
"</td><td>"_s + extentAsStr + u
"</td></tr>\n"_s;
6112 QLocale locale = QLocale();
6113 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
6114 myMetadata += u
"<tr><td class=\"highlight\">"_s
6115 + tr(
"Feature count" )
6118 + u
"</td></tr>\n"_s;
6121 myMetadata +=
"</table>\n<br><br>"_L1;
6130 myMetadata += u
"<h1>"_s + tr(
"Identification" ) + u
"</h1>\n<hr>\n"_s;
6131 myMetadata += htmlFormatter.identificationSectionHtml();
6132 myMetadata +=
"<br><br>\n"_L1;
6135 myMetadata += u
"<h1>"_s + tr(
"Extent" ) + u
"</h1>\n<hr>\n"_s;
6136 myMetadata += htmlFormatter.extentSectionHtml(
isSpatial() );
6137 myMetadata +=
"<br><br>\n"_L1;
6140 myMetadata += u
"<h1>"_s + tr(
"Access" ) + u
"</h1>\n<hr>\n"_s;
6141 myMetadata += htmlFormatter.accessSectionHtml();
6142 myMetadata +=
"<br><br>\n"_L1;
6145 myMetadata += u
"<h1>"_s + tr(
"Fields" ) + u
"</h1>\n<hr>\n<table class=\"list-view\">\n"_s;
6149 if ( !pkAttrList.isEmpty() )
6151 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Primary key attributes" ) + u
"</td><td>"_s;
6152 const auto constPkAttrList = pkAttrList;
6153 for (
int idx : constPkAttrList )
6157 myMetadata +=
"</td></tr>\n"_L1;
6163 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Count" ) + u
"</td><td>"_s + QString::number( myFields.
size() ) + u
"</td></tr>\n"_s;
6165 myMetadata +=
"</table>\n<br><table width=\"100%\" class=\"tabular-view\">\n"_L1;
6166 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;
6168 for (
int i = 0; i < myFields.
size(); ++i )
6173 rowClass = u
"class=\"odd-row\""_s;
6174 myMetadata +=
"<tr "_L1
6181 + QString::number( myField.
length() )
6183 + QString::number( myField.
precision() )
6186 +
"</td></tr>\n"_L1;
6190 myMetadata +=
"</table>\n<br><br>"_L1;
6193 myMetadata += u
"<h1>"_s + tr(
"Contacts" ) + u
"</h1>\n<hr>\n"_s;
6194 myMetadata += htmlFormatter.contactsSectionHtml();
6195 myMetadata +=
"<br><br>\n"_L1;
6198 myMetadata += u
"<h1>"_s + tr(
"Links" ) + u
"</h1>\n<hr>\n"_s;
6199 myMetadata += htmlFormatter.linksSectionHtml();
6200 myMetadata +=
"<br><br>\n"_L1;
6203 myMetadata += u
"<h1>"_s + tr(
"History" ) + u
"</h1>\n<hr>\n"_s;
6204 myMetadata += htmlFormatter.historySectionHtml();
6205 myMetadata +=
"<br><br>\n"_L1;
6209 myMetadata +=
"\n</body>\n</html>\n"_L1;
6213void QgsVectorLayer::invalidateSymbolCountedFlag()
6217 mSymbolFeatureCounted =
false;
6220void QgsVectorLayer::onFeatureCounterCompleted()
6225 mFeatureCounter =
nullptr;
6228void QgsVectorLayer::onFeatureCounterTerminated()
6232 mFeatureCounter =
nullptr;
6235void QgsVectorLayer::onJoinedFieldsChanged()
6252void QgsVectorLayer::onFeatureDeleted(
QgsFeatureId fid )
6258 if ( mEditCommandActive || mCommitChangesActive )
6260 mDeletedFids << fid;
6264 mSelectedFeatureIds.remove( fid );
6271void QgsVectorLayer::onRelationsLoaded()
6275 mEditFormConfig.onRelationsLoaded();
6278void QgsVectorLayer::onSymbolsCounted()
6282 if ( mFeatureCounter )
6284 mSymbolFeatureCounted =
true;
6285 mSymbolFeatureCountMap = mFeatureCounter->symbolFeatureCountMap();
6286 mSymbolFeatureIdMap = mFeatureCounter->symbolFeatureIdMap();
6296 return p->relationManager()->referencingRelations(
this, idx );
6305 return mWeakRelations;
6312 mWeakRelations = relations;
6321 QString joinKey = mAuxiliaryLayerKey;
6322 if ( !key.isEmpty() )
6325 if ( storage.
isValid() && !joinKey.isEmpty() )
6350 mAuxiliaryLayerKey.clear();
6352 if ( mAuxiliaryLayer )
6365 mAuxiliaryLayer.reset( alayer );
6366 if ( mAuxiliaryLayer )
6367 mAuxiliaryLayer->setParent(
this );
6375 return mAuxiliaryLayer.get();
6382 return mAuxiliaryLayer.get();
6389 if ( mDataProvider )
6394void QgsVectorLayer::emitDataChanged()
6398 if ( mDataChangedFired )
6405 if (
QgsVectorLayer *layerWeDependUpon = qobject_cast<QgsVectorLayer *>( sender() ); layerWeDependUpon && layerWeDependUpon->mCommitChangesActive )
6410 mDataChangedFired =
true;
6412 mDataChangedFired =
false;
6415void QgsVectorLayer::onDependencyAfterCommitChanges()
6420 mDataProvider->reloadData();
6429 QSet<QgsMapLayerDependency> deps;
6430 const auto constODeps = oDeps;
6437 QSet<QgsMapLayerDependency> toAdd = deps -
dependencies();
6457 if ( mDataProvider )
6481 if ( !toAdd.isEmpty() )
6491 if ( fieldIndex < 0 || fieldIndex >= mFields.count() || !mDataProvider )
6499 constraints |= mDataProvider->fieldConstraints( mFields.fieldOriginIndex( fieldIndex ) );
6509 QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > m;
6511 if ( fieldIndex < 0 || fieldIndex >= mFields.count() )
6514 QString
name = mFields.at( fieldIndex ).name();
6517 for ( ; conIt != mFieldConstraintStrength.constEnd(); ++conIt )
6519 if ( conIt.key().first ==
name )
6521 m[conIt.key().second] = mFieldConstraintStrength.value( conIt.key() );
6532 if ( index < 0 || index >= mFields.count() )
6535 QString
name = mFields.at( index ).name();
6539 constraints |= constraint;
6540 mFieldConstraints.insert(
name, constraints );
6542 mFieldConstraintStrength.insert( qMakePair(
name, constraint ), strength );
6551 if ( index < 0 || index >= mFields.count() )
6554 QString
name = mFields.at( index ).name();
6558 constraints &= ~constraint;
6559 mFieldConstraints.insert(
name, constraints );
6561 mFieldConstraintStrength.remove( qMakePair(
name, constraint ) );
6570 if ( index < 0 || index >= mFields.count() )
6573 return mFields.at( index ).constraints().constraintExpression();
6580 if ( index < 0 || index >= mFields.count() )
6583 return mFields.at( index ).constraints().constraintDescription();
6590 if ( index < 0 || index >= mFields.count() )
6593 if ( expression.isEmpty() )
6595 mFieldConstraintExpressions.remove( mFields.at( index ).name() );
6599 mFieldConstraintExpressions.insert( mFields.at( index ).name(), qMakePair( expression, description ) );
6608 if ( index < 0 || index >= mFields.count() )
6611 mFieldConfigurationFlags.insert( mFields.at( index ).name(),
flags );
6619 if ( index < 0 || index >= mFields.count() )
6622 flags.setFlag( flag, active );
6630 if ( index < 0 || index >= mFields.count() )
6633 return mFields.at( index ).configurationFlags();
6640 if ( index < 0 || index >= mFields.count() )
6644 mFieldWidgetSetups.remove( mFields.at( index ).name() );
6646 mFieldWidgetSetups.insert( mFields.at( index ).name(), setup );
6654 if ( index < 0 || index >= mFields.count() )
6657 return mFields.at( index ).editorWidgetSetup();
6667 if (
customProperty( u
"labeling/enabled"_s, QVariant(
false ) ).toBool() )
6671 settings.readFromLayerCustomProperties(
this );
6678 for (
const QString &key : constCustomPropertyKeys )
6680 if ( key.startsWith(
"labeling/"_L1 ) )
6692 return mAllowCommit;
6710 return mGeometryOptions.get();
6724 return mReadExtentFromXml;
6727void QgsVectorLayer::onDirtyTransaction(
const QString &sql,
const QString &name )
6732 if ( tr && mEditBuffer )
6734 qobject_cast<QgsVectorLayerEditPassthrough *>( mEditBuffer )->update( tr, sql,
name );
6740 QList<QgsVectorLayer *> layers;
6741 QMap<QgsVectorLayer *, QgsFeatureIds>::const_iterator i;
6744 if ( includeAuxiliaryLayers || !qobject_cast< QgsAuxiliaryLayer * >( i.key() ) )
6745 layers.append( i.key() );
Provides global constants and enumerations for use throughout the application.
@ Action
Map layers' action.
@ FormInitCode
Attribute forms' initiation code.
@ SelectAtId
Fast access to features using their ID.
@ CacheData
Provider caches source data and should force provider data reloads when dependent layers are committe...
@ 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.
@ EmptyGeometry
Edit operation resulted in an empty geometry.
@ 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.
bool isExactlyEqual(const QgsGeometry &geometry, Qgis::GeometryBackend backend=Qgis::GeometryBackend::QGIS) const
Compares the geometry with another geometry using the specified backend.
QgsBox3D boundingBox3D() const
Returns the 3D bounding box of the 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 Q_INVOKABLE 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(), Qgis::StringFormat format=Qgis::StringFormat::PlainText)
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 rounded to the spec...
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
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.
static QString threadDescription(QThread *thread)
Returns a descriptive identifier for a thread.
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.
Qgis::VectorEditResult deleteVertices(QgsFeatureId featureId, const QSet< int > &vertices)
Deletes a set of vertices from a feature.
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...
static QgsFeatureIds filterValidFeatureIds(const QgsVectorLayer *layer, const QgsFeatureIds &featureIds)
Filters a set of feature IDs to only include those that exist in the layer.
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.
Q_INVOKABLE void selectByRect(const QgsRectangle &rect, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects features found within the search rectangle (in layer's coordinates).
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 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.
Q_INVOKABLE 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.
Q_INVOKABLE 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.
Q_INVOKABLE QString attributeCustomComment(int index) const
Returns the custom comment for the field.
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.
Q_INVOKABLE void invertSelectionInRectangle(const QgsRectangle &rect)
Inverts selection of features found within the search rectangle (in layer's coordinates).
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.
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.
QgsStringMap attributeCustomComments() const
Returns a map of all the custom comments.
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.
Qgis::VectorEditResult deleteVertices(QgsFeatureId featureId, const QSet< int > &vertices)
Deletes a set of vertices from a feature.
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.
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.
Q_INVOKABLE void setFieldCustomComment(int index, const QString &customCommentString)
Sets the custom comment for the field.
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.
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 selectByIds(const QgsFeatureIds &ids, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection, bool validateIds=false)
Selects matching features using a list of feature IDs.
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.
Q_INVOKABLE QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const final
Calculates a list of unique values contained within an attribute in the layer.
Q_INVOKABLE void removeFieldCustomComment(int index)
Removes the custom comment for the field.
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.
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.