GlobalIOField.H
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) 2015-2017 OpenFOAM Foundation
9  Copyright (C) 2016-2018 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 Class
28  Foam::GlobalIOField
29 
30 Description
31  IOField with global data (so optionally read from master)
32 
33 SourceFiles
34  GlobalIOField.C
35 
36 \*---------------------------------------------------------------------------*/
37 
38 #ifndef Foam_GlobalIOField_H
39 #define Foam_GlobalIOField_H
40 
41 #include "IOField.H"
42 
43 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 
45 namespace Foam
46 {
47 
48 /*---------------------------------------------------------------------------*\
49  Class GlobalIOField Declaration
50 \*---------------------------------------------------------------------------*/
51 
52 template<class Type>
53 class GlobalIOField
54 :
55  public regIOobject,
56  public Field<Type>
57 {
58 public:
59 
60  //- The underlying content type
61  typedef Field<Type> content_type;
62 
63  //- Runtime type information
64  TypeName("Field");
65 
66 
67  // Constructors
68 
69  //- Default copy construct
70  GlobalIOField(const GlobalIOField&) = default;
71 
72  //- Construct from IOobject
73  explicit GlobalIOField(const IOobject& io);
74 
75  //- Construct from IOobject and field size (if not read)
76  GlobalIOField(const IOobject& io, const label len);
77 
78  //- Construct from IOobject and copy of List/Field content
79  GlobalIOField(const IOobject& io, const UList<Type>& content);
80 
81  //- Construct by transferring the Field content
82  GlobalIOField(const IOobject& io, Field<Type>&& content);
83 
84  //- Construct by copying/moving tmp content
85  GlobalIOField(const IOobject& io, const tmp<Field<Type>>& tfld);
86 
87 
88  //- Destructor
89  virtual ~GlobalIOField() = default;
90 
91 
92  // Member Functions
93 
94  //- Is object global
95  virtual bool global() const
96  {
97  return true;
98  }
99 
100  //- Return complete path + object name if the file exists
101  //- either in the case/processor or case, otherwise null
102  virtual fileName filePath() const
103  {
104  return globalFilePath(type());
105  }
106 
107  //- The readData method for regIOobject read operation
108  virtual bool readData(Istream& is);
109 
110  //- The writeData method for regIOobject write operation
111  bool writeData(Ostream& os) const;
112 
113 
114  // Member Operators
115 
116  //- Copy assignment of entries
117  void operator=(const GlobalIOField<Type>& rhs);
118 
119  //- Copy or move assignment of entries
120  using Field<Type>::operator=;
121 };
122 
123 
124 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
125 
126 } // End namespace Foam
127 
128 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
129 
130 #ifdef NoRepository
131 # include "GlobalIOField.C"
132 #endif
133 
134 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
135 
136 #endif
137 
138 // ************************************************************************* //
virtual bool readData(Istream &is)
The readData method for regIOobject read operation.
A class for handling file names.
Definition: fileName.H:72
TypeName("Field")
Runtime type information.
fileName globalFilePath(const word &typeName, const bool search=true) const
Redirect to fileHandler filePath, searching up if in parallel.
Definition: IOobject.C:547
bool writeData(Ostream &os) const
The writeData method for regIOobject write operation.
fileName::Type type(const fileName &name, const bool followLink=true)
Return the file type: DIRECTORY or FILE, normally following symbolic links.
Definition: POSIX.C:799
Generic templated field type.
Definition: Field.H:62
IOField with global data (so optionally read from master)
Definition: GlobalIOField.H:48
void operator=(const GlobalIOField< Type > &rhs)
Copy assignment of entries.
An Ostream is an abstract base class for all output systems (streams, files, token lists...
Definition: Ostream.H:56
OBJstream os(runTime.globalPath()/outputName)
GlobalIOField(const GlobalIOField &)=default
Default copy construct.
virtual fileName filePath() const
Return complete path + object name if the file exists either in the case/processor or case...
virtual bool global() const
Is object global.
virtual ~GlobalIOField()=default
Destructor.
regIOobject is an abstract class derived from IOobject to handle automatic object registration with t...
Definition: regIOobject.H:66
IOobject io("surfaceFilmProperties", mesh.time().constant(), mesh, IOobject::READ_IF_PRESENT, IOobject::NO_WRITE, IOobject::NO_REGISTER)
A class for managing temporary objects.
Definition: HashPtrTable.H:50
Defines the attributes of an object for which implicit objectRegistry management is supported...
Definition: IOobject.H:172
Field< Type > content_type
The underlying content type.
Definition: GlobalIOField.H:58
Namespace for OpenFOAM.