Go to the documentation of this file.
31 #ifndef OGRSF_FRMTS_H_INCLUDED
32 #define OGRSF_FRMTS_H_INCLUDED
34 #include "cpl_progress.h"
37 #include "gdal_priv.h"
47 #if !defined(GDAL_COMPILATION) && !defined(SUPPRESS_DEPRECATION_WARNINGS)
49 #define OGR_DEPRECATED(x) CPL_WARN_DEPRECATED(x)
51 #define OGR_DEPRECATED(x)
55 class OGRLayerAttrIndex;
70 class CPL_DLL
OGRLayer :
public GDALMajorObject
74 std::unique_ptr<Private> m_poPrivate;
76 void ConvertGeomsIfNecessary(
OGRFeature *poFeature );
78 class CPL_DLL FeatureIterator
81 std::unique_ptr<Private> m_poPrivate;
83 FeatureIterator(
OGRLayer* poLayer,
bool bStart);
84 FeatureIterator(FeatureIterator&& oOther) noexcept;
87 FeatureIterator& operator++();
88 bool operator!=(
const FeatureIterator& it)
const;
92 friend inline FeatureIterator
end(
OGRLayer* poLayer);
98 int m_bFilterIsEnvelope;
101 OGREnvelope m_sFilterEnvelope;
102 int m_iGeomFieldFilter;
109 OGRErr GetExtentInternal(
int iGeomField, OGREnvelope *psExtent,
int bForce );
129 FeatureIterator
begin();
132 FeatureIterator
end();
136 virtual void SetSpatialFilterRect(
double dfMinX,
double dfMinY,
137 double dfMaxX,
double dfMaxY );
139 virtual void SetSpatialFilter(
int iGeomField,
OGRGeometry * );
140 virtual void SetSpatialFilterRect(
int iGeomField,
141 double dfMinX,
double dfMinY,
142 double dfMaxX,
double dfMaxY );
144 virtual OGRErr SetAttributeFilter(
const char * );
146 virtual void ResetReading() = 0;
156 virtual const char *GetName();
159 virtual int FindFieldIndex(
const char *pszFieldName,
int bExactMatch );
163 virtual GIntBig GetFeatureCount(
int bForce = TRUE );
165 virtual OGRErr GetExtent(
int iGeomField, OGREnvelope *psExtent,
168 virtual int TestCapability(
const char * ) = 0;
171 int bApproxOK = TRUE );
172 virtual OGRErr DeleteField(
int iField );
173 virtual OGRErr ReorderFields(
int* panMap );
174 virtual OGRErr AlterFieldDefn(
int iField,
OGRFieldDefn* poNewFieldDefn,
int nFlagsIn );
177 int bApproxOK = TRUE );
179 virtual OGRErr SyncToDisk();
182 virtual void SetStyleTableDirectly(
OGRStyleTable *poStyleTable );
188 virtual OGRErr RollbackTransaction();
190 virtual const char *GetFIDColumn();
191 virtual const char *GetGeometryColumn();
193 virtual OGRErr SetIgnoredFields(
const char **papszFields );
197 char** papszOptions =
nullptr,
198 GDALProgressFunc pfnProgress =
nullptr,
199 void * pProgressArg =
nullptr );
202 char** papszOptions =
nullptr,
203 GDALProgressFunc pfnProgress =
nullptr,
204 void * pProgressArg =
nullptr );
208 GDALProgressFunc pfnProgress,
209 void * pProgressArg );
212 char** papszOptions =
nullptr,
213 GDALProgressFunc pfnProgress =
nullptr,
214 void * pProgressArg =
nullptr );
217 char** papszOptions =
nullptr,
218 GDALProgressFunc pfnProgress =
nullptr,
219 void * pProgressArg =
nullptr );
222 char** papszOptions =
nullptr,
223 GDALProgressFunc pfnProgress =
nullptr,
224 void * pProgressArg =
nullptr );
227 char** papszOptions =
nullptr,
228 GDALProgressFunc pfnProgress =
nullptr,
229 void * pProgressArg =
nullptr );
233 int GetRefCount()
const;
239 OGRErr ReorderField(
int iOldFieldPos,
int iNewFieldPos );
242 int AttributeFilterEvaluationNeedsGeometry();
245 OGRErr InitializeIndexSupport(
const char * );
246 OGRLayerAttrIndex *GetIndex() {
return m_poAttrIndex; }
247 int GetGeomFieldFilter()
const {
return m_iGeomFieldFilter; }
248 const char *GetAttrQueryString()
const {
return m_pszAttrQueryString; }
255 {
return reinterpret_cast<OGRLayerH>(poLayer); }
261 {
return reinterpret_cast<OGRLayer*
>(hLayer); }
266 OGRFeatureQuery *m_poAttrQuery;
267 char *m_pszAttrQueryString;
268 OGRLayerAttrIndex *m_poAttrIndex;
292 inline OGRLayer::FeatureIterator
end(
OGRLayer* poLayer) {
return poLayer->
end(); }
322 virtual const char *GetName() OGR_DEPRECATED(
"Use GDALDataset class instead") = 0;
324 static void DestroyDataSource(
OGRDataSource * ) OGR_DEPRECATED(
"Use GDALDataset class instead");
356 virtual const char *GetName() OGR_DEPRECATED(
"Use GDALDriver class instead") = 0;
358 virtual OGRDataSource *Open(
const char *pszName,
int bUpdate=FALSE ) OGR_DEPRECATED(
"Use GDALDriver class instead") = 0;
360 virtual int TestCapability(
const char *pszCap ) OGR_DEPRECATED(
"Use GDALDriver class instead") = 0;
362 virtual OGRDataSource *CreateDataSource(
const char *pszName,
363 char ** =
nullptr ) OGR_DEPRECATED(
"Use GDALDriver class instead");
364 virtual OGRErr DeleteDataSource(
const char *pszName ) OGR_DEPRECATED(
"Use GDALDriver class instead");
391 static GDALDataset* OpenWithDriverArg(GDALDriver* poDriver,
392 GDALOpenInfo* poOpenInfo);
393 static GDALDataset* CreateVectorOnly( GDALDriver* poDriver,
394 const char * pszName,
395 char ** papszOptions );
396 static CPLErr DeleteDataSource( GDALDriver* poDriver,
397 const char * pszName );
401 static OGRSFDriverRegistrar *GetRegistrar() OGR_DEPRECATED(
"Use GDALDriverManager class instead");
404 void RegisterDriver(
OGRSFDriver * poDriver ) OGR_DEPRECATED(
"Use GDALDriverManager class instead");
407 int GetDriverCount(
void ) OGR_DEPRECATED(
"Use GDALDriverManager class instead");
409 GDALDriver *GetDriver(
int iDriver ) OGR_DEPRECATED(
"Use GDALDriverManager class instead");
411 GDALDriver *GetDriverByName(
const char * ) OGR_DEPRECATED(
"Use GDALDriverManager class instead");
414 int GetOpenDSCount() OGR_DEPRECATED(
"Use GDALDriverManager class instead");
416 OGRDataSource *GetOpenDS(
int ) OGR_DEPRECATED(
"Use GDALDriverManager class instead");
426 void OGRRegisterAllInternal();
428 void CPL_DLL RegisterOGRFileGDB();
429 void CPL_DLL RegisterOGRShape();
430 void CPL_DLL RegisterOGRDB2();
431 void CPL_DLL RegisterOGRNTF();
432 void CPL_DLL RegisterOGRFME();
433 void CPL_DLL RegisterOGRSDTS();
434 void CPL_DLL RegisterOGRTiger();
435 void CPL_DLL RegisterOGRS57();
436 void CPL_DLL RegisterOGRTAB();
437 void CPL_DLL RegisterOGRMIF();
438 void CPL_DLL RegisterOGROGDI();
439 void CPL_DLL RegisterOGRODBC();
440 void CPL_DLL RegisterOGRWAsP();
441 void CPL_DLL RegisterOGRPG();
442 void CPL_DLL RegisterOGRMSSQLSpatial();
443 void CPL_DLL RegisterOGRMySQL();
444 void CPL_DLL RegisterOGROCI();
445 void CPL_DLL RegisterOGRDGN();
446 void CPL_DLL RegisterOGRGML();
447 void CPL_DLL RegisterOGRLIBKML();
448 void CPL_DLL RegisterOGRKML();
449 void CPL_DLL RegisterOGRGeoJSON();
450 void CPL_DLL RegisterOGRGeoJSONSeq();
451 void CPL_DLL RegisterOGRESRIJSON();
452 void CPL_DLL RegisterOGRTopoJSON();
453 void CPL_DLL RegisterOGRAVCBin();
454 void CPL_DLL RegisterOGRAVCE00();
455 void CPL_DLL RegisterOGRREC();
456 void CPL_DLL RegisterOGRMEM();
457 void CPL_DLL RegisterOGRVRT();
458 void CPL_DLL RegisterOGRDODS();
459 void CPL_DLL RegisterOGRSQLite();
460 void CPL_DLL RegisterOGRCSV();
461 void CPL_DLL RegisterOGRILI1();
462 void CPL_DLL RegisterOGRILI2();
463 void CPL_DLL RegisterOGRGRASS();
464 void CPL_DLL RegisterOGRPGeo();
465 void CPL_DLL RegisterOGRDXF();
466 void CPL_DLL RegisterOGRCAD();
467 void CPL_DLL RegisterOGRDWG();
468 void CPL_DLL RegisterOGRDGNV8();
469 void CPL_DLL RegisterOGRSDE();
470 void CPL_DLL RegisterOGRIDB();
471 void CPL_DLL RegisterOGRGMT();
472 void CPL_DLL RegisterOGRBNA();
473 void CPL_DLL RegisterOGRGPX();
474 void CPL_DLL RegisterOGRGeoconcept();
475 void CPL_DLL RegisterOGRIngres();
476 void CPL_DLL RegisterOGRXPlane();
477 void CPL_DLL RegisterOGRNAS();
478 void CPL_DLL RegisterOGRGeoRSS();
479 void CPL_DLL RegisterOGRGTM();
480 void CPL_DLL RegisterOGRVFK();
481 void CPL_DLL RegisterOGRPGDump();
482 void CPL_DLL RegisterOGROSM();
483 void CPL_DLL RegisterOGRGPSBabel();
484 void CPL_DLL RegisterOGRSUA();
485 void CPL_DLL RegisterOGROpenAir();
486 void CPL_DLL RegisterOGRPDS();
487 void CPL_DLL RegisterOGRWFS();
488 void CPL_DLL RegisterOGRWFS3();
489 void CPL_DLL RegisterOGRSOSI();
490 void CPL_DLL RegisterOGRHTF();
491 void CPL_DLL RegisterOGRAeronavFAA();
492 void CPL_DLL RegisterOGRGeomedia();
493 void CPL_DLL RegisterOGRMDB();
494 void CPL_DLL RegisterOGREDIGEO();
495 void CPL_DLL RegisterOGRGFT();
496 void CPL_DLL RegisterOGRSVG();
497 void CPL_DLL RegisterOGRCouchDB();
498 void CPL_DLL RegisterOGRCloudant();
499 void CPL_DLL RegisterOGRIdrisi();
500 void CPL_DLL RegisterOGRARCGEN();
501 void CPL_DLL RegisterOGRSEGUKOOA();
502 void CPL_DLL RegisterOGRSEGY();
503 void CPL_DLL RegisterOGRXLS();
504 void CPL_DLL RegisterOGRODS();
505 void CPL_DLL RegisterOGRXLSX();
506 void CPL_DLL RegisterOGRElastic();
507 void CPL_DLL RegisterOGRGeoPackage();
508 void CPL_DLL RegisterOGRWalk();
509 void CPL_DLL RegisterOGRCarto();
510 void CPL_DLL RegisterOGRAmigoCloud();
511 void CPL_DLL RegisterOGRSXF();
512 void CPL_DLL RegisterOGROpenFileGDB();
513 void CPL_DLL RegisterOGRSelafin();
514 void CPL_DLL RegisterOGRJML();
515 void CPL_DLL RegisterOGRPLSCENES();
516 void CPL_DLL RegisterOGRCSW();
517 void CPL_DLL RegisterOGRMongoDBv3();
518 void CPL_DLL RegisterOGRMongoDB();
519 void CPL_DLL RegisterOGRVDV();
520 void CPL_DLL RegisterOGRGMLAS();
521 void CPL_DLL RegisterOGRMVT();
522 void CPL_DLL RegisterOGRNGW();
virtual OGRLinearRing * getInteriorRing(int)
Fetch reference to indicated internal ring.
Definition: ogrpolygon.cpp:215
virtual void setMeasured(OGRBoolean bIsMeasured) override
Add or remove the M coordinate dimension.
Definition: ogrlinestring.cpp:192
OGRBoolean Is3D() const
Definition: ogr_geometry.h:363
virtual OGRBoolean IsEmpty() const =0
Returns TRUE (non-zero) if the object has no points.
virtual void setCoordinateDimension(int nDimension)
Set the coordinate dimension.
Definition: ogrgeometry.cpp:1002
virtual OGRErr addRingDirectly(OGRCurve *)
Add a ring to a polygon.
Definition: ogrcurvepolygon.cpp:419
virtual OGRGeometry * getCurveGeometry(const char *const *papszOptions=nullptr) const override
Return curve version of this geometry.
Definition: ogrpolygon.cpp:851
@ wkbPointZM
Definition: ogr_core.h:381
#define CPL_SWAP32(x)
Definition: cpl_port.h:719
int getNumGeometries() const
Fetch number of geometries in PolyhedralSurface.
Definition: ogrpolyhedralsurface.cpp:909
OGRLinearRing * stealExteriorRing()
"Steal" reference to external polygon ring.
Definition: ogrpolygon.cpp:190
Definition: ogr_geometry.h:2312
static OGRMultiPolygon * CastToMultiPolygon(OGRPolyhedralSurface *poPS)
Casts the OGRPolyhedralSurface to an OGRMultiPolygon.
Definition: ogrpolyhedralsurface.cpp:820
OGRErr addGeometryDirectly(OGRGeometry *poNewGeom)
Add a geometry directly to the container.
Definition: ogrpolyhedralsurface.cpp:877
virtual OGRErr importFromWkb(const unsigned char *, int, OGRwkbVariant, int &nBytesConsumedOut) override
Assign geometry from well known binary data.
Definition: ogrpolyhedralsurface.cpp:211
#define OGRERR_UNSUPPORTED_GEOMETRY_TYPE
Definition: ogr_core.h:295
virtual int getNumPoints() const override
Fetch vertex count.
Definition: ogr_geometry.h:1159
virtual OGRwkbGeometryType getGeometryType() const =0
Fetch geometry type.
virtual OGRwkbGeometryType getGeometryType() const override
Returns the WKB Type of PolyhedralSurface.
Definition: ogrpolyhedralsurface.cpp:109
@ wkbPoint
Definition: ogr_core.h:321
OGRLayer::FeatureIterator begin(OGRLayer *poLayer)
Definition: ogrsf_frmts.h:287
virtual OGRBoolean IsEmpty() const override
Returns TRUE (non-zero) if the object has no points.
Definition: ogrcurvepolygon.cpp:717
virtual int WkbSize() const override
Returns size of related binary representation.
Definition: ogrpolyhedralsurface.cpp:125
CPLSTRING_METHOD_DLL CPLString & Printf(const char *pszFormat,...)
Definition: cplstring.cpp:59
#define CPL_SWAPDOUBLE(p)
Definition: cpl_port.h:807
#define VSI_REALLOC_VERBOSE(pOldPtr, nNewSize)
Definition: cpl_vsi.h:288
Definition: ogr_featurestyle.h:84
virtual void set3D(OGRBoolean bIs3D)
Add or remove the Z coordinate dimension.
Definition: ogrgeometry.cpp:1025
virtual OGRErr transform(OGRCoordinateTransformation *) override
Apply arbitrary coordinate transformation to geometry.
Definition: ogrpolyhedralsurface.cpp:628
friend FeatureIterator begin(OGRLayer *poLayer)
Definition: ogrsf_frmts.h:287
void * CPLCalloc(size_t, size_t)
Definition: cpl_conv.cpp:138
virtual OGRErr importFromWkb(const unsigned char *, int, OGRwkbVariant, int &nBytesConsumedOut) override
Assign geometry from well known binary data.
Definition: ogrpolygon.cpp:318
void OGRRegisterAll(void)
Register all drivers.
Definition: ogrregisterall.cpp:38
virtual void setCoordinateDimension(int nDimension) override
Set the coordinate dimension.
Definition: ogrpolyhedralsurface.cpp:1017
@ wkbNDR
Definition: ogr_core.h:492
Definition: ogr_spatialref.h:156
virtual const char * getGeometryName() const override
Fetch WKT name for geometry type.
Definition: ogrpolyhedralsurface.cpp:95
OGRErr importFromWkt(const char **) override
Definition: ogrpolygon.cpp:445
Definition: ogr_geometry.h:2397
@ wkbPolygon25D
Definition: ogr_core.h:401
Definition: ogrlayer.cpp:39
@ wkbPolygonZM
Definition: ogr_core.h:383
@ wkbVariantPostGIS1
Definition: ogr_core.h:427
virtual OGRBoolean Intersects(const OGRGeometry *) const override
Do these features intersect?
Definition: ogrcurvepolygon.cpp:799
@ wkbPolygonM
Definition: ogr_core.h:365
Definition: ogr_geometry.h:286
virtual void swapXY() override
Swap x and y coordinates.
Definition: ogrpolyhedralsurface.cpp:1032
virtual const char * getGeometryName() const =0
Fetch WKT name for geometry type.
virtual void getEnvelope(OGREnvelope *psEnvelope) const override
Computes and returns the bounding envelope for this geometry in the passed psEnvelope structure.
Definition: ogrpolyhedralsurface.cpp:193
virtual const char * getGeometryName() const override
Fetch WKT name for geometry type.
Definition: ogrpolygon.cpp:121
Definition: ogrsf_frmts.h:70
virtual OGRGeometry * clone() const override
Make a copy of this object.
Definition: ogrpolyhedralsurface.cpp:166
Convenient string class based on std::string.
Definition: cpl_string.h:329
Definition: ogr_geometry.h:810
int WkbSize() const override
Returns size of related binary representation.
Definition: ogrpoint.cpp:272
virtual OGRErr exportToWkb(OGRwkbByteOrder, unsigned char *, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known binary format.
Definition: ogrpolygon.cpp:372
virtual OGRGeometry * getLinearGeometry(double dfMaxAngleStepSizeDegrees=0, const char *const *papszOptions=nullptr) const CPL_WARN_UNUSED_RESULT
Return, possibly approximate, non-curve version of this geometry.
Definition: ogrgeometry.cpp:3122
@ wkbPolyhedralSurfaceZM
Definition: ogr_core.h:395
OGRGeometry & operator=(const OGRGeometry &other)
Assignment operator.
Definition: ogrgeometry.cpp:137
void * CPLRealloc(void *, size_t)
Definition: cpl_conv.cpp:225
@ wkbPoint25D
Definition: ogr_core.h:399
std::unique_ptr< OGRFeature, OGRFeatureUniquePtrDeleter > OGRFeatureUniquePtr
Definition: ogr_feature.h:780
#define EQUAL(a, b)
Definition: cpl_port.h:569
int OGRBoolean
Definition: ogr_core.h:306
Definition: ogrsf_frmts.h:385
virtual void flattenTo2D() override
Convert geometry to strictly 2D. In a sense this converts all Z coordinates to 0.0.
Definition: ogrpoint.cpp:241
virtual OGRGeometry * clone() const override
Make a copy of this object.
Definition: ogrpoint.cpp:174
virtual void closeRings() override
Force rings to be closed.
Definition: ogrpolygon.cpp:807
double x
Definition: ogr_geometry.h:73
#define wkbFlatten(x)
Definition: ogr_core.h:440
#define CPLAssert(expr)
Definition: cpl_error.h:186
Definition: ogr_geometry.h:63
#define CPL_C_START
Definition: cpl_port.h:337
virtual void getEnvelope(OGREnvelope *psEnvelope) const override
Computes and returns the bounding envelope for this geometry in the passed psEnvelope structure.
Definition: ogrpoint.cpp:623
virtual OGRGeometry * clone() const CPL_WARN_UNUSED_RESULT=0
Make a copy of this object.
virtual OGRLinearRing * stealInteriorRing(int)
"Steal" reference to indicated interior ring.
Definition: ogrpolygon.cpp:263
virtual void flattenTo2D() override
Convert geometry to strictly 2D. In a sense this converts all Z coordinates to 0.0.
Definition: ogrpolyhedralsurface.cpp:616
virtual void assignSpatialReference(OGRSpatialReference *poSR) override
Assign spatial reference to this object.
Definition: ogrgeometrycollection.cpp:1237
virtual OGRErr addGeometry(const OGRGeometry *)
Add a new geometry to a collection.
Definition: ogrpolyhedralsurface.cpp:841
Definition: ogr_geometry.h:1728
OGRwkbByteOrder
Definition: ogr_core.h:489
OGRLinearRing * getExteriorRing()
Fetch reference to external polygon ring.
Definition: ogrpolygon.cpp:145
OGRCurvePolygon()
Create an empty curve polygon.
static OGRGeometry * createGeometry(OGRwkbGeometryType)
Create an empty geometry of desired type.
Definition: ogrgeometryfactory.cpp:528
friend FeatureIterator end(OGRLayer *poLayer)
Definition: ogrsf_frmts.h:292
@ wkbCurvePolygon
Definition: ogr_core.h:336
virtual OGRBoolean Intersects(const OGRGeometry *) const
Do these features intersect?
Definition: ogrgeometry.cpp:486
virtual OGRPolygon * CurvePolyToPoly(double dfMaxAngleStepSizeDegrees=0, const char *const *papszOptions=nullptr) const override
Return a polygon from a curve polygon.
Definition: ogrpolygon.cpp:818
static OGRLayerH ToHandle(OGRLayer *poLayer)
Definition: ogrsf_frmts.h:254
OGRPoint * toPoint()
Definition: ogr_geometry.h:524
virtual void set3D(OGRBoolean bIs3D) override
Add or remove the Z coordinate dimension.
Definition: ogrcurvepolygon.cpp:694
#define OGRERR_FAILURE
Definition: ogr_core.h:298
#define OGRERR_NOT_ENOUGH_MEMORY
Definition: ogr_core.h:294
@ wkbPolyhedralSurface
Definition: ogr_core.h:343
OGRPolyhedralSurface * toPolyhedralSurface()
Definition: ogr_geometry.h:762
void sfcgal_geometry_t
Definition: ogr_geometry.h:83
#define CPL_C_END
Definition: cpl_port.h:339
OGRErr importFromWkt(const char **) override
Definition: ogrpoint.cpp:478
void CPLDebug(const char *, const char *,...)
Definition: cpl_error.cpp:602
Definition: ogr_feature.h:92
virtual int getDimension() const override
Get the dimension of this object.
Definition: ogrpoint.cpp:204
OGRErr exportToWkb(OGRwkbByteOrder, unsigned char *, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known binary format.
Definition: ogrpoint.cpp:372
#define CPL_LSBPTR32(x)
Definition: cpl_port.h:834
virtual OGRGeometry * getLinearGeometry(double dfMaxAngleStepSizeDegrees=0, const char *const *papszOptions=nullptr) const override
Return, possibly approximate, non-curve version of this geometry.
Definition: ogrpolygon.cpp:838
@ wkbVariantIso
Definition: ogr_core.h:426
OGRErr removeGeometry(int iIndex, int bDelete=TRUE)
Remove a geometry from the container.
Definition: ogrpolyhedralsurface.cpp:1068
virtual void assignSpatialReference(OGRSpatialReference *poSR)
Assign spatial reference to this object.
Definition: ogrgeometry.cpp:416
virtual OGRBoolean Intersects(const OGRGeometry *) const override
Do these features intersect?
Definition: ogrpoint.cpp:778
virtual void setCoordinateDimension(int nDimension) override
Set the coordinate dimension.
Definition: ogrpoint.cpp:254
@ wkbPolygon
Definition: ogr_core.h:324
virtual OGRwkbGeometryType getGeometryType() const override
Fetch geometry type.
Definition: ogrpolygon.cpp:104
OGRSpatialReference * getSpatialReference(void) const
Returns spatial reference system for object.
Definition: ogr_geometry.h:435
OGRGeometry * getGeometryRef(int i)
Fetch geometry from container.
Definition: ogrpolyhedralsurface.cpp:931
virtual OGRGeometry * clone() const override
Make a copy of this object.
Definition: ogrcurvepolygon.cpp:103
#define VSI_CALLOC_VERBOSE(nCount, nSize)
Definition: cpl_vsi.h:283
virtual int getDimension() const override
Get the dimension of this object.
Definition: ogrpolyhedralsurface.cpp:139
@ wkbPolyhedralSurfaceM
Definition: ogr_core.h:377
Definition: ogrsf_frmts.h:317
struct _OGRPreparedGeometry OGRPreparedGeometry
Definition: ogr_geometry.h:2924
void CPLError(CPLErr eErrClass, CPLErrorNum err_no, const char *fmt,...)
Definition: cpl_error.cpp:308
Definition: ogr_feature.h:182
virtual OGRErr exportToWkt(char **ppszDstText, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known text format.
Definition: ogrlinestring.cpp:1870
virtual void setMeasured(OGRBoolean bIsMeasured) override
Set the type as Measured.
Definition: ogrpolyhedralsurface.cpp:996
static OGRLayer * FromHandle(OGRLayerH hLayer)
Definition: ogrsf_frmts.h:260
void VSIFree(void *)
Definition: cpl_vsisimple.cpp:827
virtual void empty() override
Clear geometry information. This restores the geometry to its initial state after construction,...
Definition: ogrpolyhedralsurface.cpp:148
#define CPLE_NotSupported
Definition: cpl_error.h:109
#define OGRERR_NOT_ENOUGH_DATA
Definition: ogr_core.h:293
#define OGRERR_CORRUPT_DATA
Definition: ogr_core.h:297
virtual OGRBoolean IsEmpty() const override
Returns TRUE (non-zero) if the object has no points.
Definition: ogr_geometry.h:848
virtual OGRBoolean Within(const OGRGeometry *) const override
Test for containment.
Definition: ogrpoint.cpp:761
OGRLayer::FeatureIterator end(OGRLayer *poLayer)
Definition: ogrsf_frmts.h:292
virtual void empty() override
Clear geometry information. This restores the geometry to its initial state after construction,...
Definition: ogrpoint.cpp:190
void setPointsM(int, const OGRRawPoint *, const double *)
Assign all points in a line string.
Definition: ogrlinestring.cpp:904
virtual OGRErr PointOnSurface(OGRPoint *) const override
This method relates to the SFCOM ISurface::get_PointOnSurface() method.
Definition: ogrpolyhedralsurface.cpp:776
Definition: ogrsf_frmts.h:350
#define CPL_MSBPTR32(x)
Definition: cpl_port.h:836
virtual OGRErr exportToWkt(char **ppszDstText, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known text format.
Definition: ogrpolygon.cpp:621
OGRLinearRing * toLinearRing()
Definition: ogr_geometry.h:580
int OGRErr
Definition: ogr_core.h:290
OGRCurvePolygon * toCurvePolygon()
Definition: ogr_geometry.h:664
long long GIntBig
Definition: cpl_port.h:248
OGRPolygon * toPolygon()
Definition: ogr_geometry.h:636
#define VSI_MALLOC_VERBOSE(size)
Definition: cpl_vsi.h:268
OGRPoint()
Create an empty point.
Definition: ogrpoint.cpp:54
OGRwkbGeometryType
Definition: ogr_core.h:317
static OGRErr createFromWkb(const void *, OGRSpatialReference *, OGRGeometry **, int=-1, OGRwkbVariant=wkbVariantOldOgc)
Create a geometry object of the appropriate type from its well known binary representation.
Definition: ogrgeometryfactory.cpp:105
#define CPL_UNUSED
Definition: cpl_port.h:948
virtual OGRBoolean IsEmpty() const override
Checks if the PolyhedralSurface is empty.
Definition: ogrpolyhedralsurface.cpp:968
#define CPL_WARN_UNUSED_RESULT
Definition: cpl_port.h:939
Definition: ogr_feature.h:354
virtual void swapXY() override
Swap x and y coordinates.
Definition: ogrpoint.cpp:752
#define EQUALN(a, b, n)
Definition: cpl_port.h:567
OGRErr importFromWkb(const unsigned char *, int, OGRwkbVariant, int &nBytesConsumedOut) override
Assign geometry from well known binary data.
Definition: ogrpoint.cpp:290
double getZ() const
Fetch Z coordinate.
Definition: ogr_geometry.h:857
@ wkbXDR
Definition: ogr_core.h:491
virtual OGRBoolean hasCurveGeometry(int bLookForNonLinear=FALSE) const override
Returns if this geometry is or has curve geometry.
Definition: ogrpolygon.cpp:829
OGRBoolean IsMeasured() const
Definition: ogr_geometry.h:365
OGRCurvePolygon & operator=(const OGRCurvePolygon &other)
Assignment operator.
Definition: ogrcurvepolygon.cpp:88
Definition: ogr_geometry.h:926
virtual void assignSpatialReference(OGRSpatialReference *poSR) override
Assign spatial reference to this object.
Definition: ogrcurvepolygon.cpp:708
double getY() const
Fetch Y coordinate.
Definition: ogr_geometry.h:855
CPLErr
Definition: cpl_error.h:52
virtual OGRBoolean Contains(const OGRGeometry *) const override
Test for containment.
Definition: ogrcurvepolygon.cpp:783
void setPoints(int, const OGRRawPoint *, const double *=nullptr)
Assign all points in a line string.
Definition: ogrlinestring.cpp:1018
@ wkbPolyhedralSurfaceZ
Definition: ogr_core.h:359
virtual const char * getGeometryName() const override
Fetch WKT name for geometry type.
Definition: ogrpoint.cpp:231
virtual OGRBoolean hasCurveGeometry(int bLookForNonLinear=FALSE) const override
Returns if this geometry is or has curve geometry.
Definition: ogrpolyhedralsurface.cpp:1042
Definition: ogr_geometry.h:1314
OGRErr importFromWkt(const char **) override
Definition: ogrpolyhedralsurface.cpp:353
#define OGRERR_NONE
Definition: ogr_core.h:292
char * CPLStrdup(const char *)
Definition: cpl_conv.cpp:293
Definition: ogr_feature.h:259
virtual double get_Area() const override
Returns the area enclosed.
Definition: ogrpolyhedralsurface.cpp:749
double y
Definition: ogr_geometry.h:75
@ wkbLineString
Definition: ogr_core.h:322
virtual void setMeasured(OGRBoolean bIsMeasured) override
Add or remove the M coordinate dimension.
Definition: ogrcurvepolygon.cpp:699
Definition: ogr_geometry.h:1913
Definition: ogr_geometry.h:1763
OGRBoolean IsPointOnSurface(const OGRPoint *) const
Definition: ogrpolygon.cpp:769
virtual void assignSpatialReference(OGRSpatialReference *poSR) override
Assign spatial reference to this object.
Definition: ogrpolyhedralsurface.cpp:1077
virtual OGRErr transform(OGRCoordinateTransformation *poCT) override
Apply arbitrary coordinate transformation to geometry.
Definition: ogrpoint.cpp:736
void * OGRLayerH
Definition: ogr_api.h:509
#define CPLFree
Definition: cpl_conv.h:81
virtual OGRBoolean Within(const OGRGeometry *) const
Test for containment.
Definition: ogrgeometry.cpp:4835
virtual OGRwkbGeometryType getGeometryType() const override
Fetch geometry type.
Definition: ogrpoint.cpp:214
virtual void setMeasured(OGRBoolean bIsMeasured)
Add or remove the M coordinate dimension.
Definition: ogrgeometry.cpp:1048
#define CPL_DISALLOW_COPY_ASSIGN(ClassName)
Definition: cpl_port.h:997
virtual OGRErr exportToWkt(char **ppszDstText, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known text format.
Definition: ogrpolyhedralsurface.cpp:451
virtual OGRBoolean Equals(const OGRGeometry *) const override
Returns TRUE if two geometries are equivalent.
Definition: ogrpoint.cpp:707
virtual void set3D(OGRBoolean bIs3D) override
Add or remove the Z coordinate dimension.
Definition: ogrlinestring.cpp:183
static OGRLineString * CastToLineString(OGRLinearRing *poLR)
Cast to line string.
Definition: ogrlinearring.cpp:790
virtual int WkbSize() const override
Returns size of related binary representation.
Definition: ogrpolygon.cpp:298
OGRErr exportToWkt(char **ppszDstText, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known text format.
Definition: ogrpoint.cpp:563
OGRwkbVariant
Definition: ogr_core.h:423
OGRCurve * stealExteriorRingCurve()
"Steal" reference to external ring.
Definition: ogrcurvepolygon.cpp:307
@ wkbPointM
Definition: ogr_core.h:363
virtual OGRErr exportToWkb(OGRwkbByteOrder, unsigned char *, OGRwkbVariant=wkbVariantOldOgc) const override
Convert a geometry into well known binary format.
Definition: ogrpolyhedralsurface.cpp:303
virtual OGRBoolean Equals(const OGRGeometry *) const override
Returns TRUE if two geometries are equivalent.
Definition: ogrpolyhedralsurface.cpp:709
double getX() const
Fetch X coordinate.
Definition: ogr_geometry.h:853
OGRwkbGeometryType getIsoGeometryType() const
Get the geometry type that conforms with ISO SQL/MM Part3.
Definition: ogrgeometry.cpp:756
virtual void set3D(OGRBoolean bIs3D) override
Set the type as 3D geometry.
Definition: ogrpolyhedralsurface.cpp:981
OGRPoint & operator=(const OGRPoint &other)
Assignment operator.
Definition: ogrpoint.cpp:154
#define STARTS_WITH_CI(a, b)
Definition: cpl_port.h:580
#define CPLE_AppDefined
Definition: cpl_error.h:99
unsigned int GUInt32
Definition: cpl_port.h:207
Generated for GDAL by
1.8.17.