Skip to content

Commit 4c02d7f

Browse files
committed
Keep selection if exchanging ids for added features, safety check for 0 geometry in splitFeatures method
1 parent 15539f3 commit 4c02d7f

File tree

2 files changed

+10
-0
lines changed

2 files changed

+10
-0
lines changed

src/core/qgsvectorlayereditbuffer.cpp

+6
Original file line numberDiff line numberDiff line change
@@ -386,6 +386,12 @@ bool QgsVectorLayerEditBuffer::commitChanges( QStringList& commitErrors )
386386
{
387387
if ( featuresToAdd[i].id() != ids[i] )
388388
{
389+
//update selection
390+
if ( L->mSelectedFeatureIds.contains( ids[i] ) )
391+
{
392+
L->mSelectedFeatureIds.remove( ids[i] );
393+
L->mSelectedFeatureIds.insert( featuresToAdd[i].id() );
394+
}
389395
emit featureDeleted( ids[i] );
390396
emit featureAdded( featuresToAdd[i].id() );
391397
}

src/core/qgsvectorlayereditutils.cpp

+4
Original file line numberDiff line numberDiff line change
@@ -224,6 +224,10 @@ int QgsVectorLayerEditUtils::splitFeatures( const QList<QgsPoint>& splitLine, bo
224224
QgsFeatureList::iterator select_it = featureList.begin();
225225
for ( ; select_it != featureList.end(); ++select_it )
226226
{
227+
if ( !select_it->geometry() )
228+
{
229+
continue;
230+
}
227231
QList<QgsGeometry*> newGeometries;
228232
QList<QgsPoint> topologyTestPoints;
229233
QgsGeometry* newGeometry = 0;

0 commit comments

Comments
 (0)