HighFive 3.1.1
HighFive - Header-only C++ HDF5 interface
Loading...
Searching...
No Matches
H5File.hpp
Go to the documentation of this file.
1/*
2 * Copyright (c), 2017, Adrien Devresse <adrien.devresse@epfl.ch>
3 *
4 * Distributed under the Boost Software License, Version 1.0.
5 * (See accompanying file LICENSE_1_0.txt or copy at
6 * http://www.boost.org/LICENSE_1_0.txt)
7 *
8 */
9#pragma once
10
11#include <string>
12#include <type_traits>
13
14#include "H5Object.hpp"
15#include "H5PropertyList.hpp"
18
19namespace HighFive {
20
21
25class File: public Object, public NodeTraits<File>, public AnnotateTraits<File> {
26 public:
28
29 enum class AccessMode {
30 None = 0x00u,
32 ReadOnly = 0x01u,
34 ReadWrite = 0x02u,
36 Truncate = 0x04u,
38 Excl = 0x08u,
40 Debug = 0x10u,
42 Create = 0x20u,
44 ReadSWMR = 0x40u,
46 WriteSWMR = 0x80u,
51 };
52
56 constexpr static AccessMode Excl = AccessMode::Excl;
63
71 explicit File(const std::string& filename,
72 AccessMode openFlags = ReadOnly,
73 const FileAccessProps& fileAccessProps = FileAccessProps::Default());
74
83 File(const std::string& filename,
84 AccessMode access_mode,
85 const FileCreateProps& fileCreateProps,
86 const FileAccessProps& fileAccessProps = FileAccessProps::Default());
87
89 File(File&& other) noexcept = default;
90
92 File& operator=(File&& other) = default;
93
95 File(const File& other) = default;
96
98 File& operator=(const File& other) = default;
99
103 const std::string& getName() const;
104
106 std::string getPath() const noexcept {
107 return "/";
108 }
109
111 hsize_t getMetadataBlockSize() const;
112
114 std::pair<H5F_libver_t, H5F_libver_t> getVersionBounds() const;
115
116#if H5_VERSION_GE(1, 10, 1)
118 H5F_fspace_strategy_t getFileSpaceStrategy() const;
119
121 hsize_t getFileSpacePageSize() const;
122#endif
123
129 void flush();
130
131#if H5_VERSION_GE(1, 10, 0)
133 void startSWMRWrite();
134#endif
135
138 return details::get_plist<FileCreateProps>(*this, H5Fget_create_plist);
139 }
140
143 return details::get_plist<FileAccessProps>(*this, H5Fget_access_plist);
144 }
145
147 size_t getFileSize() const;
148
155 size_t getFreeSpace() const;
156
157 protected:
158 File() = default;
159 using Object::Object;
160
161 private:
162 mutable std::string _filename{};
163
164 template <typename>
165 friend class PathTraits;
166};
167
169 using int_t = std::underlying_type<File::AccessMode>::type;
170 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) | static_cast<int_t>(rhs));
171}
172
174 using int_t = std::underlying_type<File::AccessMode>::type;
175 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) & static_cast<int_t>(rhs));
176}
177
179 using int_t = std::underlying_type<File::AccessMode>::type;
180 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) ^ static_cast<int_t>(rhs));
181}
182
184 using int_t = std::underlying_type<File::AccessMode>::type;
185 return static_cast<File::AccessMode>(~static_cast<int_t>(mode));
186}
187
189 lhs = lhs | rhs;
190 return lhs;
191}
192
194 lhs = lhs & rhs;
195 return lhs;
196}
197
199 lhs = lhs ^ rhs;
200 return lhs;
201}
202
203inline bool any(File::AccessMode mode) {
204 return mode != File::AccessMode::None;
205}
206
207
208} // namespace HighFive
209
210// H5File is the main user constructible -> bring in implementation headers
212#include "bits/H5File_misc.hpp"
Definition H5Annotate_traits.hpp:18
File class.
Definition H5File.hpp:25
FileCreateProps getCreatePropertyList() const
Get the list of properties for creation of this file.
Definition H5File.hpp:137
size_t getFileSize() const
Get the size of this file in bytes.
Definition H5File_misc.hpp:148
static constexpr AccessMode Truncate
Definition H5File.hpp:55
static constexpr AccessMode Create
Definition H5File.hpp:58
File(File &&other) noexcept=default
Keeps reference count constant, and invalidates other.
std::pair< H5F_libver_t, H5F_libver_t > getVersionBounds() const
Returns the HDF5 version compatibility bounds.
Definition H5File_misc.hpp:113
void flush()
flush
Definition H5File_misc.hpp:138
static constexpr AccessMode ReadOnly
Definition H5File.hpp:53
size_t getFreeSpace() const
Get the amount of tracked, unused space in bytes.
Definition H5File_misc.hpp:154
AccessMode
Definition H5File.hpp:29
@ Excl
Open flag: Open will fail if file already exist.
@ ReadOnly
Open flag: Read only access.
@ WriteSWMR
Open flag: Open in SWMR write.
@ OpenOrCreate
Derived open flag: Opens RW or exclusively creates.
@ Create
Open flag: Create non existing file.
@ ReadWrite
Open flag: Read Write access.
@ Debug
Open flag: Open in debug mode.
@ Truncate
Open flag: Truncate a file if already existing.
@ ReadSWMR
Open flag: Open in SWMR read.
@ Overwrite
Derived open flag: common write mode (=ReadWrite|Create|Truncate)
static constexpr AccessMode WriteSWMR
Definition H5File.hpp:62
FileAccessProps getAccessPropertyList() const
Get the list of properties for accession of this file.
Definition H5File.hpp:142
hsize_t getMetadataBlockSize() const
Returns the block size for metadata in bytes.
Definition H5File_misc.hpp:108
static constexpr AccessMode Excl
Definition H5File.hpp:56
File & operator=(File &&other)=default
Keeps reference count constant, and invalidates other.
File(const File &other)=default
Increments reference count, keeps other valid.
File & operator=(const File &other)=default
Increments reference count, keeps other valid.
File()=default
static const ObjectType type
Definition H5File.hpp:27
static constexpr AccessMode OpenOrCreate
Definition H5File.hpp:60
const std::string & getName() const
Return the name of the file.
Definition H5File_misc.hpp:99
static constexpr AccessMode ReadWrite
Definition H5File.hpp:54
static constexpr AccessMode ReadSWMR
Definition H5File.hpp:61
static constexpr AccessMode Overwrite
Definition H5File.hpp:59
static constexpr AccessMode Debug
Definition H5File.hpp:57
std::string getPath() const noexcept
Object path of a File is always "/".
Definition H5File.hpp:106
NodeTraits: Base class for Group and File.
Definition H5Node_traits.hpp:28
Definition H5Object.hpp:36
Object()
Definition H5Object_misc.hpp:20
Definition H5Path_traits.hpp:16
HDF5 property Lists.
Definition H5PropertyList.hpp:138
static const PropertyList< T > & Default() noexcept
Return the Default property type object.
Definition H5PropertyList.hpp:155
Definition assert_compatible_spaces.hpp:15
File::AccessMode operator&=(File::AccessMode &lhs, File::AccessMode rhs)
Definition H5File.hpp:193
bool any(File::AccessMode mode)
Definition H5File.hpp:203
File::AccessMode operator^=(File::AccessMode &lhs, File::AccessMode rhs)
Definition H5File.hpp:198
File::AccessMode operator~(File::AccessMode mode)
Definition H5File.hpp:183
DataTypeClass operator|(DataTypeClass lhs, DataTypeClass rhs)
Definition H5DataType.hpp:46
DataTypeClass operator&(DataTypeClass lhs, DataTypeClass rhs)
Definition H5DataType.hpp:51
ObjectType
Enum of the types of objects (H5O api)
Definition H5Object.hpp:25
const File::AccessMode & operator|=(File::AccessMode &lhs, File::AccessMode rhs)
Definition H5File.hpp:188
File::AccessMode operator^(File::AccessMode lhs, File::AccessMode rhs)
Definition H5File.hpp:178