mirror of
https://codeberg.org/comaps/comaps
synced 2025-12-20 05:13:58 +00:00
Organic Maps sources as of 02.04.2025 (fad26bbf22ac3da75e01e62aa01e5c8e11861005)
To expand with full Organic Maps and Maps.ME commits history run: git remote add om-historic [om-historic.git repo url] git fetch --tags om-historic git replace squashed-history historic-commits
This commit is contained in:
40
routing/mwm_hierarchy_handler.hpp
Normal file
40
routing/mwm_hierarchy_handler.hpp
Normal file
@@ -0,0 +1,40 @@
|
||||
#pragma once
|
||||
|
||||
#include "routing/route_weight.hpp"
|
||||
#include "routing/router.hpp"
|
||||
|
||||
#include "routing_common/num_mwm_id.hpp"
|
||||
|
||||
#include <memory>
|
||||
#include <string>
|
||||
#include <unordered_map>
|
||||
|
||||
namespace routing
|
||||
{
|
||||
|
||||
/// Class for calculating penalty while crossing country borders. Also finds parent country for mwm.
|
||||
class MwmHierarchyHandler
|
||||
{
|
||||
public:
|
||||
// Used in tests only.
|
||||
MwmHierarchyHandler() = default;
|
||||
// Used in IndexRouter.
|
||||
MwmHierarchyHandler(std::shared_ptr<NumMwmIds> numMwmIds,
|
||||
CountryParentNameGetterFn countryParentNameGetterFn);
|
||||
|
||||
bool HasCrossBorderPenalty(NumMwmId mwmId1, NumMwmId mwmId2);
|
||||
RouteWeight GetCrossBorderPenalty(NumMwmId mwmId1, NumMwmId mwmId2);
|
||||
|
||||
private:
|
||||
/// @return Parent country name for \a mwmId.
|
||||
std::string GetMwmName(NumMwmId mwmId) const;
|
||||
std::string GetParentCountry(NumMwmId mwmId) const;
|
||||
std::string const & GetParentCountryCached(NumMwmId mwmId);
|
||||
|
||||
std::shared_ptr<NumMwmIds> m_numMwmIds;
|
||||
CountryParentNameGetterFn m_countryParentNameGetterFn;
|
||||
|
||||
using MwmToCountry = std::unordered_map<NumMwmId, std::string>;
|
||||
MwmToCountry m_mwmCountriesCache;
|
||||
};
|
||||
} // namespace routing
|
||||
Reference in New Issue
Block a user