forked from osm2pgsql-dev/osm2pgsql
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexpire-tiles.hpp
83 lines (66 loc) · 2.5 KB
/
expire-tiles.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#ifndef EXPIRE_TILES_H
#define EXPIRE_TILES_H
#include <memory>
#include "osmtypes.hpp"
class reprojection;
class table_t;
class tile;
struct expire_tiles
{
expire_tiles(int maxzoom, double maxbbox,
const std::shared_ptr<reprojection> &projection);
int from_bbox(double min_lon, double min_lat, double max_lon, double max_lat);
void from_nodes_line(const nodelist_t &nodes);
void from_nodes_poly(const nodelist_t &nodes, osmid_t osm_id);
void from_wkb(const char* wkb, osmid_t osm_id);
int from_db(table_t* table, osmid_t osm_id);
/* customisable tile output. this can be passed into the
* `output_and_destroy` function to override output to a file.
* this is primarily useful for testing.
*/
struct tile_output {
virtual ~tile_output() = default;
// dirty a tile at x, y & zoom, and all descendants of that
// tile at the given zoom if zoom < min_zoom.
virtual void output_dirty_tile(int x, int y, int zoom) = 0;
};
// output the list of expired tiles to a file. note that this
// consumes the list of expired tiles destructively.
void output_and_destroy(const char *filename, int minzoom);
// output the list of expired tiles using a `tile_output`
// functor. this consumes the list of expired tiles destructively.
void output_and_destroy(tile_output *output);
// merge the list of expired tiles in the other object into this
// object, destroying the list in the other object.
void merge_and_destroy(expire_tiles &);
private:
void expire_tile(int x, int y);
int normalise_tile_x_coord(int x);
void from_line(double lon_a, double lat_a, double lon_b, double lat_b);
void from_xnodes_poly(const multinodelist_t &xnodes, osmid_t osm_id);
void from_xnodes_line(const multinodelist_t &xnodes);
double tile_width;
double max_bbox;
int map_width;
int maxzoom;
std::shared_ptr<reprojection> projection;
std::unique_ptr<tile> dirty;
};
class tile
{
public:
int mark_tile(int x, int y, int zoom, int this_zoom);
void output_and_destroy(expire_tiles::tile_output *output,
int x, int y, int this_zoom);
int merge(tile *other);
private:
int sub2x(int sub) const { return sub >> 1; }
int sub2y(int sub) const { return sub & 1; }
int num_complete() const
{
return complete[0] + complete[1] + complete[2] + complete[3];
}
std::unique_ptr<tile> subtiles[4];
char complete[4] = {0, 0, 0, 0};
};
#endif