/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | Copyright (C) 2004-2010 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 . \*---------------------------------------------------------------------------*/ #include "IOField.H" // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // template Foam::IOField::IOField(const IOobject& io) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ_IF_MODIFIED) { WarningIn("IOField::IOField(const IOobject&)") << "IOField " << name() << " constructed with IOobject::MUST_READ_IF_MODIFIED" " but IOField does not support automatic rereading." << endl; } if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk()) ) { readStream(typeName) >> *this; close(); } } template Foam::IOField::IOField(const IOobject& io, const label size) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ_IF_MODIFIED) { WarningIn("IOField::IOField(const IOobject&, const label)") << "IOField " << name() << " constructed with IOobject::MUST_READ_IF_MODIFIED" " but IOField does not support automatic rereading." << endl; } if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk()) ) { readStream(typeName) >> *this; close(); } else { Field::setSize(size); } } template Foam::IOField::IOField(const IOobject& io, const Field& f) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ_IF_MODIFIED) { WarningIn("IOField::IOField(const IOobject&, const Field&)") << "IOField " << name() << " constructed with IOobject::MUST_READ_IF_MODIFIED" " but IOField does not support automatic rereading." << endl; } if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk()) ) { readStream(typeName) >> *this; close(); } else { Field::operator=(f); } } template Foam::IOField::IOField(const IOobject& io, const Xfer >& f) : regIOobject(io) { // Temporary warning if (io.readOpt() == IOobject::MUST_READ_IF_MODIFIED) { WarningIn ( "IOField::IOField(const IOobject&, const Xfer >&)" ) << "IOField " << name() << " constructed with IOobject::MUST_READ_IF_MODIFIED" " but IOField does not support automatic rereading." << endl; } Field::transfer(f()); if ( ( io.readOpt() == IOobject::MUST_READ || io.readOpt() == IOobject::MUST_READ_IF_MODIFIED ) || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk()) ) { readStream(typeName) >> *this; close(); } } // * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * * // template Foam::IOField::~IOField() {} // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * // template bool Foam::IOField::writeData(Ostream& os) const { return (os << static_cast&>(*this)).good(); } // * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * // template void Foam::IOField::operator=(const IOField& rhs) { Field::operator=(rhs); } template void Foam::IOField::operator=(const Field& rhs) { Field::operator=(rhs); } // ************************************************************************* //