/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | cfMesh: A library for mesh generation \\ / O peration | \\ / A nd | Author: Franjo Juretic (franjo.juretic@c-fields.com) \\/ M anipulation | Copyright (C) Creative Fields, Ltd. ------------------------------------------------------------------------------- License This file is part of cfMesh. cfMesh is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. cfMesh is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with cfMesh. If not, see . Description Reads the AVL's surface mesh \*---------------------------------------------------------------------------*/ #include "argList.H" #include "objectRegistry.H" #include "Time.H" #include "triSurf.H" #include "triSurfModifier.H" #include "triFaceList.H" #include "labelLongList.H" #include "IFstream.H" using namespace Foam; // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // int main(int argc, char *argv[]) { argList::noParallel(); argList::validArgs.clear(); argList::validArgs.append("input surface file"); argList::validArgs.append("output surface file"); argList args(argc, argv); fileName inFileName(args.args()[1]); fileName outFileName(args.args()[2]); if( inFileName.ext() != "flma" ) { Info << "Cannot convert this mesh" << endl; return 0; } //- create the surface mesh triSurf ts; triSurfModifier tsm(ts); label counter; IFstream inFile(inFileName); inFile >> counter; //- read vertices pointField& points = tsm.pointsAccess(); points.setSize(counter); forAll(points, pointI) { point& p = points[pointI]; inFile >> p.x(); inFile >> p.y(); inFile >> p.z(); } //- read facets inFile >> counter; geometricSurfacePatchList patches(1); patches[0].name() = "patch"; LongList& triangles = tsm.facetsAccess(); triangles.setSize(counter); forAll(triangles, triI) { inFile >> counter; if( counter != 3 ) { Info << "Facet " << triI << " is not a triangle!!" << endl; Warning << "Cannot convert this surface!" << endl; return 0; } for(label j=0;j<3;++j) inFile >> triangles[triI][2-j]; triangles[triI].region() = 0; } //- read cell types inFile >> counter; forAll(triangles, triI) inFile >> counter; //- start reading selections inFile >> counter; for(label selI=0;selI> selName; //- read selection type label selType; inFile >> selType; //- read selection entries label size; inFile >> size; labelLongList entries(size); for(label i=0;i> entries[i]; //- store cell selections if( selType == 2 ) { Info << "Adding subset " << selName << endl; const label setID = ts.addFacetSubset(selName); forAll(entries, i) ts.addFacetToSubset(setID, entries[i]); } } //- write the surface ts.writeSurface(outFileName); Info << "End\n" << endl; return 0; } // ************************************************************************* //