BUG: UListIO: byteSize overflowing on really big faceLists
[OpenFOAM-2.0.x.git] / src / surfMesh / surfaceFormats / ofs / OFSsurfaceFormat.C
blob8568ca3da4557232ef031e9bf1bc0be92bc3bed2
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
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.
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.
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/>.
24 \*---------------------------------------------------------------------------*/
26 #include "OFSsurfaceFormat.H"
27 #include "IFstream.H"
28 #include "IStringStream.H"
29 #include "ListOps.H"
31 // * * * * * * * * * * * * * * * * Constructors  * * * * * * * * * * * * * * //
33 template<class Face>
34 Foam::fileFormats::OFSsurfaceFormat<Face>::OFSsurfaceFormat
36     const fileName& filename
39     read(filename);
43 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
45 template<class Face>
46 bool Foam::fileFormats::OFSsurfaceFormat<Face>::read
48     const fileName& filename
51     this->clear();
53     IFstream is(filename);
54     if (!is.good())
55     {
56         FatalErrorIn
57         (
58             "fileFormats::OFSsurfaceFormat::read(const fileName&)"
59         )
60             << "Cannot read file " << filename
61             << exit(FatalError);
62     }
64     // read surfZones:
65     is >> this->storedZones();
67     // read points:
68     is >> this->storedPoints();
70     // must triangulate?
71     if (MeshedSurface<Face>::isTri())
72     {
73         // read faces as 'face' and transcribe to 'triFace'
74         List<face> faceLst(is);
76         MeshedSurface<face> surf
77         (
78             xferMove(this->storedPoints()),
79             xferMove(faceLst),
80             xferMove(this->storedZones())
81         );
83         this->transcribe(surf);
84     }
85     else
86     {
87         // read faces directly
88         is >> this->storedFaces();
89     }
91     return true;
95 template<class Face>
96 bool Foam::fileFormats::OFSsurfaceFormat<Face>::read
98     Istream& is,
99     pointField& pointLst,
100     List<Face>& faceLst,
101     List<surfZone>& zoneLst
104     if (!is.good())
105     {
106         FatalErrorIn
107         (
108             "fileFormats::OFSsurfaceFormat::read"
109             "(Istream&, pointField&, List<Face>&, List<surfZone>&)"
110         )
111             << "read error "
112             << exit(FatalError);
113     }
115     // read surfZones:
116     is >> zoneLst;
118     // read points:
119     is >> pointLst;
121     // must triangulate?
122     if (MeshedSurface<Face>::isTri())
123     {
124         // read faces as 'face' and transcribe to 'triFace'
125         List<face> origFaces(is);
127         MeshedSurface<face> origSurf
128         (
129             xferMove(pointLst),
130             xferMove(origFaces),
131             xferMove(zoneLst)
132         );
134         MeshedSurface<Face> surf;
135         surf.transcribe(origSurf);
136     }
137     else
138     {
139         // read faces directly
140         is >> faceLst;
141     }
143     return true;
147 template<class Face>
148 bool Foam::fileFormats::OFSsurfaceFormat<Face>::read
150     Istream& is,
151     MeshedSurface<Face>& surf
154     surf.clear();
156     if (!is.good())
157     {
158         FatalErrorIn
159         (
160             "fileFormats::OFSsurfaceFormat::read"
161             "(Istream&, MeshedSurface<Face>&)"
162         )
163             << "read error "
164             << exit(FatalError);
165     }
167     pointField pointLst;
168     List<Face> faceLst;
169     List<surfZone> zoneLst;
171     read(is, pointLst, faceLst, zoneLst);
173     surf.reset
174     (
175         xferMove(pointLst),
176         xferMove(faceLst),
177         xferMove(zoneLst)
178     );
180     return true;
184 template<class Face>
185 bool Foam::fileFormats::OFSsurfaceFormat<Face>::read
187     Istream& is,
188     UnsortedMeshedSurface<Face>& surf
191     surf.clear();
192     MeshedSurface<Face> origSurf(is);
193     surf.transfer(origSurf);
195     return true;
200 template<class Face>
201 void Foam::fileFormats::OFSsurfaceFormat<Face>::write
203     const fileName& filename,
204     const MeshedSurfaceProxy<Face>& surf
207     const List<Face>&  faceLst = surf.faces();
208     const List<label>& faceMap = surf.faceMap();
210     OFstream os(filename);
211     if (!os.good())
212     {
213         FatalErrorIn
214         (
215             "fileFormats::OFSsurfaceFormat::write"
216             "(const fileName&, const MeshedSurfaceProxy<Face>&)"
217         )
218             << "Cannot open file for writing " << filename
219             << exit(FatalError);
220     }
223     OFSsurfaceFormatCore::writeHeader(os, surf.points(), surf.surfZones());
225     const List<surfZone>& zones = surf.surfZones();
226     const bool useFaceMap = (surf.useFaceMap() && zones.size() > 1);
228     if (useFaceMap)
229     {
230         os  << "\n// faces:"  << nl
231             << faceLst.size() << token::BEGIN_LIST << nl;
233         label faceI = 0;
234         forAll(zones, zoneI)
235         {
236             // Print all faces belonging to this zone
237             const surfZone& zone = zones[zoneI];
239             forAll(zone, localFaceI)
240             {
241                 os << faceLst[faceMap[faceI++]] << nl;
242             }
243         }
244         os << token::END_LIST << nl;
245     }
246     else
247     {
248         os  << "\n// faces:"  << nl << faceLst << nl;
249     }
251     IOobject::writeDivider(os);
253     // Check state of Ostream
254     os.check("OFSsurfaceFormat<Face>::write(Ostream&)");
258 // ************************************************************************* //