1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
/****************************************************************************
* *
* OpenNI 1.x Alpha *
* Copyright (C) 2011 PrimeSense Ltd. *
* *
* This file is part of OpenNI. *
* *
* OpenNI is free software: you can redistribute it and/or modify *
* it under the terms of the GNU Lesser General Public License as published *
* by the Free Software Foundation, either version 3 of the License, or *
* (at your option) any later version. *
* *
* OpenNI is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public License *
* along with OpenNI. If not, see <http://www.gnu.org/licenses/>. *
* *
****************************************************************************/
#ifndef _XN_MACROS_H_
#define _XN_MACROS_H_
//---------------------------------------------------------------------------
// Includes
//---------------------------------------------------------------------------
#include "XnStatusCodes.h"
//---------------------------------------------------------------------------
// Macros
//---------------------------------------------------------------------------
/** Returns the (x)th power of 2. */
#define XN_SETBITMASK(x) (1 << x-1)
/** Returns Y if X is NULL. */
#define XN_RET_IF_NULL(x, y) \
if (x == NULL) \
{ \
return (y); \
}
/** Returns Y if X isn't XN_STATUS_OK. */
#define XN_IS_STATUS_OK_RET(x, y) \
if (x != XN_STATUS_OK) \
{ \
return (y); \
}
/** Jumps to the ErrorCleanUp label if X isn't XN_STATUS_OK and return Y. */
#define XN_IS_STATUS_OK_GOCLEANUP_RET(x, y) \
if (x != XN_STATUS_OK) \
{ \
x = y; \
goto ErrorCleanUp; \
}
/** Returns X if X isn't XN_STATUS_OK. */
#define XN_IS_STATUS_OK(x) \
XN_IS_STATUS_OK_RET(x, x)
#define XN_IS_STATUS_OK_ASSERT(x) \
if (x != XN_STATUS_OK) \
{ \
XN_ASSERT(FALSE); \
return (x); \
}
/** Jumps to the ErrorCleanUp label if X isn't XN_STATUS_OK. */
#define XN_IS_STATUS_OK_GOCLEANUP(x) \
if (x != XN_STATUS_OK) \
{ \
goto ErrorCleanUp; \
}
/** Returns Y if X isn't XN_STATUS_OK. */
#define XN_IS_BOOL_OK_RET(x, y) \
if (x != TRUE) \
{ \
return (y); \
}
/** Jumps to the ErrorCleanUp label if X isn't XN_STATUS_OK and returns Y. */
#define XN_IS_BOOL_OK_GOCLEANUP_RET(x, y) \
if (x != TRUE) \
{ \
goto ErrorCleanUp; \
}
/** Jumps to the ErrorCleanUp label if X isn't XN_STATUS_OK and returns Y. */
#define XN_GOCLEANUP_RET(x, y) \
x = y; \
goto ErrorCleanUp;
/** Returns Y if X is null. */
#define XN_VALIDATE_PTR(x,y) \
if (x == NULL) \
{ \
return (y); \
}
/** Returns an output overflow error if x is beyond y */
#define XN_CHECK_INPUT_OVERFLOW(x, y) \
if (x > y) \
{ \
return (XN_STATUS_INPUT_BUFFER_OVERFLOW); \
}
/** Returns an input overflow error if x is beyond y */
#define XN_CHECK_OUTPUT_OVERFLOW(x, y) \
if (x > y) \
{ \
return (XN_STATUS_OUTPUT_BUFFER_OVERFLOW); \
}
/** Disables Copy ctor and assignment operator. Should be placed under "private:" section. */
#define XN_DISABLE_COPY_AND_ASSIGN(TypeName) \
TypeName(const TypeName&); \
void operator=(const TypeName&);
/** Disables the "local variable is initialized but not referenced" warning (if you need
to use this variable in an assert */
#define XN_REFERENCE_VARIABLE(x) \
((void)x)
#endif //_XN_MACROS_H_
|