blob: 5424bdb122cda3d56e547c3e8a199ce02041fb91 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
|
#include <string>
#include "H5Include.h"
#include "H5RefCounter.h"
#include "H5Exception.h"
#include "H5IdComponent.h"
#include "H5PropList.h"
#include "H5Object.h"
#include "H5AbstractDs.h"
#include "H5Alltypes.h"
#ifndef H5_NO_NAMESPACE
namespace H5 {
#endif
// Default constructor
AbstractDs::AbstractDs() : H5Object() {}
// Constructor that takes an id
AbstractDs::AbstractDs( const hid_t ds_id ) : H5Object( ds_id ) {}
// Copy constructor: makes copy of the original object; simply invokes
// base-class copy constructor.
AbstractDs::AbstractDs( const AbstractDs& original ) : H5Object( original ) {}
// Returns the class of the datatype that is used by this dataset
H5T_class_t AbstractDs::getTypeClass() const
{
// Gets the datatype used by this dataset or attribute.
// p_getType calls either H5Dget_type or H5Aget_type depending on
// which object invokes getTypeClass
DataType datatype( p_getType());
// Gets the class of the datatype and validate it before returning
H5T_class_t type_class = H5Tget_class( datatype.getId());
if( type_class != H5T_NO_CLASS )
return( type_class );
else
{
throw DataTypeIException();
}
}
// Returns the generic datatype of this abstract dataset which
// can be a dataset or an attribute.
DataType AbstractDs::getDataType() const
{
// Gets the id of the datatype used by this dataset or attribute.
// p_getType calls either H5Dget_type or H5Aget_type depending on
// which object invokes getTypeClass
hid_t datatype_id = p_getType(); // returned value is already validated
// Create and return the DataType object
DataType datatype( datatype_id );
return( datatype );
}
// Returns the enumeration datatype of this abstract dataset which
// can be a dataset or an attribute.
EnumType AbstractDs::getEnumType() const
{
EnumType enumtype( p_getType());
return( enumtype );
}
// Returns the compound datatype of this abstract dataset which
// can be a dataset or an attribute.
CompType AbstractDs::getCompType() const
{
CompType comptype( p_getType());
return( comptype );
}
// Returns the integer datatype of this abstract dataset which
// can be a dataset or an attribute.
IntType AbstractDs::getIntType() const
{
IntType inttype( p_getType());
return( inttype );
}
// Returns the floating-point datatype of this abstract dataset which
// can be a dataset or an attribute.
FloatType AbstractDs::getFloatType() const
{
FloatType floatype( p_getType());
return( floatype );
}
// Returns the string datatype of this abstract dataset which
// can be a dataset or an attribute.
StrType AbstractDs::getStrType() const
{
StrType strtype( p_getType());
return( strtype );
}
/* This version of getDataType is older style. New style above doesn't
use overloading. Remove it when knowing for sure that the other way
is prefered
// Gets the specific datatype of this abstract dataset which can be a
// dataset or an attribute. Several overloaded getDataType's below
// are for specific sub-datatypes.
void AbstractDs::getDataType( EnumType& enumtype ) const
{
enumtype.setId( p_getType());
}
void AbstractDs::getDataType( CompType& comptype ) const
{
comptype.setId( p_getType());
}
void AbstractDs::getDataType( IntType& inttype ) const
{
inttype.setId( p_getType());
}
void AbstractDs::getDataType( FloatType& floatype ) const
{
floatype.setId( p_getType());
}
void AbstractDs::getDataType( StrType& strtype ) const
{
strtype.setId( p_getType());
}
end of old style of getDataType */
#ifndef H5_NO_NAMESPACE
} // end namespace
#endif
|