23 #include "openPMD/config.hpp" 24 #include "openPMD/auxiliary/Export.hpp" 25 #include "openPMD/IO/AbstractIOHandler.hpp" 27 #if openPMD_HAVE_ADIOS1 && openPMD_HAVE_MPI 28 # include "openPMD/IO/AbstractIOHandlerImpl.hpp" 30 # include <adios_read.h> 36 #if openPMD_HAVE_ADIOS1 37 # include <unordered_map> 38 # include <unordered_set> 44 #if openPMD_HAVE_ADIOS1 && openPMD_HAVE_MPI 53 std::future< void > flush()
override;
76 virtual int64_t open_write(
Writable *);
77 virtual ADIOS_FILE* open_read(std::string
const & name);
79 void close(ADIOS_FILE*);
80 int64_t initialize_group(std::string
const& name);
81 void flush_attribute(int64_t group, std::string
const& name,
Attribute const&);
84 ADIOS_READ_METHOD m_readMethod;
85 std::unordered_map< Writable*, std::shared_ptr< std::string > > m_filePaths;
86 std::unordered_map< std::shared_ptr< std::string >, int64_t > m_groups;
87 std::unordered_map< std::shared_ptr< std::string >,
bool > m_existsOnDisk;
88 std::unordered_map< std::shared_ptr< std::string >, int64_t > m_openWriteFileHandles;
89 std::unordered_map< std::shared_ptr< std::string >, ADIOS_FILE* > m_openReadFileHandles;
90 std::unordered_map< ADIOS_FILE*, std::vector< ADIOS_SELECTION* > > m_scheduledReads;
91 std::unordered_map< int64_t, std::unordered_map< std::string, Attribute > > m_attributeWrites;
101 class OPENPMDAPI_EXPORT ParallelADIOS1IOHandlerImpl
Definition: IOTask.hpp:139
Definition: IOTask.hpp:223
Definition: IOTask.hpp:320
Definition: IOTask.hpp:123
Varidic datatype supporting at least all formats for attributes specified in the openPMD standard...
Definition: Attribute.hpp:50
Definition: IOTask.hpp:153
Definition: IOTask.hpp:412
Interface for communicating between logical and physically persistent data.
Definition: AbstractIOHandler.hpp:68
Public definitions of openPMD-api.
Definition: Date.cpp:29
Layer to mirror structure of logical data and persistent data in file.
Definition: Writable.hpp:55
Definition: IOTask.hpp:365
Definition: IOTask.hpp:475
Definition: IOTask.hpp:107
Definition: IOTask.hpp:516
Definition: IOTask.hpp:394
Definition: IOTask.hpp:299
Definition: IOTask.hpp:169
Definition: AbstractIOHandlerImpl.hpp:35
Definition: IOTask.hpp:428
Definition: IOTask.hpp:256
Definition: IOTask.hpp:447
Definition: IOTask.hpp:281
Definition: IOTask.hpp:207
Definition: IOTask.hpp:336
Definition: IOTask.hpp:239
Definition: ParallelADIOS1IOHandlerImpl.hpp:45