/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration |
\\ / A nd | Copyright (C) 2014-2016 OpenFOAM Foundation
\\/ 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 .
\*---------------------------------------------------------------------------*/
#include "partialWrite.H"
#include "Time.H"
#include "polyMesh.H"
#include "addToRunTimeSelectionTable.H"
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
namespace Foam
{
namespace functionObjects
{
defineTypeNameAndDebug(partialWrite, 0);
addToRunTimeSelectionTable
(
functionObject,
partialWrite,
dictionary
);
}
}
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
Foam::functionObjects::partialWrite::partialWrite
(
const word& name,
const Time& runTime,
const dictionary& dict
)
:
functionObject(name),
obr_
(
runTime.lookupObject
(
dict.lookupOrDefault("region", polyMesh::defaultRegion)
)
)
{
read(dict);
}
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
Foam::functionObjects::partialWrite::~partialWrite()
{}
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
bool Foam::functionObjects::partialWrite::read(const dictionary& dict)
{
dict.lookup("objectNames") >> objectNames_;
dict.lookup("writeInterval") >> writeInterval_;
writeInstance_ = 0;
Info<< type() << " " << name() << ":" << nl
<< " dumping every " << writeInterval_
<< " th writeTime : " << nl << endl ;
forAllConstIter(HashSet, objectNames_, iter)
{
Info<< ' ' << iter.key();
}
if (writeInterval_ < 1)
{
FatalIOErrorInFunction(dict)
<< "Illegal value for writeInterval " << writeInterval_
<< ". It should be >= 1."
<< exit(FatalIOError);
}
// Clear out any previously loaded fields
vsf_.clear();
vvf_.clear();
vSpheretf_.clear();
vSymmtf_.clear();
vtf_.clear();
ssf_.clear();
svf_.clear();
sSpheretf_.clear();
sSymmtf_.clear();
stf_.clear();
forAllConstIter(HashSet, objectNames_, iter)
{
loadField(iter.key(), vsf_, ssf_);
loadField(iter.key(), vvf_, svf_);
loadField(iter.key(), vSpheretf_, sSpheretf_);
loadField(iter.key(), vSymmtf_, sSymmtf_);
loadField(iter.key(), vtf_, stf_);
}
return true;
}
bool Foam::functionObjects::partialWrite::execute(const bool postProcess)
{
return true;
}
bool Foam::functionObjects::partialWrite::timeSet()
{
if (obr_.time().writeTime())
{
writeInstance_++;
if (writeInstance_ == writeInterval_)
{
// Next overall dump corresponds to partial write. Change
// write options to AUTO_WRITE
writeInstance_ = 0;
changeWriteOptions(vsf_, ssf_, IOobject::AUTO_WRITE);
changeWriteOptions(vvf_, svf_, IOobject::AUTO_WRITE);
changeWriteOptions
(
vSpheretf_,
sSpheretf_,
IOobject::AUTO_WRITE
);
changeWriteOptions
(
vSymmtf_,
sSymmtf_,
IOobject::AUTO_WRITE
);
changeWriteOptions(vtf_, stf_, IOobject::AUTO_WRITE);
}
else
{
changeWriteOptions(vsf_, ssf_, IOobject::NO_WRITE);
changeWriteOptions(vvf_, svf_, IOobject::NO_WRITE);
changeWriteOptions
(
vSpheretf_,
sSpheretf_,
IOobject::NO_WRITE
);
changeWriteOptions
(
vSymmtf_,
sSymmtf_,
IOobject::NO_WRITE
);
changeWriteOptions(vtf_, stf_, IOobject::NO_WRITE);
}
}
return true;
}
bool Foam::functionObjects::partialWrite::write(const bool postProcess)
{
return true;
}
// ************************************************************************* //