Loading...
Searching...
No Matches
GAMGInterfaceFieldNew.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) 2011-2015 OpenFOAM Foundation
9 Copyright (C) 2019-2021,2023 OpenCFD Ltd.
10-------------------------------------------------------------------------------
11License
12 This file is part of OpenFOAM.
13
14 OpenFOAM is free software: you can redistribute it and/or modify it
15 under the terms of the GNU General Public License as published by
16 the Free Software Foundation, either version 3 of the License, or
17 (at your option) any later version.
18
19 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22 for more details.
23
24 You should have received a copy of the GNU General Public License
25 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
27\*---------------------------------------------------------------------------*/
28
29#include "GAMGInterfaceField.H"
30
31// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
32
34(
35 const GAMGInterface& GAMGCp,
36 const lduInterfaceField& fineInterface
37)
38{
39 const word coupleType(fineInterface.interfaceFieldType());
40
41 auto* ctorPtr = lduInterfaceFieldConstructorTable(coupleType);
42
43 if (!ctorPtr)
44 {
46 (
47 "GAMGInterfaceField",
48 coupleType,
49 *lduInterfaceFieldConstructorTablePtr_
51 }
52
53 return autoPtr<GAMGInterfaceField>(ctorPtr(GAMGCp, fineInterface));
54}
55
56
58(
59 const GAMGInterface& GAMGCp,
60 const bool doTransform,
61 const int rank
62)
63{
64 const word coupleType(GAMGCp.type());
65
66 auto* ctorPtr = lduInterfaceConstructorTable(coupleType);
67
68 if (!ctorPtr)
69 {
71 (
72 "GAMGInterfaceField",
73 coupleType,
74 *lduInterfaceConstructorTablePtr_
76 }
77
78 return autoPtr<GAMGInterfaceField>(ctorPtr(GAMGCp, doTransform, rank));
79}
80
81
83(
84 const word& patchFieldType,
85 const GAMGInterface& GAMGCp,
86 Istream& is
87)
88{
89 auto* ctorPtr = IstreamConstructorTable(patchFieldType);
90
91 if (!ctorPtr)
92 {
94 (
95 "GAMGInterfaceField",
96 patchFieldType,
97 *IstreamConstructorTablePtr_
98 ) << exit(FatalError);
99 }
100
101 return autoPtr<GAMGInterfaceField>(ctorPtr(GAMGCp, is));
102}
103
104
105// ************************************************************************* //
static autoPtr< GAMGInterfaceField > New(const GAMGInterface &GAMGCp, const lduInterfaceField &fineInterface)
Return a pointer to a new interface created on freestore given.
Abstract base class for GAMG agglomerated interfaces.
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition Istream.H:60
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition autoPtr.H:65
virtual const word & interfaceFieldType() const
Return the interface type.
lduInterfaceField(const lduInterfaceField &)=delete
No copy construct.
A class for handling words, derived from Foam::string.
Definition word.H:66
#define FatalErrorInLookup(lookupTag, lookupName, lookupTable)
Report an error message using Foam::FatalError.
Definition error.H:607
error FatalError
Error stream (stdout output on all processes), with additional 'FOAM FATAL ERROR' header text and sta...
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition errorManip.H:125