tippecanoe/mvt.hpp

118 lines
2.2 KiB
C++
Raw Normal View History

#ifndef MVT_HPP
#define MVT_HPP
#include <sqlite3.h>
#include <string>
#include <map>
#include <set>
#include <vector>
struct mvt_value;
struct mvt_layer;
2016-04-25 19:13:52 +00:00
enum mvt_operation {
mvt_moveto = 1,
mvt_lineto = 2,
mvt_closepath = 7
};
struct mvt_geometry {
long long x;
long long y;
2016-04-25 19:13:52 +00:00
int /* mvt_operation */ op;
mvt_geometry(int op, long long x, long long y);
bool operator<(mvt_geometry const &s) const {
if (y < s.y || (y == s.y && x < s.x)) {
return true;
} else {
return false;
}
}
bool operator==(mvt_geometry const &s) const {
return y == s.y && x == s.x;
}
2016-04-25 19:13:52 +00:00
};
2016-04-22 22:10:16 +00:00
enum mvt_geometry_type {
2016-04-23 00:10:33 +00:00
mvt_point = 1,
mvt_linestring = 2,
mvt_polygon = 3
2016-04-22 22:10:16 +00:00
};
2016-04-25 19:13:52 +00:00
struct mvt_feature {
std::vector<unsigned> tags;
std::vector<mvt_geometry> geometry;
int /* mvt_geometry_type */ type;
2016-07-15 20:58:15 +00:00
unsigned long long id;
bool has_id;
mvt_feature() {
has_id = false;
id = 0;
}
2016-04-22 22:10:16 +00:00
};
enum mvt_value_type {
2016-04-23 00:10:33 +00:00
mvt_string,
mvt_float,
mvt_double,
mvt_int,
mvt_uint,
mvt_sint,
mvt_bool,
mvt_null,
2016-04-22 22:10:16 +00:00
};
struct mvt_value {
mvt_value_type type;
std::string string_value;
union {
float float_value;
double double_value;
long long int_value;
unsigned long long uint_value;
long long sint_value;
bool bool_value;
} numeric_value;
bool operator<(const mvt_value &o) const;
std::string toString();
2016-04-22 22:10:16 +00:00
};
struct mvt_layer {
int version;
std::string name;
std::vector<mvt_feature> features;
std::vector<std::string> keys;
std::vector<mvt_value> values;
long long extent;
// Add a key-value pair to a feature, using this layer's constant pool
void tag(mvt_feature &feature, std::string key, mvt_value value);
// For tracking the key-value constants already used in this layer
std::map<std::string, size_t> key_map;
std::map<mvt_value, size_t> value_map;
2016-04-22 22:10:16 +00:00
};
struct mvt_tile {
std::vector<mvt_layer> layers;
2016-04-25 19:13:52 +00:00
std::string encode();
bool decode(std::string &message, bool &was_compressed);
2016-04-22 22:10:16 +00:00
};
2016-04-25 19:13:52 +00:00
bool is_compressed(std::string const &data);
int decompress(std::string const &input, std::string &output);
int compress(std::string const &input, std::string &output);
int dezig(unsigned n);
mvt_value stringified_to_mvt_value(int type, const char *s);
bool is_integer(const char *s, long long *v);
bool is_unsigned_integer(const char *s, unsigned long long *v);
#endif