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
|
#pragma once
#include "indexer/ftypes_matcher.hpp"
#include "std/string.hpp"
#include "std/vector.hpp"
#include "base/macros.hpp"
class FeatureType;
namespace search
{
/// Describes 2-level POI-exception types that don't belong to any POI-common classes
/// (amenity, shop, tourism, ...). Used in search algo and search categories index generation.
class TwoLevelPOIChecker : public ftypes::BaseChecker
{
public:
TwoLevelPOIChecker();
};
// This class is used to map feature types to a restricted set of
// different search classes (do not confuse these classes with search
// categories - they are completely different things).
class Model
{
public:
enum Type
{
// Low-level features such as amenities, offices, shops, buildings
// without house number, etc.
TYPE_POI,
// All features with set house number.
TYPE_BUILDING,
TYPE_STREET,
// All low-level features except POI, BUILDING and STREET.
TYPE_UNCLASSIFIED,
TYPE_VILLAGE,
TYPE_CITY,
TYPE_STATE, // US or Canadian states
TYPE_COUNTRY,
TYPE_COUNT
};
Type GetType(FeatureType const & feature) const;
void SetCianEnabled(bool enabled) { m_cianEnabled = enabled; }
private:
bool m_cianEnabled = false;
};
string DebugPrint(Model::Type type);
} // namespace search
|