genericPointPatchField.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) 2011-2023 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::genericPointPatchField
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::calculatedPointPatchField
35 
36 SourceFiles
37  genericPointPatchField.C
38 
39 \*---------------------------------------------------------------------------*/
40 
41 #ifndef genericPointPatchField_H
42 #define genericPointPatchField_H
43 
44 #include "genericFieldBase.H"
46 #include "HashPtrTable.H"
47 
48 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
49 
50 namespace Foam
51 {
52 
53 /*---------------------------------------------------------------------------*\
54  Class genericPointPatchField Declaration
55 \*---------------------------------------------------------------------------*/
56 
57 template<class Type>
59 :
60  public genericFieldBase,
61  public calculatedPointPatchField<Type>
62 {
63  // Private Data
64 
65  //- Patch field dictionary
66  dictionary dict_;
67 
68  //- Fields
69  #define DeclareTypeFields(Type, nullArg) \
70  HashPtrTable<Field<Type>> Type##Fields_;
71  FOR_ALL_FIELD_TYPES(DeclareTypeFields);
72  #undef DeclareTypeFields
73 
74 
75 public:
76 
77  //- Runtime type information
78  TypeName("generic");
79 
80 
81  // Constructors
82 
83  //- Construct from patch, internal field and dictionary
85  (
86  const pointPatch&,
88  const dictionary&
89  );
90 
91  //- Construct by mapping given genericPointPatchField onto a new patch
93  (
95  const pointPatch&,
97  const fieldMapper&
98  );
99 
100  //- Construct as copy setting internal field reference
102  (
105  );
106 
107  //- Construct and return a clone setting internal field reference
109  (
111  ) const
112  {
114  (
116  (
117  *this,
118  iF
119  )
120  );
121  }
122 
123 
124  // Member Functions
125 
126  // Mapping functions
127 
128  //- Map the given pointPatchField onto this pointPatchField
129  virtual void map(const pointPatchField<Type>&, const fieldMapper&);
130 
131  //- Reset the pointPatchField to the given pointPatchField
132  // Used for mesh to mesh mapping
133  virtual void reset(const pointPatchField<Type>&);
134 
135 
136  //- Write
137  virtual void write(Ostream&) const;
138 };
139 
140 
141 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
142 
143 } // End namespace Foam
144 
145 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
146 
147 #ifdef NoRepository
148  #include "genericPointPatchField.C"
149 #endif
150 
151 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
152 
153 #endif
154 
155 // ************************************************************************* //
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
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 pointField.
A list of keyword definitions, which are a keyword followed by any number of values (e....
Definition: dictionary.H:162
Abstract base class for field mapping.
Definition: fieldMapper.H:48
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 ...
TypeName("generic")
Runtime type information.
virtual void write(Ostream &) const
Write.
virtual void reset(const pointPatchField< Type > &)
Reset the pointPatchField to the given pointPatchField.
virtual void map(const pointPatchField< Type > &, const fieldMapper &)
Map the given pointPatchField onto this pointPatchField.
genericPointPatchField(const pointPatch &, const DimensionedField< Type, pointMesh > &, const dictionary &)
Construct from patch, internal field and dictionary.
Abstract base class for point-mesh patch fields.
autoPtr< pointPatchField< Type > > clone() const
Disallow clone without setting internal field reference.
Basic pointPatch represents a set of points from the mesh.
Definition: pointPatch.H:57
#define DeclareTypeFields(Type, nullArg)
Fields.
Namespace for OpenFOAM.