genericLagrangianPatchField.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration | Website: https://openfoam.org
5  \\ / A nd | Copyright (C) 2025 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::genericLagrangianPatchField
26 
27 Description
28  This boundary condition provides a generic version of the \c calculated
29  condition, useful as a fallback for handling unknown patch types when
30  post-processing or running mesh manipulation utilities. Not generally
31  applicable as a user-specified condition.
32 
33 See also
34  Foam::calculatedLagrangianPatchField
35 
36 SourceFiles
37  genericLagrangianPatchField.C
38 
39 \*---------------------------------------------------------------------------*/
40 
41 #ifndef genericLagrangianPatchField_H
42 #define genericLagrangianPatchField_H
43 
44 #include "genericFieldBase.H"
46 #include "HashPtrTable.H"
47 
48 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
49 
50 namespace Foam
51 {
52 
53 /*---------------------------------------------------------------------------*\
54  Class genericLagrangianPatchField Declaration
55 \*---------------------------------------------------------------------------*/
56 
57 template<class Type>
59 :
60  public genericFieldBase,
62 {
63  // Private Data
64 
65  //- Patch field dictionary
66  dictionary dict_;
67 
68 
69 public:
70 
71  //- Runtime type information
72  TypeName("generic");
73 
74 
75  // Constructors
76 
77  //- Construct from patch, internal field and dictionary
79  (
80  const LagrangianPatch&,
81  const regIOobject&,
82  const dictionary&
83  );
84 
85  //- Construct as copy
87  (
89  );
90 
91  //- Construct as copy setting internal field reference
93  (
95  const regIOobject&
96  );
97 
98  //- Construct and return a clone
100  {
102  (
104  );
105  }
106 
107  //- Construct and return a clone setting internal field reference
109  (
110  const regIOobject& iIo
111  ) const
112  {
114  (
116  (
117  *this,
118  iIo
119  )
120  );
121  }
122 
123 
124  // Member Functions
125 
126  //- Write
127  virtual void write(Ostream&) const;
128 };
129 
130 
131 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
132 
133 } // End namespace Foam
134 
135 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
136 
137 #ifdef NoRepository
139 #endif
140 
141 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
142 
143 #endif
144 
145 // ************************************************************************* //
Base class for Lagrangian patches.
An Ostream is an abstract base class for all output systems (streams, files, token lists,...
Definition: Ostream.H:57
An auto-pointer similar to the STL auto_ptr but with automatic casting to a reference to the type and...
Definition: autoPtr.H:51
A calculated boundary condition for Lagrangian. This condition does not provide any evaluation functi...
A list of keywords followed by any number of values (e.g. words and numbers) or sub-dictionaries.
Definition: dictionary.H:162
Base class for generic field types. Facilitates down-casting so that the actual type can be queried.
This boundary condition provides a generic version of the calculated condition, useful as a fallback ...
genericLagrangianPatchField(const LagrangianPatch &, const regIOobject &, const dictionary &)
Construct from patch, internal field and dictionary.
TypeName("generic")
Runtime type information.
virtual void write(Ostream &) const
Write.
virtual autoPtr< LagrangianPatchField< Type > > clone() const
Construct and return a clone.
regIOobject is an abstract class derived from IOobject to handle automatic object registration with t...
Definition: regIOobject.H:55
Namespace for OpenFOAM.