50 lines
1.3 KiB
C++
50 lines
1.3 KiB
C++
#ifndef OSRM_TIMEZONES_HPP
|
|
#define OSRM_TIMEZONES_HPP
|
|
|
|
#include "util/log.hpp"
|
|
|
|
#include <boost/geometry.hpp>
|
|
#include <boost/geometry/index/rtree.hpp>
|
|
|
|
#include <rapidjson/document.h>
|
|
|
|
#include <chrono>
|
|
|
|
namespace osrm
|
|
{
|
|
namespace updater
|
|
{
|
|
|
|
// Time zone shape polygons loaded in R-tree
|
|
// local_time_t is a pair of a time zone shape polygon and the corresponding local time
|
|
// rtree_t is a lookup R-tree that maps a geographic point to an index in a local_time_t vector
|
|
using point_t = boost::geometry::model::
|
|
point<double, 2, boost::geometry::cs::spherical_equatorial<boost::geometry::degree>>;
|
|
using polygon_t = boost::geometry::model::polygon<point_t>;
|
|
using box_t = boost::geometry::model::box<point_t>;
|
|
using rtree_t =
|
|
boost::geometry::index::rtree<std::pair<box_t, size_t>, boost::geometry::index::rstar<8>>;
|
|
using local_time_t = std::pair<polygon_t, struct tm>;
|
|
|
|
class Timezoner
|
|
{
|
|
public:
|
|
Timezoner() = default;
|
|
|
|
Timezoner(std::string tz_filename, std::time_t utc_time_now);
|
|
|
|
struct tm operator()(const point_t &point) const;
|
|
|
|
private:
|
|
void LoadLocalTimesRTree(const std::string &tz_shapes_filename, std::time_t utc_time);
|
|
void ValidateFeature(const rapidjson::Value &feature, const std::string &filename);
|
|
|
|
struct tm default_time;
|
|
rtree_t rtree;
|
|
std::vector<local_time_t> local_times;
|
|
};
|
|
}
|
|
}
|
|
|
|
#endif
|