Skip to content

Commit

Permalink
Delete equality operator of QgsMapLayerRef and make its bool operator…
Browse files Browse the repository at this point in the history
… explicit

This will avoid implicit conversion to bool when comparing QList<QgsMapLayerRef>s in the future.
  • Loading branch information
uclaros authored and nyalldawson committed Oct 12, 2024
1 parent 43536f3 commit ca9a5cf
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 9 deletions.
12 changes: 4 additions & 8 deletions src/3d/qgs3dmapsettings.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
#include "qgsdirectionallightsettings.h"
#include "qgs3drendercontext.h"
#include "qgsthreadingutils.h"
#include "qgsmaplayerlistutils_p.h"

#include <QDomDocument>
#include <QDomElement>
Expand Down Expand Up @@ -643,17 +644,12 @@ void Qgs3DMapSettings::setLayers( const QList<QgsMapLayer *> &layers )
{
QGIS_PROTECT_QOBJECT_THREAD_ACCESS

QList<QgsMapLayerRef> lst;
lst.reserve( layers.count() );
for ( QgsMapLayer *layer : layers )
{
lst.append( layer );
}
const QList<QgsMapLayer *> raw = _qgis_listRefToRaw( mLayers );

if ( mLayers == lst )
if ( layers == raw )
return;

mLayers = lst;
mLayers = _qgis_listRawToRef( layers );
emit layersChanged();
}

Expand Down
7 changes: 6 additions & 1 deletion src/core/qgsmaplayerref.h
Original file line number Diff line number Diff line change
Expand Up @@ -85,11 +85,16 @@ struct _LayerRef
provider = l && l->dataProvider() ? l->dataProvider()->name() : QString();
}

/**
* Equality operator is deleted to avoid confusion as there are multiple ways two _LayerRef objects can be considered equal.
*/
bool operator==( const _LayerRef &other ) = delete;

/**
* Returns TRUE if the layer reference is resolved and contains a reference to an existing
* map layer.
*/
operator bool() const
explicit operator bool() const
{
return static_cast< bool >( layer.data() );
}
Expand Down

0 comments on commit ca9a5cf

Please sign in to comment.