Forward compatibility: flex
[foam-extend-3.2.git] / src / mesh / cfMesh / utilities / containers / Lists / faceListPMGI.H
blob8c29b7c933e3c863e9fc66f0750b48bbf7788a46
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
27 \*---------------------------------------------------------------------------*/
30 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
32 #include "SubList.H"
34 namespace Foam
37 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
38 // Constructors
40 inline faceListPMG::faceListPMG(const IOobject& io)
42     regIOobject(io),
43     faceList(readStream(typeName)),
44     nElmts_(faceList::size())
48 inline faceListPMG::faceListPMG(const IOobject& io, const label s)
50     regIOobject(io),
51     faceList(s),
52     nElmts_(s)
56 inline faceListPMG::faceListPMG(const IOobject& io, const faceList& fcs)
58     regIOobject(io),
59     faceList(fcs),
60     nElmts_(fcs.size())
64 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
65 // Destructor
67 inline faceListPMG::~faceListPMG()
71 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
73 inline label faceListPMG::size() const
75     return nElmts_;
78 inline void faceListPMG::setSize(const label nElmts)
80     if( nElmts >= faceList::size() )
81     {
82         if( faceList::size() != 0 )
83         {
84             Info << "Resizing faces!" << endl;
85             faceList copy(label(1.5*nElmts));
86             for(label i=0;i<nElmts_;++i)
87                 copy[i].transfer(this->operator[](i));
89             faceList::transfer(copy);
90         }
91         else
92         {
93             faceList::setSize(label(1.5*nElmts));
94         }
95     }
97     nElmts_ = nElmts;
100 inline void faceListPMG::clear()
102     nElmts_ = 0;
105 inline void faceListPMG::append(const face& f)
107     const label i = nElmts_;
108     setSize(i+1);
109     this->operator[](i) = f;
112 inline face& faceListPMG::newElmt(const label fI)
114     setSize(fI+1);
115     return this->operator[](fI);
118 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
120 inline bool faceListPMG::writeData(Ostream& os) const
122     return (os << *this).good();
125 inline void faceListPMG::operator=(const faceList& fcs)
127     setSize(fcs.size());
128     forAll(fcs, fI)
129         this->operator[](fI) = fcs[fI];
132 inline Ostream& operator<<(Ostream& os, const faceListPMG& fcs)
134     SubList<face> f(fcs, fcs.nElmts_, 0);
136     os << f;
137     return os;
140 inline Istream& operator>>(Istream& is, faceListPMG& fcs)
142     faceList& faces = static_cast<faceList&>(fcs);
143     is >> faces;
144     fcs.nElmts_  = faces.size();
146     return is;
149 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
151 } // End namespace Foam
153 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //