Initial commit for version 2.0.x patch release
[OpenFOAM-2.0.x.git] / src / triSurface / tools / labelledTri / sortLabelledTri.H
blob1c53f1d7cbf742d18bb5f0cf1092e3c770837228
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2004-2010 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM 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 OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::sortLabelledTri
27 Description
28     Helper class which when constructed with a triSurface
29     sorts the faces according to region number (or rather constructs a
30     mapping).
32 SourceFiles
33     sortLabelledTri.C
35 \*---------------------------------------------------------------------------*/
37 #ifndef sortLabelledTri_H
38 #define sortLabelledTri_H
40 #include "labelList.H"
42 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 namespace Foam
47 class sortLabelledTri;
48 class triSurface;
50 /*---------------------------------------------------------------------------*\
51                          Class surfAndLabel Declaration
52 \*---------------------------------------------------------------------------*/
54 //- Hold surface and label
55 class surfAndLabel
57     const triSurface* surfPtr_;
59     label index_;
61     // Private Classes
63         //- scalar comparison function used for sorting
64         class less
65         {
66         public:
68             inline bool operator()
69             (
70                 const surfAndLabel& one,
71                 const surfAndLabel& two
72             ) const;
73         };
76 public:
78     friend class sortLabelledTri;
80     // Constructors
82         //- Construct null
83         surfAndLabel()
84         :
85             surfPtr_(NULL),
86             index_(-1)
87         {}
89         //- Construct from surface and index
90         surfAndLabel(const triSurface& surf, const label index)
91         :
92             surfPtr_(&surf),
93             index_(index)
94         {}
98 /*---------------------------------------------------------------------------*\
99                            Class sortLabelledTri Declaration
100 \*---------------------------------------------------------------------------*/
102 class sortLabelledTri
104     public List<surfAndLabel>
107 public:
109     // Constructors
111         //- Construct from surface, sorting the faces according to patch
112         sortLabelledTri(const triSurface&);
115     // Member Functions
117         // Access
119             //- Set the labelList to those of sorted point indices
120             void indices(labelList&) const;
122             //- Return the list of sorted point indices
123             labelList indices() const;
127 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
129 } // End namespace Foam
131 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
133 #endif
135 // ************************************************************************* //