Merge pull request #5795 from atgeirr/fix-time_point-serialization

Do not serialize time_point via time_t.
This commit is contained in:
Atgeirr Flø Rasmussen 2024-12-13 14:27:44 +01:00 committed by GitHub
commit a0614bcd9c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -118,7 +118,7 @@ unpack(std::string& data,
std::size_t Packing<false,time_point>:: std::size_t Packing<false,time_point>::
packSize(const time_point&, Opm::Parallel::MPIComm comm) packSize(const time_point&, Opm::Parallel::MPIComm comm)
{ {
return Packing<true,std::time_t>::packSize(std::time_t(), comm); return Packing<true, time_point::duration::rep>::packSize(time_point::duration::rep(), comm);
} }
void Packing<false,time_point>:: void Packing<false,time_point>::
@ -127,8 +127,7 @@ pack(const time_point& data,
std::size_t& position, std::size_t& position,
Parallel::MPIComm comm) Parallel::MPIComm comm)
{ {
Packing<true,std::time_t>::pack(TimeService::to_time_t(data), Packing<true, time_point::duration::rep>::pack(data.time_since_epoch().count(), buffer, position, comm);
buffer, position, comm);
} }
void Packing<false,time_point>:: void Packing<false,time_point>::
@ -137,9 +136,9 @@ unpack(time_point& data,
std::size_t& position, std::size_t& position,
Parallel::MPIComm comm) Parallel::MPIComm comm)
{ {
std::time_t res; time_point::duration::rep res;
Packing<true,std::time_t>::unpack(res, buffer, position, comm); Packing<true, time_point::duration::rep>::unpack(res, buffer, position, comm);
data = TimeService::from_time_t(res); data = time_point(time_point::duration(res));
} }
template struct Packing<false,std::bitset<3>>; template struct Packing<false,std::bitset<3>>;