osrm-backend/include/engine/api/base_api.hpp

135 lines
4.8 KiB
C++
Raw Normal View History

2016-01-28 10:28:44 -05:00
#ifndef ENGINE_API_BASE_API_HPP
#define ENGINE_API_BASE_API_HPP
#include "engine/api/base_parameters.hpp"
#include "engine/api/flatbuffers/fbresult_generated.h"
2016-01-28 10:28:44 -05:00
#include "engine/datafacade/datafacade_base.hpp"
#include "engine/api/json_factory.hpp"
#include "engine/hint.hpp"
#include "util/coordinate_calculation.hpp"
2016-01-28 10:28:44 -05:00
#include <boost/assert.hpp>
#include <boost/range/algorithm/transform.hpp>
2016-01-28 10:28:44 -05:00
#include <vector>
namespace osrm
{
namespace engine
{
namespace api
{
class BaseAPI
2016-01-28 10:28:44 -05:00
{
public:
BaseAPI(const datafacade::BaseDataFacade &facade_, const BaseParameters &parameters_)
2016-01-28 10:28:44 -05:00
: facade(facade_), parameters(parameters_)
{
}
util::json::Array MakeWaypoints(const std::vector<PhantomNodes> &segment_end_coordinates) const
2016-01-28 10:28:44 -05:00
{
BOOST_ASSERT(parameters.coordinates.size() > 0);
BOOST_ASSERT(parameters.coordinates.size() == segment_end_coordinates.size() + 1);
util::json::Array waypoints;
waypoints.values.resize(parameters.coordinates.size());
waypoints.values[0] = MakeWaypoint(segment_end_coordinates.front().source_phantom);
2016-01-28 10:28:44 -05:00
auto out_iter = std::next(waypoints.values.begin());
2016-05-27 15:05:04 -04:00
boost::range::transform(
segment_end_coordinates, out_iter, [this](const PhantomNodes &phantom_pair) {
return MakeWaypoint(phantom_pair.target_phantom);
});
2016-01-28 10:28:44 -05:00
return waypoints;
}
// FIXME: gcc 4.9 does not like MakeWaypoints to be protected
// protected:
util::json::Object MakeWaypoint(const PhantomNode &phantom) const
2016-01-28 10:28:44 -05:00
{
if (parameters.generate_hints)
{
2017-05-11 03:13:59 -04:00
// TODO: check forward/reverse
return json::makeWaypoint(
phantom.location,
util::coordinate_calculation::fccApproximateDistance(phantom.location,
phantom.input_location),
2017-05-11 03:13:59 -04:00
facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id)).to_string(),
Hint{phantom, facade.GetCheckSum()});
}
else
{
2017-05-11 03:13:59 -04:00
// TODO: check forward/reverse
return json::makeWaypoint(
phantom.location,
util::coordinate_calculation::fccApproximateDistance(phantom.location,
phantom.input_location),
2017-05-11 03:13:59 -04:00
facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id))
.to_string());
}
2016-01-28 10:28:44 -05:00
}
2019-08-15 04:40:23 -04:00
flatbuffers::Offset<flatbuffers::Vector<flatbuffers::Offset<fbresult::Waypoint>>>
MakeWaypoints(flatbuffers::FlatBufferBuilder &builder,
const std::vector<PhantomNodes> &segment_end_coordinates) const
{
BOOST_ASSERT(parameters.coordinates.size() > 0);
BOOST_ASSERT(parameters.coordinates.size() == segment_end_coordinates.size() + 1);
std::vector<flatbuffers::Offset<fbresult::Waypoint>> waypoints;
waypoints.resize(parameters.coordinates.size());
2019-08-15 04:40:23 -04:00
waypoints[0] =
MakeWaypoint(builder, segment_end_coordinates.front().source_phantom).Finish();
std::transform(segment_end_coordinates.begin(),
segment_end_coordinates.end(),
std::next(waypoints.begin()),
[this, &builder](const PhantomNodes &phantom_pair) {
return MakeWaypoint(builder, phantom_pair.target_phantom).Finish();
});
return builder.CreateVector(waypoints);
}
// FIXME: gcc 4.9 does not like MakeWaypoints to be protected
// protected:
2019-08-15 04:40:23 -04:00
fbresult::WaypointBuilder MakeWaypoint(flatbuffers::FlatBufferBuilder &builder,
const PhantomNode &phantom) const
{
2019-08-15 04:40:23 -04:00
auto location =
fbresult::Position(static_cast<double>(util::toFloating(phantom.location.lon)),
static_cast<double>(util::toFloating(phantom.location.lat)));
auto name_string = builder.CreateString(
facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id)).to_string());
boost::optional<flatbuffers::Offset<flatbuffers::String>> hint_string = boost::none;
if (parameters.generate_hints)
{
hint_string = builder.CreateString(Hint{phantom, facade.GetCheckSum()}.ToBase64());
}
fbresult::WaypointBuilder waypoint(builder);
waypoint.add_location(&location);
2019-08-15 04:40:23 -04:00
waypoint.add_distance(util::coordinate_calculation::fccApproximateDistance(
phantom.location, phantom.input_location));
waypoint.add_name(name_string);
if (hint_string)
{
waypoint.add_hint(*hint_string);
}
return waypoint;
}
2016-01-28 10:28:44 -05:00
const datafacade::BaseDataFacade &facade;
const BaseParameters &parameters;
};
} // ns api
} // ns engine
} // ns osrm
2016-01-28 10:28:44 -05:00
#endif