00001 /*---------------------------------------------------------------------------*\ 00002 ========= | 00003 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox 00004 \\ / O peration | 00005 \\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd. 00006 \\/ M anipulation | 00007 ------------------------------------------------------------------------------- 00008 License 00009 This file is part of OpenFOAM. 00010 00011 OpenFOAM is free software: you can redistribute it and/or modify it 00012 under the terms of the GNU General Public License as published by 00013 the Free Software Foundation, either version 3 of the License, or 00014 (at your option) any later version. 00015 00016 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT 00017 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00018 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 00019 for more details. 00020 00021 You should have received a copy of the GNU General Public License 00022 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>. 00023 00024 \*---------------------------------------------------------------------------*/ 00025 00026 #include <edgeMesh/featureEdgeMesh.H> 00027 00028 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * // 00029 00030 namespace Foam 00031 { 00032 00033 defineTypeNameAndDebug(featureEdgeMesh, 0); 00034 00035 } 00036 00037 00038 // * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * // 00039 00040 00041 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // 00042 00043 00044 // * * * * * * * * * * * * * * * Friend Operators * * * * * * * * * * * * * // 00045 00046 00047 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // 00048 00049 Foam::featureEdgeMesh::featureEdgeMesh(const IOobject& io) 00050 : 00051 regIOobject(io), 00052 edgeMesh(pointField(0), edgeList(0)) 00053 { 00054 if 00055 ( 00056 io.readOpt() == IOobject::MUST_READ 00057 || (io.readOpt() == IOobject::READ_IF_PRESENT && headerOk()) 00058 ) 00059 { 00060 readStream(typeName) >> *this; 00061 close(); 00062 } 00063 00064 if (debug) 00065 { 00066 Pout<< "featureEdgeMesh::featureEdgeMesh :" 00067 << " constructed from IOobject :" 00068 << " points:" << points().size() 00069 << " edges:" << edges().size() 00070 << endl; 00071 } 00072 } 00073 00074 00075 //- Construct from components 00076 Foam::featureEdgeMesh::featureEdgeMesh 00077 ( 00078 const IOobject& io, 00079 const pointField& points, 00080 const edgeList& edges 00081 ) 00082 : 00083 regIOobject(io), 00084 edgeMesh(points, edges) 00085 {} 00086 00087 00088 // Construct as copy 00089 Foam::featureEdgeMesh::featureEdgeMesh 00090 ( 00091 const IOobject& io, 00092 const featureEdgeMesh& em 00093 ) 00094 : 00095 regIOobject(io), 00096 edgeMesh(em) 00097 {} 00098 00099 00100 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * // 00101 00102 bool Foam::featureEdgeMesh::readData(Istream& is) 00103 { 00104 is >> *this; 00105 return !is.bad(); 00106 } 00107 00108 00109 bool Foam::featureEdgeMesh::writeData(Ostream& os) const 00110 { 00111 os << *this; 00112 00113 return os.good(); 00114 } 00115 00116 00117 // * * * * * * * * * * * * * * * Friend Operators * * * * * * * * * * * * * // 00118 00119 00120 // ************************ vim: set sw=4 sts=4 et: ************************ //