Merge branch 'blender2.7'
[blender.git] / source / blender / blenloader / BLO_blend_defs.h
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  */
16 #ifndef __BLO_BLEND_DEFS_H__
17 #define __BLO_BLEND_DEFS_H__
18
19 /** \file \ingroup blenloader
20  *  \brief defines for blendfile codes
21  */
22
23 /* INTEGER CODES */
24 #ifdef __BIG_ENDIAN__
25 /* Big Endian */
26 #  define BLEND_MAKE_ID(a, b, c, d) ( (int)(a) << 24 | (int)(b) << 16 | (c) << 8 | (d) )
27 #else
28 /* Little Endian */
29 #  define BLEND_MAKE_ID(a, b, c, d) ( (int)(d) << 24 | (int)(c) << 16 | (b) << 8 | (a) )
30 #endif
31
32 /**
33  * Codes used for #BHead.code.
34  *
35  * These coexist with ID codes such as #ID_OB, #ID_SCE ... etc.
36  */
37 enum {
38         /**
39          * Arbitrary allocated memory
40          * (typically owned by #ID's, will be freed when there are no users).
41          */
42         DATA = BLEND_MAKE_ID('D', 'A', 'T', 'A'),
43         /**
44          * Used for #Global struct.
45          */
46         GLOB = BLEND_MAKE_ID('G', 'L', 'O', 'B'),
47         /**
48          * Used for storing the encoded SDNA string
49          * (decoded into an #SDNA on load).
50          */
51         DNA1 = BLEND_MAKE_ID('D', 'N', 'A', '1'),
52         /**
53          * Used to store thumbnail previews, written between #REND and #GLOB blocks,
54          * (ignored for regular file reading).
55          */
56         TEST = BLEND_MAKE_ID('T', 'E', 'S', 'T'),
57         /**
58          * Used for #RenderInfo, basic Scene and frame range info,
59          * can be easily read by other applications without writing a full blend file parser.
60          */
61         REND = BLEND_MAKE_ID('R', 'E', 'N', 'D'),
62         /**
63          * Used for #UserDef, (user-preferences data).
64          * (written to #BLENDER_STARTUP_FILE & #BLENDER_USERPREF_FILE).
65          */
66         USER = BLEND_MAKE_ID('U', 'S', 'E', 'R'),
67         /**
68          * Terminate reading (no data).
69          */
70         ENDB = BLEND_MAKE_ID('E', 'N', 'D', 'B'),
71 };
72
73 #define BLEN_THUMB_MEMSIZE_FILE(_x, _y) (sizeof(int) * (2 + (size_t)(_x) * (size_t)(_y)))
74
75 #endif  /* __BLO_BLEND_DEFS_H__ */