readSTL.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | foam-extend: Open Source CFD
4  \\ / O peration | Version: 3.2
5  \\ / A nd | Web: http://www.foam-extend.org
6  \\/ M anipulation | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9  This file is part of foam-extend.
10 
11  foam-extend is free software: you can redistribute it and/or modify it
12  under the terms of the GNU General Public License as published by the
13  Free Software Foundation, either version 3 of the License, or (at your
14  option) any later version.
15 
16  foam-extend is distributed in the hope that it will be useful, but
17  WITHOUT ANY WARRANTY; without even the implied warranty of
18  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19  General Public License for more details.
20 
21  You should have received a copy of the GNU General Public License
22  along with foam-extend. If not, see <http://www.gnu.org/licenses/>.
23 
24 \*---------------------------------------------------------------------------*/
25 
26 #include "triSurface.H"
27 #include "IFstream.H"
28 
29 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
30 
31 namespace Foam
32 {
33 
34 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
35 
36 bool triSurface::readSTL(const fileName& STLfileName)
37 {
38  token firstToken;
39  {
40  IFstream str(STLfileName);
41 
42  if (!str.good())
43  {
44  return false;
45  }
46  firstToken = token(str);
47  }
48 
49  if (firstToken.isWord())
50  {
51  word firstWord(firstToken.wordToken());
52 
53  for (size_t i = 0; i < firstWord.size(); i++)
54  {
55  firstWord[i] = std::toupper(firstWord[i]);
56  }
57 
58  if (firstWord == "SOLID")
59  {
60  return readSTLASCII(STLfileName);
61  }
62  }
63 
64  return readSTLBINARY(STLfileName);
65 }
66 
67 
68 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
69 
70 } // End namespace Foam
71 
72 // ************************************************************************* //
Foam::word
A class for handling words, derived from string.
Definition: word.H:59
Foam::fileName
A class for handling file names.
Definition: fileName.H:69
Foam::triSurface::readSTLBINARY
bool readSTLBINARY(const fileName &)
Definition: readSTLBINARY.C:41
Foam::IFstream
Input from file stream.
Definition: IFstream.H:81
Foam::token::wordToken
const word & wordToken() const
Definition: tokenI.H:226
Foam::token
A token holds items read from Istream.
Definition: token.H:67
Foam::triSurface::readSTLASCII
bool readSTLASCII(const fileName &)
IFstream.H
Foam::token::isWord
bool isWord() const
Definition: tokenI.H:221
Foam
Namespace for OpenFOAM.
Definition: combustionModel.C:30
Foam::triSurface::readSTL
bool readSTL(const fileName &)
Definition: readSTL.C:36
Foam::IOstream::good
bool good() const
Return true if next operation might succeed.
Definition: IOstream.H:333