PostGIS  3.4.0dev-r@@SVN_REVISION@@

◆ vectortile_tile_combine()

static VectorTile__Tile* vectortile_tile_combine ( VectorTile__Tile *  tile1,
VectorTile__Tile *  tile2 
)
static

Definition at line 1225 of file mvt.c.

1226 {
1227  uint32_t i, j;
1228  VectorTile__Tile *tile;
1229 
1230  /* Hopelessly messing up memory ownership here */
1231  if (tile1->n_layers == 0 && tile2->n_layers == 0)
1232  return tile1;
1233  else if (tile1->n_layers == 0)
1234  return tile2;
1235  else if (tile2->n_layers == 0)
1236  return tile1;
1237 
1238  tile = palloc(sizeof(VectorTile__Tile));
1239  vector_tile__tile__init(tile);
1240  tile->layers = palloc(sizeof(void*));
1241  tile->n_layers = 0;
1242 
1243  /* Merge all matching layers in the files (basically always only one) */
1244  for (i = 0; i < tile1->n_layers; i++)
1245  {
1246  for (j = 0; j < tile2->n_layers; j++)
1247  {
1248  VectorTile__Tile__Layer *l1 = tile1->layers[i];
1249  VectorTile__Tile__Layer *l2 = tile2->layers[j];
1250  if (strcmp(l1->name, l2->name)==0)
1251  {
1252  VectorTile__Tile__Layer *layer = vectortile_layer_combine(l1, l2);
1253  if (!layer)
1254  continue;
1255  tile->layers[tile->n_layers++] = layer;
1256  /* Add a spare slot at the end of the array */
1257  tile->layers = repalloc(tile->layers, (tile->n_layers+1) * sizeof(void*));
1258  }
1259  }
1260  }
1261  return tile;
1262 }
static VectorTile__Tile__Layer * vectortile_layer_combine(VectorTile__Tile__Layer *layer, VectorTile__Tile__Layer *layer2)
Combine 2 layers.
Definition: mvt.c:1166

References vectortile_layer_combine().

Referenced by mvt_ctx_combine().

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