mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
168 lines
4.0 KiB
C
168 lines
4.0 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2016-2019 OpenCFD Ltd.
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
| Copyright (C) 2011-2016 OpenFOAM Foundation
|
|
-------------------------------------------------------------------------------
|
|
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 "surfacePatch.H"
|
|
#include "surfZone.H"
|
|
#include "dictionary.H"
|
|
#include "word.H"
|
|
|
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
|
|
|
namespace Foam
|
|
{
|
|
defineTypeNameAndDebug(surfacePatch, 0);
|
|
}
|
|
|
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
|
|
|
Foam::surfacePatch::surfacePatch()
|
|
:
|
|
geometricSurfacePatch(word::null, word::null, -1),
|
|
size_(0),
|
|
start_(0)
|
|
{}
|
|
|
|
|
|
Foam::surfacePatch::surfacePatch(const label index)
|
|
:
|
|
geometricSurfacePatch(word::null, word::null, index),
|
|
size_(0),
|
|
start_(0)
|
|
{}
|
|
|
|
|
|
Foam::surfacePatch::surfacePatch
|
|
(
|
|
const word& geometricType,
|
|
const word& name,
|
|
const label size,
|
|
const label start,
|
|
const label index
|
|
)
|
|
:
|
|
geometricSurfacePatch(geometricType, name, index),
|
|
size_(size),
|
|
start_(start)
|
|
{}
|
|
|
|
|
|
Foam::surfacePatch::surfacePatch(Istream& is, const label index)
|
|
:
|
|
geometricSurfacePatch(is, index),
|
|
size_(0),
|
|
start_(0)
|
|
{
|
|
is >> size_ >> start_;
|
|
}
|
|
|
|
|
|
Foam::surfacePatch::surfacePatch
|
|
(
|
|
const word& name,
|
|
const dictionary& dict,
|
|
const label index
|
|
)
|
|
:
|
|
geometricSurfacePatch(name, dict, index),
|
|
size_(dict.get<label>("nFaces")),
|
|
start_(dict.get<label>("startFace"))
|
|
{}
|
|
|
|
|
|
Foam::surfacePatch::surfacePatch(const surfacePatch& sp)
|
|
:
|
|
geometricSurfacePatch(sp),
|
|
size_(sp.size()),
|
|
start_(sp.start())
|
|
{}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
|
|
|
void Foam::surfacePatch::write(Ostream& os) const
|
|
{
|
|
os << nl
|
|
<< static_cast<const geometricSurfacePatch&>(*this) << endl
|
|
<< size() << tab << start();
|
|
}
|
|
|
|
void Foam::surfacePatch::writeDict(Ostream& os) const
|
|
{
|
|
os << nl << name() << nl << token::BEGIN_BLOCK << nl;
|
|
|
|
geometricSurfacePatch::writeDict(os);
|
|
|
|
os << " nFaces " << size() << ';' << nl
|
|
<< " startFace " << start() << ';' << nl
|
|
<< token::END_BLOCK << endl;
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * //
|
|
|
|
Foam::surfacePatch::operator Foam::surfZone() const
|
|
{
|
|
return surfZone
|
|
(
|
|
this->name(),
|
|
this->size(),
|
|
this->start(),
|
|
this->index(),
|
|
this->geometricType()
|
|
);
|
|
}
|
|
|
|
|
|
bool Foam::surfacePatch::operator!=(const surfacePatch& p) const
|
|
{
|
|
return !(*this == p);
|
|
}
|
|
|
|
|
|
bool Foam::surfacePatch::operator==(const surfacePatch& p) const
|
|
{
|
|
return
|
|
(
|
|
(geometricType() == p.geometricType())
|
|
&& (size() == p.size())
|
|
&& (start() == p.start())
|
|
);
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Friend Operators * * * * * * * * * * * * * //
|
|
|
|
Foam::Ostream& Foam::operator<<(Ostream& os, const surfacePatch& p)
|
|
{
|
|
p.write(os);
|
|
os.check(FUNCTION_NAME);
|
|
return os;
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|