PostGIS 3.0.6dev-r@@SVN_REVISION@@
Loading...
Searching...
No Matches

◆ vectortile_layer_combine()

static VectorTile__Tile__Layer * vectortile_layer_combine ( const VectorTile__Tile__Layer *  layer1,
const VectorTile__Tile__Layer *  layer2 
)
static

Definition at line 1460 of file mvt.c.

1461{
1462 uint32_t i, j;
1463 int key2_offset, value2_offset;
1464 VectorTile__Tile__Layer *layer = palloc(sizeof(VectorTile__Tile__Layer));
1465 vector_tile__tile__layer__init(layer);
1466
1467 /* Take globals from layer1 */
1468 layer->version = layer1->version;
1469 layer->name = pstrdup(layer1->name);
1470 layer->has_extent = layer1->has_extent;
1471 layer->extent = layer1->extent;
1472
1473 /* Copy keys into new layer */
1474 j = 0;
1475 layer->n_keys = layer1->n_keys + layer2->n_keys;
1476 layer->keys = layer->n_keys ? palloc(layer->n_keys * sizeof(void*)) : NULL;
1477 for (i = 0; i < layer1->n_keys; i++)
1478 layer->keys[j++] = pstrdup(layer1->keys[i]);
1479 key2_offset = j;
1480 for (i = 0; i < layer2->n_keys; i++)
1481 layer->keys[j++] = pstrdup(layer2->keys[i]);
1482
1483 /* Copy values into new layer */
1484 /* TODO, apply hash logic here too, so that merged tiles */
1485 /* retain unique value maps */
1486 layer->n_values = layer1->n_values + layer2->n_values;
1487 layer->values = layer->n_values ? palloc(layer->n_values * sizeof(void*)) : NULL;
1488 j = 0;
1489 for (i = 0; i < layer1->n_values; i++)
1490 layer->values[j++] = tile_value_copy(layer1->values[i]);
1491 value2_offset = j;
1492 for (i = 0; i < layer2->n_values; i++)
1493 layer->values[j++] = tile_value_copy(layer2->values[i]);
1494
1495
1496 layer->n_features = layer1->n_features + layer2->n_features;
1497 layer->features = layer->n_features ? palloc(layer->n_features * sizeof(void*)) : NULL;
1498 j = 0;
1499 for (i = 0; i < layer1->n_features; i++)
1500 layer->features[j++] = tile_feature_copy(layer1->features[i], 0, 0);
1501 for (i = 0; i < layer2->n_features; i++)
1502 layer->features[j++] = tile_feature_copy(layer2->features[i], key2_offset, value2_offset);
1503
1504 return layer;
1505}
static VectorTile__Tile__Feature * tile_feature_copy(const VectorTile__Tile__Feature *feature, int key_offset, int value_offset)
Definition mvt.c:1416
static VectorTile__Tile__Value * tile_value_copy(const VectorTile__Tile__Value *value)
Definition mvt.c:1406

References tile_feature_copy(), and tile_value_copy().

Referenced by vectortile_tile_combine().

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