2017-04-04 18:00:17 -04:00
|
|
|
#ifndef OSRM_STORAGE_SERIALIZATION_HPP
|
|
|
|
#define OSRM_STORAGE_SERIALIZATION_HPP
|
|
|
|
|
2017-04-09 09:59:55 -04:00
|
|
|
#include "util/integer_range.hpp"
|
2017-04-10 04:35:52 -04:00
|
|
|
#include "util/vector_view.hpp"
|
2017-04-04 18:00:17 -04:00
|
|
|
|
|
|
|
#include "storage/io.hpp"
|
|
|
|
|
2017-04-09 09:59:55 -04:00
|
|
|
#include <cstdint>
|
|
|
|
|
2017-04-04 18:00:17 -04:00
|
|
|
namespace osrm
|
|
|
|
{
|
|
|
|
namespace storage
|
|
|
|
{
|
|
|
|
namespace serialization
|
|
|
|
{
|
2017-04-10 04:35:52 -04:00
|
|
|
template <typename T> inline void read(storage::io::FileReader &reader, stxxl::vector<T> &vec)
|
2017-04-09 09:59:55 -04:00
|
|
|
{
|
|
|
|
auto size = reader.ReadOne<std::uint64_t>();
|
|
|
|
vec.reserve(size);
|
|
|
|
for (auto idx : util::irange<std::size_t>(0, size))
|
|
|
|
{
|
|
|
|
(void)idx;
|
|
|
|
vec.push_back(reader.ReadOne<T>());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
inline void write(storage::io::FileWriter &writer, const stxxl::vector<T> &vec)
|
|
|
|
{
|
|
|
|
writer.WriteOne(vec.size());
|
|
|
|
for (auto idx : util::irange<std::size_t>(0, vec.size()))
|
|
|
|
{
|
|
|
|
writer.WriteOne<T>(vec[idx]);
|
|
|
|
}
|
|
|
|
}
|
2017-04-04 18:00:17 -04:00
|
|
|
|
|
|
|
template <typename T> void read(io::FileReader &reader, std::vector<T> &data)
|
|
|
|
{
|
|
|
|
const auto count = reader.ReadElementCount64();
|
|
|
|
data.resize(count);
|
|
|
|
reader.ReadInto(data.data(), count);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> void write(io::FileWriter &writer, const std::vector<T> &data)
|
|
|
|
{
|
|
|
|
const auto count = data.size();
|
|
|
|
writer.WriteElementCount64(count);
|
|
|
|
return writer.WriteFrom(data.data(), count);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> void read(io::FileReader &reader, util::vector_view<T> &data)
|
|
|
|
{
|
|
|
|
const auto count = reader.ReadElementCount64();
|
2017-04-04 19:01:00 -04:00
|
|
|
BOOST_ASSERT(data.size() == count);
|
2017-04-04 18:00:17 -04:00
|
|
|
reader.ReadInto(data.data(), count);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> void write(io::FileWriter &writer, const util::vector_view<T> &data)
|
|
|
|
{
|
|
|
|
const auto count = data.size();
|
|
|
|
writer.WriteElementCount64(count);
|
|
|
|
return writer.WriteFrom(data.data(), count);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|