fileFieldSelectionTemplates.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) 2017 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 "IOobjectList.H"
29 #include "GeometricField.H"
30 #include "fvMesh.H"
31 
32 // * * * * * * * * * * * * * Protected Member Functions * * * * * * * * * * //
33 
34 template<class Type>
36 (
37  const IOobjectList& allFileObjects,
39 ) const
40 {
41  for (const fieldInfo& fi : *this)
42  {
43  const wordList names(allFileObjects.names(Type::typeName, fi.name()));
44  if (names.size())
45  {
46  for (const word& name : names)
47  {
48  set.append(fieldInfo(wordRe(name)));
49  }
50 
51  fi.found() = true;
52  }
53  }
54 }
55 
56 
57 template<template<class> class PatchType, class MeshType>
59 (
61 ) const
62 {
63  const fvMesh& mesh = static_cast<const fvMesh&>(obr_);
64 
65  const IOobjectList allObjects(mesh, mesh.time().timeName());
66 
67  addFromFile<GeometricField<scalar, PatchType, MeshType>>(allObjects, set);
68  addFromFile<GeometricField<vector, PatchType, MeshType>>(allObjects, set);
69  addFromFile<GeometricField<sphericalTensor, PatchType, MeshType>>
70  (
71  allObjects,
72  set
73  );
74  addFromFile<GeometricField<symmTensor, PatchType, MeshType>>
75  (
76  allObjects,
77  set
78  );
79  addFromFile<GeometricField<tensor, PatchType, MeshType>>(allObjects, set);
80 }
81 
82 
83 // ************************************************************************* //
Foam::BitOps::set
void set(List< bool > &bools, const labelRange &range)
Set the specified range 'on' in a boolList.
Definition: BitOps.C:37
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::DynamicList
A 1D vector of objects of type <T> that resizes itself as necessary to accept the new objects.
Definition: DynamicList.H:55
Foam::functionObjects::fieldInfo::name
const wordRe & name() const
Definition: fieldInfo.H:107
Foam::functionObjects::fieldInfo
Helper class to store a wordRe and label used by Foam::functionObjects::fieldSelection.
Definition: fieldInfo.H:57
Foam::functionObjects::fileFieldSelection::addGeoFieldTypes
void addGeoFieldTypes(DynamicList< fieldInfo > &set) const
Add registered GeometricField types to selection.
Definition: fileFieldSelectionTemplates.C:59
IOobjectList.H
Foam::IOobjectList::names
wordList names() const
The names of the IOobjects.
Definition: IOobjectList.C:310
Foam::wordRe
A wordRe is a Foam::word, but can contain a regular expression for matching words or strings.
Definition: wordRe.H:80
Foam::functionObjects::fileFieldSelection::addFromFile
void addFromFile(const IOobjectList &allFileObjects, DynamicList< fieldInfo > &set) const
Add objects of a given type.
Definition: fileFieldSelectionTemplates.C:36
mesh
dynamicFvMesh & mesh
Definition: createDynamicFvMesh.H:6
Foam::fvMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:85
fvMesh.H
Foam::IOobjectList
List of IOobjects with searching and retrieving facilities.
Definition: IOobjectList.H:55
GeometricField.H
Foam::functionObjects::fieldInfo::found
Switch & found() const
Definition: fieldInfo.H:117
Foam::List< word >
Foam::name
word name(const expressions::valueTypeCode typeCode)
A word representation of a valueTypeCode. Empty for INVALID.
Definition: exprTraits.C:59
Foam::PtrListOps::names
List< word > names(const UPtrList< T > &list, const UnaryMatchPredicate &matcher)