QGIS API Documentation  3.8.0-Zanzibar (11aff65)
qgssinglegeometrycheck.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgssinglegeometrycheck.cpp
3  --------------------------------------
4 Date : 6.9.2018
5 Copyright : (C) 2018 by Matthias Kuhn
6 email : [email protected]
7  ***************************************************************************
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  ***************************************************************************/
15 
16 #include "qgssinglegeometrycheck.h"
18 #include "qgspoint.h"
19 
20 
21 
22 void QgsSingleGeometryCheck::collectErrors( const QMap<QString, QgsFeaturePool *> &featurePools,
23  QList<QgsGeometryCheckError *> &errors,
24  QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids ) const
25 {
26  Q_UNUSED( messages )
27  QMap<QString, QgsFeatureIds> featureIds = ids.isEmpty() ? allLayerFeatureIds( featurePools ) : ids.toMap();
28  QgsGeometryCheckerUtils::LayerFeatures layerFeatures( featurePools, featureIds, compatibleGeometryTypes(), feedback, mContext );
29  for ( const QgsGeometryCheckerUtils::LayerFeature &layerFeature : layerFeatures )
30  {
31  const auto singleErrors = processGeometry( layerFeature.geometry() );
32  for ( const auto error : singleErrors )
33  errors.append( convertToGeometryCheckError( error, layerFeature ) );
34  }
35 }
36 
37 QgsGeometryCheckErrorSingle *QgsSingleGeometryCheck::convertToGeometryCheckError( QgsSingleGeometryCheckError *singleGeometryCheckError, const QgsGeometryCheckerUtils::LayerFeature &layerFeature ) const
38 {
39  return new QgsGeometryCheckErrorSingle( singleGeometryCheckError, layerFeature );
40 }
41 
43 {
44  Q_ASSERT( mCheck == other->mCheck );
45  mErrorLocation = other->mErrorLocation;
46  mVertexId = other->mVertexId;
47  mGeometry = other->mGeometry;
48 }
49 
51 {
52  return mGeometry.equals( other->mGeometry )
53  && mCheck == other->mCheck
54  && mErrorLocation.equals( other->mErrorLocation )
55  && mVertexId == other->mVertexId;
56 }
57 
58 bool QgsSingleGeometryCheckError::handleChanges( const QList<QgsGeometryCheck::Change> &changes )
59 {
60  Q_UNUSED( changes )
61  return true;
62 }
63 
65 {
66  return mCheck->description();
67 }
68 
70 {
71  return mCheck;
72 }
73 
75 {
76  return mErrorLocation;
77 }
78 
80 {
81  return mVertexId;
82 }
83 
85  : QgsGeometryCheckError( error->check(), layerFeature, QgsPointXY( error->errorLocation().constGet()->centroid() ), error->vertexId() ) // TODO: should send geometry to QgsGeometryCheckError
86  , mError( error )
87 {
88 
89 }
90 
92 {
93  return mError;
94 }
95 
97 {
98  if ( !QgsGeometryCheckError::handleChanges( changes ) )
99  return false;
100 
101  return mError->handleChanges( changes.value( layerId() ).value( featureId() ) );
102 }
A class to represent a 2D point.
Definition: qgspointxy.h:43
QMap< QString, QgsFeatureIds > toMap() const
virtual bool isEqual(const QgsSingleGeometryCheckError *other) const
Check if this error is equal to other.
Contains a set of layers and feature ids in those layers to pass to a geometry check.
A geometry is the spatial representation of a feature.
Definition: qgsgeometry.h:111
Base class for geometry checks for a single geometry without any context of the layer or other layers...
virtual QList< QgsWkbTypes::GeometryType > compatibleGeometryTypes() const =0
A list of geometry types for which this check can be performed.
virtual bool handleChanges(const QList< QgsGeometryCheck::Change > &changes)
Apply a list of changes.
Base class for feedback objects to be used for cancellation of something running in a worker thread...
Definition: qgsfeedback.h:44
QgsGeometry errorLocation() const
The exact location of the error.
void collectErrors(const QMap< QString, QgsFeaturePool *> &featurePools, QList< QgsGeometryCheckError *> &errors, QStringList &messages, QgsFeedback *feedback=nullptr, const QgsGeometryCheck::LayerFeatureIds &ids=QgsGeometryCheck::LayerFeatureIds()) const FINAL
The main worker method.
QgsSingleGeometryCheckError * singleError() const
The underlying single error.
Utility class for identifying a unique vertex within a geometry.
QgsGeometryCheckErrorSingle(QgsSingleGeometryCheckError *singleError, const QgsGeometryCheckerUtils::LayerFeature &layerFeature)
Creates a new error for a QgsSingleGeometryCheck.
A layer feature combination to uniquely identify and access a feature in a set of layers...
QgsVertexId vertexId() const
The vertex id of the error.
QMap< QString, QgsFeatureIds > allLayerFeatureIds(const QMap< QString, QgsFeaturePool *> &featurePools) const
Returns all layers and feature ids.
const QString & layerId() const
The id of the layer on which this error has been detected.
Wraps a QgsSingleGeometryError into a standard QgsGeometryCheckError.
const QgsGeometryCheckContext * mContext
A list of layers and feature ids for each of these layers.
An error from a QgsSingleGeometryCheck.
virtual QString description() const
A human readable description of this error.
const QgsSingleGeometryCheck * check() const
The check that created this error.
bool handleChanges(const QgsGeometryCheck::Changes &changes) override
Apply a list of changes.
const QgsSingleGeometryCheck * mCheck
QMap< QString, QMap< QgsFeatureId, QList< QgsGeometryCheck::Change > > > Changes
A collection of changes.
virtual bool handleChanges(const QgsGeometryCheck::Changes &changes)
Apply a list of changes.
virtual QList< QgsSingleGeometryCheckError * > processGeometry(const QgsGeometry &geometry) const =0
Check the geometry for errors.
QgsFeatureId featureId() const
The id of the feature on which this error has been detected.
This represents an error reported by a geometry check.
virtual void update(const QgsSingleGeometryCheckError *other)
Update this error with the information from other.