Files
comaps/kml/types_v8mm.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

316 lines
12 KiB
C++

#pragma once
#include "kml/types.hpp"
namespace kml
{
// BookmarkDataV8MM contains the same fields as BookmarkDataV8 but without compilations.
struct BookmarkDataV8MM
{
DECLARE_VISITOR_AND_DEBUG_PRINT(BookmarkDataV8MM, visitor(m_id, "id"),
visitor(m_name, "name"),
visitor(m_description, "description"),
visitor(m_featureTypes, "featureTypes"),
visitor(m_customName, "customName"),
visitor(m_color, "color"),
visitor(m_icon, "icon"),
visitor(m_viewportScale, "viewportScale"),
visitor(m_timestamp, "timestamp"),
visitor(m_point, "point"),
visitor(m_boundTracks, "boundTracks"),
visitor(m_visible, "visible"),
visitor(m_nearestToponym, "nearestToponym"),
visitor(m_properties, "properties"),
VISITOR_COLLECTABLE)
DECLARE_COLLECTABLE(LocalizableStringIndex, m_name, m_description, m_customName,
m_nearestToponym, m_properties)
bool operator==(BookmarkDataV8MM const & data) const
{
return m_id == data.m_id && m_name == data.m_name &&
m_description == data.m_description &&
m_color == data.m_color && m_icon == data.m_icon &&
m_viewportScale == data.m_viewportScale &&
IsEqual(m_timestamp, data.m_timestamp) &&
m_point.EqualDxDy(data.m_point, kMwmPointAccuracy) &&
m_featureTypes == data.m_featureTypes &&
m_customName == data.m_customName &&
m_boundTracks == data.m_boundTracks &&
m_visible == data.m_visible &&
m_nearestToponym == data.m_nearestToponym &&
m_properties == data.m_properties;
}
bool operator!=(BookmarkDataV8MM const & data) const { return !operator==(data); }
BookmarkData ConvertToLatestVersion() const
{
BookmarkData data;
data.m_id = m_id;
data.m_name = m_name;
data.m_description = m_description;
data.m_featureTypes = m_featureTypes;
data.m_customName = m_customName;
data.m_color = m_color;
data.m_icon = m_icon;
data.m_viewportScale = m_viewportScale;
data.m_timestamp = m_timestamp;
data.m_point = m_point;
data.m_boundTracks = m_boundTracks;
data.m_visible = m_visible;
data.m_nearestToponym = m_nearestToponym;
data.m_properties = m_properties;
return data;
}
// Unique id (it will not be serialized in text files).
MarkId m_id = kInvalidMarkId;
// Bookmark's name.
LocalizableString m_name;
// Bookmark's description.
LocalizableString m_description;
// Bound feature's types: type indices sorted by importance, the most
// important one goes first.
std::vector<uint32_t> m_featureTypes;
// Custom bookmark's name.
LocalizableString m_customName;
// Bookmark's color.
ColorData m_color;
// Bookmark's icon.
BookmarkIcon m_icon = BookmarkIcon::None;
// Viewport scale. 0 is a default value (no scale set).
uint8_t m_viewportScale = 0;
// Creation timestamp.
TimestampMillis m_timestamp{};
// Coordinates in mercator.
m2::PointD m_point;
// Bound tracks (vector contains local track ids).
std::vector<LocalId> m_boundTracks;
// Visibility.
bool m_visible = true;
// Nearest toponym.
std::string m_nearestToponym;
// Key-value properties.
Properties m_properties;
};
struct TrackDataV8MM
{
DECLARE_VISITOR_AND_DEBUG_PRINT(TrackDataV8MM, visitor(m_id, "id"),
visitor(m_localId, "localId"),
visitor(m_name, "name"),
visitor(m_description, "description"),
visitor(m_layers, "layers"),
visitor(m_timestamp, "timestamp"),
visitor(m_geometry, "geometry"),
visitor(m_visible, "visible"),
visitor(m_constant1, "constant1"), // Extra field introduced in V8MM.
visitor(m_constant2, "constant2"), // Extra field introduced in V8MM.
visitor(m_constant3, "constant3"), // Extra field introduced in V8MM.
visitor(m_nearestToponyms, "nearestToponyms"),
visitor(m_properties, "properties"),
VISITOR_COLLECTABLE)
DECLARE_COLLECTABLE(LocalizableStringIndex, m_name, m_description, m_nearestToponyms, m_properties)
bool operator==(TrackDataV8MM const & data) const
{
return m_id == data.m_id && m_localId == data.m_localId && m_name == data.m_name &&
m_description == data.m_description && m_layers == data.m_layers &&
IsEqual(m_timestamp, data.m_timestamp) && m_geometry == data.m_geometry &&
m_visible == data.m_visible && m_nearestToponyms == data.m_nearestToponyms &&
m_properties == data.m_properties;
}
bool operator!=(TrackDataV8MM const & data) const { return !operator==(data); }
TrackData ConvertToLatestVersion() const
{
TrackData data;
data.m_id = m_id;
data.m_localId = m_localId;
data.m_name = m_name;
data.m_description = m_description;
data.m_layers = m_layers;
data.m_timestamp = m_timestamp;
data.m_geometry = m_geometry;
data.m_visible = m_visible;
data.m_nearestToponyms = m_nearestToponyms;
data.m_properties = m_properties;
return data;
}
// Unique id (it will not be serialized in text files).
TrackId m_id = kInvalidTrackId;
// Local track id.
LocalId m_localId = 0;
// Track's name.
LocalizableString m_name;
// Track's description.
LocalizableString m_description;
// Layers.
std::vector<TrackLayer> m_layers;
// Creation timestamp.
TimestampMillis m_timestamp{};
MultiGeometry m_geometry;
// Visibility.
bool m_visible = true;
// These constants were introduced in KMB V8MM. Usually have value 0. Don't know its purpose.
uint8_t m_constant1 = 0;
uint8_t m_constant2 = 0;
uint8_t m_constant3 = 0;
// Nearest toponyms.
std::vector<std::string> m_nearestToponyms;
// Key-value properties.
Properties m_properties;
};
// CategoryData8MM contains the same fields as CategoryData8 but with no compilations
struct CategoryDataV8MM
{
DECLARE_VISITOR_AND_DEBUG_PRINT(CategoryDataV8MM, visitor(m_id, "id"),
visitor(m_name, "name"),
visitor(m_imageUrl, "imageUrl"),
visitor(m_annotation, "annotation"),
visitor(m_description, "description"),
visitor(m_visible, "visible"),
visitor(m_authorName, "authorName"),
visitor(m_authorId, "authorId"),
visitor(m_rating, "rating"),
visitor(m_reviewsNumber, "reviewsNumber"),
visitor(m_lastModified, "lastModified"),
visitor(m_accessRules, "accessRules"),
visitor(m_tags, "tags"),
visitor(m_toponyms, "toponyms"),
visitor(m_languageCodes, "languageCodes"),
visitor(m_properties, "properties"),
VISITOR_COLLECTABLE)
DECLARE_COLLECTABLE(LocalizableStringIndex, m_name, m_annotation, m_description,
m_imageUrl, m_authorName, m_authorId, m_tags, m_toponyms, m_properties)
bool operator==(CategoryDataV8MM const & data) const
{
double constexpr kEps = 1e-5;
return m_id == data.m_id && m_name == data.m_name &&
m_imageUrl == data.m_imageUrl && m_annotation == data.m_annotation &&
m_description == data.m_description && m_visible == data.m_visible &&
m_accessRules == data.m_accessRules && m_authorName == data.m_authorName &&
m_authorId == data.m_authorId && fabs(m_rating - data.m_rating) < kEps &&
m_reviewsNumber == data.m_reviewsNumber && IsEqual(m_lastModified, data.m_lastModified) &&
m_tags == data.m_tags && m_toponyms == data.m_toponyms &&
m_languageCodes == data.m_languageCodes && m_properties == data.m_properties;
}
CategoryData ConvertToLatestVersion() const
{
CategoryData data;
data.m_id = m_id;
data.m_type = CompilationType::Category; // Format V8MM doesn't have m_type. Using default
data.m_name = m_name;
data.m_imageUrl = m_imageUrl;
data.m_annotation = m_annotation;
data.m_description = m_description;
data.m_visible = m_visible;
data.m_authorName = m_authorName;
data.m_authorId = m_authorId;
data.m_rating = m_rating;
data.m_reviewsNumber = m_reviewsNumber;
data.m_lastModified = m_lastModified;
data.m_accessRules = m_accessRules;
data.m_tags = m_tags;
data.m_toponyms = m_toponyms;
data.m_languageCodes = m_languageCodes;
data.m_properties = m_properties;
return data;
}
bool operator!=(CategoryDataV8MM const & data) const { return !operator==(data); }
// Unique id (it will not be serialized in text files).
MarkGroupId m_id = kInvalidMarkGroupId;
// Category's name.
LocalizableString m_name;
// Image URL.
std::string m_imageUrl;
// Category's description.
LocalizableString m_annotation;
// Category's description.
LocalizableString m_description;
// Collection visibility.
bool m_visible = true;
// Author's name.
std::string m_authorName;
// Author's id.
std::string m_authorId;
// Last modification timestamp.
TimestampMillis m_lastModified{};
// Rating.
double m_rating = 0.0;
// Number of reviews.
uint32_t m_reviewsNumber = 0;
// Access rules.
AccessRules m_accessRules = AccessRules::Local;
// Collection of tags.
std::vector<std::string> m_tags;
// Collection of geo ids for relevant toponyms.
std::vector<std::string> m_toponyms;
// Language codes.
std::vector<int8_t> m_languageCodes;
// Key-value properties.
Properties m_properties;
};
// FileDataV8MM contains the same sections as FileDataV8 but with no compilations
template <class TrackDataT> struct FileDataMMImpl
{
DECLARE_VISITOR_AND_DEBUG_PRINT(FileDataMMImpl, visitor(m_serverId, "serverId"),
visitor(m_categoryData, "category"),
visitor(m_bookmarksData, "bookmarks"),
visitor(m_tracksData, "tracks"))
bool operator==(FileDataMMImpl const & data) const
{
return m_serverId == data.m_serverId && m_categoryData == data.m_categoryData &&
m_bookmarksData == data.m_bookmarksData && m_tracksData == data.m_tracksData;
}
bool operator!=(FileDataMMImpl const & data) const { return !operator==(data); }
FileData ConvertToLatestVersion()
{
FileData data;
data.m_deviceId = m_deviceId;
data.m_serverId = m_serverId;
data.m_categoryData = m_categoryData.ConvertToLatestVersion();
data.m_bookmarksData.reserve(m_bookmarksData.size());
for (auto & d : m_bookmarksData)
data.m_bookmarksData.emplace_back(d.ConvertToLatestVersion());
data.m_tracksData.reserve(m_tracksData.size());
for (auto & t : m_tracksData)
data.m_tracksData.emplace_back(t.ConvertToLatestVersion());
return data;
}
// Device id (it will not be serialized in text files).
std::string m_deviceId;
// Server id.
std::string m_serverId;
// Category's data.
CategoryDataV8MM m_categoryData;
// Bookmarks collection.
std::vector<BookmarkDataV8MM> m_bookmarksData;
// Tracks collection.
std::vector<TrackDataT> m_tracksData;
};
using FileDataV8MM = FileDataMMImpl<TrackDataV8MM>;
} // namespace kml