int32.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2014-2016 OpenFOAM Foundation
9  Copyright (C) 2016-2019 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 Primitive
28  int32_t
29 
30 Description
31  32bit signed integer
32 
33 SourceFiles
34  int32.C
35  int32IO.C
36 
37 \*---------------------------------------------------------------------------*/
38 
39 #ifndef int32_H
40 #define int32_H
41 
42 #include <cstdint>
43 #include <climits>
44 #include <cstdlib>
45 
46 #include "word.H"
47 #include "pTraits.H"
48 #include "direction.H"
49 
50 
51 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
52 
53 namespace Foam
54 {
55 
56 class Istream;
57 class Ostream;
58 
59 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
60 
61 //- A word representation of int32 value
62 inline word name(const int32_t val)
63 {
64  return word(std::to_string(val), false); // Needs no stripping
65 }
66 
67 
68 //- A word representation of int32 value
69 template<>
70 struct nameOp<int32_t>
71 {
72  inline word operator()(const int32_t val) const
73  {
74  return word(std::to_string(val), false); // Needs no stripping
75  }
76 };
77 
78 
79 // * * * * * * * * * * * * * * * IOstream Operators * * * * * * * * * * * * //
80 
81 //- Read int32_t from stream
82 int32_t readInt32(Istream& is);
83 
84 //- Parse entire buffer as a int32_t, skipping leading/trailing whitespace.
85 // \return Parsed value or FatalIOError on any problem
86 int32_t readInt32(const char* buf);
87 
88 //- Parse entire string as a int32_t, skipping leading/trailing whitespace.
89 // \return Parsed value or FatalIOError on any problem
90 inline int32_t readInt32(const std::string& str)
91 {
92  return readInt32(str.c_str());
93 }
94 
95 //- Read entire buffer as a int32_t, skipping leading/trailing whitespace.
96 // \return True if successful.
97 bool readInt32(const char* buf, int32_t& val);
98 
99 //- Read entire string as a int32_t, skipping leading/trailing whitespace.
100 // \return True if successful.
101 inline bool readInt32(const std::string& str, int32_t& val)
102 {
103  return readInt32(str.c_str(), val);
104 }
105 
106 //- Same as readInt32
107 // \return True if successful.
108 inline bool read(const char* buf, int32_t& val)
109 {
110  return readInt32(buf, val);
111 }
112 
113 //- Same as readInt32
114 // \return True if successful.
115 inline bool read(const std::string& str, int32_t& val)
116 {
117  return readInt32(str, val);
118 }
119 
120 
121 Istream& operator>>(Istream& is, int32_t& val);
122 Ostream& operator<<(Ostream& os, const int32_t val);
123 
124 // 32bit compilation with long as int32_t
125 // - resolve explicitly for input and output
126 //
127 // Test works for gcc, icc, llvm.
128 #if (__SIZEOF_LONG__ == 4)
129  Istream& operator>>(Istream& is, long& val);
130  Ostream& operator<<(Ostream& os, const long val);
131 #endif
132 
133 
134 //- Template specialization for pTraits<int32_t>
135 template<>
136 class pTraits<int32_t>
137 {
138  int32_t p_;
139 
140 public:
141 
142  //- Component type
143  typedef int32_t cmptType;
144 
145  //- Magnitude type
146  typedef int32_t magType;
147 
148 
149  // Member constants
150 
151  //- Dimensionality of space
152  static constexpr direction dim = 3;
153 
154  //- Rank of int32_t is 0
155  static constexpr direction rank = 0;
156 
157  //- Number of components in int32_t is 1
158  static constexpr direction nComponents = 1;
159 
160 
161  // Static data members
162 
163  static const char* const typeName;
164  static const char* const componentNames[];
165  static const int32_t zero;
166  static const int32_t one;
167  static const int32_t min;
168  static const int32_t max;
169  static const int32_t rootMax;
170  static const int32_t rootMin;
171 
172 
173  // Constructors
174 
175  //- Copy construct from primitive
176  explicit pTraits(const int32_t& val);
177 
178  //- Read construct from Istream
179  pTraits(Istream& is);
180 
181 
182  // Member Functions
183 
184  //- Access to the value
185  operator int32_t() const
186  {
187  return p_;
188  }
189 
190  //- Access to the value
191  operator int32_t&()
192  {
193  return p_;
194  }
195 };
196 
197 
198 inline int32_t mag(const int32_t val)
199 {
200  return ::abs(val);
201 }
202 
203 
204 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
205 
206 } // End namespace Foam
207 
208 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
209 
210 #endif
211 
212 // ************************************************************************* //
Foam::pTraits< int32_t >::zero
static const int32_t zero
Definition: int32.H:165
Foam::val
label ListType::const_reference val
Definition: ListOps.H:407
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:62
Foam::read
bool read(const char *buf, int32_t &val)
Same as readInt32.
Definition: int32.H:108
Foam::operator>>
Istream & operator>>(Istream &, directionInfo &)
Definition: directionInfo.C:228
Foam::pTraits< int32_t >::min
static const int32_t min
Definition: int32.H:167
Foam::pTraits< int32_t >::max
static const int32_t max
Definition: int32.H:168
Foam::nameOp< int32_t >::operator()
word operator()(const int32_t val) const
Definition: int32.H:72
Foam::Istream
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition: Istream.H:61
Foam::pTraits::pTraits
pTraits(const PrimitiveType &p)
Construct from primitive.
Definition: pTraits.H:62
Foam::name
word name(const complex &c)
Return string representation of complex.
Definition: complex.C:76
Foam::nameOp
Extract name (as a word) from an object, typically using its name() method.
Definition: word.H:238
Foam::pTraits< int32_t >::cmptType
int32_t cmptType
Component type.
Definition: int32.H:143
Foam::pTraits< int32_t >::one
static const int32_t one
Definition: int32.H:166
Foam::readInt32
int32_t readInt32(Istream &is)
Read int32_t from stream.
Definition: int32IO.C:112
pTraits.H
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
direction.H
Direction is an 8-bit unsigned integer type used to represent the Cartesian directions etc.
Foam::pTraits< int32_t >::magType
int32_t magType
Magnitude type.
Definition: int32.H:146
Foam::pTraits< int32_t >::typeName
static const char *const typeName
Definition: int32.H:163
Foam::pTraits
Traits class for primitives.
Definition: pTraits.H:52
Foam::mag
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)
Foam::direction
uint8_t direction
Definition: direction.H:47
Foam::pTraits< int32_t >::rootMin
static const int32_t rootMin
Definition: int32.H:170
word.H
Foam::pTraits< int32_t >::rootMax
static const int32_t rootMax
Definition: int32.H:169
Foam::operator<<
Ostream & operator<<(Ostream &, const boundaryPatch &)
Definition: boundaryPatch.C:102