xref: /aosp_15_r20/external/openthread/src/lib/utils/utils.hpp (revision cfb92d1480a9e65faed56933e9c12405f45898b4)
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