HighFive 3.0.0
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,
47 };
48
52 constexpr static AccessMode Excl = AccessMode::Excl;
57
65 explicit File(const std::string& filename,
66 AccessMode openFlags = ReadOnly,
67 const FileAccessProps& fileAccessProps = FileAccessProps::Default());
68
77 File(const std::string& filename,
78 AccessMode access_mode,
79 const FileCreateProps& fileCreateProps,
80 const FileAccessProps& fileAccessProps = FileAccessProps::Default());
81
83 File(File&& other) noexcept = default;
84
86 File& operator=(File&& other) = default;
87
89 File(const File& other) = default;
90
92 File& operator=(const File& other) = default;
93
97 const std::string& getName() const;
98
100 std::string getPath() const noexcept {
101 return "/";
102 }
103
105 hsize_t getMetadataBlockSize() const;
106
108 std::pair<H5F_libver_t, H5F_libver_t> getVersionBounds() const;
109
110#if H5_VERSION_GE(1, 10, 1)
112 H5F_fspace_strategy_t getFileSpaceStrategy() const;
113
115 hsize_t getFileSpacePageSize() const;
116#endif
117
123 void flush();
124
127 return details::get_plist<FileCreateProps>(*this, H5Fget_create_plist);
128 }
129
132 return details::get_plist<FileAccessProps>(*this, H5Fget_access_plist);
133 }
134
136 size_t getFileSize() const;
137
144 size_t getFreeSpace() const;
145
146 protected:
147 File() = default;
148 using Object::Object;
149
150 private:
151 mutable std::string _filename{};
152
153 template <typename>
154 friend class PathTraits;
155};
156
158 using int_t = std::underlying_type<File::AccessMode>::type;
159 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) | static_cast<int_t>(rhs));
160}
161
163 using int_t = std::underlying_type<File::AccessMode>::type;
164 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) & static_cast<int_t>(rhs));
165}
166
168 using int_t = std::underlying_type<File::AccessMode>::type;
169 return static_cast<File::AccessMode>(static_cast<int_t>(lhs) ^ static_cast<int_t>(rhs));
170}
171
173 using int_t = std::underlying_type<File::AccessMode>::type;
174 return static_cast<File::AccessMode>(~static_cast<int_t>(mode));
175}
176
178 lhs = lhs | rhs;
179 return lhs;
180}
181
183 lhs = lhs & rhs;
184 return lhs;
185}
186
188 lhs = lhs ^ rhs;
189 return lhs;
190}
191
192inline bool any(File::AccessMode mode) {
193 return mode != File::AccessMode::None;
194}
195
196
197} // namespace HighFive
198
199// H5File is the main user constructible -> bring in implementation headers
201#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:126
size_t getFileSize() const
Get the size of this file in bytes.
Definition H5File_misc.hpp:130
static constexpr AccessMode Truncate
Definition H5File.hpp:51
static constexpr AccessMode Create
Definition H5File.hpp:54
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:101
void flush()
flush
Definition H5File_misc.hpp:126
static constexpr AccessMode ReadOnly
Definition H5File.hpp:49
size_t getFreeSpace() const
Get the amount of tracked, unused space in bytes.
Definition H5File_misc.hpp:136
AccessMode
Definition H5File.hpp:29
@ Excl
Open flag: Open will fail if file already exist.
@ ReadOnly
Open flag: Read only access.
@ 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.
@ Overwrite
Derived open flag: common write mode (=ReadWrite|Create|Truncate)
FileAccessProps getAccessPropertyList() const
Get the list of properties for accession of this file.
Definition H5File.hpp:131
hsize_t getMetadataBlockSize() const
Returns the block size for metadata in bytes.
Definition H5File_misc.hpp:96
static constexpr AccessMode Excl
Definition H5File.hpp:52
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:56
const std::string & getName() const
Return the name of the file.
Definition H5File_misc.hpp:87
static constexpr AccessMode ReadWrite
Definition H5File.hpp:50
static constexpr AccessMode Overwrite
Definition H5File.hpp:55
static constexpr AccessMode Debug
Definition H5File.hpp:53
std::string getPath() const noexcept
Object path of a File is always "/".
Definition H5File.hpp:100
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:182
bool any(File::AccessMode mode)
Definition H5File.hpp:192
File::AccessMode operator^=(File::AccessMode &lhs, File::AccessMode rhs)
Definition H5File.hpp:187
File::AccessMode operator~(File::AccessMode mode)
Definition H5File.hpp:172
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:177
File::AccessMode operator^(File::AccessMode lhs, File::AccessMode rhs)
Definition H5File.hpp:167