LCOV - code coverage report
Current view: top level - ogr/ogrsf_frmts/flatgeobuf - feature_generated.h (source / functions) Hit Total Coverage
Test: gdal_filtered.info Lines: 123 124 99.2 %
Date: 2025-01-18 12:42:00 Functions: 33 33 100.0 %

          Line data    Source code
       1             : // automatically generated by the FlatBuffers compiler, do not modify
       2             : 
       3             : #ifndef FLATBUFFERS_GENERATED_FEATURE_FLATGEOBUF_H_
       4             : #define FLATBUFFERS_GENERATED_FEATURE_FLATGEOBUF_H_
       5             : 
       6             : #include "flatbuffers/flatbuffers.h"
       7             : 
       8             : // Ensure the included flatbuffers.h is the same version as when this file was
       9             : // generated, otherwise it may not be compatible.
      10             : static_assert(FLATBUFFERS_VERSION_MAJOR == 2 &&
      11             :                   FLATBUFFERS_VERSION_MINOR == 0 &&
      12             :                   FLATBUFFERS_VERSION_REVISION == 6,
      13             :               "Non-compatible flatbuffers version included");
      14             : 
      15             : #include "header_generated.h"
      16             : 
      17             : namespace FlatGeobuf
      18             : {
      19             : 
      20             : struct Geometry;
      21             : struct GeometryBuilder;
      22             : 
      23             : struct Feature;
      24             : struct FeatureBuilder;
      25             : 
      26             : struct Geometry FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table
      27             : {
      28             :     typedef GeometryBuilder Builder;
      29             : 
      30             :     enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE
      31             :     {
      32             :         VT_ENDS = 4,
      33             :         VT_XY = 6,
      34             :         VT_Z = 8,
      35             :         VT_M = 10,
      36             :         VT_T = 12,
      37             :         VT_TM = 14,
      38             :         VT_TYPE = 16,
      39             :         VT_PARTS = 18
      40             :     };
      41             : 
      42        1290 :     const flatbuffers::Vector<uint32_t> *ends() const
      43             :     {
      44        1290 :         return GetPointer<const flatbuffers::Vector<uint32_t> *>(VT_ENDS);
      45             :     }
      46             : 
      47        1578 :     const flatbuffers::Vector<double> *xy() const
      48             :     {
      49        1578 :         return GetPointer<const flatbuffers::Vector<double> *>(VT_XY);
      50             :     }
      51             : 
      52         988 :     const flatbuffers::Vector<double> *z() const
      53             :     {
      54         988 :         return GetPointer<const flatbuffers::Vector<double> *>(VT_Z);
      55             :     }
      56             : 
      57         971 :     const flatbuffers::Vector<double> *m() const
      58             :     {
      59         971 :         return GetPointer<const flatbuffers::Vector<double> *>(VT_M);
      60             :     }
      61             : 
      62         829 :     const flatbuffers::Vector<double> *t() const
      63             :     {
      64         829 :         return GetPointer<const flatbuffers::Vector<double> *>(VT_T);
      65             :     }
      66             : 
      67         829 :     const flatbuffers::Vector<uint64_t> *tm() const
      68             :     {
      69         829 :         return GetPointer<const flatbuffers::Vector<uint64_t> *>(VT_TM);
      70             :     }
      71             : 
      72          86 :     FlatGeobuf::GeometryType type() const
      73             :     {
      74             :         return static_cast<FlatGeobuf::GeometryType>(
      75          86 :             GetField<uint8_t>(VT_TYPE, 0));
      76             :     }
      77             : 
      78             :     const flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Geometry>> *
      79        1722 :     parts() const
      80             :     {
      81             :         return GetPointer<const flatbuffers::Vector<
      82        1722 :             flatbuffers::Offset<FlatGeobuf::Geometry>> *>(VT_PARTS);
      83             :     }
      84             : 
      85         829 :     bool Verify(flatbuffers::Verifier &verifier) const
      86             :     {
      87        1658 :         return VerifyTableStart(verifier) && VerifyOffset(verifier, VT_ENDS) &&
      88         829 :                verifier.VerifyVector(ends()) && VerifyOffset(verifier, VT_XY) &&
      89         829 :                verifier.VerifyVector(xy()) && VerifyOffset(verifier, VT_Z) &&
      90         829 :                verifier.VerifyVector(z()) && VerifyOffset(verifier, VT_M) &&
      91         829 :                verifier.VerifyVector(m()) && VerifyOffset(verifier, VT_T) &&
      92         829 :                verifier.VerifyVector(t()) && VerifyOffset(verifier, VT_TM) &&
      93         829 :                verifier.VerifyVector(tm()) &&
      94         829 :                VerifyField<uint8_t>(verifier, VT_TYPE, 1) &&
      95         829 :                VerifyOffset(verifier, VT_PARTS) &&
      96         829 :                verifier.VerifyVector(parts()) &&
      97        1658 :                verifier.VerifyVectorOfTables(parts()) && verifier.EndTable();
      98             :     }
      99             : };
     100             : 
     101             : struct GeometryBuilder
     102             : {
     103             :     typedef Geometry Table;
     104             :     flatbuffers::FlatBufferBuilder &fbb_;
     105             :     flatbuffers::uoffset_t start_;
     106             : 
     107         313 :     void add_ends(flatbuffers::Offset<flatbuffers::Vector<uint32_t>> ends)
     108             :     {
     109         313 :         fbb_.AddOffset(Geometry::VT_ENDS, ends);
     110         313 :     }
     111             : 
     112         313 :     void add_xy(flatbuffers::Offset<flatbuffers::Vector<double>> xy)
     113             :     {
     114         313 :         fbb_.AddOffset(Geometry::VT_XY, xy);
     115         313 :     }
     116             : 
     117         313 :     void add_z(flatbuffers::Offset<flatbuffers::Vector<double>> z)
     118             :     {
     119         313 :         fbb_.AddOffset(Geometry::VT_Z, z);
     120         313 :     }
     121             : 
     122         313 :     void add_m(flatbuffers::Offset<flatbuffers::Vector<double>> m)
     123             :     {
     124         313 :         fbb_.AddOffset(Geometry::VT_M, m);
     125         313 :     }
     126             : 
     127         313 :     void add_t(flatbuffers::Offset<flatbuffers::Vector<double>> t)
     128             :     {
     129         313 :         fbb_.AddOffset(Geometry::VT_T, t);
     130         313 :     }
     131             : 
     132         313 :     void add_tm(flatbuffers::Offset<flatbuffers::Vector<uint64_t>> tm)
     133             :     {
     134         313 :         fbb_.AddOffset(Geometry::VT_TM, tm);
     135         313 :     }
     136             : 
     137         313 :     void add_type(FlatGeobuf::GeometryType type)
     138             :     {
     139         313 :         fbb_.AddElement<uint8_t>(Geometry::VT_TYPE, static_cast<uint8_t>(type),
     140             :                                  0);
     141         313 :     }
     142             : 
     143             :     void
     144         313 :     add_parts(flatbuffers::Offset<
     145             :               flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Geometry>>>
     146             :                   parts)
     147             :     {
     148         313 :         fbb_.AddOffset(Geometry::VT_PARTS, parts);
     149         313 :     }
     150             : 
     151         313 :     explicit GeometryBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb)
     152             :     {
     153         313 :         start_ = fbb_.StartTable();
     154         313 :     }
     155             : 
     156         313 :     flatbuffers::Offset<Geometry> Finish()
     157             :     {
     158         313 :         const auto end = fbb_.EndTable(start_);
     159         313 :         auto o = flatbuffers::Offset<Geometry>(end);
     160         313 :         return o;
     161             :     }
     162             : };
     163             : 
     164         313 : inline flatbuffers::Offset<Geometry> CreateGeometry(
     165             :     flatbuffers::FlatBufferBuilder &_fbb,
     166             :     flatbuffers::Offset<flatbuffers::Vector<uint32_t>> ends = 0,
     167             :     flatbuffers::Offset<flatbuffers::Vector<double>> xy = 0,
     168             :     flatbuffers::Offset<flatbuffers::Vector<double>> z = 0,
     169             :     flatbuffers::Offset<flatbuffers::Vector<double>> m = 0,
     170             :     flatbuffers::Offset<flatbuffers::Vector<double>> t = 0,
     171             :     flatbuffers::Offset<flatbuffers::Vector<uint64_t>> tm = 0,
     172             :     FlatGeobuf::GeometryType type = FlatGeobuf::GeometryType::Unknown,
     173             :     flatbuffers::Offset<
     174             :         flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Geometry>>>
     175             :         parts = 0)
     176             : {
     177         313 :     GeometryBuilder builder_(_fbb);
     178         313 :     builder_.add_parts(parts);
     179         313 :     builder_.add_tm(tm);
     180         313 :     builder_.add_t(t);
     181         313 :     builder_.add_m(m);
     182         313 :     builder_.add_z(z);
     183         313 :     builder_.add_xy(xy);
     184         313 :     builder_.add_ends(ends);
     185         313 :     builder_.add_type(type);
     186         626 :     return builder_.Finish();
     187             : }
     188             : 
     189         313 : inline flatbuffers::Offset<Geometry> CreateGeometryDirect(
     190             :     flatbuffers::FlatBufferBuilder &_fbb,
     191             :     const std::vector<uint32_t> *ends = nullptr,
     192             :     const std::vector<double> *xy = nullptr,
     193             :     const std::vector<double> *z = nullptr,
     194             :     const std::vector<double> *m = nullptr,
     195             :     const std::vector<double> *t = nullptr,
     196             :     const std::vector<uint64_t> *tm = nullptr,
     197             :     FlatGeobuf::GeometryType type = FlatGeobuf::GeometryType::Unknown,
     198             :     const std::vector<flatbuffers::Offset<FlatGeobuf::Geometry>> *parts =
     199             :         nullptr)
     200             : {
     201         313 :     auto ends__ = ends ? _fbb.CreateVector<uint32_t>(*ends) : 0;
     202         313 :     auto xy__ = xy ? _fbb.CreateVector<double>(*xy) : 0;
     203         313 :     auto z__ = z ? _fbb.CreateVector<double>(*z) : 0;
     204         313 :     auto m__ = m ? _fbb.CreateVector<double>(*m) : 0;
     205         313 :     auto t__ = t ? _fbb.CreateVector<double>(*t) : 0;
     206         313 :     auto tm__ = tm ? _fbb.CreateVector<uint64_t>(*tm) : 0;
     207             :     auto parts__ =
     208             :         parts ? _fbb.CreateVector<flatbuffers::Offset<FlatGeobuf::Geometry>>(
     209          57 :                     *parts)
     210         313 :               : 0;
     211             :     return FlatGeobuf::CreateGeometry(_fbb, ends__, xy__, z__, m__, t__, tm__,
     212         626 :                                       type, parts__);
     213             : }
     214             : 
     215             : struct Feature FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table
     216             : {
     217             :     typedef FeatureBuilder Builder;
     218             : 
     219             :     enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE
     220             :     {
     221             :         VT_GEOMETRY = 4,
     222             :         VT_PROPERTIES = 6,
     223             :         VT_COLUMNS = 8
     224             :     };
     225             : 
     226        1422 :     const FlatGeobuf::Geometry *geometry() const
     227             :     {
     228        1422 :         return GetPointer<const FlatGeobuf::Geometry *>(VT_GEOMETRY);
     229             :     }
     230             : 
     231        1418 :     const flatbuffers::Vector<uint8_t> *properties() const
     232             :     {
     233        1418 :         return GetPointer<const flatbuffers::Vector<uint8_t> *>(VT_PROPERTIES);
     234             :     }
     235             : 
     236             :     const flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Column>> *
     237        1422 :     columns() const
     238             :     {
     239             :         return GetPointer<const flatbuffers::Vector<
     240        1422 :             flatbuffers::Offset<FlatGeobuf::Column>> *>(VT_COLUMNS);
     241             :     }
     242             : 
     243         711 :     bool Verify(flatbuffers::Verifier &verifier) const
     244             :     {
     245         711 :         return VerifyTableStart(verifier) &&
     246         711 :                VerifyOffset(verifier, VT_GEOMETRY) &&
     247         711 :                verifier.VerifyTable(geometry()) &&
     248         711 :                VerifyOffset(verifier, VT_PROPERTIES) &&
     249         711 :                verifier.VerifyVector(properties()) &&
     250         711 :                VerifyOffset(verifier, VT_COLUMNS) &&
     251         711 :                verifier.VerifyVector(columns()) &&
     252        1422 :                verifier.VerifyVectorOfTables(columns()) && verifier.EndTable();
     253             :     }
     254             : };
     255             : 
     256             : struct FeatureBuilder
     257             : {
     258             :     typedef Feature Table;
     259             :     flatbuffers::FlatBufferBuilder &fbb_;
     260             :     flatbuffers::uoffset_t start_;
     261             : 
     262         206 :     void add_geometry(flatbuffers::Offset<FlatGeobuf::Geometry> geometry)
     263             :     {
     264         206 :         fbb_.AddOffset(Feature::VT_GEOMETRY, geometry);
     265         206 :     }
     266             : 
     267             :     void
     268         206 :     add_properties(flatbuffers::Offset<flatbuffers::Vector<uint8_t>> properties)
     269             :     {
     270         206 :         fbb_.AddOffset(Feature::VT_PROPERTIES, properties);
     271         206 :     }
     272             : 
     273             :     void
     274         206 :     add_columns(flatbuffers::Offset<
     275             :                 flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Column>>>
     276             :                     columns)
     277             :     {
     278         206 :         fbb_.AddOffset(Feature::VT_COLUMNS, columns);
     279         206 :     }
     280             : 
     281         206 :     explicit FeatureBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb)
     282             :     {
     283         206 :         start_ = fbb_.StartTable();
     284         206 :     }
     285             : 
     286         206 :     flatbuffers::Offset<Feature> Finish()
     287             :     {
     288         206 :         const auto end = fbb_.EndTable(start_);
     289         206 :         auto o = flatbuffers::Offset<Feature>(end);
     290         206 :         return o;
     291             :     }
     292             : };
     293             : 
     294             : inline flatbuffers::Offset<Feature>
     295         206 : CreateFeature(flatbuffers::FlatBufferBuilder &_fbb,
     296             :               flatbuffers::Offset<FlatGeobuf::Geometry> geometry = 0,
     297             :               flatbuffers::Offset<flatbuffers::Vector<uint8_t>> properties = 0,
     298             :               flatbuffers::Offset<
     299             :                   flatbuffers::Vector<flatbuffers::Offset<FlatGeobuf::Column>>>
     300             :                   columns = 0)
     301             : {
     302         206 :     FeatureBuilder builder_(_fbb);
     303         206 :     builder_.add_columns(columns);
     304         206 :     builder_.add_properties(properties);
     305         206 :     builder_.add_geometry(geometry);
     306         412 :     return builder_.Finish();
     307             : }
     308             : 
     309         206 : inline flatbuffers::Offset<Feature> CreateFeatureDirect(
     310             :     flatbuffers::FlatBufferBuilder &_fbb,
     311             :     flatbuffers::Offset<FlatGeobuf::Geometry> geometry = 0,
     312             :     const std::vector<uint8_t> *properties = nullptr,
     313             :     const std::vector<flatbuffers::Offset<FlatGeobuf::Column>> *columns =
     314             :         nullptr)
     315             : {
     316             :     auto properties__ =
     317         206 :         properties ? _fbb.CreateVector<uint8_t>(*properties) : 0;
     318             :     auto columns__ =
     319             :         columns ? _fbb.CreateVector<flatbuffers::Offset<FlatGeobuf::Column>>(
     320           0 :                       *columns)
     321         206 :                 : 0;
     322         412 :     return FlatGeobuf::CreateFeature(_fbb, geometry, properties__, columns__);
     323             : }
     324             : 
     325             : inline const FlatGeobuf::Feature *GetFeature(const void *buf)
     326             : {
     327             :     return flatbuffers::GetRoot<FlatGeobuf::Feature>(buf);
     328             : }
     329             : 
     330             : inline const FlatGeobuf::Feature *GetSizePrefixedFeature(const void *buf)
     331             : {
     332             :     return flatbuffers::GetSizePrefixedRoot<FlatGeobuf::Feature>(buf);
     333             : }
     334             : 
     335         711 : inline bool VerifyFeatureBuffer(flatbuffers::Verifier &verifier)
     336             : {
     337         711 :     return verifier.VerifyBuffer<FlatGeobuf::Feature>(nullptr);
     338             : }
     339             : 
     340             : inline bool VerifySizePrefixedFeatureBuffer(flatbuffers::Verifier &verifier)
     341             : {
     342             :     return verifier.VerifySizePrefixedBuffer<FlatGeobuf::Feature>(nullptr);
     343             : }
     344             : 
     345             : inline void FinishFeatureBuffer(flatbuffers::FlatBufferBuilder &fbb,
     346             :                                 flatbuffers::Offset<FlatGeobuf::Feature> root)
     347             : {
     348             :     fbb.Finish(root);
     349             : }
     350             : 
     351             : inline void
     352             : FinishSizePrefixedFeatureBuffer(flatbuffers::FlatBufferBuilder &fbb,
     353             :                                 flatbuffers::Offset<FlatGeobuf::Feature> root)
     354             : {
     355             :     fbb.FinishSizePrefixed(root);
     356             : }
     357             : 
     358             : }  // namespace FlatGeobuf
     359             : 
     360             : #endif  // FLATBUFFERS_GENERATED_FEATURE_FLATGEOBUF_H_

Generated by: LCOV version 1.14