fvPatchFieldBase.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) 2022-2023 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 "fvPatchField.H"
29 #include "dictionary.H"
30 
31 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
32 
33 namespace Foam
34 {
35  defineTypeNameAndDebug(fvPatchFieldBase, 0);
36 }
37 
39 (
40  Foam::debug::debugSwitch("disallowGenericFvPatchField", 0)
41 );
42 
43 
44 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
45 
47 :
48  patch_(p),
49  updated_(false),
50  manipulatedMatrix_(false),
51  useImplicit_(false),
52  patchType_()
53 {}
54 
55 
57 (
58  const fvPatch& p,
59  const word& patchType
60 )
61 :
63 {
64  patchType_ = patchType;
65 }
66 
67 
69 (
70  const fvPatch& p,
71  const dictionary& dict
72 )
73 :
75 {
76  fvPatchFieldBase::readDict(dict);
77 }
78 
79 
81 (
82  const fvPatchFieldBase& rhs,
83  const fvPatch& p
84 )
85 :
86  patch_(p),
87  updated_(false),
88  manipulatedMatrix_(false),
89  useImplicit_(rhs.useImplicit_),
90  patchType_(rhs.patchType_)
91 {}
92 
93 
95 :
96  patch_(rhs.patch_),
97  updated_(false),
98  manipulatedMatrix_(false),
99  useImplicit_(rhs.useImplicit_),
100  patchType_(rhs.patchType_)
101 {}
102 
103 
104 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
105 
107 {
108  dict.readIfPresent("patchType", patchType_, keyType::LITERAL);
109  dict.readIfPresent("useImplicit", useImplicit_, keyType::LITERAL);
110 }
111 
114 {
115  return patch_.boundaryMesh().mesh().thisDb();
116 }
117 
118 
120 {
121  if (&patch_ != &(rhs.patch_))
122  {
124  << "Different patches for fvPatchField"
125  << abort(FatalError);
126  }
127 }
128 
129 
130 // ************************************************************************* //
dictionary dict
const objectRegistry & db() const
The associated objectRegistry.
error FatalError
Error stream (stdout output on all processes), with additional &#39;FOAM FATAL ERROR&#39; header text and sta...
A list of keyword definitions, which are a keyword followed by a number of values (eg...
Definition: dictionary.H:129
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
Definition: error.H:598
int debugSwitch(const char *name, const int deflt=0)
Lookup debug switch or add default value.
Definition: debug.C:222
A finiteVolume patch using a polyPatch and a fvBoundaryMesh.
Definition: fvPatch.H:70
Template invariant parts for fvPatchField.
Definition: fvPatchField.H:77
virtual void readDict(const dictionary &dict)
Read dictionary entries.
A class for handling words, derived from Foam::string.
Definition: word.H:63
String literal.
Definition: keyType.H:82
fvPatchFieldBase(const fvPatch &p)
Construct from patch.
errorManip< error > abort(error &err)
Definition: errorManip.H:139
static int disallowGenericPatchField
Debug switch to disallow the use of generic fvPatchField.
Definition: fvPatchField.H:149
defineTypeNameAndDebug(combustionModel, 0)
volScalarField & p
void checkPatch(const fvPatchFieldBase &rhs) const
Check that patches are identical.
Registry of regIOobjects.
const objectRegistry & thisDb() const noexcept
Return the object registry.
Namespace for OpenFOAM.