/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | Copyright (C) 2004-2011 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 . Description IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionality via the objectRegistry. To facilitate IO, IOdictioanry is provided with a constructor from IOobject and writeData and write functions. \*---------------------------------------------------------------------------*/ #include "IOdictionary.H" #include "objectRegistry.H" #include "Pstream.H" // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * // defineTypeNameAndDebug(Foam::IOdictionary, 0); // * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * // // Parallel aware reading, using non-virtual type information (typeName instead // of type()) because of use in constructor. void Foam::IOdictionary::readFile(const bool masterOnly) { if (Pstream::master() || !masterOnly) { if (debug) { Pout<< "IOdictionary : Reading " << objectPath() << " from file " << endl; } readStream(typeName) >> *this; close(); } if (masterOnly && Pstream::parRun()) { // Scatter master data using communication scheme const List& comms = ( (Pstream::nProcs() < Pstream::nProcsSimpleSum) ? Pstream::linearCommunication() : Pstream::treeCommunication() ); // Master reads headerclassname from file. Make sure this gets // transfered as well as contents. Pstream::scatter(comms, const_cast(headerClassName())); Pstream::scatter(comms, note()); // Get my communication order const Pstream::commsStruct& myComm = comms[Pstream::myProcNo()]; // Reveive from up if (myComm.above() != -1) { if (debug) { Pout<< "IOdictionary : Reading " << objectPath() << " from processor " << myComm.above() << endl; } // Note: use ASCII for now - binary IO of dictionaries is // not currently supported IPstream fromAbove ( Pstream::scheduled, myComm.above(), 0, IOstream::ASCII ); IOdictionary::readData(fromAbove); } // Send to my downstairs neighbours forAll(myComm.below(), belowI) { if (debug) { Pout<< "IOdictionary : Sending " << objectPath() << " to processor " << myComm.below()[belowI] << endl; } OPstream toBelow ( Pstream::scheduled, myComm.below()[belowI], 0, Pstream::msgType(), IOstream::ASCII ); IOdictionary::writeData(toBelow); } } } // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // Foam::IOdictionary::IOdictionary(const IOobject& io) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ) { WarningIn("IOdictionary::IOdictionary(const IOobject&)") //FatalErrorIn("IOdictionary::IOdictionary(const IOobject&)") << "Dictionary " << name() << " constructed with IOobject::MUST_READ" " instead of IOobject::MUST_READ_IF_MODIFIED." << nl << "Use MUST_READ_IF_MODIFIED if you need automatic rereading." << endl; //<< abort(FatalError); } // Everyone check or just master bool masterOnly = regIOobject::fileModificationChecking == timeStampMaster || regIOobject::fileModificationChecking == inotifyMaster; // Check if header is ok for READ_IF_PRESENT bool isHeaderOk = false; if (io.readOpt() == IOobject::READ_IF_PRESENT) { if (masterOnly) { if (Pstream::master()) { isHeaderOk = headerOk(); } Pstream::scatter(isHeaderOk); } else { isHeaderOk = headerOk(); } } if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || isHeaderOk ) { readFile(masterOnly); } dictionary::name() = IOobject::objectPath(); } Foam::IOdictionary::IOdictionary(const IOobject& io, const dictionary& dict) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ) { WarningIn ( "IOdictionary::IOdictionary(const IOobject& const dictionary&)" ) << "Dictionary " << name() << " constructed with IOobject::MUST_READ" " instead of IOobject::MUST_READ_IF_MODIFIED." << nl << "Use MUST_READ_IF_MODIFIED if you need automatic rereading." << endl; } // Everyone check or just master bool masterOnly = regIOobject::fileModificationChecking == timeStampMaster || regIOobject::fileModificationChecking == inotifyMaster; // Check if header is ok for READ_IF_PRESENT bool isHeaderOk = false; if (io.readOpt() == IOobject::READ_IF_PRESENT) { if (masterOnly) { if (Pstream::master()) { isHeaderOk = headerOk(); } Pstream::scatter(isHeaderOk); } else { isHeaderOk = headerOk(); } } if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || isHeaderOk ) { readFile(masterOnly); } else { dictionary::operator=(dict); } dictionary::name() = IOobject::objectPath(); } Foam::IOdictionary::IOdictionary(const IOobject& io, Istream& is) : regIOobject(io), dictionary(is) { dictionary::name() = IOobject::objectPath(); } // * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * * // Foam::IOdictionary::~IOdictionary() {} // * * * * * * * * * * * * * * * Members Functions * * * * * * * * * * * * * // const Foam::word& Foam::IOdictionary::name() const { return regIOobject::name(); } // * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * // void Foam::IOdictionary::operator=(const IOdictionary& rhs) { dictionary::operator=(rhs); } // ************************************************************************* //