GDAL
ogr_core.h
Go to the documentation of this file.
1/******************************************************************************
2 * $Id$
3 *
4 * Project: OpenGIS Simple Features Reference Implementation
5 * Purpose: Define some core portability services for cross-platform OGR code.
6 * Author: Frank Warmerdam, warmerdam@pobox.com
7 *
8 ******************************************************************************
9 * Copyright (c) 1999, Frank Warmerdam
10 * Copyright (c) 2007-2014, Even Rouault <even dot rouault at spatialys.com>
11 *
12 * Permission is hereby granted, free of charge, to any person obtaining a
13 * copy of this software and associated documentation files (the "Software"),
14 * to deal in the Software without restriction, including without limitation
15 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
16 * and/or sell copies of the Software, and to permit persons to whom the
17 * Software is furnished to do so, subject to the following conditions:
18 *
19 * The above copyright notice and this permission notice shall be included
20 * in all copies or substantial portions of the Software.
21 *
22 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
23 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
25 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
27 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
28 * DEALINGS IN THE SOFTWARE.
29 ****************************************************************************/
30
31#ifndef OGR_CORE_H_INCLUDED
32#define OGR_CORE_H_INCLUDED
33
34#include "cpl_port.h"
35#if defined(GDAL_COMPILATION)
36#define DO_NOT_DEFINE_GDAL_DATE_NAME
37#endif
38#include "gdal_version.h"
39
46#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
47
48extern "C++"
49{
50#if !defined(DOXYGEN_SKIP)
51#include <limits>
52#endif
53
57class CPL_DLL OGREnvelope
58{
59 public:
61 OGREnvelope() : MinX(std::numeric_limits<double>::infinity()),
62 MaxX(-std::numeric_limits<double>::infinity()),
63 MinY(std::numeric_limits<double>::infinity()),
64 MaxY(-std::numeric_limits<double>::infinity())
65 {
66 }
67
69 OGREnvelope(const OGREnvelope& oOther) :
70 MinX(oOther.MinX),MaxX(oOther.MaxX), MinY(oOther.MinY), MaxY(oOther.MaxY)
71 {
72 }
73
75 OGREnvelope& operator=(const OGREnvelope&) = default;
76
78 double MinX;
79
81 double MaxX;
82
84 double MinY;
85
87 double MaxY;
88
89#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
90#pragma GCC diagnostic push
91#pragma GCC diagnostic ignored "-Wfloat-equal"
92#endif
94 int IsInit() const { return MinX != std::numeric_limits<double>::infinity(); }
95
96#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
97#pragma GCC diagnostic pop
98#endif
99
101 void Merge( OGREnvelope const& sOther ) {
102 MinX = MIN(MinX,sOther.MinX);
103 MaxX = MAX(MaxX,sOther.MaxX);
104 MinY = MIN(MinY,sOther.MinY);
105 MaxY = MAX(MaxY,sOther.MaxY);
106 }
107
109 void Merge( double dfX, double dfY ) {
110 MinX = MIN(MinX,dfX);
111 MaxX = MAX(MaxX,dfX);
112 MinY = MIN(MinY,dfY);
113 MaxY = MAX(MaxY,dfY);
114 }
115
117 void Intersect( OGREnvelope const& sOther ) {
118 if(Intersects(sOther))
119 {
120 if( IsInit() )
121 {
122 MinX = MAX(MinX,sOther.MinX);
123 MaxX = MIN(MaxX,sOther.MaxX);
124 MinY = MAX(MinY,sOther.MinY);
125 MaxY = MIN(MaxY,sOther.MaxY);
126 }
127 else
128 {
129 MinX = sOther.MinX;
130 MaxX = sOther.MaxX;
131 MinY = sOther.MinY;
132 MaxY = sOther.MaxY;
133 }
134 }
135 else
136 {
137 *this = OGREnvelope();
138 }
139 }
140
142 int Intersects(OGREnvelope const& other) const
143 {
144 return MinX <= other.MaxX && MaxX >= other.MinX &&
145 MinY <= other.MaxY && MaxY >= other.MinY;
146 }
147
149 int Contains(OGREnvelope const& other) const
150 {
151 return MinX <= other.MinX && MinY <= other.MinY &&
152 MaxX >= other.MaxX && MaxY >= other.MaxY;
153 }
154
156 bool operator== (const OGREnvelope& other) const
157 {
158#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
159#pragma GCC diagnostic push
160#pragma GCC diagnostic ignored "-Wfloat-equal"
161#endif
162 return MinX == other.MinX &&
163 MinY == other.MinY &&
164 MaxX == other.MaxX &&
165 MaxY == other.MaxY;
166
167#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
168#pragma GCC diagnostic pop
169#endif
170 }
171
173 bool operator!= (const OGREnvelope& other) const
174 {
175 return !(*this == other);
176 }
177};
178
179} // extern "C++"
180
181#else
182typedef struct
183{
184 double MinX;
185 double MaxX;
186 double MinY;
187 double MaxY;
189#endif
190
191#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
192
193extern "C++" {
194
198class CPL_DLL OGREnvelope3D : public OGREnvelope
199{
200 public:
203 MinZ(std::numeric_limits<double>::infinity()),
204 MaxZ(-std::numeric_limits<double>::infinity())
205 {
206 }
207
210 OGREnvelope(oOther),
211 MinZ(oOther.MinZ), MaxZ(oOther.MaxZ)
212 {
213 }
214
217
219 double MinZ;
220
222 double MaxZ;
223
224#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
225#pragma GCC diagnostic push
226#pragma GCC diagnostic ignored "-Wfloat-equal"
227#endif
229 int IsInit() const { return MinX != std::numeric_limits<double>::infinity(); }
230#ifdef HAVE_GCC_DIAGNOSTIC_PUSH
231#pragma GCC diagnostic pop
232#endif
233
235 void Merge( OGREnvelope3D const& sOther ) {
236 MinX = MIN(MinX,sOther.MinX);
237 MaxX = MAX(MaxX,sOther.MaxX);
238 MinY = MIN(MinY,sOther.MinY);
239 MaxY = MAX(MaxY,sOther.MaxY);
240 MinZ = MIN(MinZ,sOther.MinZ);
241 MaxZ = MAX(MaxZ,sOther.MaxZ);
242 }
243
245 void Merge( double dfX, double dfY, double dfZ ) {
246 MinX = MIN(MinX,dfX);
247 MaxX = MAX(MaxX,dfX);
248 MinY = MIN(MinY,dfY);
249 MaxY = MAX(MaxY,dfY);
250 MinZ = MIN(MinZ,dfZ);
251 MaxZ = MAX(MaxZ,dfZ);
252 }
253
255 void Intersect( OGREnvelope3D const& sOther ) {
256 if(Intersects(sOther))
257 {
258 if( IsInit() )
259 {
260 MinX = MAX(MinX,sOther.MinX);
261 MaxX = MIN(MaxX,sOther.MaxX);
262 MinY = MAX(MinY,sOther.MinY);
263 MaxY = MIN(MaxY,sOther.MaxY);
264 MinZ = MAX(MinZ,sOther.MinZ);
265 MaxZ = MIN(MaxZ,sOther.MaxZ);
266 }
267 else
268 {
269 MinX = sOther.MinX;
270 MaxX = sOther.MaxX;
271 MinY = sOther.MinY;
272 MaxY = sOther.MaxY;
273 MinZ = sOther.MinZ;
274 MaxZ = sOther.MaxZ;
275 }
276 }
277 else
278 {
279 *this = OGREnvelope3D();
280 }
281 }
282
284 int Intersects(OGREnvelope3D const& other) const
285 {
286 return MinX <= other.MaxX && MaxX >= other.MinX &&
287 MinY <= other.MaxY && MaxY >= other.MinY &&
288 MinZ <= other.MaxZ && MaxZ >= other.MinZ;
289 }
290
292 int Contains(OGREnvelope3D const& other) const
293 {
294 return MinX <= other.MinX && MinY <= other.MinY &&
295 MaxX >= other.MaxX && MaxY >= other.MaxY &&
296 MinZ <= other.MinZ && MaxZ >= other.MaxZ;
297 }
298};
299
300} // extern "C++"
301
302#else
303typedef struct
304{
305 double MinX;
306 double MaxX;
307 double MinY;
308 double MaxY;
309 double MinZ;
310 double MaxZ;
312#endif
313
315
317void CPL_DLL *OGRMalloc( size_t ) CPL_WARN_DEPRECATED("Use CPLMalloc instead.");
318void CPL_DLL *OGRCalloc( size_t, size_t ) CPL_WARN_DEPRECATED("Use CPLCalloc instead.");
319void CPL_DLL *OGRRealloc( void *, size_t ) CPL_WARN_DEPRECATED("Use CPLRealloc instead.");
320char CPL_DLL *OGRStrdup( const char * ) CPL_WARN_DEPRECATED("Use CPLStrdup instead.");
321void CPL_DLL OGRFree( void * ) CPL_WARN_DEPRECATED("Use CPLFree instead.");
324#ifdef STRICT_OGRERR_TYPE
326typedef enum
327{
338} OGRErr;
339#else
341typedef int OGRErr;
342
343#define OGRERR_NONE 0
344#define OGRERR_NOT_ENOUGH_DATA 1
345#define OGRERR_NOT_ENOUGH_MEMORY 2
346#define OGRERR_UNSUPPORTED_GEOMETRY_TYPE 3
347#define OGRERR_UNSUPPORTED_OPERATION 4
348#define OGRERR_CORRUPT_DATA 5
349#define OGRERR_FAILURE 6
350#define OGRERR_UNSUPPORTED_SRS 7
351#define OGRERR_INVALID_HANDLE 8
352#define OGRERR_NON_EXISTING_FEATURE 9
354#endif
355
357typedef int OGRBoolean;
358
359/* -------------------------------------------------------------------- */
360/* ogr_geometry.h related definitions. */
361/* -------------------------------------------------------------------- */
362
368typedef enum
369{
373 wkbLineString = 2,
375 wkbPolygon = 3,
387 wkbCurvePolygon = 10,
392 wkbCurve = 13,
396 wkbTIN = 16,
400 wkbNone = 100,
408 wkbCurveZ = 1013,
409 wkbSurfaceZ = 1014,
411 wkbTINZ = 1016,
414 wkbPointM = 2001,
416 wkbPolygonM = 2003,
426 wkbCurveM = 2013,
427 wkbSurfaceM = 2014,
429 wkbTINM = 2016,
432 wkbPointZM = 3001,
444 wkbCurveZM = 3013,
447 wkbTINZM = 3016,
450#if defined(DOXYGEN_SKIP)
451 // Sphinx doesn't like 0x8000000x constants
452 wkbPoint25D = -2147483647,
453 wkbLineString25D = -2147483646,
454 wkbPolygon25D = -2147483645,
455 wkbMultiPoint25D = -2147483644,
456 wkbMultiLineString25D = -2147483643,
457 wkbMultiPolygon25D = -2147483642,
458 wkbGeometryCollection25D = -2147483641
459#else
460 wkbPoint25D = 0x80000001,
461 wkbLineString25D = 0x80000002,
462 wkbPolygon25D = 0x80000003,
463 wkbMultiPoint25D = 0x80000004,
464 wkbMultiLineString25D = 0x80000005,
465 wkbMultiPolygon25D = 0x80000006,
466 wkbGeometryCollection25D = 0x80000007
467#endif
469
484typedef enum
485{
490
491#ifndef GDAL_COMPILATION
493#define wkb25DBit 0x80000000
494#endif
495
496#ifndef __cplusplus
498#define wkbFlatten(x) OGR_GT_Flatten((OGRwkbGeometryType)(x))
499#else
501#define wkbFlatten(x) OGR_GT_Flatten(static_cast<OGRwkbGeometryType>(x))
502#endif
503
507#define wkbHasZ(x) (OGR_GT_HasZ(x) != 0)
508
512#define wkbSetZ(x) OGR_GT_SetZ(x)
513
517#define wkbHasM(x) (OGR_GT_HasM(x) != 0)
518
522#define wkbSetM(x) OGR_GT_SetM(x)
523
524#ifndef DOXYGEN_SKIP
525#define ogrZMarker 0x21125711
526#endif
527
528const char CPL_DLL * OGRGeometryTypeToName( OGRwkbGeometryType eType );
530 OGRwkbGeometryType eExtra );
532 OGRwkbGeometryType eExtra,
533 int bAllowPromotingToCurves );
537OGRwkbGeometryType CPL_DLL OGR_GT_SetModifier( OGRwkbGeometryType eType, int bSetZ, int bSetM );
538int CPL_DLL OGR_GT_HasZ( OGRwkbGeometryType eType );
539int CPL_DLL OGR_GT_HasM( OGRwkbGeometryType eType );
540int CPL_DLL OGR_GT_IsSubClassOf( OGRwkbGeometryType eType,
541 OGRwkbGeometryType eSuperType );
548
550typedef enum
551{
552 wkbXDR = 0,
553 wkbNDR = 1
555
556#ifndef DOXYGEN_SKIP
557
558#ifndef NO_HACK_FOR_IBM_DB2_V72
559# define HACK_FOR_IBM_DB2_V72
560#endif
561
562#ifdef HACK_FOR_IBM_DB2_V72
563# define DB2_V72_FIX_BYTE_ORDER(x) ((((x) & 0x31) == (x)) ? ((x) & 0x1) : (x))
564# define DB2_V72_UNFIX_BYTE_ORDER(x) CPL_STATIC_CAST(unsigned char, OGRGeometry::bGenerate_DB2_V72_BYTE_ORDER ? ((x) | 0x30) : (x))
565#else
566# define DB2_V72_FIX_BYTE_ORDER(x) (x)
567# define DB2_V72_UNFIX_BYTE_ORDER(x) (x)
568#endif
569
570#endif /* #ifndef DOXYGEN_SKIP */
571
575#define ALTER_NAME_FLAG 0x1
576
580#define ALTER_TYPE_FLAG 0x2
581
585#define ALTER_WIDTH_PRECISION_FLAG 0x4
586
591#define ALTER_NULLABLE_FLAG 0x8
592
597#define ALTER_DEFAULT_FLAG 0x10
598
603#define ALTER_UNIQUE_FLAG 0x20
604
609#define ALTER_DOMAIN_FLAG 0x40
610
611
615#define ALTER_ALL_FLAG (ALTER_NAME_FLAG | ALTER_TYPE_FLAG | ALTER_WIDTH_PRECISION_FLAG | ALTER_NULLABLE_FLAG | ALTER_DEFAULT_FLAG | ALTER_UNIQUE_FLAG | ALTER_DOMAIN_FLAG)
616
617
618
623#define ALTER_GEOM_FIELD_DEFN_NAME_FLAG 0x1000
624
629#define ALTER_GEOM_FIELD_DEFN_TYPE_FLAG 0x2000
630
635#define ALTER_GEOM_FIELD_DEFN_NULLABLE_FLAG 0x4000
636
641#define ALTER_GEOM_FIELD_DEFN_SRS_FLAG 0x8000
642
647#define ALTER_GEOM_FIELD_DEFN_SRS_COORD_EPOCH_FLAG 0x10000
648
649
654#define ALTER_GEOM_FIELD_DEFN_ALL_FLAG (ALTER_GEOM_FIELD_DEFN_NAME_FLAG | ALTER_GEOM_FIELD_DEFN_TYPE_FLAG | ALTER_GEOM_FIELD_DEFN_NULLABLE_FLAG | ALTER_GEOM_FIELD_DEFN_SRS_FLAG | ALTER_GEOM_FIELD_DEFN_SRS_COORD_EPOCH_FLAG)
655
656
657
662#define OGR_F_VAL_NULL 0x00000001
663
668#define OGR_F_VAL_GEOM_TYPE 0x00000002
669
674#define OGR_F_VAL_WIDTH 0x00000004
675
683#define OGR_F_VAL_ALLOW_NULL_WHEN_DEFAULT 0x00000008
684
691#define OGR_F_VAL_ALLOW_DIFFERENT_GEOM_DIM 0x00000010
692
697#define OGR_F_VAL_ALL (0x7FFFFFFF & ~OGR_F_VAL_ALLOW_DIFFERENT_GEOM_DIM)
698
699/************************************************************************/
700/* ogr_feature.h related definitions. */
701/************************************************************************/
702
709typedef enum
725 OFTMaxType = 13
727
737typedef enum
738{ OFSTNone = 0,
754 OFSTMaxSubType = 5
756
761typedef enum
762{
763 OJUndefined = 0,
764 OJLeft = 1,
765 OJRight = 2
767
769#define OGRNullFID -1
770
771/* Special value for an unknown field type. This should only be used
772 * while reading a file. At the end of file any unknown types should
773 * be set to OFTString.
774*/
776#define OGRUnknownType static_cast<OGRFieldType>(-1)
784#define OGRUnsetMarker -21121
785
792#define OGRNullMarker -21122
793
794/************************************************************************/
795/* OGRField */
796/************************************************************************/
797
802typedef union {
804 int Integer;
805 GIntBig Integer64;
806 double Real;
807 char *String;
808
809 struct {
810 int nCount;
811 int *paList;
812 } IntegerList;
813
814 struct {
815 int nCount;
816 GIntBig *paList;
817 } Integer64List;
818
819 struct {
820 int nCount;
821 double *paList;
822 } RealList;
823
824 struct {
825 int nCount;
826 char **paList;
827 } StringList;
828
829 struct {
830 int nCount;
831 GByte *paData;
832 } Binary;
833
834 struct {
835 int nMarker1;
836 int nMarker2;
837 int nMarker3;
838 } Set;
839
840 struct {
841 GInt16 Year;
842 GByte Month;
843 GByte Day;
844 GByte Hour;
845 GByte Minute;
846 GByte TZFlag; /* 0=unknown, 1=localtime(ambiguous),
847 100=GMT, 104=GMT+1, 80=GMT-5, etc */
848 GByte Reserved; /* must be set to 0 */
849 float Second; /* with millisecond accuracy. at the end of the structure, so as to keep it 12 bytes on 32 bit */
850 } Date;
852} OGRField;
853
854#ifdef __cplusplus
856inline int OGR_GET_MS(float fSec) {
857 if( CPLIsNan(fSec) ) return 0;
858 if( fSec >= 999 ) return 999;
859 if( fSec <= 0 ) return 0;
860 const float fValue = (fSec - static_cast<int>(fSec)) * 1000 + 0.5f;
861 return static_cast<int>(fValue);
862}
863#endif // __cplusplus
864
865int CPL_DLL OGRParseDate( const char *pszInput, OGRField *psOutput,
866 int nOptions );
867
868/* -------------------------------------------------------------------- */
869/* Constants from ogrsf_frmts.h for capabilities. */
870/* -------------------------------------------------------------------- */
871#define OLCRandomRead "RandomRead"
872#define OLCSequentialWrite "SequentialWrite"
873#define OLCRandomWrite "RandomWrite"
874#define OLCFastSpatialFilter "FastSpatialFilter"
875#define OLCFastFeatureCount "FastFeatureCount"
876#define OLCFastGetExtent "FastGetExtent"
877#define OLCCreateField "CreateField"
878#define OLCDeleteField "DeleteField"
879#define OLCReorderFields "ReorderFields"
880#define OLCAlterFieldDefn "AlterFieldDefn"
881#define OLCAlterGeomFieldDefn "AlterGeomFieldDefn"
882#define OLCTransactions "Transactions"
883#define OLCDeleteFeature "DeleteFeature"
884#define OLCUpsertFeature "UpsertFeature"
885#define OLCFastSetNextByIndex "FastSetNextByIndex"
886#define OLCStringsAsUTF8 "StringsAsUTF8"
887#define OLCIgnoreFields "IgnoreFields"
888#define OLCCreateGeomField "CreateGeomField"
889#define OLCCurveGeometries "CurveGeometries"
890#define OLCMeasuredGeometries "MeasuredGeometries"
891#define OLCZGeometries "ZGeometries"
892#define OLCRename "Rename"
893#define OLCFastGetArrowStream "FastGetArrowStream"
895#define ODsCCreateLayer "CreateLayer"
896#define ODsCDeleteLayer "DeleteLayer"
897/* Reserved: "RenameLayer" */
898#define ODsCCreateGeomFieldAfterCreateLayer "CreateGeomFieldAfterCreateLayer"
899#define ODsCCurveGeometries "CurveGeometries"
900#define ODsCTransactions "Transactions"
901#define ODsCEmulatedTransactions "EmulatedTransactions"
902#define ODsCMeasuredGeometries "MeasuredGeometries"
903#define ODsCZGeometries "ZGeometries"
904#define ODsCRandomLayerRead "RandomLayerRead"
905/* Note the unfortunate trailing space at the end of the string */
906#define ODsCRandomLayerWrite "RandomLayerWrite "
907#define ODsCAddFieldDomain "AddFieldDomain"
908#define ODsCDeleteFieldDomain "DeleteFieldDomain"
909#define ODsCUpdateFieldDomain "UpdateFieldDomain"
911#define ODrCCreateDataSource "CreateDataSource"
912#define ODrCDeleteDataSource "DeleteDataSource"
914/* -------------------------------------------------------------------- */
915/* Layer metadata items. */
916/* -------------------------------------------------------------------- */
921#define OLMD_FID64 "OLMD_FID64"
922
923/************************************************************************/
924/* ogr_featurestyle.h related definitions. */
925/************************************************************************/
926
932{
938 OGRSTCVector = 5
940
945{
951 OGRSTUInches = 5
953
958{
967#ifndef DOXYGEN_SKIP
968 OGRSTPenLast = 8
969#endif
971
976{
985#ifndef DOXYGEN_SKIP
986 OGRSTBrushLast = 8
987#endif
988
990
995{
1008#ifndef DOXYGEN_SKIP
1009 OGRSTSymbolLast = 12
1010#endif
1012
1017{
1039#ifndef DOXYGEN_SKIP
1040 OGRSTLabelLast = 21
1041#endif
1043
1044/* -------------------------------------------------------------------- */
1045/* Field domains */
1046/* -------------------------------------------------------------------- */
1047
1052typedef struct
1053{
1055 char* pszCode;
1056
1060
1065typedef enum
1066{
1072 OFDT_GLOB
1074
1082typedef enum
1083{
1091
1099typedef enum
1100{
1108
1109/* ------------------------------------------------------------------- */
1110/* Version checking */
1111/* -------------------------------------------------------------------- */
1112
1113#ifndef DOXYGEN_SKIP
1114
1115/* Note to developers : please keep this section in sync with gdal.h */
1116
1117#ifndef GDAL_VERSION_INFO_DEFINED
1118#define GDAL_VERSION_INFO_DEFINED
1119const char CPL_DLL * CPL_STDCALL GDALVersionInfo( const char * );
1120#endif
1121
1122#ifndef GDAL_CHECK_VERSION
1123
1135int CPL_DLL CPL_STDCALL GDALCheckVersion( int nVersionMajor, int nVersionMinor,
1136 const char* pszCallingComponentName);
1137
1139#define GDAL_CHECK_VERSION(pszCallingComponentName) \
1140 GDALCheckVersion(GDAL_VERSION_MAJOR, GDAL_VERSION_MINOR, pszCallingComponentName)
1141
1142#endif
1143
1144#endif /* #ifndef DOXYGEN_SKIP */
1145
1147
1148#endif /* ndef OGR_CORE_H_INCLUDED */
Simple container for a bounding region in 3D.
Definition: ogr_core.h:199
void Merge(OGREnvelope3D const &sOther)
Update the current object by computing its union with the other rectangle.
Definition: ogr_core.h:235
int IsInit() const
Return whether the object has been initialized, that is, is non empty.
Definition: ogr_core.h:229
void Merge(double dfX, double dfY, double dfZ)
Update the current object by computing its union with the provided point.
Definition: ogr_core.h:245
int Intersects(OGREnvelope3D const &other) const
Return whether the current object intersects with the other rectangle.
Definition: ogr_core.h:284
double MaxZ
Maximum Z value.
Definition: ogr_core.h:222
OGREnvelope3D & operator=(const OGREnvelope3D &)=default
Assignment operator.
double MinZ
Minimum Z value.
Definition: ogr_core.h:219
OGREnvelope3D()
Default constructor.
Definition: ogr_core.h:202
int Contains(OGREnvelope3D const &other) const
Return whether the current object contains the other rectangle.
Definition: ogr_core.h:292
void Intersect(OGREnvelope3D const &sOther)
Update the current object by computing its intersection with the other rectangle.
Definition: ogr_core.h:255
OGREnvelope3D(const OGREnvelope3D &oOther)
Copy constructor.
Definition: ogr_core.h:209
Simple container for a bounding region (rectangle)
Definition: ogr_core.h:58
int Contains(OGREnvelope const &other) const
Return whether the current object contains the other rectangle.
Definition: ogr_core.h:149
double MinY
Minimum Y value.
Definition: ogr_core.h:84
double MaxX
Maximum X value.
Definition: ogr_core.h:81
void Intersect(OGREnvelope const &sOther)
Update the current object by computing its intersection with the other rectangle.
Definition: ogr_core.h:117
double MinX
Minimum X value.
Definition: ogr_core.h:78
OGREnvelope()
Default constructor.
Definition: ogr_core.h:61
double MaxY
Maximum Y value.
Definition: ogr_core.h:87
int IsInit() const
Return whether the object has been initialized, that is, is non empty.
Definition: ogr_core.h:94
int Intersects(OGREnvelope const &other) const
Return whether the current object intersects with the other rectangle.
Definition: ogr_core.h:142
void Merge(double dfX, double dfY)
Update the current object by computing its union with the provided point.
Definition: ogr_core.h:109
OGREnvelope & operator=(const OGREnvelope &)=default
Assignment operator.
OGREnvelope(const OGREnvelope &oOther)
Copy constructor.
Definition: ogr_core.h:69
void Merge(OGREnvelope const &sOther)
Update the current object by computing its union with the other rectangle.
Definition: ogr_core.h:101
Core portability definitions for CPL.
#define MIN(a, b)
Macro to compute the minimum of 2 values.
Definition: cpl_port.h:379
short GInt16
Int16 type.
Definition: cpl_port.h:199
#define CPL_C_END
Macro to end a block of C symbols.
Definition: cpl_port.h:306
#define CPL_C_START
Macro to start a block of C symbols.
Definition: cpl_port.h:304
#define CPLIsNan(x)
Return whether a floating-pointer number is NaN.
Definition: cpl_port.h:609
unsigned char GByte
Unsigned byte type.
Definition: cpl_port.h:203
long long GIntBig
Large signed integer type (generally 64-bit integer type).
Definition: cpl_port.h:230
#define MAX(a, b)
Macro to compute the maximum of 2 values.
Definition: cpl_port.h:381
int GDALCheckVersion(int nVersionMajor, int nVersionMinor, const char *pszCallingComponentName)
Return TRUE if GDAL library version at runtime matches nVersionMajor.nVersionMinor.
Definition: gdal_misc.cpp:2395
const char * GDALVersionInfo(const char *)
Get runtime version information.
Definition: gdal_misc.cpp:2231
OGRwkbGeometryType OGRMergeGeometryTypesEx(OGRwkbGeometryType eMain, OGRwkbGeometryType eExtra, int bAllowPromotingToCurves)
Find common geometry type.
Definition: ogrgeometry.cpp:2795
#define OGRERR_NOT_ENOUGH_MEMORY
Not enough memory.
Definition: ogr_core.h:345
int OGR_GT_HasM(OGRwkbGeometryType eType)
Return if the geometry type is a measured type.
Definition: ogrgeometry.cpp:6808
int OGR_GT_IsSurface(OGRwkbGeometryType)
Return if a geometry type is an instance of Surface.
Definition: ogrgeometry.cpp:7139
int OGRBoolean
Type for a OGR boolean.
Definition: ogr_core.h:357
OGRFieldSubType
List of field subtypes.
Definition: ogr_core.h:738
@ OFSTBoolean
Boolean integer.
Definition: ogr_core.h:741
@ OFSTInt16
Signed 16-bit integer.
Definition: ogr_core.h:743
@ OFSTUUID
UUID string representation.
Definition: ogr_core.h:753
@ OFSTJSON
JSON content.
Definition: ogr_core.h:749
@ OFSTNone
No subtype.
Definition: ogr_core.h:739
@ OFSTFloat32
Single precision (32 bit) floating point.
Definition: ogr_core.h:745
ogr_style_tool_param_symbol_id
List of parameters for use with OGRStyleSymbol.
Definition: ogr_core.h:995
@ OGRSTSymbolDy
Dy.
Definition: ogr_core.h:1001
@ OGRSTSymbolId
Id.
Definition: ogr_core.h:996
@ OGRSTSymbolSize
Size.
Definition: ogr_core.h:999
@ OGRSTSymbolFontName
Font name.
Definition: ogr_core.h:1006
@ OGRSTSymbolColor
Color.
Definition: ogr_core.h:998
@ OGRSTSymbolDx
Dx.
Definition: ogr_core.h:1000
@ OGRSTSymbolPerp
Perpendicular.
Definition: ogr_core.h:1003
@ OGRSTSymbolAngle
Angle.
Definition: ogr_core.h:997
@ OGRSTSymbolOColor
Outline color.
Definition: ogr_core.h:1007
@ OGRSTSymbolPriority
Priority.
Definition: ogr_core.h:1005
@ OGRSTSymbolStep
Step.
Definition: ogr_core.h:1002
@ OGRSTSymbolOffset
Offset.
Definition: ogr_core.h:1004
enum ogr_style_tool_param_symbol_id OGRSTSymbolParam
List of parameters for use with OGRStyleSymbol.
OGRFieldDomainMergePolicy
Merge policy for field domains.
Definition: ogr_core.h:1100
@ OFDMP_SUM
Sum.
Definition: ogr_core.h:1104
@ OFDMP_GEOMETRY_WEIGHTED
New values are computed as the weighted average of the source values.
Definition: ogr_core.h:1106
@ OFDMP_DEFAULT_VALUE
Default value.
Definition: ogr_core.h:1102
OGRwkbByteOrder
Enumeration to describe byte order.
Definition: ogr_core.h:551
@ wkbXDR
MSB/Sun/Motorola: Most Significant Byte First
Definition: ogr_core.h:552
@ wkbNDR
LSB/Intel/Vax: Least Significant Byte First
Definition: ogr_core.h:553
int OGRParseDate(const char *pszInput, OGRField *psOutput, int nOptions)
Parse date string.
Definition: ogrutils.cpp:946
#define OGRERR_UNSUPPORTED_GEOMETRY_TYPE
Unsupported geometry type.
Definition: ogr_core.h:346
OGRFieldDomainType
Type of field domain.
Definition: ogr_core.h:1066
@ OFDT_RANGE
Range (min/max)
Definition: ogr_core.h:1070
@ OFDT_CODED
Coded.
Definition: ogr_core.h:1068
@ OFDT_GLOB
Glob (used by GeoPackage)
Definition: ogr_core.h:1072
enum ogr_style_tool_param_pen_id OGRSTPenParam
List of parameters for use with OGRStylePen.
OGRwkbGeometryType OGR_GT_GetLinear(OGRwkbGeometryType eType)
Returns the non-curve geometry type that can contain the passed geometry type.
Definition: ogrgeometry.cpp:7076
int OGR_GT_IsCurve(OGRwkbGeometryType)
Return if a geometry type is an instance of Curve.
Definition: ogrgeometry.cpp:7118
OGRwkbGeometryType OGR_GT_SetZ(OGRwkbGeometryType eType)
Returns the 3D geometry type corresponding to the passed geometry type.
Definition: ogrgeometry.cpp:6830
#define OGRERR_FAILURE
Failure.
Definition: ogr_core.h:349
#define OGRERR_UNSUPPORTED_OPERATION
Unsupported operation.
Definition: ogr_core.h:347
OGRwkbVariant
Output variants of WKB we support.
Definition: ogr_core.h:485
@ wkbVariantPostGIS1
PostGIS 1.X has different codes for CurvePolygon, MultiCurve and MultiSurface.
Definition: ogr_core.h:488
@ wkbVariantOldOgc
Old-style 99-402 extended dimension (Z) WKB types.
Definition: ogr_core.h:486
@ wkbVariantIso
SFSQL 1.2 and ISO SQL/MM Part 3 extended dimension (Z&M) WKB types.
Definition: ogr_core.h:487
#define OGRERR_NONE
Success.
Definition: ogr_core.h:343
OGRwkbGeometryType OGRMergeGeometryTypes(OGRwkbGeometryType eMain, OGRwkbGeometryType eExtra)
Find common geometry type.
Definition: ogrgeometry.cpp:2758
OGRJustification
Display justification for field values.
Definition: ogr_core.h:762
OGRFieldType
List of feature field types.
Definition: ogr_core.h:710
@ OFTTime
Time.
Definition: ogr_core.h:721
@ OFTInteger64List
List of 64bit integers.
Definition: ogr_core.h:724
@ OFTIntegerList
List of 32bit integers.
Definition: ogr_core.h:712
@ OFTDate
Date.
Definition: ogr_core.h:720
@ OFTWideStringList
deprecated
Definition: ogr_core.h:718
@ OFTInteger
Simple 32bit integer.
Definition: ogr_core.h:711
@ OFTString
String of ASCII chars.
Definition: ogr_core.h:715
@ OFTBinary
Raw Binary data.
Definition: ogr_core.h:719
@ OFTRealList
List of doubles.
Definition: ogr_core.h:714
@ OFTReal
Double Precision floating point.
Definition: ogr_core.h:713
@ OFTStringList
Array of strings.
Definition: ogr_core.h:716
@ OFTDateTime
Date and Time.
Definition: ogr_core.h:722
@ OFTInteger64
Single 64bit integer.
Definition: ogr_core.h:723
@ OFTWideString
deprecated
Definition: ogr_core.h:717
OGRwkbGeometryType OGR_GT_GetCurve(OGRwkbGeometryType eType)
Returns the curve geometry type that can contain the passed geometry type.
Definition: ogrgeometry.cpp:7027
OGRwkbGeometryType
List of well known binary geometry types.
Definition: ogr_core.h:369
@ wkbPolygon25D
2.5D extension as per 99-402
Definition: ogr_core.h:454
@ wkbCurve
Curve (abstract type).
Definition: ogr_core.h:392
@ wkbLineString
1-dimensional geometric object with linear interpolation between Points, standard WKB
Definition: ogr_core.h:373
@ wkbCircularString
one or more circular arc segments connected end to end, ISO SQL/MM Part 3.
Definition: ogr_core.h:384
@ wkbSurfaceZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:445
@ wkbPolygon
planar 2-dimensional geometric object defined by 1 exterior boundary and 0 or more interior boundarie...
Definition: ogr_core.h:375
@ wkbTriangle
a Triangle.
Definition: ogr_core.h:398
@ wkbPoint25D
2.5D extension as per 99-402
Definition: ogr_core.h:452
@ wkbSurfaceZ
wkbSurface with Z component.
Definition: ogr_core.h:409
@ wkbMultiSurfaceM
ISO SQL/MM Part 3.
Definition: ogr_core.h:425
@ wkbPolygonZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:434
@ wkbMultiPolygon25D
2.5D extension as per 99-402
Definition: ogr_core.h:457
@ wkbPolyhedralSurfaceM
ISO SQL/MM Part 3.
Definition: ogr_core.h:428
@ wkbTINZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:447
@ wkbMultiPointZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:435
@ wkbPointM
ISO SQL/MM Part 3.
Definition: ogr_core.h:414
@ wkbMultiLineString
GeometryCollection of LineStrings, standard WKB.
Definition: ogr_core.h:379
@ wkbCompoundCurveM
ISO SQL/MM Part 3.
Definition: ogr_core.h:422
@ wkbUnknown
unknown type, non-standard
Definition: ogr_core.h:370
@ wkbMultiSurfaceZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:443
@ wkbTINZ
ISO SQL/MM Part 3.
Definition: ogr_core.h:411
@ wkbCircularStringM
ISO SQL/MM Part 3.
Definition: ogr_core.h:421
@ wkbPolygonM
ISO SQL/MM Part 3.
Definition: ogr_core.h:416
@ wkbMultiCurveM
ISO SQL/MM Part 3.
Definition: ogr_core.h:424
@ wkbLinearRing
non-standard, just for createGeometry()
Definition: ogr_core.h:401
@ wkbLineStringM
ISO SQL/MM Part 3.
Definition: ogr_core.h:415
@ wkbTIN
a PolyhedralSurface consisting only of Triangle patches ISO SQL/MM Part 3.
Definition: ogr_core.h:396
@ wkbGeometryCollection25D
2.5D extension as per 99-402
Definition: ogr_core.h:458
@ wkbSurfaceM
ISO SQL/MM Part 3.
Definition: ogr_core.h:427
@ wkbCurvePolygonM
ISO SQL/MM Part 3.
Definition: ogr_core.h:423
@ wkbPolyhedralSurface
a contiguous collection of polygons, which share common boundary segments, ISO SQL/MM Part 3.
Definition: ogr_core.h:394
@ wkbSurface
Surface (abstract type).
Definition: ogr_core.h:393
@ wkbMultiCurveZ
wkbMultiCurve with Z component.
Definition: ogr_core.h:406
@ wkbCircularStringZ
wkbCircularString with Z component.
Definition: ogr_core.h:403
@ wkbPoint
0-dimensional geometric object, standard WKB
Definition: ogr_core.h:372
@ wkbCompoundCurve
sequence of contiguous curves, ISO SQL/MM Part 3.
Definition: ogr_core.h:386
@ wkbPolyhedralSurfaceZ
ISO SQL/MM Part 3.
Definition: ogr_core.h:410
@ wkbGeometryCollection
geometric object that is a collection of 1 or more geometric objects, standard WKB
Definition: ogr_core.h:381
@ wkbMultiPolygon
GeometryCollection of Polygons, standard WKB.
Definition: ogr_core.h:380
@ wkbMultiPoint
GeometryCollection of Points, standard WKB.
Definition: ogr_core.h:378
@ wkbMultiLineStringM
ISO SQL/MM Part 3.
Definition: ogr_core.h:418
@ wkbMultiCurveZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:442
@ wkbMultiPoint25D
2.5D extension as per 99-402
Definition: ogr_core.h:455
@ wkbNone
non-standard, for pure attribute records
Definition: ogr_core.h:400
@ wkbMultiPointM
ISO SQL/MM Part 3.
Definition: ogr_core.h:417
@ wkbCircularStringZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:439
@ wkbCurvePolygonZ
wkbCurvePolygon with Z component.
Definition: ogr_core.h:405
@ wkbCompoundCurveZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:440
@ wkbTriangleZ
ISO SQL/MM Part 3.
Definition: ogr_core.h:412
@ wkbPointZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:432
@ wkbCurvePolygon
planar surface, defined by 1 exterior boundary and zero or more interior boundaries,...
Definition: ogr_core.h:387
@ wkbLineStringZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:433
@ wkbMultiSurface
GeometryCollection of Surfaces, ISO SQL/MM Part 3.
Definition: ogr_core.h:391
@ wkbMultiPolygonM
ISO SQL/MM Part 3.
Definition: ogr_core.h:419
@ wkbCurveZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:444
@ wkbLineString25D
2.5D extension as per 99-402
Definition: ogr_core.h:453
@ wkbMultiLineStringZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:436
@ wkbPolyhedralSurfaceZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:446
@ wkbGeometryCollectionZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:438
@ wkbTriangleZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:448
@ wkbGeometryCollectionM
ISO SQL/MM Part 3.
Definition: ogr_core.h:420
@ wkbCurveM
ISO SQL/MM Part 3.
Definition: ogr_core.h:426
@ wkbMultiLineString25D
2.5D extension as per 99-402
Definition: ogr_core.h:456
@ wkbTriangleM
ISO SQL/MM Part 3.
Definition: ogr_core.h:430
@ wkbMultiPolygonZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:437
@ wkbTINM
ISO SQL/MM Part 3.
Definition: ogr_core.h:429
@ wkbCurveZ
wkbCurve with Z component.
Definition: ogr_core.h:408
@ wkbCurvePolygonZM
ISO SQL/MM Part 3.
Definition: ogr_core.h:441
@ wkbMultiCurve
GeometryCollection of Curves, ISO SQL/MM Part 3.
Definition: ogr_core.h:390
@ wkbCompoundCurveZ
wkbCompoundCurve with Z component.
Definition: ogr_core.h:404
@ wkbMultiSurfaceZ
wkbMultiSurface with Z component.
Definition: ogr_core.h:407
OGRwkbGeometryType OGR_GT_SetModifier(OGRwkbGeometryType eType, int bSetZ, int bSetM)
Returns a XY, XYZ, XYM or XYZM geometry type depending on parameter.
Definition: ogrgeometry.cpp:6880
#define OGRERR_CORRUPT_DATA
Corrupt data.
Definition: ogr_core.h:348
ogr_style_tool_param_label_id
List of parameters for use with OGRStyleLabel.
Definition: ogr_core.h:1017
@ OGRSTLabelUnderline
Underline.
Definition: ogr_core.h:1031
@ OGRSTLabelPriority
Priority.
Definition: ogr_core.h:1032
@ OGRSTLabelAdjVert
OBSOLETE; do not use.
Definition: ogr_core.h:1036
@ OGRSTLabelBold
Bold.
Definition: ogr_core.h:1029
@ OGRSTLabelStrikeout
Strike out.
Definition: ogr_core.h:1033
@ OGRSTLabelBColor
Background color.
Definition: ogr_core.h:1023
@ OGRSTLabelPlacement
Placement.
Definition: ogr_core.h:1024
@ OGRSTLabelPerp
Perpendicular.
Definition: ogr_core.h:1028
@ OGRSTLabelOColor
Outline color.
Definition: ogr_core.h:1038
@ OGRSTLabelDx
Dx.
Definition: ogr_core.h:1026
@ OGRSTLabelHColor
Highlight color.
Definition: ogr_core.h:1037
@ OGRSTLabelItalic
Italic.
Definition: ogr_core.h:1030
@ OGRSTLabelTextString
Text string.
Definition: ogr_core.h:1020
@ OGRSTLabelSize
Size.
Definition: ogr_core.h:1019
@ OGRSTLabelAngle
Angle.
Definition: ogr_core.h:1021
@ OGRSTLabelFColor
Foreground color.
Definition: ogr_core.h:1022
@ OGRSTLabelDy
Dy.
Definition: ogr_core.h:1027
@ OGRSTLabelFontName
Font name.
Definition: ogr_core.h:1018
@ OGRSTLabelStretch
Stretch.
Definition: ogr_core.h:1034
@ OGRSTLabelAnchor
Anchor.
Definition: ogr_core.h:1025
@ OGRSTLabelAdjHor
OBSOLETE; do not use.
Definition: ogr_core.h:1035
ogr_style_tool_units_id
List of units supported by OGRStyleTools.
Definition: ogr_core.h:945
@ OGRSTUGround
Ground unit.
Definition: ogr_core.h:946
@ OGRSTUMM
Millimeter.
Definition: ogr_core.h:949
@ OGRSTUInches
Inch.
Definition: ogr_core.h:951
@ OGRSTUCM
Centimeter.
Definition: ogr_core.h:950
@ OGRSTUPoints
Points.
Definition: ogr_core.h:948
@ OGRSTUPixel
Pixel.
Definition: ogr_core.h:947
int OGR_GT_IsSubClassOf(OGRwkbGeometryType eType, OGRwkbGeometryType eSuperType)
Returns if a type is a subclass of another one.
Definition: ogrgeometry.cpp:6907
enum ogr_style_tool_class_id OGRSTClassId
OGRStyleTool derived class types (returned by GetType()).
#define OGRERR_NON_EXISTING_FEATURE
Non existing feature.
Definition: ogr_core.h:352
const char * OGRGeometryTypeToName(OGRwkbGeometryType eType)
Fetch a human readable name corresponding to an OGRwkbGeometryType value.
Definition: ogrgeometry.cpp:2535
enum ogr_style_tool_units_id OGRSTUnitId
List of units supported by OGRStyleTools.
#define OGRERR_INVALID_HANDLE
Invalid handle.
Definition: ogr_core.h:351
enum ogr_style_tool_param_brush_id OGRSTBrushParam
List of parameters for use with OGRStyleBrush.
enum ogr_style_tool_param_label_id OGRSTLabelParam
List of parameters for use with OGRStyleLabel.
#define OGRERR_NOT_ENOUGH_DATA
Not enough data to deserialize.
Definition: ogr_core.h:344
int OGRErr
Type for a OGR error.
Definition: ogr_core.h:341
int OGR_GET_MS(float fSec)
Return the number of milliseconds from a datetime with decimal seconds.
Definition: ogr_core.h:856
ogr_style_tool_param_brush_id
List of parameters for use with OGRStyleBrush.
Definition: ogr_core.h:976
@ OGRSTBrushAngle
Angle.
Definition: ogr_core.h:980
@ OGRSTBrushId
Id.
Definition: ogr_core.h:979
@ OGRSTBrushPriority
Priority.
Definition: ogr_core.h:984
@ OGRSTBrushBColor
Background color.
Definition: ogr_core.h:978
@ OGRSTBrushSize
Size.
Definition: ogr_core.h:981
@ OGRSTBrushDy
Dy.
Definition: ogr_core.h:983
@ OGRSTBrushFColor
Foreground color.
Definition: ogr_core.h:977
@ OGRSTBrushDx
Dx.
Definition: ogr_core.h:982
OGRwkbGeometryType OGR_GT_GetCollection(OGRwkbGeometryType eType)
Returns the collection type that can contain the passed geometry type.
Definition: ogrgeometry.cpp:6971
OGRwkbGeometryType OGR_GT_SetM(OGRwkbGeometryType eType)
Returns the measured geometry type corresponding to the passed geometry type.
Definition: ogrgeometry.cpp:6853
ogr_style_tool_class_id
OGRStyleTool derived class types (returned by GetType()).
Definition: ogr_core.h:932
@ OGRSTCBrush
Brush.
Definition: ogr_core.h:935
@ OGRSTCVector
Vector.
Definition: ogr_core.h:938
@ OGRSTCNone
None.
Definition: ogr_core.h:933
@ OGRSTCLabel
Label.
Definition: ogr_core.h:937
@ OGRSTCPen
Pen.
Definition: ogr_core.h:934
@ OGRSTCSymbol
Symbol.
Definition: ogr_core.h:936
OGRwkbGeometryType OGR_GT_Flatten(OGRwkbGeometryType eType)
Returns the 2D geometry type corresponding to the passed geometry type.
Definition: ogrgeometry.cpp:6759
ogr_style_tool_param_pen_id
List of parameters for use with OGRStylePen.
Definition: ogr_core.h:958
@ OGRSTPenId
Id.
Definition: ogr_core.h:962
@ OGRSTPenCap
Cap.
Definition: ogr_core.h:964
@ OGRSTPenPerOffset
Perpendicular offset.
Definition: ogr_core.h:963
@ OGRSTPenWidth
Width.
Definition: ogr_core.h:960
@ OGRSTPenColor
Color.
Definition: ogr_core.h:959
@ OGRSTPenJoin
Join.
Definition: ogr_core.h:965
@ OGRSTPenPriority
Priority.
Definition: ogr_core.h:966
@ OGRSTPenPattern
Pattern.
Definition: ogr_core.h:961
int OGR_GT_IsNonLinear(OGRwkbGeometryType)
Return if a geometry type is a non-linear geometry type.
Definition: ogrgeometry.cpp:7161
#define OGRERR_UNSUPPORTED_SRS
Unsupported SRS.
Definition: ogr_core.h:350
int OGR_GT_HasZ(OGRwkbGeometryType eType)
Return if the geometry type is a 3D geometry type.
Definition: ogrgeometry.cpp:6784
OGRFieldDomainSplitPolicy
Split policy for field domains.
Definition: ogr_core.h:1083
@ OFDSP_DEFAULT_VALUE
Default value.
Definition: ogr_core.h:1085
@ OFDSP_DUPLICATE
Duplicate.
Definition: ogr_core.h:1087
@ OFDSP_GEOMETRY_RATIO
New values are computed by the ratio of their area/length compared to the area/length of the original...
Definition: ogr_core.h:1089
Associates a code and a value.
Definition: ogr_core.h:1053
char * pszValue
Value.
Definition: ogr_core.h:1058
char * pszCode
Code.
Definition: ogr_core.h:1055
OGRFeature field attribute value union.
Definition: ogr_core.h:802