1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
|
/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration |
\\ / A nd | Copyright (C) 2011-2013 OpenFOAM Foundation
\\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
-------------------------------------------------------------------------------
License
This file is part of OpenFOAM.
OpenFOAM is free software: you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
Class
Foam::mergePolyMesh
Description
Add a given mesh to the original mesh to create a single new mesh
SourceFiles
mergePolyMesh.C
\*---------------------------------------------------------------------------*/
#ifndef mergePolyMesh_H
#define mergePolyMesh_H
#include "polyMesh.H"
#include "polyTopoChange.H"
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
namespace Foam
{
// Forward declaration of classes
/*---------------------------------------------------------------------------*\
Class mergePolyMesh Declaration
\*---------------------------------------------------------------------------*/
class mergePolyMesh
:
public polyMesh
{
// Private data
//- Topological change to accumulated all mesh changes
polyTopoChange meshMod_;
//- Patch names
DynamicList<word> patchNames_;
//- Patch dictionaries
DynamicList<dictionary> patchDicts_;
//- Point zone names
DynamicList<word> pointZoneNames_;
//- Face zone names
DynamicList<word> faceZoneNames_;
//- Cell zone names
DynamicList<word> cellZoneNames_;
// Private Member Functions
//- No copy construct
mergePolyMesh(const mergePolyMesh&) = delete;
//- No copy assignment
void operator=(const mergePolyMesh&) = delete;
//- Return patch index given a name and type
label patchIndex(const polyPatch&);
//- Return zone index given a list of active zones and a name
label zoneIndex(DynamicList<word>&, const word&);
//- Shuffle processor patches to be last
void sortProcessorPatches();
public:
//- Runtime type information
TypeName("mergePolyMesh");
// Constructors
//- Construct from IOobject
mergePolyMesh(const IOobject& io);
//- Destructor
virtual ~mergePolyMesh()
{}
// Member Functions
//- Add a mesh
void addMesh(const polyMesh& m);
//- Merge meshes
void merge();
};
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
} // End namespace Foam
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
#endif
// ************************************************************************* //
|