Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / mesh / cfMesh / utilities / containers / IODynList / IODynList.C
blob64ed5ee52c2b6b28dca351813c81e1ef49044c07
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | cfMesh: A library for mesh generation
4    \\    /   O peration     |
5     \\  /    A nd           | Author: Franjo Juretic (franjo.juretic@c-fields.com)
6      \\/     M anipulation  | Copyright (C) Creative Fields, Ltd.
7 -------------------------------------------------------------------------------
8 License
9     This file is part of cfMesh.
11     cfMesh is free software; you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation; either version 3 of the License, or (at your
14     option) any later version.
16     cfMesh 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.
21     You should have received a copy of the GNU General Public License
22     along with cfMesh.  If not, see <http://www.gnu.org/licenses/>.
24 Description
25     An IODynList of a given type is a List of that type which supports automated
26     input and output.
28 \*---------------------------------------------------------------------------*/
30 #include "IODynList.H"
32 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
34 namespace Foam
37 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
39 template<class T, class IndexType>
40 IODynList<T, IndexType>::IODynList(const IOobject& io)
42     regIOobject(io),
43     DynList<T, IndexType>()
45     if
46     (
47         io.readOpt() == IOobject::MUST_READ
48      || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk())
49     )
50     {
51         readStream(typeName) >> *this;
52         close();
53     }
57 template<class T, class IndexType>
58 IODynList<T, IndexType>::IODynList
60     const IOobject& io,
61     const IndexType size
64     regIOobject(io),
65     DynList<T, IndexType>(size)
69 template<class T, class IndexType>
70 IODynList<T, IndexType>::IODynList
72     const IOobject& io,
73     const DynList<T, IndexType>& list
76     regIOobject(io),
77     DynList<T, IndexType>()
79     if (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk())
80     {
81         readStream(typeName) >> *this;
82         close();
83     }
85     DynList<T, IndexType>::operator=(list);
89 template<class T, class IndexType>
90 void IODynList<T, IndexType>::operator=
92     const IODynList<T, IndexType>& rhs
95     DynList<T, IndexType>::operator=(rhs);
99 template<class T, class IndexType>
100 void IODynList<T, IndexType>::operator=
102     const DynList<T, IndexType>& rhs
105     DynList<T, IndexType>::operator=(rhs);
109 template<class T, class IndexType>
110 bool IODynList<T, IndexType>::writeData(Ostream& os) const
112     return (os << *this).good();
116 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
118 } // End namespace Foam
120 // ************************************************************************* //