Adding cfMesh-v1.0 into the repository
[foam-extend-3.2.git] / src / meshLibrary / utilities / meshes / polyMeshGenAddressing / polyMeshGenAddressingPointFaces.C
blob1fb1b518b9807786163e5a0fb303183a83d778d3
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | cfMesh: A library for mesh generation
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright held by the original author
6      \\/     M anipulation  |
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 \*---------------------------------------------------------------------------*/
26 #include "polyMeshGenAddressing.H"
27 #include "VRWGraphSMPModifier.H"
29 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
31 namespace Foam
34 // * * * * * * * * * * * * * Private Member Functions  * * * * * * * * * * * //
36 void polyMeshGenAddressing::calcPointFaces() const
38     if( pfPtr_)
39     {
40         FatalErrorIn("polyMeshGenAddressing::calcPointFaces()")
41             << "pointFaces already calculated"
42             << abort(FatalError);
43     }
44     else
45     {
46         const faceListPMG& faces = mesh_.faces();
47         const label nPoints = mesh_.points().size();
49         //- create the addressing
50         pfPtr_ = new VRWGraph();
51         VRWGraph& pointFaceAddr = *pfPtr_;
53         VRWGraphSMPModifier(pointFaceAddr).reverseAddressing(faces);
54         pointFaceAddr.setSize(nPoints);
55     }
58 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
60 const VRWGraph& polyMeshGenAddressing::pointFaces() const
62     if( !pfPtr_ )
63     {
64         # ifdef USE_OMP
65         if( omp_in_parallel() )
66             FatalErrorIn
67             (
68                 "const VRWGraph& polyMeshGenAddressing::pointFaces() const"
69             ) << "Calculating addressing inside a parallel region."
70                 << " This is not thread safe" << exit(FatalError);
71         # endif
73         calcPointFaces();
74     }
76     return *pfPtr_;
80 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
82 } // End namespace Foam
84 // ************************************************************************* //