Fix tutorials: coupled/conjugateHeatFoam/conjugateCavity: fix Allrun file
[OpenFOAM-1.6-ext.git] / src / meshTools / sets / topoSets / faceSet.H
blobe605c6da77ae26057d022eb0bb952ec8616258c9
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright held by original author
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 the
13     Free Software Foundation; either version 2 of the License, or (at your
14     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, write to the Free Software Foundation,
23     Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
25 Class
26     Foam::faceSet
28 Description
29     A list of face labels.
31 SourceFiles
32     faceSet.C
34 \*---------------------------------------------------------------------------*/
36 #ifndef faceSet_H
37 #define faceSet_H
39 #include "topoSet.H"
41 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
43 namespace Foam
46 /*---------------------------------------------------------------------------*\
47                            Class faceSet Declaration
48 \*---------------------------------------------------------------------------*/
50 class faceSet
52     public topoSet
54 public:
56     //- Runtime type information
57     TypeName("faceSet");
60     // Constructors
63         //- Construct from IOobject
64         faceSet(const IOobject& obj);
66         //- Construct from objectRegistry and name
67         faceSet
68         (
69             const polyMesh& mesh,
70             const word& name,
71             readOption r = MUST_READ,
72             writeOption w = NO_WRITE
73         );
75         //- Construct from additional size of labelHashSet
76         faceSet
77         (
78             const polyMesh& mesh,
79             const word& name,
80             const label,
81             writeOption w = NO_WRITE
82         );
84         //- Construct from existing set
85         faceSet
86         (
87             const polyMesh& mesh,
88             const word& name,
89             const topoSet&,
90             writeOption w = NO_WRITE
91         );
93         //- Construct from additional labelHashSet
94         faceSet
95         (
96             const polyMesh& mesh,
97             const word& name,
98             const labelHashSet&,
99             writeOption w = NO_WRITE
100         );
103     // Destructor
105         virtual ~faceSet();
108     // Member functions
110         //- Sync faceSet across coupled patches.
111         virtual void sync(const polyMesh& mesh);
113         //- Return max index+1.
114         virtual label maxSize(const polyMesh& mesh) const;
116         //- Update any stored data for new labels
117         virtual void updateMesh(const mapPolyMesh& morphMap);
119         //- Write maxLen items with label and coordinates.
120         virtual void writeDebug
121         (
122             Ostream& os,
123             const primitiveMesh&,
124             const label maxLen
125         ) const;
130 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
132 } // End namespace Foam
134 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
136 #endif
138 // ************************************************************************* //