/usr/include/qgis/qgsgeometryvalidator.h is in libqgis-dev 2.18.17+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 | /***************************************************************************
qgsgeometryvalidator.h - geometry validation thread
-------------------------------------------------------------------
Date : 03.01.2012
Copyright : (C) 2012 by Juergen E. Fischer
email : jef at norbit dot de
***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef QGSGEOMETRYVALIDATOR_H
#define QGSGEOMETRYVALIDATOR_H
#include <QThread>
#include "qgsgeometry.h"
/** \ingroup core
* \class QgsGeometryValidator
*/
class CORE_EXPORT QgsGeometryValidator : public QThread
{
Q_OBJECT
public:
//! Constructor
QgsGeometryValidator( const QgsGeometry *g, QList<QgsGeometry::Error> *errors = nullptr );
~QgsGeometryValidator();
void run() override;
void stop();
/** Validate geometry and produce a list of geometry errors */
static void validateGeometry( const QgsGeometry *g, QList<QgsGeometry::Error> &errors );
signals:
void errorFound( const QgsGeometry::Error& );
public slots:
void addError( const QgsGeometry::Error& );
private:
void validatePolyline( int i, QgsPolyline polyline, bool ring = false );
void validatePolygon( int i, const QgsPolygon &polygon );
void checkRingIntersections( int p0, int i0, const QgsPolyline &ring0, int p1, int i1, const QgsPolyline &ring1 );
double distLine2Point( const QgsPoint& p, QgsVector v, const QgsPoint& q );
bool intersectLines( const QgsPoint& p, QgsVector v, const QgsPoint& q, QgsVector w, QgsPoint &s );
bool ringInRing( const QgsPolyline &inside, const QgsPolyline &outside );
bool pointInRing( const QgsPolyline &ring, const QgsPoint &p );
QgsGeometry mG;
QList<QgsGeometry::Error> *mErrors;
bool mStop;
int mErrorCount;
}; // class QgsGeometryValidator
#endif
|