forked from osm2pgsql-dev/osm2pgsql
-
Notifications
You must be signed in to change notification settings - Fork 0
/
table.hpp
114 lines (94 loc) · 3.49 KB
/
table.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#ifndef TABLE_H
#define TABLE_H
#include "pgsql.hpp"
#include "osmtypes.hpp"
#include <cstddef>
#include <string>
#include <vector>
#include <utility>
#include <memory>
#include <boost/optional.hpp>
#include <boost/format.hpp>
typedef std::vector<std::string> hstores_t;
typedef std::vector<std::pair<std::string, std::string> > columns_t;
class table_t
{
public:
table_t(const std::string& conninfo, const std::string& name, const std::string& type, const columns_t& columns, const hstores_t& hstore_columns, const int srid,
const bool append, const bool slim, const bool droptemp, const int hstore_mode, const bool enable_hstore_index,
const boost::optional<std::string>& table_space, const boost::optional<std::string>& table_space_index);
table_t(const table_t& other);
~table_t();
void start();
void stop();
void begin();
void commit();
void write_row(const osmid_t id, const taglist_t &tags, const std::string &geom);
void write_node(const osmid_t id, const taglist_t &tags, double lat, double lon);
void delete_row(const osmid_t id);
std::string const& get_name();
struct pg_result_closer
{
void operator() (PGresult* result)
{
PQclear(result);
}
};
//interface from retrieving well known binary geometry from the table
class wkb_reader
{
friend table_t;
public:
const char* get_next()
{
if (m_current < m_count) {
return PQgetvalue(m_result.get(), m_current++, 0);
}
return nullptr;
}
int get_count() const { return m_count; }
void reset()
{
//NOTE: PQgetvalue doc doesn't say if you can call it
// multiple times with the same row col
m_current = 0;
}
private:
wkb_reader(PGresult* result)
: m_result(result), m_count(PQntuples(result)), m_current(0)
{}
std::unique_ptr<PGresult, pg_result_closer> m_result;
int m_count;
int m_current;
};
wkb_reader get_wkb_reader(const osmid_t id);
protected:
void connect();
void stop_copy();
void teardown();
void write_columns(const taglist_t &tags, std::string& values, std::vector<bool> *used);
void write_tags_column(const taglist_t &tags, std::string& values,
const std::vector<bool> &used);
void write_hstore_columns(const taglist_t &tags, std::string& values);
void escape4hstore(const char *src, std::string& dst);
void escape_type(const std::string &value, const std::string &type, std::string& dst);
std::string conninfo;
std::string name;
std::string type;
pg_conn *sql_conn;
bool copyMode;
std::string buffer;
std::string srid;
bool append;
bool slim;
bool drop_temp;
int hstore_mode;
bool enable_hstore_index;
columns_t columns;
hstores_t hstore_columns;
std::string copystr;
boost::optional<std::string> table_space;
boost::optional<std::string> table_space_index;
boost::format single_fmt, point_fmt, del_fmt;
};
#endif