Fix classes for service member function definitions
This commit is contained in:
parent
247d0d5290
commit
f10da205bb
@ -14,9 +14,9 @@ namespace server
|
|||||||
namespace service
|
namespace service
|
||||||
{
|
{
|
||||||
|
|
||||||
engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
engine::Status MatchService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
||||||
std::string &options,
|
std::string &options,
|
||||||
util::json::Object &json_result)
|
util::json::Object &result)
|
||||||
{
|
{
|
||||||
// TODO(daniel-j-h)
|
// TODO(daniel-j-h)
|
||||||
return Status::Error;
|
return Status::Error;
|
||||||
|
@ -14,9 +14,9 @@ namespace server
|
|||||||
namespace service
|
namespace service
|
||||||
{
|
{
|
||||||
|
|
||||||
engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
engine::Status NearestService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
||||||
std::string &options,
|
std::string &options,
|
||||||
util::json::Object &json_result)
|
util::json::Object &result)
|
||||||
{
|
{
|
||||||
// TODO(daniel-j-h)
|
// TODO(daniel-j-h)
|
||||||
return Status::Error;
|
return Status::Error;
|
||||||
|
@ -14,12 +14,18 @@ namespace server
|
|||||||
namespace service
|
namespace service
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace {
|
namespace
|
||||||
|
{
|
||||||
|
|
||||||
const constexpr char PARAMETER_SIZE_MISMATCH_MSG[] = "Number of elements in %1% size %2% does not match coordinate size %3%";
|
const constexpr char PARAMETER_SIZE_MISMATCH_MSG[] =
|
||||||
|
"Number of elements in %1% size %2% does not match coordinate size %3%";
|
||||||
|
|
||||||
template<typename ParamT>
|
template <typename ParamT>
|
||||||
bool constrainParamSize(const char* msg_template, const char* name, const ParamT& param, const std::size_t target_size, std::string& help)
|
bool constrainParamSize(const char *msg_template,
|
||||||
|
const char *name,
|
||||||
|
const ParamT ¶m,
|
||||||
|
const std::size_t target_size,
|
||||||
|
std::string &help)
|
||||||
{
|
{
|
||||||
if (param.size() > 0 && param.size() != target_size)
|
if (param.size() > 0 && param.size() != target_size)
|
||||||
{
|
{
|
||||||
@ -29,16 +35,20 @@ bool constrainParamSize(const char* msg_template, const char* name, const ParamT
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string getWrongOptionHelp(const engine::api::RouteParameters& parameters)
|
std::string getWrongOptionHelp(const engine::api::RouteParameters ¶meters)
|
||||||
{
|
{
|
||||||
std::string help;
|
std::string help;
|
||||||
|
|
||||||
const auto coord_size = parameters.coordinates.size();
|
const auto coord_size = parameters.coordinates.size();
|
||||||
|
|
||||||
const bool param_size_mismatch = constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "hints", parameters.hints, coord_size, help)
|
const bool param_size_mismatch = constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "hints",
|
||||||
|| constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "bearings", parameters.bearings, coord_size, help)
|
parameters.hints, coord_size, help) ||
|
||||||
|| constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "radiuses", parameters.radiuses, coord_size, help)
|
constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "bearings",
|
||||||
|| constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "uturns", parameters.uturns, coord_size, help);
|
parameters.bearings, coord_size, help) ||
|
||||||
|
constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "radiuses",
|
||||||
|
parameters.radiuses, coord_size, help) ||
|
||||||
|
constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "uturns",
|
||||||
|
parameters.uturns, coord_size, help);
|
||||||
|
|
||||||
if (!param_size_mismatch && parameters.coordinates.size() < 2)
|
if (!param_size_mismatch && parameters.coordinates.size() < 2)
|
||||||
{
|
{
|
||||||
@ -51,16 +61,17 @@ std::string getWrongOptionHelp(const engine::api::RouteParameters& parameters)
|
|||||||
|
|
||||||
engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
||||||
std::string &options,
|
std::string &options,
|
||||||
util::json::Object &json_result)
|
util::json::Object &result)
|
||||||
{
|
{
|
||||||
|
|
||||||
auto options_iterator = options.begin();
|
auto options_iterator = options.begin();
|
||||||
auto parameters = api::parseParameters<engine::api::RouteParameters>(options_iterator, options.end());
|
auto parameters =
|
||||||
|
api::parseParameters<engine::api::RouteParameters>(options_iterator, options.end());
|
||||||
if (!parameters || options_iterator != options.end())
|
if (!parameters || options_iterator != options.end())
|
||||||
{
|
{
|
||||||
const auto position = std::distance(options.begin(), options_iterator);
|
const auto position = std::distance(options.begin(), options_iterator);
|
||||||
json_result.values["code"] = "invalid-options";
|
result.values["code"] = "invalid-options";
|
||||||
json_result.values["message"] =
|
result.values["message"] =
|
||||||
"Options string malformed close to position " + std::to_string(position);
|
"Options string malformed close to position " + std::to_string(position);
|
||||||
return engine::Status::Error;
|
return engine::Status::Error;
|
||||||
}
|
}
|
||||||
@ -70,13 +81,13 @@ engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> co
|
|||||||
|
|
||||||
if (!parameters->IsValid())
|
if (!parameters->IsValid())
|
||||||
{
|
{
|
||||||
json_result.values["code"] = "invalid-options";
|
result.values["code"] = "invalid-options";
|
||||||
json_result.values["message"] = getWrongOptionHelp(*parameters);
|
result.values["message"] = getWrongOptionHelp(*parameters);
|
||||||
return engine::Status::Error;
|
return engine::Status::Error;
|
||||||
}
|
}
|
||||||
BOOST_ASSERT(parameters->IsValid());
|
BOOST_ASSERT(parameters->IsValid());
|
||||||
|
|
||||||
return BaseService::routing_machine.Route(*parameters, json_result);
|
return BaseService::routing_machine.Route(*parameters, result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,12 +14,18 @@ namespace server
|
|||||||
namespace service
|
namespace service
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace {
|
namespace
|
||||||
|
{
|
||||||
|
|
||||||
const constexpr char PARAMETER_SIZE_MISMATCH_MSG[] = "Number of elements in %1% size %2% does not match coordinate size %3%";
|
const constexpr char PARAMETER_SIZE_MISMATCH_MSG[] =
|
||||||
|
"Number of elements in %1% size %2% does not match coordinate size %3%";
|
||||||
|
|
||||||
template<typename ParamT>
|
template <typename ParamT>
|
||||||
bool constrainParamSize(const char* msg_template, const char* name, const ParamT& param, const std::size_t target_size, std::string& help)
|
bool constrainParamSize(const char *msg_template,
|
||||||
|
const char *name,
|
||||||
|
const ParamT ¶m,
|
||||||
|
const std::size_t target_size,
|
||||||
|
std::string &help)
|
||||||
{
|
{
|
||||||
if (param.size() > 0 && param.size() != target_size)
|
if (param.size() > 0 && param.size() != target_size)
|
||||||
{
|
{
|
||||||
@ -29,15 +35,18 @@ bool constrainParamSize(const char* msg_template, const char* name, const ParamT
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string getWrongOptionHelp(const engine::api::TableParameters& parameters)
|
std::string getWrongOptionHelp(const engine::api::TableParameters ¶meters)
|
||||||
{
|
{
|
||||||
std::string help;
|
std::string help;
|
||||||
|
|
||||||
const auto coord_size = parameters.coordinates.size();
|
const auto coord_size = parameters.coordinates.size();
|
||||||
|
|
||||||
const bool param_size_mismatch = constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "hints", parameters.hints, coord_size, help)
|
const bool param_size_mismatch = constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "hints",
|
||||||
|| constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "bearings", parameters.bearings, coord_size, help)
|
parameters.hints, coord_size, help) ||
|
||||||
|| constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "radiuses", parameters.radiuses, coord_size, help);
|
constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "bearings",
|
||||||
|
parameters.bearings, coord_size, help) ||
|
||||||
|
constrainParamSize(PARAMETER_SIZE_MISMATCH_MSG, "radiuses",
|
||||||
|
parameters.radiuses, coord_size, help);
|
||||||
|
|
||||||
if (!param_size_mismatch && parameters.coordinates.size() < 2)
|
if (!param_size_mismatch && parameters.coordinates.size() < 2)
|
||||||
{
|
{
|
||||||
@ -50,16 +59,17 @@ std::string getWrongOptionHelp(const engine::api::TableParameters& parameters)
|
|||||||
|
|
||||||
engine::Status TableService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
engine::Status TableService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
||||||
std::string &options,
|
std::string &options,
|
||||||
util::json::Object &json_result)
|
util::json::Object &result)
|
||||||
{
|
{
|
||||||
|
|
||||||
auto options_iterator = options.begin();
|
auto options_iterator = options.begin();
|
||||||
auto parameters = api::parseParameters<engine::api::TableParameters>(options_iterator, options.end());
|
auto parameters =
|
||||||
|
api::parseParameters<engine::api::TableParameters>(options_iterator, options.end());
|
||||||
if (!parameters || options_iterator != options.end())
|
if (!parameters || options_iterator != options.end())
|
||||||
{
|
{
|
||||||
const auto position = std::distance(options.begin(), options_iterator);
|
const auto position = std::distance(options.begin(), options_iterator);
|
||||||
json_result.values["code"] = "invalid-options";
|
result.values["code"] = "invalid-options";
|
||||||
json_result.values["message"] =
|
result.values["message"] =
|
||||||
"Options string malformed close to position " + std::to_string(position);
|
"Options string malformed close to position " + std::to_string(position);
|
||||||
return engine::Status::Error;
|
return engine::Status::Error;
|
||||||
}
|
}
|
||||||
@ -69,13 +79,13 @@ engine::Status TableService::RunQuery(std::vector<util::FixedPointCoordinate> co
|
|||||||
|
|
||||||
if (!parameters->IsValid())
|
if (!parameters->IsValid())
|
||||||
{
|
{
|
||||||
json_result.values["code"] = "invalid-options";
|
result.values["code"] = "invalid-options";
|
||||||
json_result.values["message"] = getWrongOptionHelp(*parameters);
|
result.values["message"] = getWrongOptionHelp(*parameters);
|
||||||
return engine::Status::Error;
|
return engine::Status::Error;
|
||||||
}
|
}
|
||||||
BOOST_ASSERT(parameters->IsValid());
|
BOOST_ASSERT(parameters->IsValid());
|
||||||
|
|
||||||
return BaseService::routing_machine.Table(*parameters, json_result);
|
return BaseService::routing_machine.Table(*parameters, result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,9 +14,9 @@ namespace server
|
|||||||
namespace service
|
namespace service
|
||||||
{
|
{
|
||||||
|
|
||||||
engine::Status RouteService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
engine::Status TripService::RunQuery(std::vector<util::FixedPointCoordinate> coordinates,
|
||||||
std::string &options,
|
std::string &options,
|
||||||
util::json::Object &json_result)
|
util::json::Object &result)
|
||||||
{
|
{
|
||||||
// TODO(daniel-j-h)
|
// TODO(daniel-j-h)
|
||||||
return Status::Error;
|
return Status::Error;
|
||||||
|
Loading…
Reference in New Issue
Block a user