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
|
#include "generator/generator_tests_support/routing_helpers.hpp"
#include "testing/testing.hpp"
#include "generator/gen_mwm_info.hpp"
#include "generator/osm_id.hpp"
#include "coding/file_writer.hpp"
#include "base/string_utils.hpp"
#include "std/utility.hpp"
namespace generator
{
void ReEncodeOsmIdsToFeatureIdsMapping(string const & mappingContent, string const & outputFilePath)
{
strings::SimpleTokenizer lineIter(mappingContent, "\n\r" /* line delimiters */);
gen::Accumulator<pair<osm::Id, uint32_t>> osmIdsToFeatureIds;
for (; lineIter; ++lineIter)
{
strings::SimpleTokenizer idIter(*lineIter, ", \t" /* id delimiters */);
uint64_t osmId = 0;
TEST(idIter, ());
TEST(strings::to_uint64(*idIter, osmId), ("Cannot convert to uint64_t:", *idIter));
TEST(idIter, ("Wrong feature ids to osm ids mapping."));
++idIter;
uint32_t featureId = 0;
TEST(idIter, ());
TEST(strings::to_uint(*idIter, featureId), ("Cannot convert to uint:", *idIter));
osmIdsToFeatureIds.Add(make_pair(osm::Id::Way(osmId), featureId));
++idIter;
TEST(!idIter, ());
}
FileWriter osm2ftWriter(outputFilePath);
osmIdsToFeatureIds.Flush(osm2ftWriter);
}
} // namespace generator
|