#ifndef ENGINE_API_BASE_API_HPP #define ENGINE_API_BASE_API_HPP #include "engine/api/base_parameters.hpp" #include "engine/datafacade/datafacade_base.hpp" #include "engine/api/json_factory.hpp" #include "engine/hint.hpp" #include #include #include namespace osrm { namespace engine { namespace api { class BaseAPI { public: BaseAPI(const datafacade::BaseDataFacade &facade_, const BaseParameters ¶meters_) : facade(facade_), parameters(parameters_) { } util::json::Array MakeWaypoints(const std::vector &segment_end_coordinates) const { 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); auto out_iter = std::next(waypoints.values.begin()); boost::range::transform( segment_end_coordinates, out_iter, [this](const PhantomNodes &phantom_pair) { return MakeWaypoint(phantom_pair.target_phantom); }); return waypoints; } // FIXME: gcc 4.9 does not like MakeWaypoints to be protected // protected: util::json::Object MakeWaypoint(const PhantomNode &phantom) const { if (parameters.generate_hints) { return json::makeWaypoint(phantom.location, facade.GetNameForID(phantom.name_id).to_string(), Hint{phantom, facade.GetCheckSum()}); } else { return json::makeWaypoint(phantom.location, facade.GetNameForID(phantom.name_id).to_string()); } } const datafacade::BaseDataFacade &facade; const BaseParameters ¶meters; }; } // ns api } // ns engine } // ns osrm #endif