XdmfAttributeType.hpp 4.1 KB
Newer Older
Kenneth Leiter's avatar
Kenneth Leiter committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*****************************************************************************/
/*                                    XDMF                                   */
/*                       eXtensible Data Model and Format                    */
/*                                                                           */
/*  Id : XdmfAttributeType.hpp                                               */
/*                                                                           */
/*  Author:                                                                  */
/*     Kenneth Leiter                                                        */
/*     kenneth.leiter@arl.army.mil                                           */
/*     US Army Research Laboratory                                           */
/*     Aberdeen Proving Ground, MD                                           */
/*                                                                           */
/*     Copyright @ 2011 US Army Research Laboratory                          */
/*     All Rights Reserved                                                   */
/*     See Copyright.txt for details                                         */
/*                                                                           */
/*     This software is distributed WITHOUT ANY WARRANTY; without            */
/*     even the implied warranty of MERCHANTABILITY or FITNESS               */
/*     FOR A PARTICULAR PURPOSE.  See the above copyright notice             */
/*     for more information.                                                 */
/*                                                                           */
/*****************************************************************************/

24
25
26
#ifndef XDMFATTRIBUTETYPE_HPP_
#define XDMFATTRIBUTETYPE_HPP_

27
// Includes
28
#include "Xdmf.hpp"
29
#include "XdmfItemProperty.hpp"
30

31
/**
32
33
 * @brief Property describing the type of values an XdmfAttribute
 * contains.
34
 *
35
36
37
38
 * XdmfAttributeType is a property used by XdmfAttribute to specify
 * what type of values the XdmfAttribute contains. A specific
 * XdmfAttributeType can be created by calling one of the static
 * methods in the class, i.e. XdmfAttributeType::Scalar().
39
 *
40
41
 * Example of use:
 *
42
43
44
 * C++
 *
 * @dontinclude ExampleXdmfAttribute.cpp
45
46
47
48
49
50
 * @skipline //#initialization
 * @until //#initialization
 * @skipline //#setType
 * @until //#setType
 * @skipline //#getType
 * @until //#getType
51
52
53
54
 *
 * Python
 *
 * @dontinclude XdmfExampleAttribute.py
55
56
57
58
59
60
 * @skipline #//initialization
 * @until #//initialization
 * @skipline #//setType
 * @until #//setType
 * @skipline #//getType
 * @until #//getType
61
 *
62
 * Xdmf supports the following attribute types:
63
64
65
66
67
68
69
 *   NoAttributeType
 *   Scalar
 *   Vector
 *   Tensor
 *   Matrix
 *   Tensor6
 *   GlobalId
70
 */
71
class XDMF_EXPORT XdmfAttributeType : public XdmfItemProperty {
72

73
public:
74

75
  virtual ~XdmfAttributeType();
76

77
  friend class XdmfAttribute;
78

79
  // Supported Xdmf Attribute Types
80
81
82
83
84
85
86
  static shared_ptr<const XdmfAttributeType> NoAttributeType();
  static shared_ptr<const XdmfAttributeType> Scalar();
  static shared_ptr<const XdmfAttributeType> Vector();
  static shared_ptr<const XdmfAttributeType> Tensor();
  static shared_ptr<const XdmfAttributeType> Matrix();
  static shared_ptr<const XdmfAttributeType> Tensor6();
  static shared_ptr<const XdmfAttributeType> GlobalId();
87

88
89
  void
  getProperties(std::map<std::string, std::string> & collectedProperties) const;
90

91
protected:
92

93
94
95
96
97
98
  /**
   * Protected constructor for XdmfAttributeType.  The constructor is
   * protected because all attribute types supported by Xdmf should be
   * accessed through more specific static methods that construct
   * XdmfAttributeTypes - i.e. XdmfAttributeType::Scalar().
   *
99
   * @param	name	The name of the XdmfAttributeType to construct.
100
101
   */
  XdmfAttributeType(const std::string & name);
102

103
private:
104

105
106
  XdmfAttributeType(const XdmfAttributeType &); // Not implemented.
  void operator=(const XdmfAttributeType &); // Not implemented.
107

108
  static shared_ptr<const XdmfAttributeType>
109
  New(const std::map<std::string, std::string> & itemProperties);
110

111
  std::string mName;
112
113
114
};

#endif /* XDMFATTRIBUTETYPE_HPP_ */