osrm-backend/include/extractor/extraction_containers.hpp

73 lines
2.4 KiB
C++
Raw Normal View History

#ifndef EXTRACTION_CONTAINERS_HPP
#define EXTRACTION_CONTAINERS_HPP
2016-05-27 15:05:04 -04:00
#include "extractor/first_and_last_segment_of_way.hpp"
#include "extractor/internal_extractor_edge.hpp"
#include "extractor/query_node.hpp"
2016-01-02 11:13:44 -05:00
#include "extractor/restriction.hpp"
2016-05-27 15:05:04 -04:00
#include "extractor/scripting_environment.hpp"
2017-03-04 05:52:40 -05:00
#include "storage/io.hpp"
2016-01-05 10:51:13 -05:00
namespace osrm
{
namespace extractor
{
/**
* Uses memory containers to store all the data that
* is collected by the extractor callbacks.
*
* The data is the filtered, aggregated and finally written to disk.
*/
2014-05-09 10:17:31 -04:00
class ExtractionContainers
{
void PrepareNodes();
void PrepareRestrictions();
void PrepareEdges(ScriptingEnvironment &scripting_environment);
2017-03-04 05:52:40 -05:00
void WriteNodes(storage::io::FileWriter &file_out) const;
void WriteEdges(storage::io::FileWriter &file_out) const;
void WriteCharData(const std::string &file_name);
2016-01-05 06:04:04 -05:00
2014-05-09 10:17:31 -04:00
public:
using NodeIDVector = std::vector<OSMNodeID>;
using NodeVector = std::vector<QueryNode>;
using EdgeVector = std::vector<InternalExtractorEdge>;
using WayIDStartEndVector = std::vector<FirstAndLastSegmentOfWay>;
using NameCharData = std::vector<unsigned char>;
using NameOffsets = std::vector<unsigned>;
2013-11-13 15:23:44 -05:00
std::vector<OSMNodeID> barrier_nodes;
std::vector<OSMNodeID> traffic_signals;
NodeIDVector used_node_id_list;
NodeVector all_nodes_list;
EdgeVector all_edges_list;
NameCharData name_char_data;
NameOffsets name_offsets;
// an adjacency array containing all turn lane masks
WayIDStartEndVector way_start_end_id_list;
unsigned max_internal_node_id;
2017-07-27 05:42:13 -04:00
// list of restrictions before we transform them into the output types. Input containers
// reference OSMNodeIDs. We can only transform them to the correct internal IDs after we've read
// everything. Without a multi-parse approach, we have to remember the output restrictions
// before converting them to the internal formats
std::vector<InputConditionalTurnRestriction> restrictions_list;
// turn restrictions split into conditional and unconditional turn restrictions
std::vector<ConditionalTurnRestriction> conditional_turn_restrictions;
std::vector<TurnRestriction> unconditional_turn_restrictions;
ExtractionContainers();
2013-08-05 11:28:57 -04:00
void PrepareData(ScriptingEnvironment &scripting_environment,
const std::string &osrm_path,
const std::string &names_data_path);
};
2016-01-05 10:51:13 -05:00
}
}
#endif /* EXTRACTION_CONTAINERS_HPP */