openPMD-api
 
Loading...
Searching...
No Matches
ParallelHDF5IOHandler.hpp
1/* Copyright 2017-2025 Fabian Koller, Axel Huebl, Franz Poeschel, Luca Fedeli
2 *
3 * This file is part of openPMD-api.
4 *
5 * openPMD-api is free software: you can redistribute it and/or modify
6 * it under the terms of of either the GNU General Public License or
7 * the GNU Lesser General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * openPMD-api is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License and the GNU Lesser General Public License
15 * for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * and the GNU Lesser General Public License along with openPMD-api.
19 * If not, see <http://www.gnu.org/licenses/>.
20 */
21#pragma once
22
23#include "openPMD/IO/AbstractIOHandler.hpp"
24#include "openPMD/auxiliary/JSON_internal.hpp"
25#include "openPMD/config.hpp"
26
27#include <future>
28#include <memory>
29#include <string>
30
31namespace openPMD
32{
34
35class ParallelHDF5IOHandler : public AbstractIOHandler
36{
37public:
38#if openPMD_HAVE_MPI
39 ParallelHDF5IOHandler(
40 std::optional<std::unique_ptr<AbstractIOHandler>> initialize_from,
41 std::string path,
42 Access,
43 MPI_Comm,
44 json::TracingJSON config);
45#else
46 ParallelHDF5IOHandler(
47 std::optional<std::unique_ptr<AbstractIOHandler>> initialize_from,
48 std::string const &path,
49 Access,
50 json::TracingJSON config);
51#endif
52 ~ParallelHDF5IOHandler() override;
53
54 std::string backendName() const override
55 {
56 return "MPI_HDF5";
57 }
58
59 std::future<void> flush(internal::ParsedFlushParams &) override;
60
61private:
62 std::unique_ptr<ParallelHDF5IOHandlerImpl> m_impl;
63}; // ParallelHDF5IOHandler
64} // namespace openPMD
std::future< void > flush(internal::ParsedFlushParams &) override
Process operations in queue according to FIFO.
Definition ParallelHDF5IOHandler.cpp:79
std::string backendName() const override
The currently used backend.
Definition ParallelHDF5IOHandler.hpp:54
Definition ParallelHDF5IOHandlerImpl.hpp:38
Extend nlohmann::json with tracing of which keys have been accessed by operator[]().
Definition JSON_internal.hpp:69
Public definitions of openPMD-api.
Definition Date.cpp:29
Access
File access mode to use during IO.
Definition Access.hpp:58
Definition FlushParametersInternal.hpp:32