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