Merging trunk up to revision 41245.
[blender-staging.git] / source / blender / blenkernel / BKE_utildefines.h
1 /* 
2  *
3  * ***** BEGIN GPL LICENSE BLOCK *****
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software Foundation,
17  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18  *
19  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
20  * All rights reserved.
21  *
22  * The Original Code is: all of this file.
23  *
24  * Contributor(s): none yet.
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 /** \file BKE_utildefines.h
30  *  \ingroup bke
31  *  \brief blender format specific macros
32  *  \note generic defines should go in BLI_utildefines.h
33  */
34
35
36 #ifndef BKE_UTILDEFINES_H
37 #define BKE_UTILDEFINES_H
38
39 /* these values need to be hardcoded in structs, dna does not recognize defines */
40 /* also defined in DNA_space_types.h */
41 #ifndef FILE_MAXDIR
42 #define FILE_MAXDIR                     160
43 #define FILE_MAXFILE            80
44 #define FILE_MAX                        240
45 #endif
46
47 /* this weirdo pops up in two places ... */
48 #if !defined(WIN32)
49 #  ifndef O_BINARY
50 #    define O_BINARY 0
51 #  endif
52 #endif
53
54 /* INTEGER CODES */
55 #ifdef __BIG_ENDIAN__
56    /* Big Endian */
57 #  define MAKE_ID(a,b,c,d) ( (int)(a)<<24 | (int)(b)<<16 | (c)<<8 | (d) )
58 #else
59    /* Little Endian */
60 #  define MAKE_ID(a,b,c,d) ( (int)(d)<<24 | (int)(c)<<16 | (b)<<8 | (a) )
61 #endif
62
63 #define ID_NEW(a)               if( (a) && (a)->id.newid ) (a)= (void *)(a)->id.newid
64
65 #define DATA MAKE_ID('D','A','T','A')
66 #define GLOB MAKE_ID('G','L','O','B')
67
68 #define DNA1 MAKE_ID('D','N','A','1')
69 #define TEST MAKE_ID('T','E','S','T') /* used as preview between 'REND' and 'GLOB' */
70 #define REND MAKE_ID('R','E','N','D')
71 #define USER MAKE_ID('U','S','E','R')
72
73 #define ENDB MAKE_ID('E','N','D','B')
74
75 /* Bit operations */
76 #define BTST(a,b)        ( ( (a) & 1<<(b) )!=0 )
77 #define BNTST(a,b)       ( ( (a) & 1<<(b) )==0 )
78 #define BTST2(a,b,c) ( BTST( (a), (b) ) || BTST( (a), (c) ) )
79 #define BSET(a,b)        ( (a) | 1<<(b) )
80 #define BCLR(a,b)        ( (a) & ~(1<<(b)) )
81 /* bit-row */
82 #define BROW(min, max)  (((max)>=31? 0xFFFFFFFF: (1<<(max+1))-1) - ((min)? ((1<<(min))-1):0) )
83
84 #define BMEMSET(mem, val, size) {unsigned int _i; char *_c = (char*) mem; for (_i=0; _i<size; _i++) *_c++ = val;}
85
86 #endif // BKE_UTILDEFINES_H