lumpedPointIOMovement.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) 2016-2022 OpenCFD Ltd.
9 -------------------------------------------------------------------------------
10 License
11  This file is part of OpenFOAM.
12 
13  OpenFOAM is free software: you can redistribute it and/or modify it
14  under the terms of the GNU General Public License as published by
15  the Free Software Foundation, either version 3 of the License, or
16  (at your option) any later version.
17 
18  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
19  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21  for more details.
22 
23  You should have received a copy of the GNU General Public License
24  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
25 
26 \*---------------------------------------------------------------------------*/
27 
28 #include "lumpedPointIOMovement.H"
29 #include "Time.H"
30 
31 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
32 
33 namespace Foam
34 {
36 }
37 
38 
39 // * * * * * * * * * * * * * Static Member Functions * * * * * * * * * * * * //
40 
43 {
45  (
47  );
48 }
49 
50 
53 (
54  const objectRegistry& obr,
55  label ownerId
56 )
57 {
59  (
60  IOobject
61  (
63  obr.time().caseSystem(),
64  obr,
68  ),
69  ownerId // tag this patch as owner too
70  );
71 }
72 
73 
74 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
75 
76 Foam::lumpedPointIOMovement::lumpedPointIOMovement
77 (
78  const IOobject& io,
79  label ownerId
80 )
81 :
84 {
85  if (isReadRequired())
86  {
87  bool ok = readData(readStream(typeName));
88  close();
89 
90  if (ok)
91  {
92  this->ownerId(ownerId);
93  }
94  }
95 }
96 
97 
98 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
99 
101 {
102  dictionary dict(is);
104  readDict(dict);
105 
106  return is.check(FUNCTION_NAME);
107 }
108 
109 
111 {
112  os << *this;
113  return os.good();
114 }
115 
116 
117 // * * * * * * * * * * * * * * * IOstream Operators * * * * * * * * * * * * //
118 
119 Foam::Ostream& Foam::operator<<(Ostream& os, const lumpedPointIOMovement& obj)
120 {
121  obj.writeDict(os);
122 
124  return os;
125 }
126 
127 
128 // ************************************************************************* //
dictionary dict
virtual bool check(const char *operation) const
Check IOstream status for given operation.
Definition: IOstream.C:45
Ignore writing from objectRegistry::writeObject()
static const word canonicalName
The canonical name ("lumpedPointMovement") for the dictionary.
bool writeData(Ostream &os) const
The writeData member function required by regIOobject.
fileName caseSystem() const
Return the system name for the case, which is ../system() for parallel runs.
Definition: TimePathsI.H:135
defineTypeName(manifoldCellsMeshObject)
label ownerId() const
An owner Id, if needed for bookkeeping purposes.
IO-registered version of lumpedPointMovement.
void close()
Close Istream.
Type * getObjectPtr(const word &name, const bool recursive=false) const
Return non-const pointer to the object of the given Type, using a const-cast to have it behave like a...
const Time & time() const noexcept
Return time registry.
static lumpedPointIOMovement * getMovementObject(const objectRegistry &obr)
Find the movement object or nullptr if not found.
bool readData(Istream &is)
The readData member function used by regIOobject.
An Ostream is an abstract base class for all output systems (streams, files, token lists...
Definition: Ostream.H:56
OBJstream os(runTime.globalPath()/outputName)
#define FUNCTION_NAME
bool isReadRequired() const noexcept
True if (MUST_READ | READ_MODIFIED) bits are set.
Ostream & operator<<(Ostream &, const boundaryPatch &p)
Write boundaryPatch as dictionary entries (without surrounding braces)
Definition: boundaryPatch.C:77
bool good() const noexcept
True if next operation might succeed.
Definition: IOstream.H:281
static autoPtr< lumpedPointIOMovement > New(const objectRegistry &obr, label ownerId=-1)
Create a movement object in the registry by reading system dictionary.
regIOobject is an abstract class derived from IOobject to handle automatic object registration with t...
Definition: regIOobject.H:66
Pointer management similar to std::unique_ptr, with some additional methods and type checking...
Definition: HashPtrTable.H:48
IOobject io("surfaceFilmProperties", mesh.time().constant(), mesh, IOobject::READ_IF_PRESENT, IOobject::NO_WRITE, IOobject::NO_REGISTER)
Registry of regIOobjects.
static autoPtr< T > New(Args &&... args)
Construct autoPtr with forwarding arguments.
Definition: autoPtr.H:178
Defines the attributes of an object for which implicit objectRegistry management is supported...
Definition: IOobject.H:172
Request registration (bool: true)
The movement driver that describes initial point locations, the current state of the points/rotations...
Namespace for OpenFOAM.