Code cleanup: BKE_ prefix for public sequencer functions
[blender.git] / source / blender / blenkernel / intern / seqcache.c
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  * Peter Schlaile <peter [at] schlaile [dot] de> 2010
19  *
20  * Contributor(s): Sergey Sharybin
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24
25 /** \file blender/blenkernel/intern/seqcache.c
26  *  \ingroup bke
27  */
28
29
30 #include <stddef.h>
31
32 #include "BLO_sys_types.h"  /* for intptr_t */
33
34 #include "MEM_guardedalloc.h"
35
36 #include "DNA_sequence_types.h"
37 #include "BKE_sequencer.h"
38
39 #include "IMB_moviecache.h"
40
41 typedef struct SeqCacheKey {
42         struct Sequence *seq;
43         SeqRenderData context;
44         float cfra;
45         seq_stripelem_ibuf_t type;
46 } SeqCacheKey;
47
48 static struct MovieCache *moviecache = NULL;
49
50 static int seq_cmp_render_data(const SeqRenderData *a, const SeqRenderData *b)
51 {
52         if (a->preview_render_size < b->preview_render_size) {
53                 return -1;
54         }
55         if (a->preview_render_size > b->preview_render_size) {
56                 return 1;
57         }
58
59         if (a->rectx < b->rectx) {
60                 return -1;
61         }
62         if (a->rectx > b->rectx) {
63                 return 1;
64         }
65
66         if (a->recty < b->recty) {
67                 return -1;
68         }
69         if (a->recty > b->recty) {
70                 return 1;
71         }
72
73         if (a->bmain < b->bmain) {
74                 return -1;
75         }
76         if (a->bmain > b->bmain) {
77                 return 1;
78         }
79
80         if (a->scene < b->scene) {
81                 return -1;
82         }
83         if (a->scene > b->scene) {
84                 return 1;
85         }
86
87         if (a->motion_blur_shutter < b->motion_blur_shutter) {
88                 return -1;
89         }
90         if (a->motion_blur_shutter > b->motion_blur_shutter) {
91                 return 1;
92         }
93
94         if (a->motion_blur_samples < b->motion_blur_samples) {
95                 return -1;
96         }
97         if (a->motion_blur_samples > b->motion_blur_samples) {
98                 return 1;
99         }
100
101         return 0;
102 }
103
104 static unsigned int seq_hash_render_data(const SeqRenderData *a)
105 {
106         unsigned int rval = a->rectx + a->recty;
107
108         rval ^= a->preview_render_size;
109         rval ^= ((intptr_t) a->bmain) << 6;
110         rval ^= ((intptr_t) a->scene) << 6;
111         rval ^= (int)(a->motion_blur_shutter * 100.0f) << 10;
112         rval ^= a->motion_blur_samples << 24;
113
114         return rval;
115 }
116
117 static unsigned int seqcache_hashhash(const void *key_)
118 {
119         const SeqCacheKey *key = (SeqCacheKey *) key_;
120         unsigned int rval = seq_hash_render_data(&key->context);
121
122         rval ^= *(unsigned int *) &key->cfra;
123         rval += key->type;
124         rval ^= ((intptr_t) key->seq) << 6;
125
126         return rval;
127 }
128
129 static int seqcache_hashcmp(const void *a_, const void *b_)
130 {
131         const SeqCacheKey *a = (SeqCacheKey *) a_;
132         const SeqCacheKey *b = (SeqCacheKey *) b_;
133
134         if (a->seq < b->seq) {
135                 return -1;
136         }
137         if (a->seq > b->seq) {
138                 return 1;
139         }
140
141         if (a->cfra < b->cfra) {
142                 return -1;
143         }
144         if (a->cfra > b->cfra) {
145                 return 1;
146         }
147
148         if (a->type < b->type) {
149                 return -1;
150         }
151         if (a->type > b->type) {
152                 return 1;
153         }
154
155         return seq_cmp_render_data(&a->context, &b->context);
156 }
157
158 void BKE_sequencer_stripelem_cache_destruct(void)
159 {
160         if (moviecache)
161                 IMB_moviecache_free(moviecache);
162 }
163
164 void BKE_sequencer_stripelem_cache_cleanup(void)
165 {
166         if (moviecache) {
167                 IMB_moviecache_free(moviecache);
168                 moviecache = IMB_moviecache_create("seqcache", sizeof(SeqCacheKey), seqcache_hashhash, seqcache_hashcmp);
169         }
170 }
171
172 struct ImBuf *BKE_sequencer_cache_get(
173         SeqRenderData context, struct Sequence *seq,
174         float cfra, seq_stripelem_ibuf_t type)
175 {
176
177         if (moviecache && seq) {
178                 SeqCacheKey key;
179
180                 key.seq = seq;
181                 key.context = context;
182                 key.cfra = cfra - seq->start;
183                 key.type = type;
184
185                 return IMB_moviecache_get(moviecache, &key);
186         }
187
188         return NULL;
189 }
190
191 void BKE_sequencer_cache_put(
192         SeqRenderData context, struct Sequence *seq,
193         float cfra, seq_stripelem_ibuf_t type, struct ImBuf *i)
194 {
195         SeqCacheKey key;
196
197         if (!i) {
198                 return;
199         }
200
201         if (!moviecache) {
202                 moviecache = IMB_moviecache_create("seqcache", sizeof(SeqCacheKey), seqcache_hashhash, seqcache_hashcmp);
203         }
204
205         key.seq = seq;
206         key.context = context;
207         key.cfra = cfra - seq->start;
208         key.type = type;
209
210         IMB_moviecache_put(moviecache, &key, i);
211 }