OpenMesh
Loading...
Searching...
No Matches
BinaryHelper.hh
1/* ========================================================================= *
2 * *
3 * OpenMesh *
4 * Copyright (c) 2001-2015, RWTH-Aachen University *
5 * Department of Computer Graphics and Multimedia *
6 * All rights reserved. *
7 * www.openmesh.org *
8 * *
9 *---------------------------------------------------------------------------*
10 * This file is part of OpenMesh. *
11 *---------------------------------------------------------------------------*
12 * *
13 * Redistribution and use in source and binary forms, with or without *
14 * modification, are permitted provided that the following conditions *
15 * are met: *
16 * *
17 * 1. Redistributions of source code must retain the above copyright notice, *
18 * this list of conditions and the following disclaimer. *
19 * *
20 * 2. Redistributions in binary form must reproduce the above copyright *
21 * notice, this list of conditions and the following disclaimer in the *
22 * documentation and/or other materials provided with the distribution. *
23 * *
24 * 3. Neither the name of the copyright holder nor the names of its *
25 * contributors may be used to endorse or promote products derived from *
26 * this software without specific prior written permission. *
27 * *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39 * *
40 * ========================================================================= */
41
42/*===========================================================================*\
43 * *
44 * $Revision$ *
45 * $Date$ *
46 * *
47\*===========================================================================*/
48
49
50//=============================================================================
51//
52// Helper Functions for binary reading / writing
53//
54//=============================================================================
55
56#ifndef OPENMESH_BINARY_HELPER_HH
57#define OPENMESH_BINARY_HELPER_HH
58
59
60//== INCLUDES =================================================================
61
62#include <OpenMesh/Core/System/config.h>
63// -------------------- STL
64#if defined( OM_CC_MIPS )
65# include <stdio.h>
66#else
67# include <cstdio>
68#endif
69#include <iosfwd>
70// -------------------- OpenMesh
71
72
73//== NAMESPACES ===============================================================
74
75namespace OpenMesh {
76namespace IO {
77
78
79//=============================================================================
80
81
86
87//-----------------------------------------------------------------------------
88
89
92short int read_short(FILE* _in, bool _swap=false);
93
96int read_int(FILE* _in, bool _swap=false);
97
100float read_float(FILE* _in, bool _swap=false);
101
104double read_double(FILE* _in, bool _swap=false);
105
108short int read_short(std::istream& _in, bool _swap=false);
109
112int read_int(std::istream& _in, bool _swap=false);
113
116float read_float(std::istream& _in, bool _swap=false);
117
120double read_double(std::istream& _in, bool _swap=false);
121
122
125void write_short(short int _i, FILE* _out, bool _swap=false);
126
129void write_int(int _i, FILE* _out, bool _swap=false);
130
133void write_float(float _f, FILE* _out, bool _swap=false);
134
137void write_double(double _d, FILE* _out, bool _swap=false);
138
141void write_short(short int _i, std::ostream& _out, bool _swap=false);
142
145void write_int(int _i, std::ostream& _out, bool _swap=false);
146
149void write_float(float _f, std::ostream& _out, bool _swap=false);
150
153void write_double(double _d, std::ostream& _out, bool _swap=false);
154
156
157
158//=============================================================================
159} // namespace IO
160} // namespace OpenMesh
161//=============================================================================
162#endif // OPENMESH_MESHREADER_HH defined
163//=============================================================================
164
Contains all the mesh ingredients like the polygonal mesh, the triangle mesh, different mesh kernels ...
Definition MeshItems.hh:64
This namespace contains functions for reading and writing polygonal meshes and a list of supported fi...
short int read_short(FILE *_in, bool _swap=false)
Binary read a short from _is and perform byte swapping if _swap is true.
float read_float(FILE *_in, bool _swap=false)
Binary read a float from _is and perform byte swapping if _swap is true.
void write_int(int _i, FILE *_out, bool _swap=false)
Binary write an int to _os and perform byte swapping if _swap is true.
void write_double(double _d, FILE *_out, bool _swap=false)
Binary write a double to _os and perform byte swapping if _swap is true.
void write_short(short int _i, FILE *_out, bool _swap=false)
Binary write a short to _os and perform byte swapping if _swap is true.
int read_int(FILE *_in, bool _swap=false)
Binary read an int from _is and perform byte swapping if _swap is true.
double read_double(FILE *_in, bool _swap=false)
Binary read a double from _is and perform byte swapping if _swap is true.
void write_float(float _f, FILE *_out, bool _swap=false)
Binary write a float to _os and perform byte swapping if _swap is true.

Project OpenMesh, ©  Computer Graphics Group, RWTH Aachen. Documentation generated using doxygen .