14#if HIGHFIVE_CXX_STD >= 17
27inline DataTypeClass convert_type_class(
const H5T_class_t& tclass);
29inline hid_t create_string(std::size_t length);
33 return _hid == H5I_INVALID_HID;
37 return convert_type_class(detail::h5t_get_class(
_hid));
41 return detail::h5t_get_size(
_hid);
45 return detail::h5t_equal(
_hid, other.
_hid) > 0;
49 return !(*
this == other);
53 return detail::h5t_is_variable_str(
_hid) > 0;
61 return detail::h5t_equal(
_hid, H5T_STD_REF_OBJ) > 0;
70 detail::h5i_inc_ref(
_hid);
93 "Fixed-length, null-terminated need at least one byte to store the null-character.");
96 _hid = detail::h5t_copy(H5T_C_S1);
98 detail::h5t_set_size(
_hid, hsize_t(size));
99 detail::h5t_set_cset(
_hid, H5T_cset_t(character_set));
100 detail::h5t_set_strpad(
_hid, H5T_str_t(padding));
104 _hid = detail::h5t_copy(H5T_C_S1);
106 detail::h5t_set_size(
_hid, H5T_VARIABLE);
107 detail::h5t_set_cset(
_hid, H5T_cset_t(character_set));
113 _hid = detail::h5t_copy(H5T_NATIVE_CHAR);
118 _hid = detail::h5t_copy(H5T_NATIVE_SCHAR);
123 _hid = detail::h5t_copy(H5T_NATIVE_UCHAR);
129 _hid = detail::h5t_copy(H5T_NATIVE_SHORT);
134 _hid = detail::h5t_copy(H5T_NATIVE_USHORT);
140 _hid = detail::h5t_copy(H5T_NATIVE_INT);
145 _hid = detail::h5t_copy(H5T_NATIVE_UINT);
151 _hid = detail::h5t_copy(H5T_NATIVE_LONG);
156 _hid = detail::h5t_copy(H5T_NATIVE_ULONG);
162 _hid = detail::h5t_copy(H5T_NATIVE_LLONG);
167 _hid = detail::h5t_copy(H5T_NATIVE_ULLONG);
173 _hid = detail::h5t_copy(H5T_NATIVE_FLOAT);
178 _hid = detail::h5t_copy(H5T_NATIVE_DOUBLE);
183 _hid = detail::h5t_copy(H5T_NATIVE_LDOUBLE);
189 _hid = create_string(H5T_VARIABLE);
192#if HIGHFIVE_CXX_STD >= 17
196 _hid = detail::h5t_copy(H5T_NATIVE_B8);
202template <
size_t StrLen>
206 :
DataType(create_string(StrLen)) {}
214 CompoundType({{
"r", create_datatype<T>(), 0}, {
"i", create_datatype<T>(),
sizeof(T)}},
215 sizeof(std::complex<T>))) {
216 static_assert(std::is_arithmetic<T>::value,
217 "std::complex accepts only floating point and integral numbers.");
223 return {{
"FALSE", details::Boolean::HighFiveFalse}, {
"TRUE", details::Boolean::HighFiveTrue}};
231 "Missing specialization of AtomicType<T>. Therefore, type T is not supported by HighFive.");
239 _hid = detail::h5t_copy(H5T_STD_REF_OBJ);
244 if (detail::h5t_get_class(hid) == H5T_COMPOUND) {
245 auto number_of_members = detail::h5t_get_nmembers(hid);
246 if (number_of_members == -1) {
248 std::to_string(hid));
250 if (number_of_members == 0) {
252 std::to_string(hid));
255 auto member_type = detail::h5t_get_member_type(hid, 0);
257 detail::h5t_close(member_type);
259 }
else if (detail::h5t_get_class(hid) == H5T_STRING) {
262 return detail::h5t_get_size(hid);
281#define _H5_STRUCT_PADDING(current_size, member_size) \
282 (((member_size) >= (current_size)) \
283 ? (((member_size) - (current_size)) % (member_size)) \
284 : ((((member_size) - (((current_size) - (member_size)) % (member_size)))) % \
287inline void CompoundType::create(
size_t size) {
289 size_t current_size = 0, max_atomic_size = 0;
292 for (
auto& member: members) {
293 size_t member_size = detail::h5t_get_size(member.base_type.getId());
295 if (member_size == 0) {
296 throw DataTypeException(
"Cannot get size of DataType with hid: " +
297 std::to_string(member.base_type.getId()));
308 current_size = member.offset + member_size;
312 max_atomic_size = std::max(max_atomic_size, first_atomic_size);
319 _hid = detail::h5t_create(H5T_COMPOUND, size);
322 for (
const auto& member: members) {
323 detail::h5t_insert(
_hid, member.name.c_str(), member.offset, member.base_type.getId());
327#undef _H5_STRUCT_PADDING
331 object.
getId(), name.c_str(),
getId(), H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
337 _hid = detail::h5t_enum_create(
AtomicType<
typename std::underlying_type<T>::type>{}.
getId());
340 for (
const auto& member: members) {
341 detail::h5t_enum_insert(_hid, member.name.c_str(), &(member.value));
348 object.getId(), name.c_str(), getId(), H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
353inline hid_t create_string(
size_t length) {
354 hid_t _hid = detail::h5t_copy(H5T_C_S1);
355 detail::h5t_set_size(_hid, length);
356 detail::h5t_set_cset(_hid, H5T_CSET_UTF8);
361inline DataTypeClass convert_type_class(
const H5T_class_t& tclass) {
450 if (
sizeof(T) != t.
getSize()) {
451 std::ostringstream ss;
452 ss <<
"Size of array type " <<
sizeof(T) <<
" != that of memory datatype " << t.
getSize()
467 return create_datatype<HighFive::details::Boolean>();
#define HIGHFIVE_REGISTER_TYPE(type, function)
Macro to extend datatype of HighFive.
Definition H5DataType.hpp:363
#define _H5_STRUCT_PADDING(current_size, member_size)
Definition H5DataType_misc.hpp:281
AtomicType()
Definition H5DataType_misc.hpp:205
AtomicType()
Definition H5DataType_misc.hpp:212
create an HDF5 DataType from a C++ type
Definition H5DataType.hpp:189
AtomicType()
Definition H5DataType_misc.hpp:228
Create a compound HDF5 datatype.
Definition H5DataType.hpp:200
void commit(const Object &object, const std::string &name) const
Commit datatype into the given Object.
Definition H5DataType_misc.hpp:329
Exception specific to HighFive DataType interface.
Definition H5Exception.hpp:94
HDF5 Data Type.
Definition H5DataType.hpp:61
bool operator==(const DataType &other) const
Definition H5DataType_misc.hpp:44
bool isFixedLenStr() const
Returns whether the type is a fixed-length string.
Definition H5DataType_misc.hpp:56
size_t getSize() const
Returns the length (in bytes) of this type elements.
Definition H5DataType_misc.hpp:40
bool isVariableStr() const
Returns whether the type is a variable-length string.
Definition H5DataType_misc.hpp:52
bool empty() const noexcept
Check the DataType was default constructed.
Definition H5DataType_misc.hpp:32
std::string string() const
Returns a friendly description of the type (e.g. Float32)
Definition H5DataType_misc.hpp:76
DataTypeClass getClass() const
Return the fundamental type.
Definition H5DataType_misc.hpp:36
bool isReference() const
Returns whether the type is a Reference.
Definition H5DataType_misc.hpp:60
StringType asStringType() const
Returns this datatype as a StringType.
Definition H5DataType_misc.hpp:64
bool operator!=(const DataType &other) const
Definition H5DataType_misc.hpp:48
Create a enum HDF5 datatype.
Definition H5DataType.hpp:298
void commit(const Object &object, const std::string &name) const
Commit datatype into the given Object.
Definition H5DataType_misc.hpp:346
FixedLengthStringType(size_t size, StringPadding padding, CharacterSet character_set=CharacterSet::Ascii)
Create a fixed length string datatype.
Definition H5DataType_misc.hpp:88
Definition H5Object.hpp:35
hid_t getId() const noexcept
getId
Definition H5Object_misc.hpp:63
bool isValid() const noexcept
isValid
Definition H5Object_misc.hpp:59
hid_t _hid
Definition H5Object.hpp:86
Definition H5DataType.hpp:130
StringPadding getPadding() const
For fixed length stings return the padding.
Definition H5DataType_misc.hpp:80
CharacterSet getCharacterSet() const
For stings return the character set.
Definition H5DataType_misc.hpp:84
VariableLengthStringType(CharacterSet character_set=CharacterSet::Ascii)
Create a variable length string HDF5 datatype.
Definition H5DataType_misc.hpp:103
Definition assert_compatible_spaces.hpp:15
EnumType< details::Boolean > create_enum_boolean()
Definition H5DataType_misc.hpp:222
DataType create_and_check_datatype()
Create a DataType instance representing type T and perform a sanity check on its size.
Definition H5DataType_misc.hpp:434
DataType create_datatype()
Create a DataType instance representing type T.
Definition H5DataType_misc.hpp:427
CharacterSet
Definition H5DataType.hpp:125
DataType create_datatype< bool >()
Definition H5DataType_misc.hpp:466
size_t find_first_atomic_member_size(hid_t hid)
Definition H5DataType_misc.hpp:242
DataTypeClass
Enum of Fundamental data classes.
Definition H5DataType.hpp:31
StringPadding
Definition string_padding.hpp:7