mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
- forwards to the underlying HashTable erase, but frees things owned by the registry as well (ie, performs a checkOut)
439 lines
9.8 KiB
C
439 lines
9.8 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2011-2017 OpenFOAM Foundation
|
|
\\/ M anipulation | Copyright (C) 2015-2019 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/>.
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "objectRegistry.H"
|
|
#include "Time.H"
|
|
#include "predicates.H"
|
|
|
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
|
|
|
namespace Foam
|
|
{
|
|
defineTypeNameAndDebug(objectRegistry, 0);
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Local Functions * * * * * * * * * * * * * * //
|
|
|
|
namespace Foam
|
|
{
|
|
|
|
// Templated implementation for erase() with iterator range.
|
|
// Prefer not to expose directly.
|
|
template<class InputIter>
|
|
static label eraseImpl(objectRegistry& obr, InputIter first, InputIter last)
|
|
{
|
|
label changed = 0;
|
|
|
|
for
|
|
(
|
|
const label nTotal = obr.size();
|
|
changed < nTotal && first != last; // Terminate early
|
|
++first
|
|
)
|
|
{
|
|
if (obr.erase(*first))
|
|
{
|
|
++changed;
|
|
}
|
|
}
|
|
|
|
return changed;
|
|
}
|
|
|
|
} // End namespace Foam
|
|
|
|
|
|
// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
|
|
|
|
bool Foam::objectRegistry::parentNotTime() const
|
|
{
|
|
return (&parent_ != dynamic_cast<const objectRegistry*>(&time_));
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
|
|
|
Foam::objectRegistry::objectRegistry(const Time& t, const label nObjects)
|
|
:
|
|
regIOobject
|
|
(
|
|
IOobject
|
|
(
|
|
word::validate(t.caseName()),
|
|
t.path(),
|
|
t,
|
|
IOobject::NO_READ,
|
|
IOobject::AUTO_WRITE,
|
|
false
|
|
),
|
|
true // to flag that this is the top-level regIOobject
|
|
),
|
|
HashTable<regIOobject*>(nObjects),
|
|
time_(t),
|
|
parent_(t),
|
|
dbDir_(name()),
|
|
event_(1)
|
|
{}
|
|
|
|
|
|
Foam::objectRegistry::objectRegistry(const IOobject& io, const label nObjects)
|
|
:
|
|
regIOobject(io),
|
|
HashTable<regIOobject*>(nObjects),
|
|
time_(io.time()),
|
|
parent_(io.db()),
|
|
dbDir_(parent_.dbDir()/local()/name()),
|
|
event_(1)
|
|
{
|
|
writeOpt() = IOobject::AUTO_WRITE;
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
|
|
|
Foam::objectRegistry::~objectRegistry()
|
|
{
|
|
objectRegistry::clear();
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
|
|
|
Foam::HashTable<Foam::wordHashSet> Foam::objectRegistry::classes() const
|
|
{
|
|
return classesImpl(*this, predicates::always());
|
|
}
|
|
|
|
|
|
Foam::label Foam::objectRegistry::count(const char* clsName) const
|
|
{
|
|
// No nullptr check - only called with string literals
|
|
return count(static_cast<word>(clsName));
|
|
}
|
|
|
|
|
|
Foam::wordList Foam::objectRegistry::names() const
|
|
{
|
|
return HashTable<regIOobject*>::toc();
|
|
}
|
|
|
|
|
|
Foam::wordList Foam::objectRegistry::sortedNames() const
|
|
{
|
|
return HashTable<regIOobject*>::sortedToc();
|
|
}
|
|
|
|
|
|
Foam::wordList Foam::objectRegistry::names(const char* clsName) const
|
|
{
|
|
// No nullptr check - only called with string literals
|
|
return names(static_cast<word>(clsName));
|
|
}
|
|
|
|
|
|
Foam::wordList Foam::objectRegistry::sortedNames(const char* clsName) const
|
|
{
|
|
// No nullptr check - only called with string literals
|
|
return sortedNames(static_cast<word>(clsName));
|
|
}
|
|
|
|
|
|
const Foam::objectRegistry& Foam::objectRegistry::subRegistry
|
|
(
|
|
const word& name,
|
|
const bool forceCreate,
|
|
const bool recursive
|
|
) const
|
|
{
|
|
if (forceCreate && !foundObject<objectRegistry>(name, recursive))
|
|
{
|
|
objectRegistry* subObr = new objectRegistry
|
|
(
|
|
IOobject
|
|
(
|
|
name,
|
|
time().constant(),
|
|
*this,
|
|
IOobject::NO_READ,
|
|
IOobject::NO_WRITE
|
|
)
|
|
);
|
|
subObr->store();
|
|
}
|
|
|
|
return lookupObject<objectRegistry>(name, recursive);
|
|
}
|
|
|
|
|
|
Foam::label Foam::objectRegistry::getEvent() const
|
|
{
|
|
label curEvent = event_++;
|
|
|
|
if (event_ == labelMax)
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
WarningInFunction
|
|
<< "Event counter has overflowed. "
|
|
<< "Resetting counter on all dependent objects." << nl
|
|
<< "This might cause extra evaluations." << endl;
|
|
}
|
|
|
|
// Reset event counter
|
|
curEvent = 1;
|
|
event_ = 2;
|
|
|
|
// No need to reset dependent objects; overflow is now handled
|
|
// in regIOobject::upToDate
|
|
}
|
|
|
|
return curEvent;
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::checkIn(regIOobject& io) const
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
Pout<< "objectRegistry::checkIn(regIOobject&) : "
|
|
<< name() << " : checking in " << io.name()
|
|
<< " of type " << io.type()
|
|
<< endl;
|
|
}
|
|
|
|
objectRegistry& obr = const_cast<objectRegistry&>(*this);
|
|
|
|
bool ok = obr.insert(io.name(), &io);
|
|
|
|
if (!ok && objectRegistry::debug)
|
|
{
|
|
WarningInFunction
|
|
<< name() << " : attempted to checkIn object with name "
|
|
<< io.name() << " which was already checked in"
|
|
<< endl;
|
|
}
|
|
|
|
return ok;
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::checkOut(regIOobject& io) const
|
|
{
|
|
objectRegistry& obr = const_cast<objectRegistry&>(*this);
|
|
|
|
iterator iter = obr.find(io.name());
|
|
|
|
if (iter.found())
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
Pout<< "objectRegistry::checkOut(regIOobject&) : "
|
|
<< name() << " : checking out " << io.name()
|
|
<< endl;
|
|
}
|
|
|
|
if (iter.val() != &io)
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
WarningInFunction
|
|
<< name() << " : attempt to checkOut copy of "
|
|
<< iter.key()
|
|
<< endl;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
return obr.erase(iter);
|
|
}
|
|
|
|
|
|
if (objectRegistry::debug)
|
|
{
|
|
Pout<< "objectRegistry::checkOut(regIOobject&) : "
|
|
<< name() << " : could not find " << io.name() << " in registry"
|
|
<< endl;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
void Foam::objectRegistry::clear()
|
|
{
|
|
// Free anything owned by the registry
|
|
for (iterator iter = begin(); iter != end(); ++iter)
|
|
{
|
|
regIOobject* ptr = iter.val();
|
|
|
|
if (ptr && ptr->ownedByRegistry())
|
|
{
|
|
delete ptr;
|
|
}
|
|
}
|
|
|
|
HashTable<regIOobject*>::clear();
|
|
}
|
|
|
|
|
|
void Foam::objectRegistry::clearStorage()
|
|
{
|
|
objectRegistry::clear();
|
|
HashTable<regIOobject*>::clearStorage();
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::erase(const iterator& iter)
|
|
{
|
|
// Free anything owned by the registry
|
|
|
|
if (iter.found())
|
|
{
|
|
regIOobject* ptr = iter.val();
|
|
|
|
bool ok = HashTable<regIOobject*>::erase(iter);
|
|
|
|
if (ptr && ptr->ownedByRegistry())
|
|
{
|
|
delete ptr;
|
|
}
|
|
|
|
return ok;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::erase(const word& key)
|
|
{
|
|
return erase(find(key));
|
|
}
|
|
|
|
|
|
Foam::label Foam::objectRegistry::erase(std::initializer_list<word> keys)
|
|
{
|
|
return eraseImpl(*this, keys.begin(), keys.end());
|
|
}
|
|
|
|
|
|
Foam::label Foam::objectRegistry::erase(const UList<word>& keys)
|
|
{
|
|
return eraseImpl(*this, keys.begin(), keys.end());
|
|
}
|
|
|
|
|
|
void Foam::objectRegistry::rename(const word& newName)
|
|
{
|
|
regIOobject::rename(newName);
|
|
|
|
// Adjust dbDir_ as well
|
|
const auto i = dbDir_.rfind('/');
|
|
|
|
if (i == string::npos)
|
|
{
|
|
dbDir_ = newName;
|
|
}
|
|
else
|
|
{
|
|
dbDir_.replace(i+1, string::npos, newName);
|
|
}
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::modified() const
|
|
{
|
|
for (const_iterator iter = cbegin(); iter != cend(); ++iter)
|
|
{
|
|
if (iter()->modified())
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
void Foam::objectRegistry::readModifiedObjects()
|
|
{
|
|
for (iterator iter = begin(); iter != end(); ++iter)
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
Pout<< "objectRegistry::readModifiedObjects() : "
|
|
<< name() << " : Considering reading object "
|
|
<< iter.key() << endl;
|
|
}
|
|
|
|
iter()->readIfModified();
|
|
}
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::readIfModified()
|
|
{
|
|
readModifiedObjects();
|
|
return true;
|
|
}
|
|
|
|
|
|
bool Foam::objectRegistry::writeObject
|
|
(
|
|
IOstream::streamFormat fmt,
|
|
IOstream::versionNumber ver,
|
|
IOstream::compressionType cmp,
|
|
const bool valid
|
|
) const
|
|
{
|
|
bool ok = true;
|
|
|
|
for (const_iterator iter = cbegin(); iter != cend(); ++iter)
|
|
{
|
|
if (objectRegistry::debug)
|
|
{
|
|
Pout<< "objectRegistry::write() : "
|
|
<< name() << " : Considering writing object "
|
|
<< iter.key()
|
|
<< " of type " << iter()->type()
|
|
<< " with writeOpt " << iter()->writeOpt()
|
|
<< " to file " << iter()->objectPath()
|
|
<< endl;
|
|
}
|
|
|
|
if (iter()->writeOpt() != NO_WRITE)
|
|
{
|
|
ok = iter()->writeObject(fmt, ver, cmp, valid) && ok;
|
|
}
|
|
}
|
|
|
|
return ok;
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|