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 Class 00025 Foam::internalWriter 00026 00027 Description 00028 Write fields (internal). 00029 00030 SourceFiles 00031 internalWriter.C 00032 internalWriterTemplates.C 00033 00034 \*---------------------------------------------------------------------------*/ 00035 00036 #ifndef internalWriter_H 00037 #define internalWriter_H 00038 00039 #include <OpenFOAM/OFstream.H> 00040 #include <finiteVolume/volFields.H> 00041 #include <OpenFOAM/pointFields.H> 00042 #include "vtkMesh.H" 00043 00044 using namespace Foam; 00045 00046 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00047 00048 namespace Foam 00049 { 00050 00051 class volPointInterpolation; 00052 00053 /*---------------------------------------------------------------------------*\ 00054 Class internalWriter Declaration 00055 \*---------------------------------------------------------------------------*/ 00056 00057 class internalWriter 00058 { 00059 const vtkMesh& vMesh_; 00060 00061 const bool binary_; 00062 00063 const fileName fName_; 00064 00065 std::ofstream os_; 00066 00067 public: 00068 00069 // Constructors 00070 00071 //- Construct from components 00072 internalWriter 00073 ( 00074 const vtkMesh&, 00075 const bool binary, 00076 const fileName& 00077 ); 00078 00079 00080 // Member Functions 00081 00082 std::ofstream& os() 00083 { 00084 return os_; 00085 } 00086 00087 //- Write cellIDs 00088 void writeCellIDs(); 00089 00090 //- Write generic GeometricFields 00091 template<class Type, template<class> class PatchField, class GeoMesh> 00092 void write 00093 ( 00094 const PtrList<GeometricField<Type, PatchField, GeoMesh> >& 00095 ); 00096 00097 //- Interpolate and write volFields 00098 template<class Type> 00099 void write 00100 ( 00101 const volPointInterpolation&, 00102 const PtrList<GeometricField<Type, fvPatchField, volMesh> >& 00103 ); 00104 }; 00105 00106 00107 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00108 00109 } // End namespace Foam 00110 00111 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00112 00113 #ifdef NoRepository 00114 # include "internalWriterTemplates.C" 00115 #endif 00116 00117 00118 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00119 00120 #endif 00121 00122 // ************************ vim: set sw=4 sts=4 et: ************************ //