PostGIS  2.3.7dev-r@@SVN_REVISION@@
CIRC_NODE* lwgeom_calculate_circ_tree ( const LWGEOM lwgeom)

Definition at line 925 of file lwgeodetic_tree.c.

References COLLECTIONTYPE, LINETYPE, lwcollection_calculate_circ_tree(), lwerror(), lwgeom_is_empty(), lwline_calculate_circ_tree(), lwpoint_calculate_circ_tree(), lwpoly_calculate_circ_tree(), lwtype_name(), MULTILINETYPE, MULTIPOINTTYPE, MULTIPOLYGONTYPE, POINTTYPE, POLYGONTYPE, and LWGEOM::type.

Referenced by CircTreeBuilder(), geography_distance_cache_tolerance(), geography_tree_distance(), lwcollection_calculate_circ_tree(), test_tree_circ_distance(), and test_tree_circ_distance_threshold().

926 {
927  if ( lwgeom_is_empty(lwgeom) )
928  return NULL;
929 
930  switch ( lwgeom->type )
931  {
932  case POINTTYPE:
933  return lwpoint_calculate_circ_tree((LWPOINT*)lwgeom);
934  case LINETYPE:
935  return lwline_calculate_circ_tree((LWLINE*)lwgeom);
936  case POLYGONTYPE:
937  return lwpoly_calculate_circ_tree((LWPOLY*)lwgeom);
938  case MULTIPOINTTYPE:
939  case MULTILINETYPE:
940  case MULTIPOLYGONTYPE:
941  case COLLECTIONTYPE:
943  default:
944  lwerror("Unable to calculate spherical index tree for type %s", lwtype_name(lwgeom->type));
945  return NULL;
946  }
947 
948 }
#define LINETYPE
Definition: liblwgeom.h:85
static CIRC_NODE * lwpoint_calculate_circ_tree(const LWPOINT *lwpoint)
#define POLYGONTYPE
Definition: liblwgeom.h:86
#define MULTIPOINTTYPE
Definition: liblwgeom.h:87
const char * lwtype_name(uint8_t type)
Return the type name string associated with a type number (e.g.
Definition: lwutil.c:216
#define MULTIPOLYGONTYPE
Definition: liblwgeom.h:89
static CIRC_NODE * lwline_calculate_circ_tree(const LWLINE *lwline)
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
Definition: liblwgeom.h:84
uint8_t type
Definition: liblwgeom.h:395
static CIRC_NODE * lwpoly_calculate_circ_tree(const LWPOLY *lwpoly)
static CIRC_NODE * lwcollection_calculate_circ_tree(const LWCOLLECTION *lwcol)
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:1310
#define MULTILINETYPE
Definition: liblwgeom.h:88
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
Definition: lwutil.c:102
#define COLLECTIONTYPE
Definition: liblwgeom.h:90

Here is the call graph for this function:

Here is the caller graph for this function: