PostGIS  3.0.6dev-r@@SVN_REVISION@@

◆ gserialized2_peek_first_point()

int gserialized2_peek_first_point ( const GSERIALIZED g,
POINT4D out_point 
)

Definition at line 548 of file gserialized2.c.

549 {
550  uint8_t *geometry_start = gserialized2_get_geometry_p(g);
551 
552  uint32_t isEmpty = (((uint32_t *)geometry_start)[1]) == 0;
553  if (isEmpty)
554  {
555  return LW_FAILURE;
556  }
557 
558  uint32_t type = (((uint32_t *)geometry_start)[0]);
559  /* Setup double_array_start depending on the geometry type */
560  double *double_array_start = NULL;
561  switch (type)
562  {
563  case (POINTTYPE):
564  /* For points we only need to jump over the type and npoints 32b ints */
565  double_array_start = (double *)(geometry_start + 2 * sizeof(uint32_t));
566  break;
567 
568  default:
569  lwerror("%s is currently not implemented for type %d", __func__, type);
570  return LW_FAILURE;
571  }
572 
573  gserialized2_copy_point(double_array_start, g->gflags, out_point);
574  return LW_SUCCESS;
575 }
static uint8_t * gserialized2_get_geometry_p(const GSERIALIZED *g)
Definition: gserialized2.c:104
static void gserialized2_copy_point(double *dptr, lwflags_t flags, POINT4D *out_point)
Definition: gserialized2.c:531
#define LW_FAILURE
Definition: liblwgeom.h:110
#define LW_SUCCESS
Definition: liblwgeom.h:111
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
Definition: liblwgeom.h:116
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
Definition: lwutil.c:190
type
Definition: ovdump.py:42
uint8_t gflags
Definition: liblwgeom.h:432

References GSERIALIZED::gflags, gserialized2_copy_point(), gserialized2_get_geometry_p(), LW_FAILURE, LW_SUCCESS, lwerror(), POINTTYPE, and ovdump::type.

Referenced by gserialized_peek_first_point(), and peek2_point_helper().

Here is the call graph for this function:
Here is the caller graph for this function: