OpenFOAM: API Guide
v2112
The open source CFD toolbox
simplifiedDynamicFvMesh.C
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) 2018-2021 OpenCFD Ltd.
9
-------------------------------------------------------------------------------
10
License
11
This file is part of OpenFOAM.
12
13
OpenFOAM is free software: you can redistribute it and/or modify it
14
under the terms of the GNU General Public License as published by
15
the Free Software Foundation, either version 3 of the License, or
16
(at your option) any later version.
17
18
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
19
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21
for more details.
22
23
You should have received a copy of the GNU General Public License
24
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
25
26
\*---------------------------------------------------------------------------*/
27
28
#include "
simplifiedDynamicFvMesh.H
"
29
#include "
staticFvMesh.H
"
30
31
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
32
33
namespace
Foam
34
{
35
namespace
simplifiedMeshes
36
{
37
defineTypeNameAndDebug
(
simplifiedDynamicFvMeshBase
, 0);
38
defineRunTimeSelectionTable
(
simplifiedDynamicFvMeshBase
, time);
39
}
40
}
41
42
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
43
44
Foam::autoPtr<Foam::dynamicFvMesh>
45
Foam::simplifiedMeshes::simplifiedDynamicFvMeshBase::New
46
(
47
const
IOobject
&
io
48
)
49
{
50
IOobject
dictHeader
51
(
52
"dynamicMeshDict"
,
53
io
.
time
().
constant
(),
54
polyMesh::regionName
(
io
.
name
()),
55
io
.
db
(),
56
IOobject::MUST_READ_IF_MODIFIED
,
57
IOobject::NO_WRITE
,
58
false
59
);
60
61
if
(dictHeader.
typeHeaderOk
<
IOdictionary
>(
true
))
62
{
63
IOdictionary
dict
(dictHeader);
64
65
const
word
modelType(
dict
.
get
<
word
>(
"dynamicFvMesh"
));
66
67
auto
* ctorPtr = timeConstructorTable(modelType);
68
69
if
(ctorPtr)
70
{
71
Info
<<
"Selecting simplified mesh model "
<< modelType <<
endl
;
72
return
autoPtr<dynamicFvMesh>
(ctorPtr(
io
.
time
(),
io
.
name
()));
73
}
74
}
75
76
Info
<<
"Selecting simplified mesh model "
<<
staticFvMesh::typeName
<<
endl
;
77
return
autoPtr<dynamicFvMesh>
78
(
79
new
SimplifiedDynamicFvMesh<staticFvMesh>
(
io
.
time
(),
io
.
name
())
80
);
81
}
82
83
84
// ************************************************************************* //
Foam::IOdictionary
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Definition:
IOdictionary.H:57
Foam::IOobject
Defines the attributes of an object for which implicit objectRegistry management is supported,...
Definition:
IOobject.H:170
Foam::IOobject::name
const word & name() const noexcept
Return the object name.
Definition:
IOobjectI.H:65
Foam::IOobject::time
const Time & time() const
Return Time associated with the objectRegistry.
Definition:
IOobject.C:506
Foam::IOobject::typeHeaderOk
bool typeHeaderOk(const bool checkType=true, const bool search=true, const bool verbose=true)
Read header (uses typeFilePath to find file) and check its info.
Definition:
IOobjectTemplates.C:39
Foam::IOobject::db
const objectRegistry & db() const noexcept
Return the local objectRegistry.
Definition:
IOobject.C:500
Foam::IOobject::NO_WRITE
@ NO_WRITE
Definition:
IOobject.H:187
Foam::IOobject::MUST_READ_IF_MODIFIED
@ MUST_READ_IF_MODIFIED
Definition:
IOobject.H:180
Foam::TimePaths::constant
const word & constant() const
Return constant name.
Definition:
TimePathsI.H:96
Foam::Time::New
static autoPtr< Time > New()
Construct (dummy) Time - no functionObjects or libraries.
Definition:
Time.C:717
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition:
autoPtr.H:66
Foam::dictionary::get
T get(const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const
Definition:
dictionaryTemplates.C:107
Foam::polyMesh::regionName
const word & regionName() const
The mesh region name or word::null if polyMesh::defaultRegion.
Definition:
polyMesh.C:854
Foam::simplifiedMeshes::SimplifiedDynamicFvMesh
Definition:
simplifiedDynamicFvMesh.H:99
Foam::simplifiedMeshes::simplifiedDynamicFvMeshBase
Definition:
simplifiedDynamicFvMesh.H:57
Foam::word
A class for handling words, derived from Foam::string.
Definition:
word.H:68
defineTypeNameAndDebug
#define defineTypeNameAndDebug(Type, DebugSwitch)
Define the typeName and debug information.
Definition:
className.H:121
io
IOobject io("surfaceFilmProperties", mesh.time().constant(), mesh, IOobject::READ_IF_PRESENT, IOobject::NO_WRITE, false)
Foam
Namespace for OpenFOAM.
Definition:
atmBoundaryLayer.C:34
Foam::Info
messageStream Info
Information stream (stdout output on master, null elsewhere)
Foam::endl
Ostream & endl(Ostream &os)
Add newline and flush stream.
Definition:
Ostream.H:372
defineRunTimeSelectionTable
#define defineRunTimeSelectionTable(baseType, argNames)
Define run-time selection table.
Definition:
runTimeSelectionTables.H:374
dict
dictionary dict
Definition:
searchingEngine.H:14
simplifiedDynamicFvMesh.H
staticFvMesh.H
Foam::ensightPTraits::typeName
static const char *const typeName
The type name used in ensight case files.
Definition:
ensightPTraits.H:56
src
dynamicFvMesh
simplifiedDynamicFvMesh
simplifiedDynamicFvMesh.C
Generated by
1.9.5
OPENFOAM® is a registered
trademark
of OpenCFD Ltd.