QGIS API Documentation  3.17.0-Master (8af46bc54f)
Go to the documentation of this file.
1 /***************************************************************************
2  memoryprovider.h - provider with storage in memory
3  ------------------
4  begin : June 2008
5  copyright : (C) 2008 by Martin Dobias
6  email : wonder dot sk at gmail dot com
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  ***************************************************************************/
16 #define SIP_NO_FILE
18 #include "qgsvectordataprovider.h"
20 #include "qgsfields.h"
23 typedef QMap<QgsFeatureId, QgsFeature> QgsFeatureMap;
25 class QgsSpatialIndex;
27 class QgsMemoryFeatureIterator;
29 class QgsMemoryProvider final: public QgsVectorDataProvider
30 {
33  public:
34  explicit QgsMemoryProvider( const QString &uri, const QgsVectorDataProvider::ProviderOptions &coordinateTransformContext,
35  QgsDataProvider::ReadFlags flags = QgsDataProvider::ReadFlags() );
37  ~QgsMemoryProvider() override;
40  static QString providerKey();
42  static QString providerDescription();
48  static QgsMemoryProvider *createProvider( const QString &uri, const QgsVectorDataProvider::ProviderOptions &coordinateTransformContext,
49  QgsDataProvider::ReadFlags flags = QgsDataProvider::ReadFlags() );
51  /* Implementation of functions from QgsVectorDataProvider */
53  QgsAbstractFeatureSource *featureSource() const override;
55  QString dataSourceUri( bool expandAuthConfig = true ) const override;
56  QString storageType() const override;
57  QgsFeatureIterator getFeatures( const QgsFeatureRequest &request ) const override;
58  QgsWkbTypes::Type wkbType() const override;
59  long featureCount() const override;
60  QgsFields fields() const override;
61  bool addFeatures( QgsFeatureList &flist, QgsFeatureSink::Flags flags = QgsFeatureSink::Flags() ) override;
62  bool deleteFeatures( const QgsFeatureIds &id ) override;
63  bool addAttributes( const QList<QgsField> &attributes ) override;
64  bool renameAttributes( const QgsFieldNameMap &renamedAttributes ) override;
65  bool deleteAttributes( const QgsAttributeIds &attributes ) override;
66  bool changeAttributeValues( const QgsChangedAttributesMap &attr_map ) override;
67  bool changeGeometryValues( const QgsGeometryMap &geometry_map ) override;
68  QString subsetString() const override;
69  bool setSubsetString( const QString &theSQL, bool updateFeatureCount = true ) override;
70  bool supportsSubsetString() const override { return true; }
71  bool createSpatialIndex() override;
73  QgsVectorDataProvider::Capabilities capabilities() const override;
74  bool truncate() override;
76  /* Implementation of functions from QgsDataProvider */
78  QString name() const override;
79  QString description() const override;
80  QgsRectangle extent() const override;
81  void updateExtents() override;
82  bool isValid() const override;
83  QgsCoordinateReferenceSystem crs() const override;
84  void handlePostCloneOperations( QgsVectorDataProvider *source ) override;
86  private:
87  // Coordinate reference system
90  // fields
91  QgsFields mFields;
92  QgsWkbTypes::Type mWkbType;
93  mutable QgsRectangle mExtent;
95  // features
96  QgsFeatureMap mFeatures;
97  QgsFeatureId mNextFeatureId;
99  // indexing
100  QgsSpatialIndex *mSpatialIndex = nullptr;
102  QString mSubsetString;
104  friend class QgsMemoryFeatureSource;
105 };
Wrapper for iterator of features from vector data provider or vector layer.
QMap< QgsFeatureId, QgsGeometry > QgsGeometryMap
Definition: qgsfeature.h:578
virtual bool setSubsetString(const QString &subset, bool updateFeatureCount=true)
Set the subset string used to create a subset of features in the layer.
A rectangle specified with double values.
Definition: qgsrectangle.h:41
QSet< QgsFeatureId > QgsFeatureIds
Definition: qgsfeatureid.h:37
virtual QString subsetString() const
Returns the subset definition string (typically sql) currently in use by the layer and used by the pr...
virtual QgsVectorDataProvider::Capabilities capabilities() const
Returns flags containing the supported capabilities.
QgsWkbTypes::Type wkbType() const override=0
Returns the geometry type which is returned by this layer.
virtual void updateExtents()
Update the extents of the layer.
virtual bool addAttributes(const QList< QgsField > &attributes)
Adds new attributes to the provider.
QList< QgsFeature > QgsFeatureList
Definition: qgsfeature.h:583
virtual bool deleteFeatures(const QgsFeatureIds &id)
Deletes one or more features from the provider.
virtual bool renameAttributes(const QgsFieldNameMap &renamedAttributes)
Renames existing attributes.
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features ...
Definition: qgsfeatureid.h:28
Container of fields for a vector layer.
Definition: qgsfields.h:44
virtual QString name() const =0
Returns a provider name.
virtual QgsAbstractFeatureSource * featureSource() const =0
Returns feature source object that can be used for querying provider&#39;s data.
QSet< int > QgsAttributeIds
virtual bool createSpatialIndex()
Creates a spatial index on the datasource (if supported by the provider type).
bool addFeatures(QgsFeatureList &flist, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a list of features to the sink.
The WKB type describes the number of dimensions a geometry has.
Definition: qgswkbtypes.h:69
virtual bool isValid() const =0
Returns true if this is a valid layer.
virtual QgsCoordinateReferenceSystem crs() const =0
Returns the coordinate system for the data source.
QgsFields fields() const override=0
Returns the fields associated with this data provider.
virtual bool changeAttributeValues(const QgsChangedAttributesMap &attr_map)
Changes attribute values of existing features.
virtual QString dataSourceUri(bool expandAuthConfig=false) const
Gets the data source specification.
This class wraps a request for features to a vector layer (or directly its vector data provider)...
virtual SpatialIndexPresence hasSpatialIndex() const
Returns an enum value representing the presence of a valid spatial index on the source, if it can be determined.
virtual bool supportsSubsetString() const
Returns true if the provider supports setting of subset strings.
virtual bool changeGeometryValues(const QgsGeometryMap &geometry_map)
Changes geometries of existing features.
Base class that can be used for any class that is capable of returning features.
QMap< int, QString > QgsFieldNameMap
Definition: qgsattributes.h:44
QMap< QgsFeatureId, QgsFeature > QgsFeatureMap
Setting options for creating vector data providers.
A spatial index for QgsFeature objects.
QMap< QgsFeatureId, QgsAttributeMap > QgsChangedAttributesMap
Definition: qgsfeature.h:569
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const override=0
Query the provider for features specified in request.
long featureCount() const override=0
Number of features in the layer.
virtual bool truncate()
Removes all features from the layer.
This class represents a coordinate reference system (CRS).
virtual QString description() const =0
Returns description.
virtual bool deleteAttributes(const QgsAttributeIds &attributes)
Deletes existing attributes from the provider.
virtual void handlePostCloneOperations(QgsVectorDataProvider *source)
Handles any post-clone operations required after this vector data provider was cloned from the source...
Enumeration of spatial index presence states.
virtual QgsRectangle extent() const =0
Returns the extent of the layer.
virtual QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
This is the base class for vector data providers.