dynamicFvMesh.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 | Copyright (C) 2011 OpenFOAM Foundation
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
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.
15 
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.
20 
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/>.
23 
24 Class
25  Foam::dynamicFvMesh
26 
27 Description
28  Abstract base class for geometry and/or topology changing fvMesh.
29 
30 SourceFiles
31  dynamicFvMesh.C
32  dynamicFvMeshNew.C
33 
34 \*---------------------------------------------------------------------------*/
35 
36 #ifndef dynamicFvMesh_H
37 #define dynamicFvMesh_H
38 
39 #include "fvMesh.H"
40 #include "autoPtr.H"
41 #include "runTimeSelectionTables.H"
42 
43 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 
45 namespace Foam
46 {
47 
48 /*---------------------------------------------------------------------------*\
49  Class dynamicFvMesh Declaration
50 \*---------------------------------------------------------------------------*/
51 
52 class dynamicFvMesh
53 :
54  public fvMesh
55 {
56  // Private Member Functions
57 
58  //- Disallow default bitwise copy construct
60 
61  //- Disallow default bitwise assignment
62  void operator=(const dynamicFvMesh&);
63 
64 
65 public:
66 
67  //- Runtime type information
68  TypeName("dynamicFvMesh");
69 
70 
71  // Declare run-time constructor selection table
72 
74  (
75  autoPtr,
77  IOobject,
78  (const IOobject& io),
79  (io)
80  );
81 
82 
83  // Constructors
84 
85  //- Construct from objectRegistry, and read/write options
86  explicit dynamicFvMesh(const IOobject& io);
87 
88  //- Construct from components without boundary.
89  // Boundary is added using addFvPatches() member function
91  (
92  const IOobject& io,
93  const Xfer<pointField>& points,
94  const Xfer<faceList>& faces,
95  const Xfer<labelList>& allOwner,
96  const Xfer<labelList>& allNeighbour,
97  const bool syncPar = true
98  );
99 
100  //- Construct without boundary from cells rather than owner/neighbour.
101  // Boundary is added using addPatches() member function
103  (
104  const IOobject& io,
105  const Xfer<pointField>& points,
106  const Xfer<faceList>& faces,
107  const Xfer<cellList>& cells,
108  const bool syncPar = true
109  );
110 
111 
112  // Selectors
113 
114  //- Select null constructed
115  static autoPtr<dynamicFvMesh> New(const IOobject& io);
116 
117 
118  //- Destructor
119  virtual ~dynamicFvMesh();
120 
121 
122  // Member Functions
123 
124  //- Update the mesh for both mesh motion and topology change
125  virtual bool update() = 0;
126 };
127 
128 
129 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
130 
131 } // End namespace Foam
132 
133 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
134 
135 #endif
136 
137 // ************************************************************************* //
A simple container for copying or transferring objects of type <T>.
Definition: Xfer.H:85
const cellList & cells() const
virtual const pointField & points() const
Return raw points.
Definition: polyMesh.C:979
virtual ~dynamicFvMesh()
Destructor.
Definition: dynamicFvMesh.C:90
TypeName("dynamicFvMesh")
Runtime type information.
virtual bool update()=0
Update the mesh for both mesh motion and topology change.
Abstract base class for geometry and/or topology changing fvMesh.
Definition: dynamicFvMesh.H:51
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:78
static autoPtr< dynamicFvMesh > New(const IOobject &io)
Select null constructed.
An auto-pointer similar to the STL auto_ptr but with automatic casting to a reference to the type and...
Definition: PtrList.H:53
Macros to ease declaration of run-time selection tables.
declareRunTimeSelectionTable(autoPtr, dynamicFvMesh, IOobject,(const IOobject &io),(io))
virtual const faceList & faces() const
Return raw faces.
Definition: polyMesh.C:1004
IOobject defines the attributes of an object for which implicit objectRegistry management is supporte...
Definition: IOobject.H:91
Namespace for OpenFOAM.