PostGIS  2.5.0dev-r@@SVN_REVISION@@

◆ lwgeom_count_vertices()

uint32_t lwgeom_count_vertices ( const LWGEOM geom)

Count the total number of vertices in any LWGEOM.

Count the total number of vertices in any LWGEOM.

TODO: Make sure the internal functions don't overflow

Definition at line 1234 of file lwgeom.c.

References CIRCSTRINGTYPE, COLLECTIONTYPE, COMPOUNDTYPE, CURVEPOLYTYPE, LINETYPE, lwcollection_count_vertices(), LWDEBUGF, lwerror(), lwgeom_is_empty(), lwline_count_vertices(), lwpoly_count_vertices(), lwtype_name(), MULTICURVETYPE, MULTILINETYPE, MULTIPOINTTYPE, MULTIPOLYGONTYPE, MULTISURFACETYPE, POINTTYPE, POLYGONTYPE, POLYHEDRALSURFACETYPE, TINTYPE, TRIANGLETYPE, LWGEOM::type, and LWCOLLECTION::type.

Referenced by _lwt_toposnap(), lwcollection_count_vertices(), lwcompound_get_lwpoint(), lwgeom_calculate_mbc(), lwgeom_needs_bbox(), LWGEOM_npoints(), LWGEOM_numpoints_linestring(), LWGEOM_pointn_linestring(), lwgeom_subdivide_recursive(), lwgeom_voronoi_diagram(), test_lwgeom_count_vertices(), test_lwpoly_construct_circle(), test_misc_count_vertices(), test_on_gser_lwgeom_count_vertices(), test_point_count(), and wkt_parser_curvepolygon_add_ring().

1235 {
1236  int result = 0;
1237 
1238  /* Null? Zero. */
1239  if( ! geom ) return 0;
1240 
1241  LWDEBUGF(4, "lwgeom_count_vertices got type %s",
1242  lwtype_name(geom->type));
1243 
1244  /* Empty? Zero. */
1245  if( lwgeom_is_empty(geom) ) return 0;
1246 
1247  switch (geom->type)
1248  {
1249  case POINTTYPE:
1250  result = 1;
1251  break;
1252  case TRIANGLETYPE:
1253  case CIRCSTRINGTYPE:
1254  case LINETYPE:
1255  result = lwline_count_vertices((LWLINE *)geom);
1256  break;
1257  case POLYGONTYPE:
1258  result = lwpoly_count_vertices((LWPOLY *)geom);
1259  break;
1260  case COMPOUNDTYPE:
1261  case CURVEPOLYTYPE:
1262  case MULTICURVETYPE:
1263  case MULTISURFACETYPE:
1264  case MULTIPOINTTYPE:
1265  case MULTILINETYPE:
1266  case MULTIPOLYGONTYPE:
1267  case POLYHEDRALSURFACETYPE:
1268  case TINTYPE:
1269  case COLLECTIONTYPE:
1270  result = lwcollection_count_vertices((LWCOLLECTION *)geom);
1271  break;
1272  default:
1273  lwerror("%s: unsupported input geometry type: %s",
1274  __func__, lwtype_name(geom->type));
1275  break;
1276  }
1277  LWDEBUGF(3, "counted %d vertices", result);
1278  return result;
1279 }
#define LINETYPE
Definition: liblwgeom.h:85
#define MULTICURVETYPE
Definition: liblwgeom.h:94
uint32_t lwcollection_count_vertices(LWCOLLECTION *col)
Definition: lwcollection.c:507
#define POLYGONTYPE
Definition: liblwgeom.h:86
#define CURVEPOLYTYPE
Definition: liblwgeom.h:93
#define COMPOUNDTYPE
Definition: liblwgeom.h:92
#define MULTIPOINTTYPE
Definition: liblwgeom.h:87
uint32_t lwline_count_vertices(LWLINE *line)
Definition: lwline.c:519
#define TRIANGLETYPE
Definition: liblwgeom.h:97
#define POLYHEDRALSURFACETYPE
Definition: liblwgeom.h:96
const char * lwtype_name(uint8_t type)
Return the type name string associated with a type number (e.g.
Definition: lwutil.c:218
uint32_t lwpoly_count_vertices(LWPOLY *poly)
Definition: lwpoly.c:425
#define TINTYPE
Definition: liblwgeom.h:98
int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members) ...
Definition: lwgeom.c:1392
#define MULTIPOLYGONTYPE
Definition: liblwgeom.h:89
#define MULTISURFACETYPE
Definition: liblwgeom.h:95
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
Definition: liblwgeom.h:84
uint8_t type
Definition: liblwgeom.h:398
#define CIRCSTRINGTYPE
Definition: liblwgeom.h:91
#define MULTILINETYPE
Definition: liblwgeom.h:88
#define LWDEBUGF(level, msg,...)
Definition: lwgeom_log.h:88
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
Definition: lwutil.c:190
#define COLLECTIONTYPE
Definition: liblwgeom.h:90
Here is the call graph for this function:
Here is the caller graph for this function: