medit_io.h
Go to the documentation of this file.
1 // The libMesh Finite Element Library.
2 // Copyright (C) 2002-2018 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
3 
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either
7 // version 2.1 of the License, or (at your option) any later version.
8 
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 // Lesser General Public License for more details.
13 
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 
18 
19 
20 #ifndef LIBMESH_MEDIT_IO_H
21 #define LIBMESH_MEDIT_IO_H
22 
23 // Local includes
24 #include "libmesh/libmesh_common.h"
25 #include "libmesh/mesh_output.h"
26 
27 // C++ includes
28 #include <cstddef>
29 
30 namespace libMesh
31 {
32 
33 // Forward declarations:
34 class MeshBase;
35 
47 class MEDITIO : public MeshOutput<MeshBase>
48 {
49 public:
50 
55  explicit
56  MEDITIO (const MeshBase &);
57 
63  MEDITIO (const MeshBase &, unsigned int c);
64 
68  virtual void write (const std::string &) override;
69 
75 
80  virtual void write_nodal_data (const std::string &,
81  const std::vector<Number> &,
82  const std::vector<std::string> &) override;
83 
87  bool & binary ();
88 
89 private:
90 
96  void write_ascii (const std::string &,
97  const std::vector<Number> * = nullptr,
98  const std::vector<std::string> * = nullptr);
99 
103  bool _binary;
104 
105  unsigned int scalar_idx;
106 };
107 
108 
109 
110 // ------------------------------------------------------------
111 // medit_io inline members
112 inline
113 MEDITIO::MEDITIO (const MeshBase & mesh_in) :
114  MeshOutput<MeshBase> (mesh_in),
115  _binary (false),
116  scalar_idx (0)
117 {
118 }
119 
120 inline
121 MEDITIO::MEDITIO (const MeshBase & mesh_in, unsigned int c) :
122  MeshOutput<MeshBase> (mesh_in),
123  _binary (false),
124  scalar_idx (c)
125 {
126 }
127 
128 
129 inline
131 {
132  return _binary;
133 }
134 
135 
136 } // namespace libMesh
137 
138 
139 #endif // LIBMESH_MEDIT_IO_H
unsigned int scalar_idx
Definition: medit_io.h:105
virtual void write(const std::string &) override
Definition: medit_io.C:37
Base class for Mesh.
Definition: mesh_base.h:77
bool & binary()
Definition: medit_io.h:130
virtual void write_nodal_data(const std::string &, const std::vector< Number > &, const std::vector< std::string > &) override
Definition: medit_io.C:46
MEDITIO(const MeshBase &)
Definition: medit_io.h:113
void write_ascii(const std::string &, const std::vector< Number > *=nullptr, const std::vector< std::string > *=nullptr)
Definition: medit_io.C:59