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
|
#include <string>
#include "H5Include.h"
#include "H5Exception.h"
#include "H5Library.h"
#ifndef H5_NO_NAMESPACE
namespace H5 {
#endif
// This static variable will be set to true when dontAtExit is called
bool H5Library::need_cleanup = false;
// Initializes the HDF5 library.
void H5Library::open()
{
herr_t ret_value = H5open();
if( ret_value < 0 )
{
throw LibraryIException("H5Library::open", "H5open failed");
}
}
// Flushes all data to disk, closes files, and cleans up memory.
void H5Library::close()
{
herr_t ret_value = H5close();
if( ret_value < 0 )
{
throw LibraryIException("H5Library::close", "H5close failed");
}
}
// Instructs library not to install atexit cleanup routine
void H5Library::dontAtExit()
{
herr_t ret_value = H5dont_atexit();
if( ret_value < 0 )
{
throw LibraryIException("H5Library::dontAtExit", "H5dont_atexit failed");
}
}
// Returns the HDF library release number.
void H5Library::getLibVersion( unsigned& majnum, unsigned& minnum, unsigned& relnum )
{
herr_t ret_value = H5get_libversion( &majnum, &minnum, &relnum );
if( ret_value < 0 )
{
throw LibraryIException("H5Library::getLibVersion", "H5get_libversion failed");
}
}
// Verifies that the arguments match the version numbers compiled
// into the library
void H5Library::checkVersion( unsigned majnum, unsigned minnum, unsigned relnum )
{
herr_t ret_value = H5check_version( majnum, minnum, relnum );
if( ret_value < 0 )
{
throw LibraryIException("H5Library::checkVersion", "H5check_version failed");
}
}
#ifndef H5_NO_NAMESPACE
} // end namespace
#endif
|