triSurfaceGeoMesh.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2011 OpenFOAM Foundation
9  Copyright (C) 2021,2025 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 Class
28  Foam::triSurfaceGeoMesh
29 
30 Description
31  The triSurface GeoMesh (for holding face fields).
32 
33 \*---------------------------------------------------------------------------*/
34 
35 #ifndef Foam_triSurfaceGeoMesh_H
36 #define Foam_triSurfaceGeoMesh_H
37 
38 #include "GeoMesh.H"
39 #include "triSurface.H"
40 
41 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
42 
43 namespace Foam
44 {
45 
46 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47 
49 :
50  public GeoMesh<triSurface>
51 {
52 public:
53 
54  // Constructors
55 
56  //- Construct from triSurface reference
57  explicit triSurfaceGeoMesh(const triSurface& mesh)
58  :
60  {}
61 
62 
63  // Static Functions
64 
65  //- The geometric (internal) size - number of faces.
66  // Method name expected by GeoMesh interface
67  static label size(const triSurface& mesh)
68  {
69  return mesh.size();
70  }
71 
72  //- The geometric boundary size - not used.
73  // Method name expected by GeoMesh interface
74  static label boundary_size(const triSurface& mesh) noexcept
75  {
76  return 0;
77  }
78 
79 
80  // Member Functions
81 
82  //- The geometric (internal) size - number of faces.
83  // Method name expected by GeoMesh interface
84  label size() const
85  {
86  return size(mesh_);
87  }
88 };
89 
90 
91 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
92 
93 } // End namespace Foam
94 
95 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
96 
97 #endif
98 
99 // ************************************************************************* //
triSurfaceGeoMesh(const triSurface &mesh)
Construct from triSurface reference.
static label boundary_size(const triSurface &mesh) noexcept
The geometric boundary size - not used.
The triSurface GeoMesh (for holding face fields).
dynamicFvMesh & mesh
const direction noexcept
Definition: scalarImpl.H:265
label size() const
The geometric (internal) size - number of faces.
Generic mesh wrapper used by volMesh, surfaceMesh, pointMesh etc.
Definition: GeoMesh.H:45
Triangulated surface description with patch information.
Definition: triSurface.H:71
const triSurface & mesh_
Reference to Mesh.
Definition: GeoMesh.H:54
Namespace for OpenFOAM.