GNU Octave 7.1.0
A high-level interpreted language, primarily intended for numerical computations, mostly compatible with Matlab
ls-hdf5.h
Go to the documentation of this file.
1////////////////////////////////////////////////////////////////////////
2//
3// Copyright (C) 2003-2022 The Octave Project Developers
4//
5// See the file COPYRIGHT.md in the top-level directory of this
6// distribution or <https://octave.org/copyright/>.
7//
8// This file is part of Octave.
9//
10// Octave is free software: you can redistribute it and/or modify it
11// under the terms of the GNU General Public License as published by
12// the Free Software Foundation, either version 3 of the License, or
13// (at your option) any later version.
14//
15// Octave is distributed in the hope that it will be useful, but
16// WITHOUT ANY WARRANTY; without even the implied warranty of
17// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18// GNU General Public License for more details.
19//
20// You should have received a copy of the GNU General Public License
21// along with Octave; see the file COPYING. If not, see
22// <https://www.gnu.org/licenses/>.
23//
24////////////////////////////////////////////////////////////////////////
25
26#if ! defined (octave_ls_hdf5_h)
27#define octave_ls_hdf5_h 1
28
29#include "octave-config.h"
30
31#include <iosfwd>
32
33#include "oct-hdf5-types.h"
34#include "ov.h"
35
36// first, we need to define our own dummy stream subclass, since
37// HDF5 needs to do its own file i/o
38
39// hdf5_fstreambase is used for both input and output streams, modeled
40// on the fstreambase class in <fstream.h>
41
42class hdf5_fstreambase : virtual public std::ios
43{
44public:
45
46 // HDF5 uses an "id" to refer to an open file
48
49 // keep track of current item index in the file
51
53
55
56 OCTINTERP_API hdf5_fstreambase (const char *name, int mode, int /* prot */ = 0);
57
58 OCTINTERP_API void close (void);
59
60 OCTINTERP_API void open (const char *name, int mode, int);
61
62 OCTINTERP_API void open_create (const char *name, int mode);
63};
64
65// input and output streams, subclassing istream and ostream
66// so that we can pass them for stream parameters in the functions below.
67
68class hdf5_ifstream : public hdf5_fstreambase, public std::istream
69{
70public:
71
72 hdf5_ifstream () : hdf5_fstreambase (), std::istream (nullptr) { }
73
74 hdf5_ifstream (const char *name, int mode = std::ios::in | std::ios::binary,
75 int prot = 0)
76 : hdf5_fstreambase (name, mode, prot), std::istream (nullptr) { }
77
78 void open (const char *name, int mode = std::ios::in | std::ios::binary,
79 int prot = 0)
80 { hdf5_fstreambase::open (name, mode, prot); }
81};
82
83class hdf5_ofstream : public hdf5_fstreambase, public std::ostream
84{
85public:
86
87 hdf5_ofstream () : hdf5_fstreambase (), std::ostream (nullptr) { }
88
89 hdf5_ofstream (const char *name, int mode = std::ios::out | std::ios::binary,
90 int prot = 0)
91 : hdf5_fstreambase (name, mode, prot), std::ostream (nullptr) { }
92
93 void open (const char *name, int mode = std::ios::out | std::ios::binary,
94 int prot = 0)
95 { hdf5_fstreambase::open (name, mode, prot); }
96};
97
98// Callback data structure for passing data to hdf5_read_next_data, below.
99
101{
102public:
104 : name (), global (false), tc (), doc () { }
105
106 // the following fields are set by hdf5_read_data on successful return:
107
108 // the name of the variable
109 std::string name;
110
111 // whether it is global
112 bool global;
113
114 // the value of the variable, in Octave form
116
117 // a documentation string (NULL if none)
118 std::string doc;
119};
120
121extern OCTINTERP_API octave_hdf5_id
123
124extern OCTINTERP_API octave_hdf5_id
126
127extern OCTINTERP_API bool
129
130extern OCTINTERP_API octave_hdf5_err
131hdf5_read_next_data (octave_hdf5_id group_id, const char *name, void *dv);
132
133extern OCTINTERP_API octave_hdf5_err
134hdf5_h5g_iterate (octave_hdf5_id loc_id, const char *name, int *idx,
135 void *operator_data);
136
137extern OCTINTERP_API bool
138add_hdf5_data (octave_hdf5_id loc_id, const octave_value& tc,
139 const std::string& name, const std::string& doc,
140 bool mark_global, bool save_as_floats);
141
142extern OCTINTERP_API int
143save_hdf5_empty (octave_hdf5_id loc_id, const char *name, const dim_vector& d);
144
145extern OCTINTERP_API int
146load_hdf5_empty (octave_hdf5_id loc_id, const char *name, dim_vector& d);
147
148extern OCTINTERP_API std::string
149read_hdf5_data (std::istream& is, const std::string& filename, bool& global,
150 octave_value& tc, std::string& doc,
151 const string_vector& argv, int argv_idx, int argc);
152
153extern OCTINTERP_API bool
154save_hdf5_data (std::ostream& os, const octave_value& tc,
155 const std::string& name, const std::string& doc,
156 bool mark_global, bool save_as_floats);
157
158extern OCTINTERP_API bool
159hdf5_check_attr (octave_hdf5_id loc_id, const char *attr_name);
160
161extern OCTINTERP_API bool
163 const char *attr_name, void *buf);
164
165extern OCTINTERP_API octave_hdf5_err
166hdf5_add_attr (octave_hdf5_id loc_id, const char *attr_name);
167
168
169extern OCTINTERP_API octave_hdf5_err
171 const char *attr_name, void *buf);
172
173#endif
Vector representing the dimensions (size) of an Array.
Definition: dim-vector.h:94
OCTINTERP_API void open(const char *name, int mode, int)
Definition: ls-hdf5.cc:123
OCTINTERP_API void open_create(const char *name, int mode)
Definition: ls-hdf5.cc:142
octave_hdf5_id file_id
Definition: ls-hdf5.h:47
OCTINTERP_API void close(void)
Definition: ls-hdf5.cc:103
int current_item
Definition: ls-hdf5.h:50
hdf5_ifstream()
Definition: ls-hdf5.h:72
void open(const char *name, int mode=std::ios::in|std::ios::binary, int prot=0)
Definition: ls-hdf5.h:78
hdf5_ifstream(const char *name, int mode=std::ios::in|std::ios::binary, int prot=0)
Definition: ls-hdf5.h:74
hdf5_ofstream()
Definition: ls-hdf5.h:87
void open(const char *name, int mode=std::ios::out|std::ios::binary, int prot=0)
Definition: ls-hdf5.h:93
hdf5_ofstream(const char *name, int mode=std::ios::out|std::ios::binary, int prot=0)
Definition: ls-hdf5.h:89
save_type
Definition: data-conv.h:87
QString name
F77_RET_T const F77_DBLE const F77_DBLE F77_DBLE * d
OCTINTERP_API bool save_hdf5_data(std::ostream &os, const octave_value &tc, const std::string &name, const std::string &doc, bool mark_global, bool save_as_floats)
Definition: ls-hdf5.cc:1502
OCTINTERP_API int load_hdf5_empty(octave_hdf5_id loc_id, const char *name, dim_vector &d)
Definition: ls-hdf5.cc:1307
OCTINTERP_API octave_hdf5_err hdf5_add_scalar_attr(octave_hdf5_id loc_id, octave_hdf5_id type_id, const char *attr_name, void *buf)
Definition: ls-hdf5.cc:1207
OCTINTERP_API octave_hdf5_id save_type_to_hdf5(save_type st)
Definition: ls-hdf5.cc:1351
OCTINTERP_API bool add_hdf5_data(octave_hdf5_id loc_id, const octave_value &tc, const std::string &name, const std::string &doc, bool mark_global, bool save_as_floats)
Definition: ls-hdf5.cc:1407
OCTINTERP_API std::string read_hdf5_data(std::istream &is, const std::string &filename, bool &global, octave_value &tc, std::string &doc, const string_vector &argv, int argv_idx, int argc)
Definition: ls-hdf5.cc:1081
OCTINTERP_API bool hdf5_types_compatible(octave_hdf5_id t1, octave_hdf5_id t2)
Definition: ls-hdf5.cc:269
OCTINTERP_API octave_hdf5_err hdf5_add_attr(octave_hdf5_id loc_id, const char *attr_name)
Definition: ls-hdf5.cc:1166
OCTINTERP_API bool hdf5_check_attr(octave_hdf5_id loc_id, const char *attr_name)
Definition: ls-hdf5.cc:300
OCTINTERP_API octave_hdf5_err hdf5_h5g_iterate(octave_hdf5_id loc_id, const char *name, int *idx, void *operator_data)
Definition: ls-hdf5.cc:1061
OCTINTERP_API int save_hdf5_empty(octave_hdf5_id loc_id, const char *name, const dim_vector &d)
Definition: ls-hdf5.cc:1251
OCTINTERP_API octave_hdf5_id hdf5_make_complex_type(octave_hdf5_id num_type)
Definition: ls-hdf5.cc:405
OCTINTERP_API octave_hdf5_err hdf5_read_next_data(octave_hdf5_id group_id, const char *name, void *dv)
Definition: ls-hdf5.cc:1047
OCTINTERP_API bool hdf5_get_scalar_attr(octave_hdf5_id loc_id, octave_hdf5_id type_id, const char *attr_name, void *buf)
Definition: ls-hdf5.cc:347
STL namespace.
int octave_hdf5_err
int64_t octave_hdf5_id
octave_value tc
Definition: ls-hdf5.h:115
std::string name
Definition: ls-hdf5.h:109
hdf5_callback_data(void)
Definition: ls-hdf5.h:103
std::string doc
Definition: ls-hdf5.h:118