#ifndef OSRM_PARTITIONER_SERILIZATION_HPP #define OSRM_PARTITIONER_SERILIZATION_HPP #include "partitioner/serialization.hpp" #include "storage/io.hpp" namespace osrm { namespace partitioner { namespace files { // read .osrm.partition file template inline void readPartition(const boost::filesystem::path &path, MultiLevelPartitionT &mlp) { static_assert(std::is_same::value || std::is_same::value, ""); const auto fingerprint = storage::tar::FileReader::VerifyFingerprint; storage::tar::FileReader reader{path, fingerprint}; serialization::read(reader, "/mld/multilevelpartition", mlp); } // writes .osrm.partition file template inline void writePartition(const boost::filesystem::path &path, const MultiLevelPartitionT &mlp) { static_assert(std::is_same::value || std::is_same::value, ""); const auto fingerprint = storage::tar::FileWriter::GenerateFingerprint; storage::tar::FileWriter writer{path, fingerprint}; serialization::write(writer, "/mld/multilevelpartition", mlp); } // reads .osrm.cells file template inline void readCells(const boost::filesystem::path &path, CellStorageT &storage) { static_assert(std::is_same::value || std::is_same::value, ""); const auto fingerprint = storage::tar::FileReader::VerifyFingerprint; storage::tar::FileReader reader{path, fingerprint}; serialization::read(reader, "/mld/cellstorage", storage); } // writes .osrm.cells file template inline void writeCells(const boost::filesystem::path &path, CellStorageT &storage) { static_assert(std::is_same::value || std::is_same::value, ""); const auto fingerprint = storage::tar::FileWriter::GenerateFingerprint; storage::tar::FileWriter writer{path, fingerprint}; serialization::write(writer, "/mld/cellstorage", storage); } // reads .osrm.mldgr file template inline void readGraph(const boost::filesystem::path &path, MultiLevelGraphT &graph, std::uint32_t &connectivity_checksum) { static_assert(std::is_same::value, ""); storage::tar::FileReader reader{path, storage::tar::FileReader::VerifyFingerprint}; reader.ReadInto("/mld/connectivity_checksum", connectivity_checksum); serialization::read(reader, "/mld/multilevelgraph", graph); } // writes .osrm.mldgr file template inline void writeGraph(const boost::filesystem::path &path, const MultiLevelGraphT &graph, const std::uint32_t connectivity_checksum) { static_assert(std::is_same::value, ""); storage::tar::FileWriter writer{path, storage::tar::FileWriter::GenerateFingerprint}; writer.WriteElementCount64("/mld/connectivity_checksum", 1); writer.WriteFrom("/mld/connectivity_checksum", connectivity_checksum); serialization::write(writer, "/mld/multilevelgraph", graph); } } } } #endif