00001 /*---------------------------------------------------------------------------*\ 00002 ========= | 00003 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox 00004 \\ / O peration | 00005 \\ / A nd | Copyright (C) 1991-2010 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 00013 the Free Software Foundation, either version 3 of the License, or 00014 (at your 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, see <http://www.gnu.org/licenses/>. 00023 00024 InNamespace 00025 Foam::mapClouds 00026 00027 Description 00028 Generic Geometric field mapper. For "real" mapping, add template 00029 specialisations for mapping of internal fields depending on mesh 00030 type. 00031 00032 \*---------------------------------------------------------------------------*/ 00033 00034 #ifndef mapClouds_H 00035 #define mapClouds_H 00036 00037 #include "cloud.H" 00038 #include <OpenFOAM/objectRegistry.H> 00039 00040 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00041 00042 namespace Foam 00043 { 00044 00045 //- Generic Geometric field mapper. 00046 // For "real" mapping, add template specialisations for mapping of internal 00047 // fields depending on mesh type. 00048 inline void mapClouds(const objectRegistry& db, const mapPolyMesh& mapper) 00049 { 00050 HashTable<const cloud*> clouds(db.lookupClass<cloud>()); 00051 00052 for 00053 ( 00054 HashTable<const cloud*>::iterator iter = clouds.begin(); 00055 iter != clouds.end(); 00056 ++iter 00057 ) 00058 { 00059 cloud& c = const_cast<cloud&>(*iter()); 00060 00061 if (polyMesh::debug) 00062 { 00063 Info<< "Mapping cloud " << c.name() << endl; 00064 } 00065 00066 c.autoMap(mapper); 00067 } 00068 } 00069 00070 00071 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00072 00073 } // End namespace Foam 00074 00075 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00076 00077 #endif 00078 00079 // ************************ vim: set sw=4 sts=4 et: ************************ //