blob: 31e9acdee5faba5f5f59fb2b3e314f14a04b0a4d (
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
|
// C++ informative line for the emacs editor: -*- C++ -*-
#ifndef _IdComponent_H
#define _IdComponent_H
// IdComponent provides a mechanism to handle
// reference counting for an identifier of any HDF5 object.
#ifndef H5_NO_NAMESPACE
namespace H5 {
#endif
class IdComponent {
public:
// Parent classes must reset the current IdComponent copy
// before setting new id to control reference count
void setId( hid_t new_id );
// Pure virtual function so appropriate close function can
// be called by subclasses' for the corresponding object
virtual void p_close() const = 0;
// Creates an object to hold an HDF5 identifier
IdComponent( const hid_t h5_id );
// Copy constructor: makes copy of the original IdComponent object.
IdComponent( const IdComponent& original );
// Gets the value of IdComponent's data member
virtual hid_t getId () const;
// Increment reference counter
void incRefCount();
// Decrement reference counter
void decRefCount();
// Get the reference counter to this identifier
int getCounter();
// Decrements the reference counter then determines if there are no more
// reference to this object
bool noReference();
// Assignment operator
virtual IdComponent& operator=( const IdComponent& rhs );
// Resets this IdComponent instance
//template <class Type>
//void reset( Type* parent );
void reset();
void resetId();
// Destructor
virtual ~IdComponent();
protected:
hid_t id; // HDF5 object id
RefCounter* ref_count; // used to keep track of the
// number of copies of an object
// Default constructor
IdComponent();
}; // end class IdComponent
// BMR - including template member function implementation here to
// prevent compilation errors. When the compilers support template
// member functions in *.C files, move them to IdComponent.C.
// This function makes sure that this IdComponent instance actually
// represents an HDF5 component and that this HDF5 component is no longer
// referenced, then calls the parent function p_close to close the
// appropriate HDF5 component. In addition, this identifier instance
// will delete itself.
// Type is the class of the instance to whom this IdComponent object
// belongs.
/* 11/10/00 - BMR: commented this member function because many compilers
still have no support for member template function. The function is
replaced by resetIdComponent in H5Idtemplates.h
template <class Type>
void IdComponent::reset( Type* parent )
{
if( ref_count->noReference()) // ref_count is decremented here
{
if( id > 0 )
parent->p_close(); // which p_close depends on whom this
// IdComponent object belongs to
delete ref_count; // delete the reference counter
delete this; // this IdComponent object deletes itself
}
}
*/
#ifndef H5_NO_NAMESPACE
}
#endif
#endif
|