BUG: UListIO: byteSize overflowing on really big faceLists
[OpenFOAM-2.0.x.git] / src / surfMesh / surfaceFormats / stl / STLsurfaceFormat.H
blob900f5a20dc33736d96beba4a9135549bc2eff3e3
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::fileFormats::STLsurfaceFormat
27 Description
28     Provide a means of reading/writing STL files (ASCII and binary).
30 Note
31     For efficiency, the zones are sorted before creating the faces.
32     The class is thus derived from MeshedSurface.
34 SourceFiles
35     STLsurfaceFormat.C
36     STLsurfaceFormatASCII.L
38 \*---------------------------------------------------------------------------*/
40 #ifndef STLsurfaceFormat_H
41 #define STLsurfaceFormat_H
43 #include "STLsurfaceFormatCore.H"
44 #include "MeshedSurface.H"
45 #include "MeshedSurfaceProxy.H"
46 #include "UnsortedMeshedSurface.H"
48 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
50 namespace Foam
52 namespace fileFormats
55 /*---------------------------------------------------------------------------*\
56                      Class STLsurfaceFormat Declaration
57 \*---------------------------------------------------------------------------*/
59 template<class Face>
60 class STLsurfaceFormat
62     public MeshedSurface<Face>
64     // Private Member Functions
66         //- Write Face (ASCII)
67         static inline void writeShell
68         (
69             Ostream&,
70             const pointField&,
71             const Face&
72         );
74         //- Write Face (BINARY)
75         static inline void writeShell
76         (
77             ostream&,
78             const pointField&,
79             const Face&,
80             const label zoneI
81         );
83         //- Disallow default bitwise copy construct
84         STLsurfaceFormat(const STLsurfaceFormat<Face>&);
86         //- Disallow default bitwise assignment
87         void operator=(const STLsurfaceFormat<Face>&);
90 public:
92     // Constructors
94         //- Construct from file name
95         STLsurfaceFormat(const fileName&);
98     // Selectors
100         //- Read file and return surface
101         static autoPtr<MeshedSurface<Face> > New(const fileName& name)
102         {
103             return autoPtr<MeshedSurface<Face> >
104             (
105                 new STLsurfaceFormat<Face>(name)
106             );
107         }
110     //- Destructor
111     virtual ~STLsurfaceFormat()
112     {}
115     // Member Functions
117         //- Write surface mesh components by proxy (as ASCII)
118         static void writeAscii
119         (
120             const fileName&,
121             const MeshedSurfaceProxy<Face>&
122         );
124         //- Write surface mesh components by proxy (as BINARY)
125         static void writeBinary
126         (
127             const fileName&,
128             const MeshedSurfaceProxy<Face>&
129         );
131         //- Write surface mesh components by proxy
132         //  as ASCII or BINARY, depending on the extension
133         static void write(const fileName&, const MeshedSurfaceProxy<Face>&);
135         //- Write UnsortedMeshedSurface (as ASCII) sorted by zone
136         static void writeAscii
137         (
138             const fileName&,
139             const UnsortedMeshedSurface<Face>&
140         );
142         //- Write UnsortedMeshedSurface (as BINARY) unsorted by zone
143         static void writeBinary
144         (
145             const fileName&,
146             const UnsortedMeshedSurface<Face>&
147         );
149         //- Write UnsortedMeshedSurface
150         //  as ASCII or BINARY, depending on the extension
151         static void write(const fileName&, const UnsortedMeshedSurface<Face>&);
153         //- Read from file
154         virtual bool read(const fileName&);
156         //- Write object
157         virtual void write(const fileName& name) const
158         {
159             write(name, MeshedSurfaceProxy<Face>(*this));
160         }
164 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
166 } // End namespace fileFormats
167 } // End namespace Foam
169 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
171 #ifdef NoRepository
172 #   include "STLsurfaceFormat.C"
173 #endif
175 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
177 #endif
179 // ************************************************************************* //