openPMD-api
 
Loading...
Searching...
No Matches
ParallelHDF5IOHandlerImpl.hpp
1/* Copyright 2017-2025 Fabian Koller, Axel Huebl, Franz Poeschel
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/AbstractIOHandlerImpl.hpp"
24#include "openPMD/config.hpp"
25
26#if openPMD_HAVE_MPI
27#include <mpi.h>
28#if openPMD_HAVE_HDF5
29#include "openPMD/IO/HDF5/HDF5IOHandlerImpl.hpp"
30#include "openPMD/auxiliary/JSON_internal.hpp"
31#endif
32#endif
33
34namespace openPMD
35{
36#if openPMD_HAVE_HDF5 && openPMD_HAVE_MPI
37class ParallelHDF5IOHandlerImpl : public HDF5IOHandlerImpl
38{
39public:
40 ParallelHDF5IOHandlerImpl(AbstractIOHandler *, MPI_Comm);
41 ~ParallelHDF5IOHandlerImpl() override;
42
43 MPI_Comm m_mpiComm;
44 MPI_Info m_mpiInfo;
45
46 std::future<void> flush(internal::ParsedFlushParams &);
47}; // ParallelHDF5IOHandlerImpl
48#else
50{}; // ParallelHDF5IOHandlerImpl
51#endif
52} // namespace openPMD
Interface for communicating between logical and physically persistent data.
Definition AbstractIOHandler.hpp:206
Definition ParallelHDF5IOHandlerImpl.hpp:38
Public definitions of openPMD-api.
Definition Date.cpp:29
Definition FlushParametersInternal.hpp:32