coordinateSystemNew.C
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-2018 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 \*---------------------------------------------------------------------------*/
25 
26 #include "coordinateSystem.H"
27 #include "dictionary.H"
28 
29 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
30 
32 (
33  const objectRegistry& obr,
34  const dictionary& dict
35 )
36 {
37  const dictionary& coordDict = dict.subDict(typeName_());
38  word coordType = coordDict.lookup("type");
39 
40  dictionaryConstructorTable::iterator cstrIter =
41  dictionaryConstructorTablePtr_->find(coordType);
42 
43  if (cstrIter == dictionaryConstructorTablePtr_->end())
44  {
46  (
47  dict
48  ) << "Unknown coordinateSystem type "
49  << coordType << nl << nl
50  << "Valid coordinateSystem types are :" << nl
51  << dictionaryConstructorTablePtr_->sortedToc()
52  << exit(FatalIOError);
53  }
54 
55  return autoPtr<coordinateSystem>(cstrIter()(obr, coordDict));
56 }
57 
58 
60 (
61  const dictionary& dict
62 )
63 {
64  const dictionary& coordDict = dict.subDict(typeName_());
65 
66  return autoPtr<coordinateSystem>(new coordinateSystem(coordDict));
67 }
68 
69 
71 (
72  Istream& is
73 )
74 {
75  const word name(is);
76  const dictionary dict(is);
77 
78  return autoPtr<coordinateSystem>(new coordinateSystem(name, dict));
79 }
80 
81 
82 // ************************************************************************* //
Base class for other coordinate system specifications.
dictionary dict
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition: errorManip.H:124
A list of keyword definitions, which are a keyword followed by any number of values (e...
Definition: dictionary.H:137
An Istream is an abstract base class for all input systems (streams, files, token lists etc)...
Definition: Istream.H:57
const dictionary & subDict(const word &) const
Find and return a sub-dictionary.
Definition: dictionary.C:692
A class for handling words, derived from string.
Definition: word.H:59
static const char nl
Definition: Ostream.H:265
word name(const complex &)
Return a string representation of a complex.
Definition: complex.C:47
static autoPtr< coordinateSystem > New(const objectRegistry &obr, const dictionary &dict)
Select constructed from dictionary and objectRegistry.
#define FatalIOErrorInFunction(ios)
Report an error message using Foam::FatalIOError.
Definition: error.H:331
Registry of regIOobjects.
ITstream & lookup(const word &, bool recursive=false, bool patternMatch=true) const
Find and return an entry data stream.
Definition: dictionary.C:576
IOerror FatalIOError