You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
158 lines
5.3 KiB
158 lines
5.3 KiB
2 years ago
|
// C++ informative line for the emacs editor: -*- C++ -*-
|
||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||
|
* Copyright by The HDF Group. *
|
||
|
* All rights reserved. *
|
||
|
* *
|
||
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||
|
* terms governing use, modification, and redistribution, is contained in *
|
||
|
* the COPYING file, which can be found at the root of the source code *
|
||
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
||
|
* If you do not have access to either file, you may request a copy from *
|
||
|
* help@hdfgroup.org. *
|
||
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||
|
|
||
|
#ifndef H5DataSpace_H
|
||
|
#define H5DataSpace_H
|
||
|
|
||
|
namespace H5 {
|
||
|
|
||
|
/*! \class DataSpace
|
||
|
\brief Class DataSpace inherits from IdComponent and provides wrappers for
|
||
|
the HDF5's dataspaces.
|
||
|
*/
|
||
|
// Inheritance: IdComponent
|
||
|
class H5_DLLCPP DataSpace : public IdComponent {
|
||
|
public:
|
||
|
///\brief Default DataSpace objects
|
||
|
static const DataSpace &ALL;
|
||
|
|
||
|
// Creates a dataspace object given the space type
|
||
|
DataSpace(H5S_class_t type = H5S_SCALAR);
|
||
|
|
||
|
// Creates a simple dataspace
|
||
|
DataSpace(int rank, const hsize_t *dims, const hsize_t *maxdims = NULL);
|
||
|
|
||
|
// Creates a DataSpace object using an existing dataspace id.
|
||
|
DataSpace(const hid_t space_id);
|
||
|
|
||
|
// Copy constructor - same as the original DataSpace.
|
||
|
DataSpace(const DataSpace &original);
|
||
|
|
||
|
// Assignment operator
|
||
|
DataSpace &operator=(const DataSpace &rhs);
|
||
|
|
||
|
// Closes this dataspace.
|
||
|
virtual void close() override;
|
||
|
|
||
|
// Makes copy of an existing dataspace.
|
||
|
void copy(const DataSpace &like_space);
|
||
|
|
||
|
// Copies the extent of this dataspace.
|
||
|
void extentCopy(const DataSpace &dest_space) const;
|
||
|
// removed from 1.8.18 and 1.10.1
|
||
|
// void extentCopy(DataSpace& dest_space) const;
|
||
|
|
||
|
// Gets the bounding box containing the current selection.
|
||
|
void getSelectBounds(hsize_t *start, hsize_t *end) const;
|
||
|
|
||
|
// Gets the number of element points in the current selection.
|
||
|
hssize_t getSelectElemNpoints() const;
|
||
|
|
||
|
// Retrieves the list of element points currently selected.
|
||
|
void getSelectElemPointlist(hsize_t startpoint, hsize_t numpoints, hsize_t *buf) const;
|
||
|
|
||
|
// Gets the list of hyperslab blocks currently selected.
|
||
|
void getSelectHyperBlocklist(hsize_t startblock, hsize_t numblocks, hsize_t *buf) const;
|
||
|
|
||
|
// Get number of hyperslab blocks.
|
||
|
hssize_t getSelectHyperNblocks() const;
|
||
|
|
||
|
// Gets the number of elements in this dataspace selection.
|
||
|
hssize_t getSelectNpoints() const;
|
||
|
|
||
|
// Retrieves dataspace dimension size and maximum size.
|
||
|
int getSimpleExtentDims(hsize_t *dims, hsize_t *maxdims = NULL) const;
|
||
|
|
||
|
// Gets the dimensionality of this dataspace.
|
||
|
int getSimpleExtentNdims() const;
|
||
|
|
||
|
// Gets the number of elements in this dataspace.
|
||
|
// 12/05/00 - changed return type to hssize_t from hsize_t - C API
|
||
|
hssize_t getSimpleExtentNpoints() const;
|
||
|
|
||
|
// Gets the current class of this dataspace.
|
||
|
H5S_class_t getSimpleExtentType() const;
|
||
|
|
||
|
// Determines if this dataspace is a simple one.
|
||
|
bool isSimple() const;
|
||
|
|
||
|
// Sets the offset of this simple dataspace.
|
||
|
void offsetSimple(const hssize_t *offset) const;
|
||
|
|
||
|
// Selects the entire dataspace.
|
||
|
void selectAll() const;
|
||
|
|
||
|
// Selects array elements to be included in the selection for
|
||
|
// this dataspace.
|
||
|
void selectElements(H5S_seloper_t op, const size_t num_elements, const hsize_t *coord) const;
|
||
|
|
||
|
// Selects a hyperslab region to add to the current selected region.
|
||
|
void selectHyperslab(H5S_seloper_t op, const hsize_t *count, const hsize_t *start,
|
||
|
const hsize_t *stride = NULL, const hsize_t *block = NULL) const;
|
||
|
|
||
|
// Resets the selection region to include no elements.
|
||
|
void selectNone() const;
|
||
|
|
||
|
// Verifies that the selection is within the extent of the dataspace.
|
||
|
bool selectValid() const;
|
||
|
|
||
|
// Removes the extent from this dataspace.
|
||
|
void setExtentNone() const;
|
||
|
|
||
|
// Sets or resets the size of this dataspace.
|
||
|
void setExtentSimple(int rank, const hsize_t *current_size, const hsize_t *maximum_size = NULL) const;
|
||
|
|
||
|
///\brief Returns this class name.
|
||
|
virtual H5std_string
|
||
|
fromClass() const override
|
||
|
{
|
||
|
return ("DataSpace");
|
||
|
}
|
||
|
|
||
|
// Gets the dataspace id.
|
||
|
virtual hid_t getId() const override;
|
||
|
|
||
|
// Deletes the global constant
|
||
|
static void deleteConstants();
|
||
|
|
||
|
// Destructor: properly terminates access to this dataspace.
|
||
|
virtual ~DataSpace() override;
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
|
||
|
protected:
|
||
|
// Sets the dataspace id.
|
||
|
virtual void p_setId(const hid_t new_id) override;
|
||
|
|
||
|
#endif // DOXYGEN_SHOULD_SKIP_THIS
|
||
|
|
||
|
private:
|
||
|
hid_t id; // HDF5 dataspace id
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
|
||
|
static DataSpace *ALL_;
|
||
|
|
||
|
// Creates the global constant
|
||
|
static DataSpace *getConstant();
|
||
|
|
||
|
// Friend function to set DataSpace id. For library use only.
|
||
|
friend void f_DataSpace_setId(DataSpace *dspace, hid_t new_id);
|
||
|
|
||
|
#endif // DOXYGEN_SHOULD_SKIP_THIS
|
||
|
|
||
|
}; // end of DataSpace
|
||
|
} // namespace H5
|
||
|
|
||
|
#endif // H5DataSpace_H
|