Introduce osm_nodes annotations for 64-bit OSM Node Ids

This commit is contained in:
Siarhei Fedartsou 2022-08-27 21:53:32 +02:00
parent bfb74c2dad
commit 466ed10ef8
6 changed files with 56 additions and 12 deletions

View File

@ -10,6 +10,8 @@ table Annotation {
duration: [uint];
datasources: [uint];
nodes: [uint];
osm_nodes: [ulong];
weight: [uint];
speed: [float];
metadata: Metadata;

View File

@ -7,6 +7,7 @@
#include "engine/api/json_factory.hpp"
#include "engine/phantom_node.hpp"
#include "util/json_container.hpp"
#include <boost/assert.hpp>
@ -110,6 +111,11 @@ class NearestAPI final : public BaseAPI
nodes.values.push_back(node_values.second);
waypoint.values["nodes"] = std::move(nodes);
util::json::Array osm_nodes;
osm_nodes.values.emplace_back(std::to_string(node_values.first));
osm_nodes.values.emplace_back(std::to_string(node_values.second));
waypoint.values["osm_nodes"] = std::move(osm_nodes);
return waypoint;
});
response.values["waypoints"] = std::move(waypoints);

View File

@ -28,6 +28,7 @@
#include "util/json_util.hpp"
#include <iterator>
#include <string>
#include <vector>
namespace osrm
@ -822,14 +823,43 @@ class RouteAPI : public BaseAPI
return anno.datasource;
});
}
if (requested_annotations & RouteParameters::AnnotationsType::Nodes)
if (requested_annotations & RouteParameters::AnnotationsType::Nodes ||
requested_annotations & RouteParameters::AnnotationsType::OSMNodes)
{
util::json::Array nodes;
util::json::Array osm_nodes;
nodes.values.reserve(leg_geometry.node_ids.size());
for (const auto node_id : leg_geometry.node_ids)
{
const auto osm_node_id =
static_cast<std::uint64_t>(facade.GetOSMNodeIDOfNode(node_id));
if (requested_annotations & RouteParameters::AnnotationsType::Nodes)
{
nodes.values.emplace_back(osm_node_id);
}
if (requested_annotations & RouteParameters::AnnotationsType::OSMNodes)
{
osm_nodes.values.emplace_back(osm_node_id);
}
}
if (requested_annotations & RouteParameters::AnnotationsType::Nodes)
{
annotation.values["nodes"] = nodes;
}
if (requested_annotations & RouteParameters::AnnotationsType::OSMNodes)
{
annotation.values["osmnodes"] = osm_nodes;
}
}
if (requested_annotations & RouteParameters::AnnotationsType::OSMNodes)
{
util::json::Array nodes;
nodes.values.reserve(leg_geometry.node_ids.size());
for (const auto node_id : leg_geometry.node_ids)
{
nodes.values.push_back(
static_cast<std::uint64_t>(facade.GetOSMNodeIDOfNode(node_id)));
nodes.values.push_back(std::to_string(
static_cast<std::uint64_t>(facade.GetOSMNodeIDOfNode(node_id))));
}
annotation.values["nodes"] = std::move(nodes);
}

View File

@ -70,13 +70,14 @@ struct RouteParameters : public BaseParameters
enum class AnnotationsType
{
None = 0,
Duration = 0x01,
Nodes = 0x02,
Distance = 0x04,
Weight = 0x08,
Datasources = 0x10,
Speed = 0x20,
All = Duration | Nodes | Distance | Weight | Datasources | Speed
Duration = 1 << 1,
Nodes = 1 << 2,
Distance = 1 << 3,
Weight = 1 << 4,
Datasources = 1 << 5,
Speed = 1 << 6,
OSMNodes = 1 << 7,
All = Duration | Nodes | Distance | Weight | Datasources | Speed | OSMNodes
};
RouteParameters() = default;

View File

@ -778,6 +778,11 @@ inline bool parseCommonParameters(const v8::Local<v8::Object> &obj, ParamType &p
params->annotations_type =
params->annotations_type | osrm::RouteParameters::AnnotationsType::Nodes;
}
else if (annotations_str == "osm_nodes")
{
params->annotations_type =
params->annotations_type | osrm::RouteParameters::AnnotationsType::OSMNodes;
}
else if (annotations_str == "distance")
{
params->annotations_type =

View File

@ -73,8 +73,8 @@ struct RouteParametersGrammar : public BaseParametersGrammar<Iterator, Signature
"full", engine::api::RouteParameters::OverviewType::Full)(
"false", engine::api::RouteParameters::OverviewType::False);
annotations_type.add("duration", AnnotationsType::Duration)("nodes",
AnnotationsType::Nodes)(
annotations_type.add("duration", AnnotationsType::Duration)(
"nodes", AnnotationsType::Nodes)("osm_nodes", AnnotationsType::OSMNodes)(
"distance", AnnotationsType::Distance)("weight", AnnotationsType::Weight)(
"datasources", AnnotationsType::Datasources)("speed", AnnotationsType::Speed);