Forward compatibility: flex
[foam-extend-3.2.git] / src / surfMesh / MeshedSurface / MeshedSurfaceCore.C
blob7d69c20030c439720d8a4d9f9b7df739344e05ee
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend 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     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 \*---------------------------------------------------------------------------*/
26 #include "objectRegistry.H"
27 #include "foamTime.H"
28 #include "MeshedSurface.H"
30 // * * * * * * * * * * * * * Private Member Functions  * * * * * * * * * * * //
32 namespace Foam
35     // specialization: from face -> triFace
36     template<>
37     void Foam::MeshedSurface<triFace>::transcribe(MeshedSurface<face>& surf)
38     {
39         // first triangulate
40         surf.triangulate();
41         this->storedPoints().transfer(surf.storedPoints());
42         this->storedZones().transfer(surf.storedZones());
44         // transcribe from face -> triFace
45         List<face>&    origFaces = surf.storedFaces();
46         List<triFace>  newFaces(origFaces.size());
47         forAll(origFaces, faceI)
48         {
49             newFaces[faceI] = triFace
50             (
51                 static_cast<const UList<label>&>(origFaces[faceI])
52             );
53         }
54         surf.clear();
56         this->storedFaces().transfer(newFaces);
57     }
60     // specialization: from face -> face
61     template<>
62     void Foam::MeshedSurface<face>::transcribe(MeshedSurface<face>& surf)
63     {
64         this->transfer(surf);
65     }
68 }  // end of namespace Foam
71 // * * * * * * * * * * * * Protected Member Functions  * * * * * * * * * * * //
74 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
77 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
79 // ************************************************************************* //