cleanup endian handling
[blender.git] / source / blender / blenkernel / BKE_utildefines.h
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) 2001-2002 by NaN Holding BV.
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 */
29
30 /** \file BKE_utildefines.h
31  *  \ingroup bke
32  *  \brief blender format spesific macros
33  *  \note generic defines should go in BLI_utildefines.h
34  */
35
36
37 #ifndef BKE_UTILDEFINES_H
38 #define BKE_UTILDEFINES_H
39
40 /* these values need to be hardcoded in structs, dna does not recognize defines */
41 /* also defined in DNA_space_types.h */
42 #ifndef FILE_MAXDIR
43 #define FILE_MAXDIR                     160
44 #define FILE_MAXFILE            80
45 #define FILE_MAX                        240
46 #endif
47
48 /* this weirdo pops up in two places ... */
49 #if !defined(WIN32)
50 #  ifndef O_BINARY
51 #    define O_BINARY 0
52 #  endif
53 #endif
54
55 /* INTEGER CODES */
56 #ifdef __BIG_ENDIAN__
57    /* Big Endian */
58 #  define MAKE_ID(a,b,c,d) ( (int)(a)<<24 | (int)(b)<<16 | (c)<<8 | (d) )
59 #else
60    /* Little Endian */
61 #  define MAKE_ID(a,b,c,d) ( (int)(d)<<24 | (int)(c)<<16 | (b)<<8 | (a) )
62 #endif
63
64 #define ID_NEW(a)               if( (a) && (a)->id.newid ) (a)= (void *)(a)->id.newid
65
66 #define DATA MAKE_ID('D','A','T','A')
67 #define GLOB MAKE_ID('G','L','O','B')
68
69 #define DNA1 MAKE_ID('D','N','A','1')
70 #define TEST MAKE_ID('T','E','S','T') /* used as preview between 'REND' and 'GLOB' */
71 #define REND MAKE_ID('R','E','N','D')
72 #define USER MAKE_ID('U','S','E','R')
73
74 #define ENDB MAKE_ID('E','N','D','B')
75
76 /* Bit operations */
77 #define BTST(a,b)        ( ( (a) & 1<<(b) )!=0 )
78 #define BNTST(a,b)       ( ( (a) & 1<<(b) )==0 )
79 #define BTST2(a,b,c) ( BTST( (a), (b) ) || BTST( (a), (c) ) )
80 #define BSET(a,b)        ( (a) | 1<<(b) )
81 #define BCLR(a,b)        ( (a) & ~(1<<(b)) )
82 /* bit-row */
83 #define BROW(min, max)  (((max)>=31? 0xFFFFFFFF: (1<<(max+1))-1) - ((min)? ((1<<(min))-1):0) )
84
85 #define BMEMSET(mem, val, size) {unsigned int _i; char *_c = (char*) mem; for (_i=0; _i<size; _i++) *_c++ = val;}
86
87 #endif // BKE_UTILDEFINES_H