implements and fixes #997
- ServerPaths object can be populated by passing base path to OSRM - reduces code/functionality duplication in node-OSRM
This commit is contained in:
parent
5bb7e62a7c
commit
b9e1d3116c
@ -46,6 +46,7 @@ namespace boost { namespace interprocess { class named_mutex; } }
|
|||||||
#include "../Server/DataStructures/SharedBarriers.h"
|
#include "../Server/DataStructures/SharedBarriers.h"
|
||||||
#include "../Server/DataStructures/SharedDataFacade.h"
|
#include "../Server/DataStructures/SharedDataFacade.h"
|
||||||
#include "../Util/make_unique.hpp"
|
#include "../Util/make_unique.hpp"
|
||||||
|
#include "../Util/ProgramOptions.h"
|
||||||
#include "../Util/SimpleLogger.h"
|
#include "../Util/SimpleLogger.h"
|
||||||
|
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
@ -57,8 +58,8 @@ namespace boost { namespace interprocess { class named_mutex; } }
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
OSRM_impl::OSRM_impl(const ServerPaths &server_paths, const bool use_shared_memory)
|
OSRM_impl::OSRM_impl(const ServerPaths &paths, const bool use_shared_memory)
|
||||||
: use_shared_memory(use_shared_memory)
|
: server_paths(paths)
|
||||||
{
|
{
|
||||||
if (use_shared_memory)
|
if (use_shared_memory)
|
||||||
{
|
{
|
||||||
@ -67,6 +68,8 @@ OSRM_impl::OSRM_impl(const ServerPaths &server_paths, const bool use_shared_memo
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// populate base path
|
||||||
|
populate_base_path(server_paths);
|
||||||
query_data_facade = new InternalDataFacade<QueryEdge::EdgeData>(server_paths);
|
query_data_facade = new InternalDataFacade<QueryEdge::EdgeData>(server_paths);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,6 +56,7 @@ class OSRM_impl
|
|||||||
private:
|
private:
|
||||||
void RegisterPlugin(BasePlugin *plugin);
|
void RegisterPlugin(BasePlugin *plugin);
|
||||||
PluginMap plugin_map;
|
PluginMap plugin_map;
|
||||||
|
ServerPaths server_paths;
|
||||||
bool use_shared_memory;
|
bool use_shared_memory;
|
||||||
SharedBarriers *barrier;
|
SharedBarriers *barrier;
|
||||||
// base class pointer to the objects
|
// base class pointer to the objects
|
||||||
|
@ -45,6 +45,109 @@ const static unsigned INIT_OK_START_ENGINE = 0;
|
|||||||
const static unsigned INIT_OK_DO_NOT_START_ENGINE = 1;
|
const static unsigned INIT_OK_DO_NOT_START_ENGINE = 1;
|
||||||
const static unsigned INIT_FAILED = -1;
|
const static unsigned INIT_FAILED = -1;
|
||||||
|
|
||||||
|
inline void populate_base_path(ServerPaths & server_paths)
|
||||||
|
{
|
||||||
|
// populate the server_path object
|
||||||
|
auto path_iterator = server_paths.find("base");
|
||||||
|
BOOST_ASSERT(server_paths.end() != path_iterator);
|
||||||
|
std::string base_string = path_iterator->second.string();
|
||||||
|
SimpleLogger().Write() << "populating base path: " << base_string;
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("hsgrdata");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".hsgr";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".hsgr not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("nodesdata");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".nodes";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".nodes not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("edgesdata");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".edges";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".edges not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("geometries");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".geometry";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".geometry not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("ramindex");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".ramIndex";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".ramIndex not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("fileindex");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".fileIndex";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".fileIndex not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("namesdata");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".names";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw OSRMException(base_string + ".namesIndex not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
path_iterator = server_paths.find("timestamp");
|
||||||
|
if (path_iterator != server_paths.end() &&
|
||||||
|
!boost::filesystem::is_regular_file(path_iterator->second))
|
||||||
|
{
|
||||||
|
path_iterator->second = base_string + ".timestamp";
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleLogger().Write() << "HSGR file:\t" << server_paths["hsgrdata"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Nodes file:\t" << server_paths["nodesdata"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Edges file:\t" << server_paths["edgesdata"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Geometry file:\t" << server_paths["geometries"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "RAM file:\t" << server_paths["ramindex"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Index file:\t" << server_paths["fileindex"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Names file:\t" << server_paths["namesdata"];
|
||||||
|
SimpleLogger().Write(logDEBUG) << "Timestamp file:\t" << server_paths["timestamp"];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// generate boost::program_options object for the routing part
|
// generate boost::program_options object for the routing part
|
||||||
inline unsigned GenerateServerProgramOptions(const int argc,
|
inline unsigned GenerateServerProgramOptions(const int argc,
|
||||||
const char *argv[],
|
const char *argv[],
|
||||||
@ -169,94 +272,6 @@ inline unsigned GenerateServerProgramOptions(const int argc,
|
|||||||
|
|
||||||
if (!use_shared_memory && option_variables.count("base"))
|
if (!use_shared_memory && option_variables.count("base"))
|
||||||
{
|
{
|
||||||
path_iterator = paths.find("base");
|
|
||||||
BOOST_ASSERT(paths.end() != path_iterator);
|
|
||||||
std::string base_string = path_iterator->second.string();
|
|
||||||
|
|
||||||
path_iterator = paths.find("hsgrdata");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".hsgr";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".hsgr not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("nodesdata");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".nodes";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".nodes not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("edgesdata");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".edges";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".edges not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("geometries");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".geometry";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".geometry not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("ramindex");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".ramIndex";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".ramIndex not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("fileindex");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".fileIndex";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".fileIndex not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("namesdata");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".names";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw OSRMException(base_string + ".namesIndex not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
path_iterator = paths.find("timestamp");
|
|
||||||
if (path_iterator != paths.end() &&
|
|
||||||
!boost::filesystem::is_regular_file(path_iterator->second))
|
|
||||||
{
|
|
||||||
path_iterator->second = base_string + ".timestamp";
|
|
||||||
}
|
|
||||||
|
|
||||||
return INIT_OK_START_ENGINE;
|
return INIT_OK_START_ENGINE;
|
||||||
}
|
}
|
||||||
if (use_shared_memory && !option_variables.count("base"))
|
if (use_shared_memory && !option_variables.count("base"))
|
||||||
|
12
routed.cpp
12
routed.cpp
@ -108,20 +108,10 @@ int main(int argc, const char *argv[])
|
|||||||
{
|
{
|
||||||
SimpleLogger().Write(logDEBUG) << "Loading from shared memory";
|
SimpleLogger().Write(logDEBUG) << "Loading from shared memory";
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
SimpleLogger().Write() << "HSGR file:\t" << server_paths["hsgrdata"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Nodes file:\t" << server_paths["nodesdata"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Edges file:\t" << server_paths["edgesdata"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Geometry file:\t" << server_paths["geometries"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "RAM file:\t" << server_paths["ramindex"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Index file:\t" << server_paths["fileindex"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Names file:\t" << server_paths["namesdata"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Timestamp file:\t" << server_paths["timestamp"];
|
|
||||||
SimpleLogger().Write(logDEBUG) << "Threads:\t" << requested_thread_num;
|
SimpleLogger().Write(logDEBUG) << "Threads:\t" << requested_thread_num;
|
||||||
SimpleLogger().Write(logDEBUG) << "IP address:\t" << ip_address;
|
SimpleLogger().Write(logDEBUG) << "IP address:\t" << ip_address;
|
||||||
SimpleLogger().Write(logDEBUG) << "IP port:\t" << ip_port;
|
SimpleLogger().Write(logDEBUG) << "IP port:\t" << ip_port;
|
||||||
}
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
int sig = 0;
|
int sig = 0;
|
||||||
sigset_t new_mask;
|
sigset_t new_mask;
|
||||||
|
Loading…
Reference in New Issue
Block a user