GDAL
ogr_wkb.h
1/******************************************************************************
2 *
3 * Project: OGR
4 * Purpose: WKB geometry related methods
5 * Author: Even Rouault <even dot rouault at spatialys.com>
6 *
7 ******************************************************************************
8 * Copyright (c) 2022, Even Rouault <even dot rouault at spatialys.com>
9 *
10 * SPDX-License-Identifier: MIT
11 ****************************************************************************/
12
13#ifndef OGR_WKB_H_INCLUDED
14#define OGR_WKB_H_INCLUDED
15
16#include <cstdint>
17
18#include "cpl_port.h"
19#include "ogr_core.h"
20
21#include <vector>
22
23bool CPL_DLL OGRWKBGetGeomType(const GByte *pabyWkb, size_t nWKBSize,
24 bool &bNeedSwap, uint32_t &nType);
25bool OGRWKBPolygonGetArea(const GByte *&pabyWkb, size_t &nWKBSize,
26 double &dfArea);
27bool OGRWKBMultiPolygonGetArea(const GByte *&pabyWkb, size_t &nWKBSize,
28 double &dfArea);
29
30bool CPL_DLL OGRWKBGetBoundingBox(const GByte *pabyWkb, size_t nWKBSize,
31 OGREnvelope3D &sEnvelope);
32
33bool CPL_DLL OGRWKBGetBoundingBox(const GByte *pabyWkb, size_t nWKBSize,
34 OGREnvelope &sEnvelope);
35
36bool CPL_DLL OGRWKBIntersectsPessimistic(const GByte *pabyWkb, size_t nWKBSize,
37 const OGREnvelope &sEnvelope);
38
39void CPL_DLL OGRWKBFixupCounterClockWiseExternalRing(GByte *pabyWkb,
40 size_t nWKBSize);
41
50const GByte CPL_DLL *WKBFromEWKB(GByte *pabyEWKB, size_t nEWKBSize,
51 size_t &nWKBSizeOut, int *pnSRIDOut);
52
54class CPL_DLL OGRWKBPointUpdater
55{
56 public:
58 virtual ~OGRWKBPointUpdater() = default;
59
61 virtual bool update(bool bNeedSwap, void *x, void *y, void *z, void *m) = 0;
62};
63
64bool CPL_DLL OGRWKBUpdatePoints(GByte *pabyWkb, size_t nWKBSize,
65 OGRWKBPointUpdater &oUpdater);
66
69{
70#ifdef OGR_WKB_TRANSFORM_ALL_AT_ONCE
71 std::vector<bool> abNeedSwap{};
72 std::vector<bool> abIsEmpty{};
73 std::vector<void *> apdfX{};
74 std::vector<void *> apdfY{};
75 std::vector<void *> apdfZ{};
76 std::vector<void *> apdfM{};
77 std::vector<double> adfX{};
78 std::vector<double> adfY{};
79 std::vector<double> adfZ{};
80 std::vector<double> adfM{};
81 std::vector<int> anErrorCodes{};
82
83 void clear();
84#endif
85};
86
88bool CPL_DLL OGRWKBTransform(GByte *pabyWkb, size_t nWKBSize,
91 OGREnvelope3D &sEnvelope);
92
93/************************************************************************/
94/* OGRAppendBuffer */
95/************************************************************************/
96
98class CPL_DLL OGRAppendBuffer
99{
100 public:
103
106
110 inline void *GetPtrForNewBytes(size_t nItemSize)
111 {
112 if (nItemSize > m_nCapacity - m_nSize)
113 {
114 if (!Grow(nItemSize))
115 return nullptr;
116 }
117 void *pRet = static_cast<GByte *>(m_pRawBuffer) + m_nSize;
118 m_nSize += nItemSize;
119 return pRet;
120 }
121
123 inline size_t GetSize() const
124 {
125 return m_nSize;
126 }
127
128 protected:
130 size_t m_nCapacity = 0;
131
133 size_t m_nSize = 0;
134
136 void *m_pRawBuffer = nullptr;
137
141 virtual bool Grow(size_t nItemSize) = 0;
142
143 private:
144 OGRAppendBuffer(const OGRAppendBuffer &) = delete;
145 OGRAppendBuffer &operator=(const OGRAppendBuffer &) = delete;
146};
147
148/************************************************************************/
149/* OGRWKTToWKBTranslator */
150/************************************************************************/
151
154{
155 OGRAppendBuffer &m_oAppendBuffer;
156 bool m_bCanUseStrtod = false;
157
158 public:
160 explicit OGRWKTToWKBTranslator(OGRAppendBuffer &oAppendBuffer);
161
169 size_t TranslateWKT(void *pabyWKTStart, size_t nLength,
170 bool bCanAlterByteAfter);
171};
172
173#endif // OGR_WKB_H_INCLUDED
Append buffer that can be grown dynamically.
Definition ogr_wkb.h:99
size_t GetSize() const
Return the number of valid bytes in the buffer.
Definition ogr_wkb.h:123
void * GetPtrForNewBytes(size_t nItemSize)
Return the pointer at which nItemSize bytes can be written, or nullptr in case of error.
Definition ogr_wkb.h:110
virtual bool Grow(size_t nItemSize)=0
Extend the capacity of m_pRawBuffer to be at least m_nSize + nItemSize large.
virtual ~OGRAppendBuffer()
Destructor.
OGRAppendBuffer()
Constructor.
Interface for transforming between coordinate systems.
Definition ogr_spatialref.h:773
Simple container for a bounding region in 3D.
Definition ogr_core.h:200
Simple container for a bounding region (rectangle)
Definition ogr_core.h:45
Object to update point coordinates in a WKB geometry.
Definition ogr_wkb.h:55
virtual bool update(bool bNeedSwap, void *x, void *y, void *z, void *m)=0
Update method.
Translate WKT geometry to WKB geometry and append it to a buffer.
Definition ogr_wkb.h:154
Core portability definitions for CPL.
unsigned char GByte
Unsigned byte type.
Definition cpl_port.h:169
Core portability services for cross-platform OGR code.
Transformation cache.
Definition ogr_wkb.h:69