forked from organicmaps/organicmaps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathopenlr_decoder.hpp
61 lines (45 loc) · 1.53 KB
/
openlr_decoder.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
#pragma once
#include "openlr/stats.hpp"
#include "indexer/data_source.hpp"
#include "base/exception.hpp"
#include <cstdint>
#include <functional>
#include <string>
#include <unordered_set>
#include <vector>
namespace openlr
{
struct LinearSegment;
struct DecodedPath;
DECLARE_EXCEPTION(DecoderError, RootException);
class Graph;
class RoadInfoGetter;
class OpenLRDecoder
{
public:
using CountryParentNameGetter = std::function<std::string(std::string const &)>;
class SegmentsFilter
{
public:
SegmentsFilter(std::string const & idsPath, bool const multipointsOnly);
bool Matches(LinearSegment const & segment) const;
private:
std::unordered_set<uint32_t> m_ids;
bool m_idsSet;
bool const m_multipointsOnly;
};
OpenLRDecoder(std::vector<FrozenDataSource> & dataSources,
CountryParentNameGetter const & countryParentNameGetter);
// Maps partner segments to mwm paths. |segments| should be sorted by partner id.
void DecodeV2(std::vector<LinearSegment> const & segments, uint32_t const numThreads,
std::vector<DecodedPath> & paths);
void DecodeV3(std::vector<LinearSegment> const & segments, uint32_t numThreads,
std::vector<DecodedPath> & paths);
private:
template <typename Decoder, typename Stats>
void Decode(std::vector<LinearSegment> const & segments, uint32_t const numThreads,
std::vector<DecodedPath> & paths);
std::vector<FrozenDataSource> & m_dataSources;
CountryParentNameGetter m_countryParentNameGetter;
};
} // namespace openlr