#include "indexer/classificator_loader.hpp" #include "indexer/classificator.hpp" #include "indexer/drawing_rules.hpp" #include "indexer/map_style_reader.hpp" #include "platform/platform.hpp" #include "coding/reader.hpp" #include "coding/reader_streambuf.hpp" #include "base/logging.hpp" #include #include #include namespace { void ReadCommon(std::unique_ptr classificator, std::unique_ptr types) { Classificator & c = classif(); c.Clear(); { //LOG(LINFO, ("Reading classificator")); ReaderStreamBuf buffer(move(classificator)); std::istream s(&buffer); c.ReadClassificator(s); } { //LOG(LINFO, ("Reading types mapping")); ReaderStreamBuf buffer(move(types)); std::istream s(&buffer); c.ReadTypesMapping(s); } } } // namespace namespace classificator { void Load() { LOG(LDEBUG, ("Reading of classificator started")); Platform & p = GetPlatform(); MapStyle const originMapStyle = GetStyleReader().GetCurrentStyle(); for (size_t i = 0; i < MapStyleCount; ++i) { auto const mapStyle = static_cast(i); // Read the merged style only if it was requested. if (mapStyle != MapStyleMerged || originMapStyle == MapStyleMerged) { GetStyleReader().SetCurrentStyle(mapStyle); ReadCommon(p.GetReader("classificator.txt"), p.GetReader("types.txt")); drule::LoadRules(); } } GetStyleReader().SetCurrentStyle(originMapStyle); LOG(LDEBUG, ("Reading of classificator finished")); } void LoadTypes(std::string const & classificatorFileStr, std::string const & typesFileStr) { ReadCommon(std::make_unique(classificatorFileStr.data(), classificatorFileStr.size()), std::make_unique(typesFileStr.data(), typesFileStr.size())); } } // namespace classificator