thermalBaffleModelNew.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 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
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/>.
26 
27 \*---------------------------------------------------------------------------*/
28 
29 #include "thermalBaffleModel.H"
30 
31 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
32 
33 namespace Foam
34 {
35 namespace regionModels
36 {
37 namespace thermalBaffleModels
38 {
39 
40 // * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
41 
43 {
44  const IOdictionary dict
45  (
46  IOobject
47  (
48  "thermalBaffleProperties",
49  mesh.time().constant(),
50  mesh,
53  false // Do not register
54  )
55  );
56 
57  const word modelType
58  (
59  dict.getOrDefault<word>("thermalBaffleModel", "thermalBaffle")
60  );
61 
62  auto cstrIter = meshConstructorTablePtr_->cfind(modelType);
63 
64  if (!cstrIter.found())
65  {
67  (
68  dict,
69  "thermalBaffleModel",
70  modelType,
71  *meshConstructorTablePtr_
72  ) << exit(FatalIOError);
73  }
74 
75  return autoPtr<thermalBaffleModel>(cstrIter()(modelType, mesh));
76 }
77 
78 
80 (
81  const fvMesh& mesh,
82  const dictionary& dict
83 )
84 {
85  const word modelType
86  (
87  dict.getOrDefault<word>("thermalBaffleModel", "thermalBaffle")
88  );
89 
90  auto cstrIter = dictionaryConstructorTablePtr_->cfind(modelType);
91 
92  if (!cstrIter.found())
93  {
95  (
96  dict,
97  "thermalBaffleModel",
98  modelType,
99  *dictionaryConstructorTablePtr_
100  ) << exit(FatalIOError);
101  }
102 
103  return autoPtr<thermalBaffleModel>(cstrIter()(modelType, mesh, dict));
104 }
105 
106 
107 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
108 
109 } // End namespace thermalBaffleModels
110 } // End namespace regionModels
111 } // End namespace Foam
112 
113 // ************************************************************************* //
Foam::IOobject::NO_WRITE
Definition: IOobject.H:130
Foam::IOdictionary
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Definition: IOdictionary.H:54
Foam::IOobject
Defines the attributes of an object for which implicit objectRegistry management is supported,...
Definition: IOobject.H:104
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:62
thermalBaffleModel.H
Foam::FatalIOError
IOerror FatalIOError
Foam::regionModels::thermalBaffleModels::thermalBaffleModel::New
static autoPtr< thermalBaffleModel > New(const fvMesh &mesh)
Return a reference to the selected model.
Definition: thermalBaffleModelNew.C:42
FatalIOErrorInLookup
#define FatalIOErrorInLookup(ios, lookupTag, lookupName, lookupTable)
Report an error message using Foam::FatalIOError.
Definition: error.H:406
dict
dictionary dict
Definition: searchingEngine.H:14
Foam::dictionary
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition: dictionary.H:121
mesh
dynamicFvMesh & mesh
Definition: createDynamicFvMesh.H:6
Foam::fvMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:83
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::exit
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition: errorManip.H:130
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition: HashPtrTable.H:53
Foam::IOobject::MUST_READ_IF_MODIFIED
Definition: IOobject.H:121