1*cfb92d14SAndroid Build Coastguard Worker /*
2*cfb92d14SAndroid Build Coastguard Worker * Copyright (c) 2024, The OpenThread Authors.
3*cfb92d14SAndroid Build Coastguard Worker * All rights reserved.
4*cfb92d14SAndroid Build Coastguard Worker *
5*cfb92d14SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
6*cfb92d14SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions are met:
7*cfb92d14SAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
8*cfb92d14SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
9*cfb92d14SAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
10*cfb92d14SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
11*cfb92d14SAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
12*cfb92d14SAndroid Build Coastguard Worker * 3. Neither the name of the copyright holder nor the
13*cfb92d14SAndroid Build Coastguard Worker * names of its contributors may be used to endorse or promote products
14*cfb92d14SAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
15*cfb92d14SAndroid Build Coastguard Worker *
16*cfb92d14SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*cfb92d14SAndroid Build Coastguard Worker * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*cfb92d14SAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*cfb92d14SAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20*cfb92d14SAndroid Build Coastguard Worker * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*cfb92d14SAndroid Build Coastguard Worker * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*cfb92d14SAndroid Build Coastguard Worker * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*cfb92d14SAndroid Build Coastguard Worker * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*cfb92d14SAndroid Build Coastguard Worker * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*cfb92d14SAndroid Build Coastguard Worker * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*cfb92d14SAndroid Build Coastguard Worker * POSSIBILITY OF SUCH DAMAGE.
27*cfb92d14SAndroid Build Coastguard Worker */
28*cfb92d14SAndroid Build Coastguard Worker
29*cfb92d14SAndroid Build Coastguard Worker /**
30*cfb92d14SAndroid Build Coastguard Worker * @file
31*cfb92d14SAndroid Build Coastguard Worker * This file includes macros for validating runtime conditions.
32*cfb92d14SAndroid Build Coastguard Worker *
33*cfb92d14SAndroid Build Coastguard Worker * The macros in this file should be exclusively used by code under 'lib'. It's RECOMMENDED that only
34*cfb92d14SAndroid Build Coastguard Worker * include this file in sources under 'lib' and not include this file in headers under 'lib'. Because
35*cfb92d14SAndroid Build Coastguard Worker * headers under 'lib' may be included externally and the common macros may cause redefinition.
36*cfb92d14SAndroid Build Coastguard Worker *
37*cfb92d14SAndroid Build Coastguard Worker */
38*cfb92d14SAndroid Build Coastguard Worker
39*cfb92d14SAndroid Build Coastguard Worker #ifndef LIB_UTILS_CODE_UTILS_HPP_
40*cfb92d14SAndroid Build Coastguard Worker #define LIB_UTILS_CODE_UTILS_HPP_
41*cfb92d14SAndroid Build Coastguard Worker
42*cfb92d14SAndroid Build Coastguard Worker #include <stdbool.h>
43*cfb92d14SAndroid Build Coastguard Worker #include <stddef.h>
44*cfb92d14SAndroid Build Coastguard Worker
45*cfb92d14SAndroid Build Coastguard Worker /**
46*cfb92d14SAndroid Build Coastguard Worker * Checks for the specified status, which is expected to commonly be successful, and branches to the local
47*cfb92d14SAndroid Build Coastguard Worker * label 'exit' if the status is unsuccessful.
48*cfb92d14SAndroid Build Coastguard Worker *
49*cfb92d14SAndroid Build Coastguard Worker * @param[in] aStatus A scalar status to be evaluated against zero (0).
50*cfb92d14SAndroid Build Coastguard Worker *
51*cfb92d14SAndroid Build Coastguard Worker */
52*cfb92d14SAndroid Build Coastguard Worker #define EXPECT_NO_ERROR(aStatus) \
53*cfb92d14SAndroid Build Coastguard Worker do \
54*cfb92d14SAndroid Build Coastguard Worker { \
55*cfb92d14SAndroid Build Coastguard Worker if ((aStatus) != 0) \
56*cfb92d14SAndroid Build Coastguard Worker { \
57*cfb92d14SAndroid Build Coastguard Worker goto exit; \
58*cfb92d14SAndroid Build Coastguard Worker } \
59*cfb92d14SAndroid Build Coastguard Worker } while (false)
60*cfb92d14SAndroid Build Coastguard Worker
61*cfb92d14SAndroid Build Coastguard Worker /**
62*cfb92d14SAndroid Build Coastguard Worker * Does nothing. This is passed to EXPECT when there is no action to do.
63*cfb92d14SAndroid Build Coastguard Worker *
64*cfb92d14SAndroid Build Coastguard Worker */
65*cfb92d14SAndroid Build Coastguard Worker #define NO_ACTION
66*cfb92d14SAndroid Build Coastguard Worker
67*cfb92d14SAndroid Build Coastguard Worker /**
68*cfb92d14SAndroid Build Coastguard Worker * Checks for the specified condition, which is expected to commonly be true, and both executes @a ... and
69*cfb92d14SAndroid Build Coastguard Worker * branches to the local label 'exit' if the condition is false.
70*cfb92d14SAndroid Build Coastguard Worker *
71*cfb92d14SAndroid Build Coastguard Worker * @param[in] aCondition A Boolean expression to be evaluated.
72*cfb92d14SAndroid Build Coastguard Worker * @param[in] aAction An optional expression or block to execute when the assertion fails.
73*cfb92d14SAndroid Build Coastguard Worker *
74*cfb92d14SAndroid Build Coastguard Worker */
75*cfb92d14SAndroid Build Coastguard Worker #define EXPECT(aCondition, aAction) \
76*cfb92d14SAndroid Build Coastguard Worker do \
77*cfb92d14SAndroid Build Coastguard Worker { \
78*cfb92d14SAndroid Build Coastguard Worker if (!(aCondition)) \
79*cfb92d14SAndroid Build Coastguard Worker { \
80*cfb92d14SAndroid Build Coastguard Worker aAction; \
81*cfb92d14SAndroid Build Coastguard Worker goto exit; \
82*cfb92d14SAndroid Build Coastguard Worker } \
83*cfb92d14SAndroid Build Coastguard Worker } while (false)
84*cfb92d14SAndroid Build Coastguard Worker
85*cfb92d14SAndroid Build Coastguard Worker /**
86*cfb92d14SAndroid Build Coastguard Worker * Unconditionally executes @a ... and branches to the local label 'exit'.
87*cfb92d14SAndroid Build Coastguard Worker *
88*cfb92d14SAndroid Build Coastguard Worker * @note The use of this interface implies neither success nor failure for the overall exit status of the enclosing
89*cfb92d14SAndroid Build Coastguard Worker * function body.
90*cfb92d14SAndroid Build Coastguard Worker *
91*cfb92d14SAndroid Build Coastguard Worker * @param[in] ... An optional expression or block to execute when the assertion fails.
92*cfb92d14SAndroid Build Coastguard Worker *
93*cfb92d14SAndroid Build Coastguard Worker */
94*cfb92d14SAndroid Build Coastguard Worker #define EXIT_NOW(...) \
95*cfb92d14SAndroid Build Coastguard Worker do \
96*cfb92d14SAndroid Build Coastguard Worker { \
97*cfb92d14SAndroid Build Coastguard Worker __VA_ARGS__; \
98*cfb92d14SAndroid Build Coastguard Worker goto exit; \
99*cfb92d14SAndroid Build Coastguard Worker } while (false)
100*cfb92d14SAndroid Build Coastguard Worker
101*cfb92d14SAndroid Build Coastguard Worker /**
102*cfb92d14SAndroid Build Coastguard Worker * Executes the `statement` and ignores the return value.
103*cfb92d14SAndroid Build Coastguard Worker *
104*cfb92d14SAndroid Build Coastguard Worker * This is primarily used to indicate the intention of developer that the return value of a function/method can be
105*cfb92d14SAndroid Build Coastguard Worker * safely ignored.
106*cfb92d14SAndroid Build Coastguard Worker *
107*cfb92d14SAndroid Build Coastguard Worker * @param[in] aStatement The function/method to execute.
108*cfb92d14SAndroid Build Coastguard Worker *
109*cfb92d14SAndroid Build Coastguard Worker */
110*cfb92d14SAndroid Build Coastguard Worker #define IGNORE_RETURN(aStatement) \
111*cfb92d14SAndroid Build Coastguard Worker do \
112*cfb92d14SAndroid Build Coastguard Worker { \
113*cfb92d14SAndroid Build Coastguard Worker if (aStatement) \
114*cfb92d14SAndroid Build Coastguard Worker { \
115*cfb92d14SAndroid Build Coastguard Worker } \
116*cfb92d14SAndroid Build Coastguard Worker } while (false)
117*cfb92d14SAndroid Build Coastguard Worker
118*cfb92d14SAndroid Build Coastguard Worker /**
119*cfb92d14SAndroid Build Coastguard Worker * Overload the new operator to new an object at a specific address.
120*cfb92d14SAndroid Build Coastguard Worker *
121*cfb92d14SAndroid Build Coastguard Worker * @param[in] p The pointer of the address.
122*cfb92d14SAndroid Build Coastguard Worker *
123*cfb92d14SAndroid Build Coastguard Worker */
operator new(size_t,void * p)124*cfb92d14SAndroid Build Coastguard Worker inline void *operator new(size_t, void *p) throw() { return p; }
125*cfb92d14SAndroid Build Coastguard Worker
126*cfb92d14SAndroid Build Coastguard Worker #endif // LIB_UTILS_CODE_UTILS_HPP_
127