2016-10-04 20:02:44 +00:00
|
|
|
|
|
|
|
/** \addtogroup platform */
|
|
|
|
/** @{*/
|
2017-10-24 15:05:45 +00:00
|
|
|
/**
|
|
|
|
* \defgroup platform_Assert Assert macros
|
|
|
|
* @{
|
|
|
|
*/
|
2014-05-29 06:57:21 +00:00
|
|
|
/* mbed Microcontroller Library
|
|
|
|
* Copyright (c) 2006-2013 ARM Limited
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2014-05-28 14:41:29 +00:00
|
|
|
#ifndef MBED_ASSERT_H
|
|
|
|
#define MBED_ASSERT_H
|
2014-05-28 13:29:12 +00:00
|
|
|
|
2016-11-02 02:30:56 +00:00
|
|
|
#include "mbed_preprocessor.h"
|
2018-10-05 13:52:52 +00:00
|
|
|
#include "mbed_toolchain.h"
|
2016-11-02 02:30:56 +00:00
|
|
|
|
2014-05-28 13:29:12 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2018-10-17 21:59:07 +00:00
|
|
|
/** Internal mbed assert function which is invoked when MBED_ASSERT macro fails.
|
2014-05-29 06:57:21 +00:00
|
|
|
* This function is active only if NDEBUG is not defined prior to including this
|
2014-05-28 13:29:12 +00:00
|
|
|
* assert header file.
|
2015-07-13 16:20:11 +00:00
|
|
|
* In case of MBED_ASSERT failing condition, error() is called with the assertation message.
|
2018-10-17 21:59:07 +00:00
|
|
|
* @param expr Expression to be checked.
|
2014-05-28 13:29:12 +00:00
|
|
|
* @param file File where assertation failed.
|
|
|
|
* @param line Failing assertation line number.
|
|
|
|
*/
|
2018-10-05 13:52:52 +00:00
|
|
|
MBED_NORETURN void mbed_assert_internal(const char *expr, const char *file, int line);
|
2014-05-28 13:29:12 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-10-24 15:05:45 +00:00
|
|
|
/** MBED_ASSERT
|
|
|
|
* Declare runtime assertions: results in runtime error if condition is false
|
|
|
|
*
|
|
|
|
* @note
|
2017-10-27 20:38:18 +00:00
|
|
|
* Use of MBED_ASSERT is limited to Debug and Develop builds.
|
2017-10-24 15:05:45 +00:00
|
|
|
*
|
|
|
|
* @code
|
|
|
|
*
|
|
|
|
* int Configure(serial_t *obj) {
|
|
|
|
* MBED_ASSERT(obj);
|
|
|
|
* }
|
|
|
|
* @endcode
|
|
|
|
*/
|
2014-05-28 13:29:12 +00:00
|
|
|
#ifdef NDEBUG
|
|
|
|
#define MBED_ASSERT(expr) ((void)0)
|
|
|
|
|
|
|
|
#else
|
|
|
|
#define MBED_ASSERT(expr) \
|
|
|
|
do { \
|
2014-05-29 06:57:21 +00:00
|
|
|
if (!(expr)) { \
|
2014-05-28 13:29:12 +00:00
|
|
|
mbed_assert_internal(#expr, __FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
#endif
|
|
|
|
|
2016-10-21 19:28:37 +00:00
|
|
|
|
|
|
|
/** MBED_STATIC_ASSERT
|
|
|
|
* Declare compile-time assertions, results in compile-time error if condition is false
|
|
|
|
*
|
|
|
|
* The assertion acts as a declaration that can be placed at file scope, in a
|
|
|
|
* code block (except after a label), or as a member of a C++ class/struct/union.
|
|
|
|
*
|
|
|
|
* @note
|
|
|
|
* Use of MBED_STATIC_ASSERT as a member of a struct/union is limited:
|
|
|
|
* - In C++, MBED_STATIC_ASSERT is valid in class/struct/union scope.
|
|
|
|
* - In C, MBED_STATIC_ASSERT is not valid in struct/union scope, and
|
|
|
|
* MBED_STRUCT_STATIC_ASSERT is provided as an alternative that is valid
|
|
|
|
* in C and C++ class/struct/union scope.
|
|
|
|
*
|
|
|
|
* @code
|
|
|
|
* MBED_STATIC_ASSERT(MBED_LIBRARY_VERSION >= 120,
|
|
|
|
* "The mbed library must be at least version 120");
|
|
|
|
*
|
|
|
|
* int main() {
|
|
|
|
* MBED_STATIC_ASSERT(sizeof(int) >= sizeof(char),
|
|
|
|
* "An int must be larger than a char");
|
|
|
|
* }
|
|
|
|
* @endcode
|
|
|
|
*/
|
|
|
|
#if defined(__cplusplus) && (__cplusplus >= 201103L || __cpp_static_assert >= 200410L)
|
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) static_assert(expr, msg)
|
|
|
|
#elif !defined(__cplusplus) && __STDC_VERSION__ >= 201112L
|
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) _Static_assert(expr, msg)
|
|
|
|
#elif defined(__cplusplus) && defined(__GNUC__) && defined(__GXX_EXPERIMENTAL_CXX0X__) \
|
|
|
|
&& (__GNUC__*100 + __GNUC_MINOR__) > 403L
|
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) __extension__ static_assert(expr, msg)
|
|
|
|
#elif !defined(__cplusplus) && defined(__GNUC__) && !defined(__CC_ARM) \
|
|
|
|
&& (__GNUC__*100 + __GNUC_MINOR__) > 406L
|
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) __extension__ _Static_assert(expr, msg)
|
|
|
|
#elif defined(__ICCARM__)
|
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) static_assert(expr, msg)
|
|
|
|
#else
|
2016-11-02 02:30:56 +00:00
|
|
|
#define MBED_STATIC_ASSERT(expr, msg) \
|
|
|
|
enum {MBED_CONCAT(MBED_ASSERTION_AT_, __LINE__) = sizeof(char[(expr) ? 1 : -1])}
|
2016-10-21 19:28:37 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/** MBED_STRUCT_STATIC_ASSERT
|
|
|
|
* Declare compile-time assertions, results in compile-time error if condition is false
|
|
|
|
*
|
|
|
|
* Unlike MBED_STATIC_ASSERT, MBED_STRUCT_STATIC_ASSERT can and must be used
|
|
|
|
* as a member of a C/C++ class/struct/union.
|
|
|
|
*
|
|
|
|
* @code
|
|
|
|
* struct thing {
|
|
|
|
* MBED_STATIC_ASSERT(2 + 2 == 4,
|
|
|
|
* "Hopefully the universe is mathematically consistent");
|
|
|
|
* };
|
|
|
|
* @endcode
|
|
|
|
*/
|
|
|
|
#define MBED_STRUCT_STATIC_ASSERT(expr, msg) int : (expr) ? 0 : -1
|
|
|
|
|
|
|
|
|
2014-05-28 13:29:12 +00:00
|
|
|
#endif
|
2016-10-04 20:02:44 +00:00
|
|
|
|
2017-10-24 15:05:45 +00:00
|
|
|
/**@}*/
|
|
|
|
|
|
|
|
/**@}*/
|
|
|
|
|