PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ vectortile_tile_combine()

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

Definition at line 1226 of file mvt.c.

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

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: