]> git.donarmstrong.com Git - kiibohd-controller.git/blob - Bootloader/mchck-cdefs.h
Code cleanup
[kiibohd-controller.git] / Bootloader / mchck-cdefs.h
1 /* Copyright (c) 2011,2012 Simon Schubert <2@0x2c.org>.
2  * Modifications by Jacob Alexander 2014-2015 <haata@kiibohd.com>
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (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, see <http://www.gnu.org/licenses/>.
16  */
17
18 #pragma once
19
20 // ----- Compiler Includes -----
21
22 #include <sys/param.h>
23
24
25
26 // ----- Defines & Macros -----
27
28
29 #define _CONCAT(x,y) _CONCAT1(x,y)
30 #define _CONCAT1(x,y) x ## y
31 #define _STR(a) #a
32
33 typedef __CHAR16_TYPE__ char16_t;
34
35 #define __packed __attribute__((__packed__))
36
37 /* From FreeBSD: compile-time asserts */
38 #define CTASSERT(x)             _Static_assert(x, _STR(x))
39
40 #define CTASSERT_SIZE_BYTE(t, s)     CTASSERT(sizeof(t) == (s))
41 #define CTASSERT_SIZE_BIT(t, s)     CTASSERT(sizeof(t) * 8 == (s))
42
43 #define UNION_STRUCT_START(size)                                \
44         union {                                                 \
45         _CONCAT(_CONCAT(uint, size), _t) raw;                 \
46         struct {                                                \
47         /* just to swallow the following semicolon */           \
48         struct _CONCAT(_CONCAT(__dummy_, __COUNTER__), _t) {}
49
50 #define UNION_STRUCT_END                        \
51         }; /* struct */                         \
52         }; /* union */
53
54
55 /**
56  * From <news:dqgm2f$ije$1@sunnews.cern.ch>,
57  * <https://groups.google.com/forum/#!topic/comp.std.c/d-6Mj5Lko_s>
58  */
59 #define __PP_NARG(...)                          \
60         __PP_NARG_(__0, ## __VA_ARGS__, __PP_RSEQ_N())
61 #define __PP_NARG_(...)                         \
62         __PP_ARG_N(__VA_ARGS__)
63 #define __PP_ARG_N(                                     \
64         _1, _2, _3, _4, _5, _6, _7, _8, _9,_10,         \
65         _11,_12,_13,_14,_15,_16,_17,_18,_19,_20,        \
66         _21,_22,_23,_24,_25,_26,_27,_28,_29,_30,        \
67         _31,_32,_33,_34,_35,_36,_37,_38,_39,_40,        \
68         _41,_42,_43,_44,_45,_46,_47,_48,_49,_50,        \
69         _51,_52,_53,_54,_55,_56,_57,_58,_59,_60,        \
70         _61,_62,_63,N,...) N
71 #define __PP_RSEQ_N()                           \
72         62,61,60,                               \
73                 59,58,57,56,55,54,53,52,51,50,  \
74                 49,48,47,46,45,44,43,42,41,40,  \
75                 39,38,37,36,35,34,33,32,31,30,  \
76                 29,28,27,26,25,24,23,22,21,20,  \
77                 19,18,17,16,15,14,13,12,11,10,  \
78                 9,8,7,6,5,4,3,2,1,0
79
80 /**
81  * From <https://github.com/pfultz2/Cloak/wiki/C-Preprocessor-tricks,-tips,-and-idioms>
82  */
83 #define __CAT(a, ...) __PRIMITIVE_CAT(a, __VA_ARGS__)
84 #define __PRIMITIVE_CAT(a, ...) a ## __VA_ARGS__
85
86 #define __IIF(c) __PRIMITIVE_CAT(__IIF_, c)
87 #define __IIF_0(t, ...) __VA_ARGS__
88 #define __IIF_1(t, ...) t
89
90 #define __COMPL(b) __PRIMITIVE_CAT(__COMPL_, b)
91 #define __COMPL_0 1
92 #define __COMPL_1 0
93
94 #define __CHECK_N(x, n, ...) n
95 #define __CHECK(...) __CHECK_N(__VA_ARGS__, 0,)
96 #define __PROBE(x) x, 1,
97
98 #define __NOT(x) __CHECK(__PRIMITIVE_CAT(__NOT_, x))
99 #define __NOT_0 __PROBE(~)
100
101 #define __BOOL(x) __COMPL(__NOT(x))
102 #define __IF(c) __IIF(__BOOL(c))
103
104 #define __EAT(...)
105 #define __EXPAND(...) __VA_ARGS__
106 #define __WHEN(c) __IF(c)(__EXPAND, __EAT)
107
108 #define __HEAD(h, ...) h
109 #define __TAIL(h, ...) __VA_ARGS__
110
111 #define __EVAL(...)  __EVAL1(__EVAL1(__EVAL1(__VA_ARGS__)))
112 #define __EVAL1(...) __EVAL2(__EVAL2(__EVAL2(__VA_ARGS__)))
113 #define __EVAL2(...) __EVAL3(__EVAL3(__EVAL3(__VA_ARGS__)))
114 #define __EVAL3(...) __EVAL4(__EVAL4(__EVAL4(__VA_ARGS__)))
115 #define __EVAL4(...) __EVAL5(__EVAL5(__EVAL5(__VA_ARGS__)))
116 #define __EVAL5(...) __EVAL6(__EVAL6(__EVAL6(__VA_ARGS__)))
117 #define __EVAL6(...) __VA_ARGS__
118
119 #define __EMPTY()
120 #define __DEFER(id) id __EMPTY()
121 #define __OBSTRUCT(...) __VA_ARGS__ __DEFER(__EMPTY)()
122 #define __CAT_ARG(f, a) __OBSTRUCT(f) a
123
124 #define __REPEAT(...) __EVAL(__REPEAT_(__VA_ARGS__))
125 #define __REPEAT_INNER(...) __OBSTRUCT(__REPEAT_INDIRECT) () (__VA_ARGS__)
126 #define __REPEAT_INDIRECT() __REPEAT_
127 #define __REPEAT_(iter, itermacro, macro, a, ...)                       \
128         __OBSTRUCT(macro)(iter, a)                                      \
129         __WHEN(__PP_NARG(__VA_ARGS__))                                  \
130                 (                                                       \
131                         __OBSTRUCT(__REPEAT_INDIRECT) () (              \
132                                 itermacro(iter, a), itermacro, macro, __VA_ARGS__ \
133                                 )                                       \
134                         )
135