Files
comaps/track_analyzing/utils.hpp
Konstantin Pastbin e3e4a1985a 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
2025-05-08 21:10:51 +07:00

61 lines
2.2 KiB
C++

#pragma once
#include "track_analyzing/exceptions.hpp"
#include "track_analyzing/track.hpp"
#include "routing/geometry.hpp"
#include "routing_common/num_mwm_id.hpp"
#include "storage/storage.hpp"
#include "platform/platform.hpp"
#include <algorithm>
#include <cstdint>
#include <functional>
#include <memory>
#include <string>
#include <vector>
namespace track_analyzing
{
using StringFilter = std::function<bool(std::string const &)>;
double CalcSubtrackLength(MatchedTrack::const_iterator begin, MatchedTrack::const_iterator end,
routing::Geometry & geometry);
double CalcTrackLength(MatchedTrack const & track, routing::Geometry & geometry);
double CalcSpeedKMpH(double meters, uint64_t secondsElapsed);
void ReadTracks(std::shared_ptr<routing::NumMwmIds> numMwmIds, std::string const & filename,
MwmToMatchedTracks & mwmToMatchedTracks);
MatchedTrack const & GetMatchedTrack(MwmToMatchedTracks const & mwmToMatchedTracks,
routing::NumMwmIds const & numMwmIds,
std::string const & mwmName, std::string const & user,
size_t trackIdx);
std::string GetCurrentVersionMwmFile(storage::Storage const & storage, std::string const & mwmName);
template <typename MwmToTracks, typename ToDo>
void ForTracksSortedByMwmName(MwmToTracks const & mwmToTracks, routing::NumMwmIds const & numMwmIds,
ToDo && toDo)
{
std::vector<std::string> mwmNames;
mwmNames.reserve(mwmToTracks.size());
for (auto const & it : mwmToTracks)
mwmNames.push_back(numMwmIds.GetFile(it.first).GetName());
std::sort(mwmNames.begin(), mwmNames.end());
for (auto const & mwmName : mwmNames)
{
auto const mwmId = numMwmIds.GetId(platform::CountryFile(mwmName));
auto mwmIt = mwmToTracks.find(mwmId);
CHECK(mwmIt != mwmToTracks.cend(), ());
toDo(mwmName, mwmIt->second);
}
}
void ForEachTrackFile(
std::string const & filepath, std::string const & extension,
std::shared_ptr<routing::NumMwmIds> numMwmIds,
std::function<void(std::string const & filename, MwmToMatchedTracks const &)> && toDo);
} // namespace track_analyzing