summaryrefslogtreecommitdiffstats
path: root/c++/src/H5StrType.h
blob: 4015998cef11765a5d342f05c568d37e850a6eca (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
// 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 __H5StrType_H
#define __H5StrType_H

namespace H5 {

//! Class StrType operates on HDF5 string datatypes.
class H5_DLLCPP StrType : public AtomType {
   public:
	// Creates a string type using a predefined type
	StrType(const PredType& pred_type);

	// Creates a string type with specified length - may be obsolete
	StrType(const PredType& pred_type, const size_t& size);

	// Creates a string type with specified length
	StrType(const int dummy, const size_t& size);

        // Gets the string datatype of the specified dataset
	StrType(const DataSet& dataset);

	// Retrieves the character set type of this string datatype.
	H5T_cset_t getCset() const;

	// Sets character set to be used.
	void setCset(H5T_cset_t cset) const;

	// Retrieves the string padding method for this string datatype.
	H5T_str_t getStrpad() const;

	// Defines the storage mechanism for character strings.
	void setStrpad(H5T_str_t strpad) const;

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

	// default constructor
	StrType();

	// Creates a string datatype using an existing id
	StrType(const hid_t existing_id);

	// Copy constructor - makes a copy of the original object
	StrType(const StrType& original);

	// Noop destructor.
	virtual ~StrType();
};
}
#endif // __H5StrType_H