style cleanup
[blender.git] / source / blender / imbuf / intern / dds / Stream.cpp
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributors: Amorilia (amorilia@users.sourceforge.net)
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 /** \file blender/imbuf/intern/dds/Stream.cpp
24  *  \ingroup imbdds
25  */
26
27
28 #include <Stream.h>
29
30 #include <stdio.h>  // printf
31 #include <string.h> // memcpy
32
33 unsigned int Stream::seek(unsigned int p)
34 {
35         if (p > size) {
36                 printf("DDS: trying to seek beyond end of stream (corrupt file?)");
37         }
38         else {
39                 pos = p;
40         }
41
42         return pos;
43 }
44
45 unsigned int mem_read(Stream & mem, unsigned long long & i)
46 {
47         if (mem.pos + 8 > mem.size) {
48                 printf("DDS: trying to read beyond end of stream (corrupt file?)");
49                 return(0);
50         };
51         memcpy(&i, mem.mem + mem.pos, 8); // @@ todo: make sure little endian
52         mem.pos += 8;
53         return(8);
54 }
55
56 unsigned int mem_read(Stream & mem, unsigned int & i)
57 {
58         if (mem.pos + 4 > mem.size) {
59                 printf("DDS: trying to read beyond end of stream (corrupt file?)");
60                 return(0);
61         };
62         memcpy(&i, mem.mem + mem.pos, 4); // @@ todo: make sure little endian
63         mem.pos += 4;
64         return(4);
65 }
66
67 unsigned int mem_read(Stream & mem, unsigned short & i)
68 {
69         if (mem.pos + 2 > mem.size) {
70                 printf("DDS: trying to read beyond end of stream (corrupt file?)");
71                 return(0);
72         };
73         memcpy(&i, mem.mem + mem.pos, 2); // @@ todo: make sure little endian
74         mem.pos += 2;
75         return(2);
76 }
77
78 unsigned int mem_read(Stream & mem, unsigned char & i)
79 {
80         if (mem.pos + 1 > mem.size) {
81                 printf("DDS: trying to read beyond end of stream (corrupt file?)");
82                 return(0);
83         };
84         i = (mem.mem + mem.pos)[0];
85         mem.pos += 1;
86         return(1);
87 }
88
89 unsigned int mem_read(Stream & mem, unsigned char *i, unsigned int cnt)
90 {
91         if (mem.pos + cnt > mem.size) {
92                 printf("DDS: trying to read beyond end of stream (corrupt file?)");
93                 return(0);
94         };
95         memcpy(i, mem.mem + mem.pos, cnt);
96         mem.pos += cnt;
97         return(cnt);
98 }
99