PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ _lwt_UpdateEdgeRingSideFace()

static int _lwt_UpdateEdgeRingSideFace ( LWT_TOPOLOGY topo,
LWT_EDGERING ring,
LWT_ELEMID  face 
)
static

Definition at line 6501 of file lwgeom_topo.c.

6503 {
6504  LWT_ISO_EDGE *forward_edges = NULL;
6505  int forward_edges_count = 0;
6506  LWT_ISO_EDGE *backward_edges = NULL;
6507  int backward_edges_count = 0;
6508  int i, ret;
6509 
6510  /* Make a list of forward_edges and backward_edges */
6511 
6512  forward_edges = lwalloc(sizeof(LWT_ISO_EDGE) * ring->size);
6513  forward_edges_count = 0;
6514  backward_edges = lwalloc(sizeof(LWT_ISO_EDGE) * ring->size);
6515  backward_edges_count = 0;
6516 
6517  for ( i=0; i<ring->size; ++i )
6518  {
6519  LWT_EDGERING_ELEM *elem = ring->elems[i];
6520  LWT_ISO_EDGE *edge = elem->edge;
6521  LWT_ELEMID id = edge->edge_id;
6522  if ( elem->left )
6523  {
6524  LWDEBUGF(3, "Forward edge %d is %d", forward_edges_count, id);
6525  forward_edges[forward_edges_count].edge_id = id;
6526  forward_edges[forward_edges_count++].face_left = face;
6527  edge->face_left = face;
6528  }
6529  else
6530  {
6531  LWDEBUGF(3, "Backward edge %d is %d", forward_edges_count, id);
6532  backward_edges[backward_edges_count].edge_id = id;
6533  backward_edges[backward_edges_count++].face_right = face;
6534  edge->face_right = face;
6535  }
6536  }
6537 
6538  /* Update forward edges */
6539  if ( forward_edges_count )
6540  {
6541  ret = lwt_be_updateEdgesById(topo, forward_edges,
6542  forward_edges_count,
6544  if ( ret == -1 )
6545  {
6546  lwfree( forward_edges );
6547  lwfree( backward_edges );
6548  lwerror("Backend error: %s", lwt_be_lastErrorMessage(topo->be_iface));
6549  return -1;
6550  }
6551  if ( ret != forward_edges_count )
6552  {
6553  lwfree( forward_edges );
6554  lwfree( backward_edges );
6555  lwerror("Unexpected error: %d edges updated when expecting %d (forward)",
6556  ret, forward_edges_count);
6557  return -1;
6558  }
6559  }
6560 
6561  /* Update backward edges */
6562  if ( backward_edges_count )
6563  {
6564  ret = lwt_be_updateEdgesById(topo, backward_edges,
6565  backward_edges_count,
6567  if ( ret == -1 )
6568  {
6569  lwfree( forward_edges );
6570  lwfree( backward_edges );
6571  lwerror("Backend error: %s", lwt_be_lastErrorMessage(topo->be_iface));
6572  return -1;
6573  }
6574  if ( ret != backward_edges_count )
6575  {
6576  lwfree( forward_edges );
6577  lwfree( backward_edges );
6578  lwerror("Unexpected error: %d edges updated when expecting %d (backward)",
6579  ret, backward_edges_count);
6580  return -1;
6581  }
6582  }
6583 
6584  lwfree( forward_edges );
6585  lwfree( backward_edges );
6586 
6587  return 0;
6588 }
void lwfree(void *mem)
Definition: lwutil.c:242
void * lwalloc(size_t size)
Definition: lwutil.c:227
#define LWT_COL_EDGE_FACE_RIGHT
LWT_INT64 LWT_ELEMID
Identifier of topology element.
#define LWT_COL_EDGE_FACE_LEFT
#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
const char * lwt_be_lastErrorMessage(const LWT_BE_IFACE *be)
Definition: lwgeom_topo.c:119
static int lwt_be_updateEdgesById(LWT_TOPOLOGY *topo, const LWT_ISO_EDGE *edges, int numedges, int upd_fields)
Definition: lwgeom_topo.c:299
LWT_ISO_EDGE * edge
Definition: lwgeom_topo.c:6313
LWT_EDGERING_ELEM ** elems
Definition: lwgeom_topo.c:6323
LWT_ELEMID face_right
LWT_ELEMID face_left
LWT_ELEMID edge_id
const LWT_BE_IFACE * be_iface

References LWT_TOPOLOGY_T::be_iface, LWT_EDGERING_ELEM_T::edge, LWT_ISO_EDGE::edge_id, LWT_EDGERING_T::elems, LWT_ISO_EDGE::face_left, LWT_ISO_EDGE::face_right, LWT_EDGERING_ELEM_T::left, lwalloc(), LWDEBUGF, lwerror(), lwfree(), lwt_be_lastErrorMessage(), lwt_be_updateEdgesById(), LWT_COL_EDGE_FACE_LEFT, LWT_COL_EDGE_FACE_RIGHT, and LWT_EDGERING_T::size.

Referenced by _lwt_RegisterFaceOnEdgeSide(), and lwt_Polygonize().

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