file.hpp
Go to the documentation of this file.
1 
5 /* Copyright (c) 2005-2010 Taneli Kalvas. All rights reserved.
6  *
7  * You can redistribute this software and/or modify it under the terms
8  * of the GNU General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option)
10  * any later version.
11  *
12  * This library is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this library (file "COPYING" included in the package);
19  * if not, write to the Free Software Foundation, Inc., 51 Franklin
20  * Street, Fifth Floor, Boston, MA 02110-1301 USA
21  *
22  * If you have questions about your rights to use or distribute this
23  * software, please contact Berkeley Lab's Technology Transfer
24  * Department at TTD@lbl.gov. Other questions, comments and bug
25  * reports should be sent directly to the author via email at
26  * taneli.kalvas@jyu.fi.
27  *
28  * NOTICE. This software was developed under partial funding from the
29  * U.S. Department of Energy. As such, the U.S. Government has been
30  * granted for itself and others acting on its behalf a paid-up,
31  * nonexclusive, irrevocable, worldwide license in the Software to
32  * reproduce, prepare derivative works, and perform publicly and
33  * display publicly. Beginning five (5) years after the date
34  * permission to assert copyright is obtained from the U.S. Department
35  * of Energy, and subject to any subsequent five (5) year renewals,
36  * the U.S. Government is granted for itself and others acting on its
37  * behalf a paid-up, nonexclusive, irrevocable, worldwide license in
38  * the Software to reproduce, prepare derivative works, distribute
39  * copies to the public, perform publicly and display publicly, and to
40  * permit others to do so.
41  */
42 
43 #ifndef FILE_HPP
44 #define FILE_HPP 1
45 
46 
47 #include <iostream>
48 #include <stdint.h>
49 
50 #define FILEID_GEOMETRY 1001
51 
52 #define FILEID_FUNCSOLID 2001
53 #define FILEID_CSGSOLID 2002
54 #define FILEID_DXFSOLID 2003
55 #define FILEID_STLSOLID 2004
56 
57 #define FILEID_PARTICLEDB2D 3001
58 #define FILEID_PARTICLEDBCYL 3002
59 #define FILEID_PARTICLEDB3D 3003
60 
61 #define FILEID_SCALARFIELD 4001
62 
63 #define FILEID_VECTORFIELD 5001
64 
65 
66 /* **************** *
67  * Write *
68  * **************** */
69 
70 
73 void write_int8( std::ostream &os, int8_t value );
74 
75 
78 void write_int16( std::ostream &os, int16_t value );
79 
80 
83 void write_int32( std::ostream &os, int32_t value );
84 
85 
88 void write_uint32( std::ostream &os, uint32_t value );
89 
90 
93 void write_double( std::ostream &os, double value );
94 
95 
99 void write_compressed_block( std::ostream &os, uint32_t len, const int8_t *data );
100 
101 
102 /* **************** *
103  * Read *
104  * **************** */
105 
106 
109 int8_t read_int8( std::istream &is );
110 
111 
114 int16_t read_int16( std::istream &is );
115 
116 
119 int32_t read_int32( std::istream &is );
120 
121 
124 uint32_t read_uint32( std::istream &is );
125 
126 
129 double read_double( std::istream &is );
130 
131 
134 uint32_t read_compressed_block( std::istream &is, uint32_t len, int8_t *dest );
135 
136 
137 #endif
138 
void write_compressed_block(std::ostream &os, uint32_t len, const int8_t *data)
Write data block data of length len bytes into stream os in compressed form.
void write_int32(std::ostream &os, int32_t value)
Write int32_t value into stream os.
int8_t read_int8(std::istream &is)
Read int8_t from stream is.
void write_int8(std::ostream &os, int8_t value)
Write int8_t value into stream os.
int16_t read_int16(std::istream &is)
Read int16_t from stream is.
uint32_t read_compressed_block(std::istream &is, uint32_t len, int8_t *dest)
Read compressed data block of length len bytes from stream is.
void write_double(std::ostream &os, double value)
Write double value into stream os.
void write_uint32(std::ostream &os, uint32_t value)
Write uint32_t value into stream os.
void write_int16(std::ostream &os, int16_t value)
Write int16_t value into stream os.
uint32_t read_uint32(std::istream &is)
Read uint32_t from stream is.
int32_t read_int32(std::istream &is)
Read int32_t from stream is.
double read_double(std::istream &is)
Readd double from stream is.