summaryrefslogtreecommitdiffstats
path: root/c++/src/H5AbstractDs.C
diff options
context:
space:
mode:
authorBinh-Minh Ribler <bmribler@hdfgroup.org>2000-11-14 21:30:12 (GMT)
committerBinh-Minh Ribler <bmribler@hdfgroup.org>2000-11-14 21:30:12 (GMT)
commit92041a68656c59813619ae1f26ed211b7f028e86 (patch)
treeaaa3256c9a9f0adde21570eac9254f7ce00450b1 /c++/src/H5AbstractDs.C
parent36acd5381e3977164e0d6d666f8ce97cc53f9387 (diff)
downloadhdf5-92041a68656c59813619ae1f26ed211b7f028e86.zip
hdf5-92041a68656c59813619ae1f26ed211b7f028e86.tar.gz
hdf5-92041a68656c59813619ae1f26ed211b7f028e86.tar.bz2
[svn-r2897] Purpose:
C++ API for 1.3.x branch Description: The *.C and *.h files named different than those in 1.2.x. They are in the form: 'H5' + classname, or just classname if the classname is already prefixed with 'H5' to avoid ambiguity in documentation context. This version has several hidden bugs fixed and an improvement on the reference counting approach. The classes and their inheritance structure are listed below: --------------------------------------- H5Library Exception RefCounter IdComponent H5File DataSpace H5Object Group AbstractDs DataSet Attribute DataType PredType EnumType CompType AtomType StrType IntType FloatType PropList FileCreatPropList FileAccPropList DSetCreatPropList DSetMemXferPropList --------------------------------------- IdComponent uses RefCounter to keep track of opened objects so proper termination of HDF5 objects can be maintained. Each class has a .h file containing the class declaration and a .C file containing its definition. In addition to the classes files, the following files do not have class information: - H5Cpp.h: header file to be included in user's application - H5Idtemplates.h: contains a template function used by several classes - H5Classes.h: contains forward class declarations - H5CommonFG.*: contains common code used by classes H5File and Group - H5Include.h: contains the hdf5.h header file and the #undef RCSID to work around the problem: multiple defined RcsId - H5Alltypes.h: simply serves as a container to hold the header files of all datatypes to simplify the header file inclusion Platforms: Solaris (arabica) and Linux
Diffstat (limited to 'c++/src/H5AbstractDs.C')
-rw-r--r--c++/src/H5AbstractDs.C132
1 files changed, 132 insertions, 0 deletions
diff --git a/c++/src/H5AbstractDs.C b/c++/src/H5AbstractDs.C
new file mode 100644
index 0000000..5424bdb
--- /dev/null
+++ b/c++/src/H5AbstractDs.C
@@ -0,0 +1,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