QGIS API Documentation 4.0.0-Norrköping (1ddcee3d0e4)
Loading...
Searching...
No Matches
qgsvectordataprovider.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsvectordataprovider.h - DataProvider Interface for vector layers
3 --------------------------------------
4 Date : 23-Sep-2004
5 Copyright : (C) 2004 by Marco Hugentobler
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#ifndef QGSVECTORDATAPROVIDER_H
16#define QGSVECTORDATAPROVIDER_H
17
18class QTextCodec;
19
20#include "qgis_core.h"
21
22#include <QHash>
23#include <QList>
24#include <QMap>
25#include <QSet>
26
27//QGIS Includes
28#include "qgis_sip.h"
29#include "qgsdataprovider.h"
30#include "qgsfeature.h"
33#include "qgsrelation.h"
34#include "qgsfeaturesink.h"
35#include "qgsfeaturesource.h"
36#include "qgsfeaturerequest.h"
38
39typedef QList<int> QgsAttributeList SIP_SKIP;
40typedef QSet<int> QgsAttributeIds SIP_SKIP;
41typedef QHash<int, QString> QgsAttrPalIndexNameHash;
42
44class QgsTransaction;
45class QgsFeedback;
48
49
57class CORE_EXPORT QgsVectorDataProvider : public QgsDataProvider, public QgsFeatureSink, public QgsFeatureSource
58{
59 Q_OBJECT
60
61 friend class QgsTransaction;
63
64 public:
67
77 );
78
95
99 virtual QString storageType() const;
100
106 QgsFeatureIterator getFeatures( const QgsFeatureRequest &request = QgsFeatureRequest() ) const override = 0;
107
111 Qgis::WkbType wkbType() const override = 0;
112
117 long long featureCount() const override = 0;
118
124 virtual bool empty() const;
125
135 virtual bool isSqlQuery() const;
136
144
155 Qgis::FeatureAvailability hasFeatures() const override;
156
160 QgsFields fields() const override = 0;
161
163 QgsRectangle sourceExtent() const override;
164 QgsBox3D sourceExtent3D() const override;
165 QString sourceName() const override { return QString(); }
166
171 QString dataComment() const override;
172
181 QVariant minimumValue( int index ) const override;
182
191 QVariant maximumValue( int index ) const override;
192
202 virtual QStringList uniqueStringsMatching( int index, const QString &substring, int limit = -1, QgsFeedback *feedback = nullptr ) const;
203
215 virtual QVariant aggregate(
216 Qgis::Aggregate aggregate, int index, const QgsAggregateCalculator::AggregateParameters &parameters, QgsExpressionContext *context, bool &ok, QgsFeatureIds *fids = nullptr
217 ) const;
218
225 virtual void enumValues( int index, QStringList &enumList SIP_OUT ) const
226 {
227 Q_UNUSED( index )
228 enumList.clear();
229 }
230
233 QString lastError() const override;
234
241 virtual bool deleteFeatures( const QgsFeatureIds &id );
242
249 virtual bool truncate();
250
257 virtual bool cancelReload();
258
264 virtual bool addAttributes( const QList<QgsField> &attributes );
265
273 virtual bool deleteAttributes( const QgsAttributeIds &attributes );
274
282 virtual bool renameAttributes( const QgsFieldNameMap &renamedAttributes );
283
292 virtual bool changeAttributeValues( const QgsChangedAttributesMap &attr_map );
293
305 virtual bool changeFeatures( const QgsChangedAttributesMap &attr_map, const QgsGeometryMap &geometry_map );
306
318 virtual QVariant defaultValue( int fieldIndex ) const;
319
326 virtual QString defaultValueClause( int fieldIndex ) const;
327
333 QgsFieldConstraints::Constraints fieldConstraints( int fieldIndex ) const;
334
341 virtual bool skipConstraintCheck( int fieldIndex, QgsFieldConstraints::Constraint constraint, const QVariant &value = QVariant() ) const;
342
350 virtual bool changeGeometryValues( const QgsGeometryMap &geometry_map );
351
356 virtual bool createSpatialIndex();
357
359 virtual bool createAttributeIndex( int field );
360
369 Q_INVOKABLE virtual Qgis::VectorProviderCapabilities capabilities() const;
370
374 QString capabilitiesString() const;
375
382 virtual Qgis::VectorDataProviderAttributeEditCapabilities attributeEditCapabilities() const;
383
396 virtual void setEncoding( const QString &e );
397
403 QString encoding() const;
404
408 int fieldNameIndex( const QString &fieldName ) const;
409
413 QMap<QString, int> fieldNameMap() const;
414
418 virtual QgsAttributeList attributeIndexes() const;
419
423 virtual QgsAttributeList pkAttributeIndexes() const;
424
430 virtual QString geometryColumnName() const;
431
437 Q_DECL_DEPRECATED QgsAttrPalIndexNameHash palAttributeIndexNames() const SIP_DEPRECATED;
438
442 bool supportedType( const QgsField &field ) const;
443
445 {
447 const QString &typeDesc, const QString &typeName, QMetaType::Type type, int minLen = 0, int maxLen = 0, int minPrec = 0, int maxPrec = 0, QMetaType::Type subType = QMetaType::Type::UnknownType
448 )
449 : mTypeDesc( typeDesc )
450 , mTypeName( typeName )
451 , mType( type )
452 , mMinLen( minLen )
453 , mMaxLen( maxLen )
454 , mMinPrec( minPrec )
455 , mMaxPrec( maxPrec )
456 , mSubType( subType )
457 {}
458
459 Q_DECL_DEPRECATED NativeType(
460 const QString &typeDesc, const QString &typeName, QVariant::Type type, int minLen = 0, int maxLen = 0, int minPrec = 0, int maxPrec = 0, QVariant::Type subType = QVariant::Type::Invalid
461 )
462 : mTypeDesc( typeDesc )
463 , mTypeName( typeName )
464 , mType( QgsVariantUtils::variantTypeToMetaType( type ) )
465 , mMinLen( minLen )
466 , mMaxLen( maxLen )
467 , mMinPrec( minPrec )
468 , mMaxPrec( maxPrec )
469 , mSubType( QgsVariantUtils::variantTypeToMetaType( subType ) ) SIP_DEPRECATED
470 {}
471
472
473 QString mTypeDesc;
474 QString mTypeName;
475 QMetaType::Type mType;
480 QMetaType::Type mSubType;
481 };
482
486 QList< QgsVectorDataProvider::NativeType > nativeTypes() const;
487
492 virtual bool doesStrictFeatureTypeCheck() const { return true; }
493
495 static QStringList availableEncodings();
496
500 bool hasErrors() const;
501
505 void clearErrors();
506
510 QStringList errors() const;
511
527 virtual QgsFeatureRenderer *createRenderer( const QVariantMap &configuration = QVariantMap() ) const SIP_FACTORY;
528
544 virtual QgsAbstractVectorLayerLabeling *createLabeling( const QVariantMap &configuration = QVariantMap() ) const SIP_FACTORY;
545
549 static QVariant convertValue( QMetaType::Type type, const QString &value );
550
556 Q_DECL_DEPRECATED static QVariant convertValue( QVariant::Type type, const QString &value ) SIP_DEPRECATED;
557
561 virtual QgsTransaction *transaction() const;
562
566 Q_DECL_DEPRECATED virtual void forceReload() SIP_DEPRECATED { reloadData(); }
567
571 virtual QSet<QgsMapLayerDependency> dependencies() const;
572
579 virtual QList<QgsRelation> discoverRelations( const QgsVectorLayer *target, const QList<QgsVectorLayer *> &layers ) const;
580
586 virtual QString translateMetadataKey( const QString &mdKey ) const { return mdKey; }
587
594 virtual QString translateMetadataValue( const QString &mdKey, const QVariant &value ) const
595 {
596 Q_UNUSED( mdKey )
597 return value.toString();
598 }
599
606 virtual bool hasMetadata() const { return true; }
607
614 virtual void handlePostCloneOperations( QgsVectorDataProvider *source );
615
618
619 QgsDataProviderElevationProperties *elevationProperties() override;
620 const QgsDataProviderElevationProperties *elevationProperties() const override SIP_SKIP;
621
622 signals:
623
628 void raiseError( const QString &msg ) const;
629
630 protected:
635 void clearMinMaxCache();
636
640 void fillMinMaxCache() const;
641
650 void pushError( const QString &msg ) const;
651
657 QgsGeometry convertToProviderType( const QgsGeometry &geom ) const;
658
665
666#ifdef SIP_PYQT5_RUN
667
672 QTextCodec *textEncoding() const;
673#endif
674
680 static QgsGeometry convertToProviderType( const QgsGeometry &geometry, Qgis::WkbType providerGeometryType );
681
682
683 private:
684 mutable bool mCacheMinMaxDirty = true;
685 mutable QMap<int, QVariant> mCacheMinValues, mCacheMaxValues;
686
688 QTextCodec *mEncoding = nullptr;
689
691 QgsAttributeList mAttributesToFetch;
692
694 QList< NativeType > mNativeTypes;
695
697 mutable QStringList mErrors;
698
699 std::unique_ptr< QgsVectorDataProviderTemporalCapabilities > mTemporalCapabilities;
700 std::unique_ptr< QgsDataProviderElevationProperties > mElevationProperties;
701
702 static QStringList sEncodings;
703
707 virtual void setTransaction( QgsTransaction * /*transaction*/ ) {}
708};
709
710#endif
@ EditingCapabilities
Bitmask of all editing capabilities.
Definition qgis.h:551
QFlags< VectorLayerTypeFlag > VectorLayerTypeFlags
Vector layer type flags.
Definition qgis.h:440
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
Definition qgis.h:512
FeatureAvailability
Possible return value for QgsFeatureSource::hasFeatures() to determine if a source is empty.
Definition qgis.h:603
QFlags< VectorProviderCapability > VectorProviderCapabilities
Vector data provider capabilities.
Definition qgis.h:562
Aggregate
Available aggregates to calculate.
Definition qgis.h:6174
QFlags< VectorDataProviderAttributeEditCapability > VectorDataProviderAttributeEditCapabilities
Attribute editing capabilities which may be supported by vector data providers.
Definition qgis.h:628
WkbType
The WKB type describes the number of dimensions a geometry has.
Definition qgis.h:294
Base class that can be used for any class that is capable of returning features.
Abstract base class - its implementations define different approaches to the labeling of a vector lay...
A 3-dimensional box composed of x, y, z coordinates.
Definition qgsbox3d.h:45
Represents a coordinate reference system (CRS).
Base class for handling elevation related properties for a data provider.
virtual Qgis::DataProviderFlags flags() const
Returns the generic data provider flags.
virtual QString dataComment() const
Returns a short comment for the data that this provider is providing access to (e....
QgsDataProvider(const QString &uri=QString(), const QgsDataProvider::ProviderOptions &providerOptions=QgsDataProvider::ProviderOptions(), Qgis::DataProviderReadFlags flags=Qgis::DataProviderReadFlags())
Create a new dataprovider with the specified in the uri.
virtual QgsDataProviderTemporalCapabilities * temporalCapabilities()
Returns the provider's temporal capabilities.
QgsDataSourceUri uri() const
Gets the data source specification.
virtual void reloadData()
Reloads the data from the source for providers with data caches to synchronize, changes in the data s...
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
Wrapper for iterator of features from vector data provider or vector layer.
Abstract base class for all 2D vector feature renderers.
Wraps a request for features to a vector layer (or directly its vector data provider).
An interface for objects which accept features via addFeature(s) methods.
virtual QString lastError() const
Returns the most recent error encountered by the sink, e.g.
virtual bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags())=0
Adds a list of features to the sink.
QFlags< Flag > Flags
An interface for objects which provide features via a getFeatures method.
virtual QgsCoordinateReferenceSystem sourceCrs() const =0
Returns the coordinate reference system for features in the source.
virtual Qgis::FeatureAvailability hasFeatures() const
Determines if there are any features available in the source.
virtual QVariant minimumValue(int fieldIndex) const
Returns the minimum value for an attribute column or an invalid variant in case of error.
virtual QVariant maximumValue(int fieldIndex) const
Returns the maximum value for an attribute column or an invalid variant in case of error.
virtual QgsRectangle sourceExtent() const
Returns the extent of all geometries from the source.
virtual QgsBox3D sourceExtent3D() const
Returns the 3D extent of all geometries from the source.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
Constraint
Constraints which may be present on a field.
QFlags< Constraint > Constraints
Encapsulate a field in an attribute table or data source.
Definition qgsfield.h:56
Container of fields for a vector layer.
Definition qgsfields.h:46
A geometry is the spatial representation of a feature.
A rectangle specified with double values.
Allows creation of a multi-layer database-side transaction.
Contains utility functions for working with QVariants and QVariant types.
Implementation of data provider temporal properties for QgsVectorDataProviders.
Base class for vector data providers.
void pushError(const QString &msg) const
Push a notification about errors that happened in this providers scope.
virtual void enumValues(int index, QStringList &enumList) const
Returns the possible enum values of an attribute.
void setNativeTypes(const QList< QgsVectorDataProvider::NativeType > &nativeTypes)
Set the list of native types supported by this provider.
QString sourceName() const override
Returns a friendly display name for the source.
static const int EditingCapabilities
Bitmask of all provider's editing capabilities.
virtual QString translateMetadataValue(const QString &mdKey, const QVariant &value) const
Gets the translated metadata value.
long long featureCount() const override=0
Number of features in the layer.
virtual QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
void clearMinMaxCache()
Invalidates the min/max cache.
void raiseError(const QString &msg) const
Signals an error in this provider.
QTextCodec * textEncoding() const
Gets this providers encoding.
QgsVectorDataProvider(const QString &uri=QString(), const QgsDataProvider::ProviderOptions &providerOptions=QgsDataProvider::ProviderOptions(), Qgis::DataProviderReadFlags flags=Qgis::DataProviderReadFlags())
Constructor for a vector data provider.
virtual bool isSqlQuery() const
Returns true if the layer is a query (SQL) layer.
virtual bool empty() const
Returns true if the layer does not contain any feature.
QList< QgsVectorDataProvider::NativeType > nativeTypes() const
Returns the names of the supported types.
virtual bool doesStrictFeatureTypeCheck() const
Returns true if the provider is strict about the type of inserted features (e.g.
QgsGeometry convertToProviderType(const QgsGeometry &geom) const
Converts the geometry to the provider type if possible / necessary.
virtual QgsAbstractFeatureSource * featureSource() const =0
Returns feature source object that can be used for querying provider's data.
virtual bool hasMetadata() const
Returns true if the data source has metadata, false otherwise.
virtual Qgis::VectorLayerTypeFlags vectorLayerTypeFlags() const
Returns the vector layer type flags.
QgsFields fields() const override=0
Returns the fields associated with this data provider.
Qgis::WkbType wkbType() const override=0
Returns the geometry type which is returned by this layer.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const override=0
Query the provider for features specified in request.
void fillMinMaxCache() const
Populates the cache of minimum and maximum attribute values.
virtual Q_DECL_DEPRECATED void forceReload()
virtual QString translateMetadataKey(const QString &mdKey) const
Gets the translated metadata key.
Represents a vector layer which manages a vector based dataset.
#define SIP_DEPRECATED
Definition qgis_sip.h:113
#define SIP_SKIP
Definition qgis_sip.h:133
#define SIP_OUT
Definition qgis_sip.h:57
#define SIP_FACTORY
Definition qgis_sip.h:83
#define SIP_INOUT
Definition qgis_sip.h:78
QMap< int, QString > QgsFieldNameMap
QMap< QgsFeatureId, QgsGeometry > QgsGeometryMap
QMap< QgsFeatureId, QgsAttributeMap > QgsChangedAttributesMap
QList< QgsFeature > QgsFeatureList
QSet< QgsFeatureId > QgsFeatureIds
QList< int > QgsAttributeList
Definition qgsfield.h:30
QList< int > QgsAttributeList
QSet< int > QgsAttributeIds
QHash< int, QString > QgsAttrPalIndexNameHash
A bundle of parameters controlling aggregate calculation.
Setting options for creating vector data providers.
NativeType(const QString &typeDesc, const QString &typeName, QMetaType::Type type, int minLen=0, int maxLen=0, int minPrec=0, int maxPrec=0, QMetaType::Type subType=QMetaType::Type::UnknownType)
Q_DECL_DEPRECATED NativeType(const QString &typeDesc, const QString &typeName, QVariant::Type type, int minLen=0, int maxLen=0, int minPrec=0, int maxPrec=0, QVariant::Type subType=QVariant::Type::Invalid)