Skip to content
Snippets Groups Projects
Commit 03b8275a authored by Mark OLESEN's avatar Mark OLESEN
Browse files

ENH: add foamListRegions utility

- list all regions from constant/regionProperties:
     * foamListRegions

- list specific region type from constant/regionProperties:
     * foamListRegions fluid
     * foamListRegions solid
parent cf15d299
Branches
Tags
No related merge requests found
foamListRegions.C
EXE = $(FOAM_APPBIN)/foamListRegions
EXE_INC = \
-I$(LIB_SRC)/regionModels/regionModel/lnInclude
EXE_LIBS = \
-lregionModels
/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration |
\\ / A nd | Copyright (C) 2017 OpenCFD Ltd.
\\/ M anipulation |
-------------------------------------------------------------------------------
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/>.
Application
foamListRegions
Group
grpPostProcessingUtilities
Description
List regions from constant/regionProperties.
To simplify parsing of the output, the normal banner information
is suppressed.
Usage
\b foamListRegions [OPTION]
\*---------------------------------------------------------------------------*/
#include "argList.H"
#include "Time.H"
#include "regionProperties.H"
using namespace Foam;
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
int main(int argc, char *argv[])
{
argList::addNote("List regions from constant/regionProperties");
argList::noBanner();
argList::noParallel();
argList::noJobInfo();
argList::noFunctionObjects();
// No profiling since there is no time loop
// Non-mandatory arguments
argList::addArgument("regionType ... regionType");
#include "setRootCaseNonMandatoryArgs.H"
// As per "createTime.H", but quieter.
Time runTime(Time::controlDictName, args);
regionProperties rp(runTime);
// We now handle checking args and general sanity etc.
wordList regionTypes;
if (args.size() > 1)
{
regionTypes.setSize(args.size()-1);
label nTypes = 0;
for (label argi = 1; argi < args.size(); ++argi)
{
regionTypes[nTypes] = args[argi];
if (rp.found(regionTypes[nTypes]))
{
++nTypes;
}
else
{
std::cerr<< "No region-type: " << regionTypes[nTypes] << nl;
}
}
regionTypes.setSize(nTypes);
}
else
{
regionTypes = rp.sortedToc();
}
for (const word& regionType : regionTypes)
{
const wordList& regionNames = rp[regionType];
for (const word& regionName : regionNames)
{
Info<< regionName << nl;
}
}
return 0;
}
// ************************************************************************* //
......@@ -7,12 +7,12 @@ runApplication topoSet
runApplication splitMeshRegions -cellZones -overwrite
# Remove fluid fields from solid regions (important for post-processing)
for i in heater leftSolid rightSolid
for i in $(foamListRegions solid)
do
rm -f 0*/$i/{nut,alphat,epsilon,k,U,p_rgh}
done
for i in bottomWater topAir heater leftSolid rightSolid
for i in $(foamListRegions)
do
runApplication -s $i changeDictionary -region $i
done
......
......@@ -11,15 +11,15 @@ runApplication snappyHexMesh -overwrite
runApplication splitMeshRegions -cellZones -overwrite
# remove fluid fields from solid regions (important for post-processing)
for i in heater leftSolid rightSolid
for i in $(foamListRegions solid)
do
rm -f 0*/$i/{nut,alphat,epsilon,k,U,p_rgh}
done
for i in bottomAir topAir heater leftSolid rightSolid
for i in $(foamListRegions)
do
runApplication -s $i changeDictionary -region $i
runApplication -s $i changeDictionary -region $i
done
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment