OpenFOAM logo
Open Source CFD Toolkit

mapClouds.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------------*\
00002   =========                 |
00003   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
00004    \\    /   O peration     |
00005     \\  /    A nd           | Copyright (C) 1991-2005 OpenCFD Ltd.
00006      \\/     M anipulation  |
00007 -------------------------------------------------------------------------------
00008 License
00009     This file is part of OpenFOAM.
00010 
00011     OpenFOAM is free software; you can redistribute it and/or modify it
00012     under the terms of the GNU General Public License as published by the
00013     Free Software Foundation; either version 2 of the License, or (at your
00014     option) any later version.
00015 
00016     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
00017     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00018     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
00019     for more details.
00020 
00021     You should have received a copy of the GNU General Public License
00022     along with OpenFOAM; if not, write to the Free Software Foundation,
00023     Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
00024 
00025 Class
00026     mapClouds
00027 
00028 Description
00029     Generic Geometric field mapper.  For "real" mapping, add template
00030     specialisations for mapping of internal fields depending on mesh
00031     type.
00032 
00033 \*---------------------------------------------------------------------------*/
00034 
00035 #ifndef mapClouds_H
00036 #define mapClouds_H
00037 
00038 #include "cloud.H"
00039 #include "objectRegistry.H"
00040 
00041 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00042 
00043 namespace Foam
00044 {
00045 
00046 inline void mapClouds(const objectRegistry& db, const mapPolyMesh& mapper)
00047 {
00048     HashTable<const cloud*> clouds(db.lookupClass<cloud>());
00049 
00050     for
00051     (
00052         HashTable<const cloud*>::iterator iter = clouds.begin();
00053         iter != clouds.end();
00054         ++iter
00055     )
00056     {
00057         cloud& c = const_cast<cloud&>(*iter());
00058 
00059         if (polyMesh::debug)
00060         {
00061             Info<< "Mapping cloud " << c.name() << endl;
00062         }
00063 
00064         c.autoMap(mapper);
00065     }
00066 }
00067 
00068 
00069 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00070 
00071 } // End namespace Foam
00072 
00073 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00074 
00075 #endif
00076 
00077 // ************************************************************************* //
For further information go to www.openfoam.org