Branch data Line data Source code
1 : : /*************************************************************************** 2 : : qgsgeometryfollowboundariescheck.h 3 : : --------------------- 4 : : begin : September 2017 5 : : copyright : (C) 2017 by Sandro Mani / Sourcepole AG 6 : : email : smani at sourcepole dot ch 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 : : #define SIP_NO_FILE 17 : : 18 : : #ifndef QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H 19 : : #define QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H 20 : : 21 : : #include "qgsgeometrycheck.h" 22 : : 23 : : class QgsSpatialIndex; 24 : : 25 : : 26 : : /** 27 : : * \ingroup analysis 28 : : * \brief A follow boundaries check. 29 : : */ 30 : : class ANALYSIS_EXPORT QgsGeometryFollowBoundariesCheck : public QgsGeometryCheck 31 : : { 32 : 0 : Q_DECLARE_TR_FUNCTIONS( QgsGeometryFollowBoundariesCheck ) 33 : : public: 34 : : QgsGeometryFollowBoundariesCheck( QgsGeometryCheckContext *context, const QVariantMap &configuration, QgsVectorLayer *checkLayer ); 35 : : ~QgsGeometryFollowBoundariesCheck() override; 36 : 1 : static QList<QgsWkbTypes::GeometryType> factoryCompatibleGeometryTypes() {return {QgsWkbTypes::PolygonGeometry}; } 37 : : static bool factoryIsCompatible( QgsVectorLayer *layer ) SIP_SKIP { return factoryCompatibleGeometryTypes().contains( layer->geometryType() ); } 38 : 1 : QList<QgsWkbTypes::GeometryType> compatibleGeometryTypes() const override { return factoryCompatibleGeometryTypes(); } 39 : : void collectErrors( const QMap<QString, QgsFeaturePool *> &featurePools, QList<QgsGeometryCheckError *> &errors, QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids = LayerFeatureIds() ) const override; 40 : : void fixError( const QMap<QString, QgsFeaturePool *> &featurePools, QgsGeometryCheckError *error, int method, const QMap<QString, int> &mergeAttributeIndices, Changes &changes ) const override; 41 : : Q_DECL_DEPRECATED QStringList resolutionMethods() const override; 42 : 0 : static QString factoryDescription() { return tr( "Polygon does not follow boundaries" ); } 43 : 0 : QString description() const override { return factoryDescription(); } 44 : 0 : static QString factoryId() { return QStringLiteral( "QgsGeometryFollowBoundariesCheck" ); } 45 : 0 : QString id() const override { return factoryId(); } 46 : 0 : QgsGeometryCheck::CheckType checkType() const override { return factoryCheckType(); } 47 : : static QgsGeometryCheck::CheckType factoryCheckType() SIP_SKIP; 48 : : private: 49 : : enum ResolutionMethod { NoChange }; 50 : : QgsVectorLayer *mCheckLayer; 51 : : QgsSpatialIndex *mIndex = nullptr; 52 : : 53 : : QgsGeometryFollowBoundariesCheck( const QgsGeometryFollowBoundariesCheck & ) = delete; 54 : : QgsGeometryFollowBoundariesCheck &operator=( const QgsGeometryFollowBoundariesCheck & ) = delete; 55 : : }; 56 : : 57 : : #endif // QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H