Cleanup: limit scope of temporary variables
[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 #pragma once
17
18 /** \file
19  * \ingroup blenloader
20  * \brief defines for blend-file 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)))