FreeFOAM The Cross-Platform CFD Toolkit
IOMap.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd.
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
11  OpenFOAM is free software: you can redistribute it and/or modify it
12  under the terms of the GNU General Public License as published by
13  the Free Software Foundation, either version 3 of the License, or
14  (at your option) any later version.
15 
16  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19  for more details.
20 
21  You should have received a copy of the GNU General Public License
22  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
23 
24 \*---------------------------------------------------------------------------*/
25 
26 #include <OpenFOAM/IOMap.H>
27 
28 // * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * * //
29 
30 template<class T>
32 :
33  regIOobject(io)
34 {
35  if
36  (
39  )
40  {
41  readStream(typeName) >> *this;
42  close();
43  }
44 }
45 
46 template<class T>
47 Foam::IOMap<T>::IOMap(const IOobject& io, const label size)
48 :
49  regIOobject(io)
50 {
51  if
52  (
55  )
56  {
57  readStream(typeName) >> *this;
58  close();
59  }
60  else
61  {
62  Map<T>::setSize(size);
63  }
64 }
65 
66 
67 template<class T>
68 Foam::IOMap<T>::IOMap(const IOobject& io, const Map<T>& map)
69 :
70  regIOobject(io)
71 {
72  if
73  (
76  )
77  {
78  readStream(typeName) >> *this;
79  close();
80  }
81  else
82  {
83  Map<T>::operator=(map);
84  }
85 }
86 
87 
88 template<class T>
89 Foam::IOMap<T>::IOMap(const IOobject& io, const Xfer<Map<T> >& map)
90 :
91  regIOobject(io)
92 {
93  Map<T>::transfer(map());
94 
95  if
96  (
99  )
100  {
101  readStream(typeName) >> *this;
102  close();
103  }
104 }
105 
106 
107 // * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * * //
108 
109 template<class T>
111 {}
112 
113 
114 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
115 
116 template<class T>
118 {
119  return (os << *this).good();
120 }
121 
122 
123 // * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * //
124 
125 template<class T>
127 {
128  Map<T>::operator=(rhs);
129 }
130 
131 
132 template<class T>
134 {
135  Map<T>::operator=(rhs);
136 }
137 
138 
139 // ************************ vim: set sw=4 sts=4 et: ************************ //