h5cpp  0.3.3
A modern C++ wrapper for the HDF5 C library
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
dataset_transfer.hpp
Go to the documentation of this file.
1 //
2 // (c) Copyright 2017 DESY,ESS
3 //
4 // This file is part of h5cpp.
5 //
6 // This library is free software; you can redistribute it and/or modify it
7 // under the terms of the GNU Lesser General Public License as published
8 // by the Free Software Foundation; either version 2.1 of the License, or
9 // (at your option) any later version.
10 //
11 // This library is distributed in the hope that it will be useful, but
12 // WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY
13 // or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
14 // License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public License
17 // along with this library; if not, write to the
18 // Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor
19 // Boston, MA 02110-1301 USA
20 // ===========================================================================
21 //
22 // Authors:
23 // Eugen Wintersberger <eugen.wintersberger@desy.de>
24 // Martin Shetty <martin.shetty@esss.se>
25 // Created on: Aug 28, 2017
26 //
27 #pragma once
28 
30 #include <h5cpp/core/windows.hpp>
31 
32 namespace hdf5 {
33 namespace property {
34 
35 #ifdef WITH_MPI
36 enum class MPITransferMode : std::underlying_type<H5FD_mpio_xfer_t>::type
37 {
38  INDEPENDENT = H5FD_MPIO_INDEPENDENT,
39  COLLECTIVE = H5FD_MPIO_COLLECTIVE
40 };
41 
42 std::ostream &operator<<(std::ostream &stream,const MPITransferMode &mode);
43 
44 enum class MPIChunkOption : std::underlying_type<H5FD_mpio_chunk_opt_t>::type
45 {
46  ONE_LINK_CHUNKED = H5FD_MPIO_CHUNK_ONE_IO,
47  MULTI_CHUNK = H5FD_MPIO_CHUNK_MULTI_IO
48 };
49 
50 std::ostream &operator<<(std::ostream &stream,const MPIChunkOption &option);
51 #endif
52 
54  public:
57 
58  explicit DatasetTransferList(ObjectHandle &&handle);
59 
60 #ifdef WITH_MPI
61  void mpi_transfer_mode(MPITransferMode mode) const;
62  MPITransferMode mpi_transfer_mode() const;
63 
64  void mpi_chunk_option(MPIChunkOption option) const;
65  MPIChunkOption mpi_chunk_option() const;
66 
67 
68 #endif
69 };
70 
71 } // namespace property
72 } // namespace hdf5
Wrapper for hid_t object identifiers.
Definition: object_handle.hpp:66
Definition: attribute.hpp:43
DLL_EXPORT std::ostream & operator<<(std::ostream &stream, const DatasetFillValueStatus &status)
Definition: dataset_transfer.hpp:53
#define DLL_EXPORT
Definition: windows.hpp:35
base class for property lists
Definition: property_list.hpp:45