forked from openPMD/openPMD-api
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathParallelADIOS1IOHandler.hpp
66 lines (56 loc) · 1.98 KB
/
ParallelADIOS1IOHandler.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* Copyright 2017-2021 Fabian Koller
*
* This file is part of openPMD-api.
*
* openPMD-api is free software: you can redistribute it and/or modify
* it under the terms of of either the GNU General Public License or
* the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* openPMD-api is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License and the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU General Public License
* and the GNU Lesser General Public License along with openPMD-api.
* If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include "openPMD/config.hpp"
#include "openPMD/auxiliary/Export.hpp"
#include "openPMD/auxiliary/JSON_internal.hpp"
#include "openPMD/IO/AbstractIOHandler.hpp"
#include <future>
#include <memory>
#include <string>
#if openPMD_HAVE_ADIOS1
# include <queue>
#endif
namespace openPMD
{
class OPENPMDAPI_EXPORT ParallelADIOS1IOHandlerImpl;
class OPENPMDAPI_EXPORT ParallelADIOS1IOHandler : public AbstractIOHandler
{
friend class ParallelADIOS1IOHandlerImpl;
public:
# if openPMD_HAVE_MPI
ParallelADIOS1IOHandler(std::string path, Access, json::TracingJSON , MPI_Comm);
# else
ParallelADIOS1IOHandler(std::string path, Access, json::TracingJSON);
# endif
~ParallelADIOS1IOHandler() override;
std::string backendName() const override { return "MPI_ADIOS1"; }
std::future< void > flush() override;
#if openPMD_HAVE_ADIOS1
void enqueue(IOTask const&) override;
#endif
private:
#if openPMD_HAVE_ADIOS1
std::queue< IOTask > m_setup;
#endif
std::unique_ptr< ParallelADIOS1IOHandlerImpl > m_impl;
}; // ParallelADIOS1IOHandler
} // openPMD