00001 /*---------------------------------------------------------------------------*\ 00002 ========= | 00003 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox 00004 \\ / O peration | 00005 \\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd. 00006 \\/ M anipulation | 00007 ------------------------------------------------------------------------------- 00008 License 00009 This file is part of OpenFOAM. 00010 00011 OpenFOAM is free software: you can redistribute it and/or modify it 00012 under the terms of the GNU General Public License as published by 00013 the Free Software Foundation, either version 3 of the License, or 00014 (at your option) any later version. 00015 00016 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT 00017 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00018 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 00019 for more details. 00020 00021 You should have received a copy of the GNU General Public License 00022 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>. 00023 00024 \*---------------------------------------------------------------------------*/ 00025 00026 #include "FTRsurfaceFormat.H" 00027 #include <OpenFOAM/Keyed.H> 00028 #include <OpenFOAM/IFstream.H> 00029 00030 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // 00031 00032 template<class Face> 00033 Foam::fileFormats::FTRsurfaceFormat<Face>::FTRsurfaceFormat 00034 ( 00035 const fileName& filename 00036 ) 00037 { 00038 read(filename); 00039 } 00040 00041 00042 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * // 00043 00044 template<class Face> 00045 bool Foam::fileFormats::FTRsurfaceFormat<Face>::read 00046 ( 00047 const fileName& filename 00048 ) 00049 { 00050 this->clear(); 00051 00052 IFstream is(filename); 00053 if (!is.good()) 00054 { 00055 FatalErrorIn 00056 ( 00057 "fileFormats::FTRsurfaceFormat::read(const fileName&)" 00058 ) 00059 << "Cannot read file " << filename 00060 << exit(FatalError); 00061 } 00062 00063 List<ftrPatch> ftrPatches(is); 00064 00065 // points read directly 00066 is >> this->storedPoints(); 00067 00068 // triFaces read with attached keys 00069 List< Keyed<triFace> > facesRead(is); 00070 00071 List<Face> faceLst(facesRead.size()); 00072 List<label> zoneIds(facesRead.size()); 00073 00074 // disentangle faces/keys - already triangulated 00075 forAll(facesRead, faceI) 00076 { 00077 // unfortunately cannot transfer to save memory 00078 faceLst[faceI] = facesRead[faceI]; 00079 zoneIds[faceI] = facesRead[faceI].key(); 00080 } 00081 00082 this->storedFaces().transfer(faceLst); 00083 this->storedZoneIds().transfer(zoneIds); 00084 facesRead.clear(); 00085 00086 // change ftrPatch into surfZoneIdentifier 00087 List<surfZoneIdentifier> newZones(ftrPatches.size()); 00088 forAll(newZones, zoneI) 00089 { 00090 newZones[zoneI] = surfZoneIdentifier 00091 ( 00092 ftrPatches[zoneI].name(), 00093 zoneI 00094 ); 00095 } 00096 00097 this->storedZoneToc().transfer(newZones); 00098 return true; 00099 } 00100 00101 00102 // ************************ vim: set sw=4 sts=4 et: ************************ //