- clear some warnings
[blender.git] / source / blender / blenloader / intern / undofile.c
1 /**
2  * $Id$
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  * The Original Code is Copyright (C) 2004 Blender Foundation
21  * All rights reserved.
22  *
23  * The Original Code is: all of this file.
24  *
25  * Contributor(s): none yet.
26  *
27  * ***** END GPL LICENSE BLOCK *****
28  * .blend file reading entry point
29  */
30
31 #include <stdlib.h>
32 #include <string.h>
33 #include <stdio.h>
34 #include <math.h>
35
36 #include "MEM_guardedalloc.h"
37
38 #include "DNA_listBase.h"
39
40
41 #include "BLO_undofile.h"
42
43 #include "BLI_blenlib.h"
44 #include "BLI_linklist.h"
45
46
47
48 /* **************** support for memory-write, for undo buffers *************** */
49
50 /* not memfile itself */
51 void BLO_free_memfile(MemFile *memfile)
52 {
53         MemFileChunk *chunk;
54         
55         while( (chunk = (memfile->chunks.first) ) ) {
56                 if(chunk->ident==0) MEM_freeN(chunk->buf);
57                 BLI_remlink(&memfile->chunks, chunk);
58                 MEM_freeN(chunk);
59         }
60         memfile->size= 0;
61 }
62
63 /* to keep list of memfiles consistent, 'first' is always first in list */
64 /* result is that 'first' is being freed */
65 void BLO_merge_memfile(MemFile *first, MemFile *second)
66 {
67         MemFileChunk *fc, *sc;
68         
69         fc= first->chunks.first;
70         sc= second->chunks.first;
71         while (fc || sc) {
72                 if(fc && sc) {
73                         if(sc->ident) {
74                                 sc->ident= 0;
75                                 fc->ident= 1;
76                         }
77                 }
78                 if(fc) fc= fc->next;
79                 if(sc) sc= sc->next;
80         }
81         
82         BLO_free_memfile(first);
83 }
84
85 static int my_memcmp(int *mem1, int *mem2, int len)
86 {
87         register int a= len, *mema= mem1, *memb= mem2;
88         
89         while(a--) {
90                 if( *mema != *memb) return 1;
91                 mema++;
92                 memb++;
93         }
94         return 0;
95 }
96
97 void add_memfilechunk(MemFile *compare, MemFile *current, char *buf, unsigned int size)
98 {
99         static MemFileChunk *compchunk=NULL;
100         MemFileChunk *curchunk;
101         
102         /* this function inits when compare != NULL or when current==NULL */
103         if(compare) {
104                 compchunk= compare->chunks.first;
105                 return;
106         }
107         if(current==NULL) {
108                 compchunk= NULL;
109                 return;
110         }
111         
112         curchunk= MEM_mallocN(sizeof(MemFileChunk), "MemFileChunk");
113         curchunk->size= size;
114         curchunk->buf= NULL;
115         curchunk->ident= 0;
116         BLI_addtail(&current->chunks, curchunk);
117         
118         /* we compare compchunk with buf */
119         if(compchunk) {
120                 if(compchunk->size == curchunk->size) {
121                         if( my_memcmp((int *)compchunk->buf, (int *)buf, size/4)==0) {
122                                 curchunk->buf= compchunk->buf;
123                                 curchunk->ident= 1;
124                         }
125                 }
126                 compchunk= compchunk->next;
127         }
128         
129         /* not equal... */
130         if(curchunk->buf==NULL) {
131                 curchunk->buf= MEM_mallocN(size, "Chunk buffer");
132                 memcpy(curchunk->buf, buf, size);
133                 current->size += size;
134         }
135 }
136