PostGIS  3.0.6dev-r@@SVN_REVISION@@

◆ perform_cluster_within_distance_test()

static void perform_cluster_within_distance_test ( double  tolerance,
char **  wkt_inputs,
uint32_t  num_inputs,
char **  wkt_outputs,
uint32_t  num_outputs 
)
static

Definition at line 122 of file cu_geos_cluster.c.

123 {
124  LWGEOM** lw_results;
125  uint32_t num_clusters;
126 
127  LWGEOM** expected_outputs = WKTARRAY2LWGEOM(wkt_outputs, num_outputs);
128  LWGEOM** lw_inputs = WKTARRAY2LWGEOM(wkt_inputs, num_inputs);
129 
130  cluster_within_distance(lw_inputs, num_inputs, tolerance, &lw_results, &num_clusters);
131 
132  CU_ASSERT_EQUAL(num_outputs, num_clusters);
133 
134  assert_all_results_found(lw_results, num_clusters, expected_outputs, num_outputs);
135 
136  /* Cleanup */
137  uint32_t i;
138  for(i = 0; i < num_outputs; i++)
139  {
140  lwgeom_free(expected_outputs[i]);
141  lwgeom_free(lw_results[i]);
142  }
143  lwfree(lw_results);
144  lwfree(expected_outputs);
145  lwfree(lw_inputs);
146 }
static void assert_all_results_found(LWGEOM **results, size_t num_outputs, LWGEOM **expected, size_t num_expected_outputs)
static LWGEOM ** WKTARRAY2LWGEOM(char **wkt_array, size_t num_geoms)
int cluster_within_distance(LWGEOM **geoms, uint32_t num_geoms, double tolerance, LWGEOM ***clusterGeoms, uint32_t *num_clusters)
Takes an array of LWGEOM* and constructs an array of LWGEOM*, where each element in the constructed a...
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1138
void lwfree(void *mem)
Definition: lwutil.c:242

References assert_all_results_found(), cluster_within_distance(), lwfree(), lwgeom_free(), and WKTARRAY2LWGEOM().

Referenced by basic_distance_test(), basic_test(), empty_inputs_test(), nonsequential_test(), and single_input_test().

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