summaryrefslogtreecommitdiffstats
path: root/c++/src/H5Attribute.h
blob: eced64e13f62f151a0a7ad0bb603d4ec90cf3fc2 (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
// C++ informative line for the emacs editor: -*- C++ -*-
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 * Copyright by The HDF Group.                                               *
 * Copyright by the Board of Trustees of the University of Illinois.         *
 * 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 files COPYING and Copyright.html.  COPYING can be found at the root   *
 * of the source code distribution tree; Copyright.html can be found at the  *
 * root level of an installed copy of the electronic HDF5 document set and   *
 * is linked from the top-level documents page.  It can also be found at     *
 * http://hdfgroup.org/HDF5/doc/Copyright.html.  If you do not have          *
 * access to either file, you may request a copy from help@hdfgroup.org.     *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

#ifndef __H5Attribute_H
#define __H5Attribute_H

#ifndef H5_NO_NAMESPACE
namespace H5 {
#endif

/*! \class Attribute
    \brief Class Attribute operates on HDF5 attributes.

    An attribute has many characteristics similar to a dataset, thus both
    Attribute and DataSet are derivatives of AbstractDs.  Attribute also
    inherits from IdComponent because an attribute is an HDF5 component that
    is identified by an identifier.
*/
class H5_DLLCPP Attribute : public AbstractDs, public IdComponent {
   public:

	// Copy constructor: makes a copy of an existing Attribute object.
	Attribute( const Attribute& original );

	// Default constructor
	Attribute();

	// Creates a copy of an existing attribute using the attribute id
	Attribute( const hid_t attr_id );

	// Closes this attribute.
	virtual void close();

	// Gets the name of the file, in which this attribute belongs.
	H5std_string getFileName() const;

	// Gets the name of this attribute.
	ssize_t getName(char* attr_name, size_t buf_size = 0) const;
	H5std_string getName(size_t len) const;
	H5std_string getName() const;
	ssize_t getName(H5std_string& attr_name, size_t len = 0) const;
	// The overloaded function below is replaced by the one above and it
	// is kept for backward compatibility purpose.
	ssize_t getName( size_t buf_size, H5std_string& attr_name ) const;

	// Gets a copy of the dataspace for this attribute.
	virtual DataSpace getSpace() const;

	// Returns the amount of storage size required for this attribute.
	virtual hsize_t getStorageSize() const;

	// Returns the in memory size of this attribute's data.
	virtual size_t getInMemDataSize() const;

	// Reads data from this attribute.
	void read( const DataType& mem_type, void *buf ) const;
	void read( const DataType& mem_type, H5std_string& strg ) const;

	// Writes data to this attribute.
	void write(const DataType& mem_type, const void *buf ) const;
	void write(const DataType& mem_type, const H5std_string& strg ) const;

	// Flushes all buffers associated with the file specified by this
	// attribute to disk.
	void flush( H5F_scope_t scope ) const;

	///\brief Returns this class name.
	virtual H5std_string fromClass () const { return("Attribute"); }

	// Gets the attribute id.
	virtual hid_t getId() const;

	// Destructor: properly terminates access to this attribute.
	virtual ~Attribute();

   protected:
#ifndef DOXYGEN_SHOULD_SKIP_THIS
	// Sets the attribute id.
	virtual void p_setId(const hid_t new_id);
#endif // DOXYGEN_SHOULD_SKIP_THIS

   private:
	hid_t id;	// HDF5 attribute id

	// This function contains the common code that is used by
	// getTypeClass and various API functions getXxxType
	// defined in AbstractDs for generic datatype and specific
	// sub-types
	virtual hid_t p_get_type() const;

	// Reads variable or fixed len strings from this attribute.
	void p_read_variable_len(const DataType& mem_type, H5std_string& strg) const;
	void p_read_fixed_len(const DataType& mem_type, H5std_string& strg) const;

	// do not inherit H5Object::iterateAttrs
	int iterateAttrs() { return 0; }

	// do not inherit H5Object::renameAttr
	void renameAttr() {}

	// Friend function to set Attribute id.  For library use only.
	friend void f_Attribute_setId(Attribute* attr, hid_t new_id);

};
#ifndef H5_NO_NAMESPACE
}
#endif
#endif // __H5Attribute_H