Welcome to mirror list, hosted at ThFree Co, Russian Federation.

locality_index_builder.cpp « indexer - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: e26842e3e35845e53a198c30e0e70f49fabc5bea (plain)
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
#include "indexer/locality_index_builder.hpp"

#include "indexer/locality_object.hpp"

#include "defines.hpp"

#include "coding/file_container.hpp"
#include "coding/var_record_reader.hpp"

#include "base/logging.hpp"

namespace indexer
{
namespace
{
template <class Reader>
class LocalityVector
{
  DISALLOW_COPY(LocalityVector);

public:
  LocalityVector(Reader const & reader) : m_recordReader(reader, 256 /* expectedRecordSize */) {}

  template <class ToDo>
  void ForEach(ToDo && toDo) const
  {
    m_recordReader.ForEachRecord([&](uint32_t pos, char const * data, uint32_t /*size*/) {
      LocalityObject o;
      o.Deserialize(data);
      toDo(o);
    });
  }

private:
  friend class LocalityVectorReader;

  VarRecordReader<FilesContainerR::TReader, &VarRecordSizeReaderVarint> m_recordReader;
};

// Test features vector (reader) that combines all the needed data for stand-alone work.
// Used in generator_tool and unit tests.
class LocalityVectorReader
{
  DISALLOW_COPY(LocalityVectorReader);

public:
  explicit LocalityVectorReader(string const & filePath)
    : m_cont(filePath), m_vector(m_cont.GetReader(LOCALITY_DATA_FILE_TAG))
  {
  }

  LocalityVector<ModelReaderPtr> const & GetVector() const { return m_vector; }

private:
  FilesContainerR m_cont;
  LocalityVector<ModelReaderPtr> m_vector;
};

template <int DEPTH_LEVELS>
bool BuildLocalityIndexFromDataFile(string const & dataFile,
                                    covering::CoverLocality const & coverLocality,
                                    string const & outFileName,
                                    string const & localityIndexFileTag)
{
  try
  {
    string const idxFileName(outFileName + LOCALITY_INDEX_TMP_EXT);
    {
      LocalityVectorReader localities(dataFile);
      FileWriter writer(idxFileName);

      covering::BuildLocalityIndex<LocalityVector<ModelReaderPtr>, FileWriter, DEPTH_LEVELS>(
          localities.GetVector(), writer, coverLocality, outFileName);
    }

    FilesContainerW(outFileName, FileWriter::OP_WRITE_TRUNCATE)
        .Write(idxFileName, localityIndexFileTag);
    FileWriter::DeleteFileX(idxFileName);
  }
  catch (Reader::Exception const & e)
  {
    LOG(LERROR, ("Error while reading file:", e.Msg()));
    return false;
  }
  catch (Writer::Exception const & e)
  {
    LOG(LERROR, ("Error writing index file:", e.Msg()));
    return false;
  }
  return true;
}
}  // namespace

bool BuildGeoObjectsIndexFromDataFile(string const & dataFile, string const & outFileName)
{
  auto coverObject = [](indexer::LocalityObject const & o, int cellDepth,
                        uint64_t cellPenaltyArea) {
    return covering::CoverGeoObject(o, cellDepth, cellPenaltyArea);
  };
  return BuildLocalityIndexFromDataFile<kGeoObjectsDepthLevels>(dataFile, coverObject, outFileName,
                                                                GEO_OBJECTS_INDEX_FILE_TAG);
}

bool BuildRegionsIndexFromDataFile(string const & dataFile, string const & outFileName)
{
  auto coverRegion = [](indexer::LocalityObject const & o, int cellDepth,
                        uint64_t cellPenaltyArea) {
    return covering::CoverRegion(o, cellDepth, cellPenaltyArea);
  };
  return BuildLocalityIndexFromDataFile<kRegionsDepthLevels>(dataFile, coverRegion, outFileName,
                                                             REGIONS_INDEX_FILE_TAG);
}
}  // namespace indexer