FreeFOAM The Cross-Platform CFD Toolkit
Hosted by SourceForge:
Get FreeFOAM at SourceForge.net.
            Fast, secure and Free Open Source software downloads

faceMesh.H

Go to the documentation of this file.
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 Class
00025     Foam::faceMesh
00026 
00027 Description
00028     Storage for surface mesh i.e. points and faces.
00029 
00030 SourceFiles
00031 
00032 \*---------------------------------------------------------------------------*/
00033 
00034 #ifndef faceMesh_H
00035 #define faceMesh_H
00036 
00037 #include <OpenFOAM/PrimitivePatch_.H>
00038 #include <OpenFOAM/faceList.H>
00039 
00040 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00041 
00042 namespace Foam
00043 {
00044 
00045 /*---------------------------------------------------------------------------*\
00046                            Class faceMesh Declaration
00047 \*---------------------------------------------------------------------------*/
00048 
00049 class faceMesh
00050 :
00051     public PrimitivePatch<face, List, pointField>
00052 {
00053     // Private member functions
00054 
00055         PrimitivePatch<face, List, pointField> read(Istream& is)
00056         {
00057             pointField points(is);
00058             faceList faces(is);
00059             return PrimitivePatch<face, Foam::List, pointField>(faces, points);
00060         }
00061 
00062 
00063 public:
00064 
00065     // Constructors
00066 
00067         //- Construct from components
00068         faceMesh(const faceList& faces, const pointField& points)
00069         :
00070             PrimitivePatch<face, Foam::List, pointField>(faces, points)
00071         {}
00072 
00073         //- Construct from Istream
00074         faceMesh(Istream& is)
00075         :
00076             PrimitivePatch<face, Foam::List, pointField>(read(is))
00077         {}
00078 
00079 
00080     // Member Functions
00081 
00082         void flip()
00083         {
00084             forAll(*this, i)
00085             {
00086                 face& f = operator[](i);
00087                 f = f.reverseFace();
00088             }
00089             clearOut();
00090         }
00091 
00092     // IOstream Operators
00093 
00094         friend Ostream& operator<<(Ostream& os, const faceMesh& fm)
00095         {
00096             return os
00097                 << fm.points()
00098                 << token::NL
00099                 << static_cast<PrimitivePatch<face, Foam::List, pointField> >
00100                    (fm);
00101         }
00102 };
00103 
00104 
00105 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00106 
00107 } // End namespace Foam
00108 
00109 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00110 
00111 #endif
00112 
00113 // ************************ vim: set sw=4 sts=4 et: ************************ //
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines