mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-22 17:31:58 -05:00
LibC: Allow multiple includes of <assert.h>
ISO C requires in section 7.2: The assert macro is redefined according to the current state of NDEBUG each time that <assert.h> is included. Also add tests for `assert` multiple inclusion accordingly.
This commit is contained in:
parent
7b8398ea0d
commit
682f89d5bc
3 changed files with 36 additions and 7 deletions
|
@ -31,6 +31,7 @@ LICENSE_HEADER_CHECK_EXCLUDES = {
|
||||||
# We check that "#pragma once" is present
|
# We check that "#pragma once" is present
|
||||||
PRAGMA_ONCE_STRING = '#pragma once'
|
PRAGMA_ONCE_STRING = '#pragma once'
|
||||||
PRAGMA_ONCE_CHECK_EXCLUDES = {
|
PRAGMA_ONCE_CHECK_EXCLUDES = {
|
||||||
|
'Userland/Libraries/LibC/assert.h',
|
||||||
}
|
}
|
||||||
|
|
||||||
# We make sure that there's a blank line before and after pragma once
|
# We make sure that there's a blank line before and after pragma once
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
#include <LibTest/TestCase.h>
|
#include <LibTest/TestCase.h>
|
||||||
|
|
||||||
|
#undef NDEBUG
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
|
||||||
|
@ -20,3 +21,25 @@ TEST_CASE(assert)
|
||||||
return Test::Crash::Failure::DidNotCrash;
|
return Test::Crash::Failure::DidNotCrash;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define NDEBUG
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
TEST_CASE(assert_reinclude)
|
||||||
|
{
|
||||||
|
EXPECT_NO_CRASH("This should not assert", [] {
|
||||||
|
assert(!"This should not assert");
|
||||||
|
return Test::Crash::Failure::DidNotCrash;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
#undef NDEBUG
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
TEST_CASE(assert_rereinclude)
|
||||||
|
{
|
||||||
|
EXPECT_CRASH("This should assert", [] {
|
||||||
|
assert(!"This should assert");
|
||||||
|
return Test::Crash::Failure::DidNotCrash;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
|
@ -4,16 +4,25 @@
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#ifndef _ASSERT_H
|
||||||
|
# define _ASSERT_H
|
||||||
|
|
||||||
|
# define __stringify_helper(x) # x
|
||||||
|
# define __stringify(x) __stringify_helper(x)
|
||||||
|
|
||||||
|
# ifndef __cplusplus
|
||||||
|
# define static_assert _Static_assert
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
|
|
||||||
|
#undef assert
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
__attribute__((noreturn)) void __assertion_failed(const char* msg);
|
__attribute__((noreturn)) void __assertion_failed(const char* msg);
|
||||||
# define __stringify_helper(x) # x
|
|
||||||
# define __stringify(x) __stringify_helper(x)
|
|
||||||
# define assert(expr) \
|
# define assert(expr) \
|
||||||
(__builtin_expect(!(expr), 0) \
|
(__builtin_expect(!(expr), 0) \
|
||||||
? __assertion_failed(#expr "\n" __FILE__ ":" __stringify(__LINE__)) \
|
? __assertion_failed(#expr "\n" __FILE__ ":" __stringify(__LINE__)) \
|
||||||
|
@ -23,8 +32,4 @@ __attribute__((noreturn)) void __assertion_failed(const char* msg);
|
||||||
# define assert(expr) ((void)(0))
|
# define assert(expr) ((void)(0))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __cplusplus
|
|
||||||
# define static_assert _Static_assert
|
|
||||||
#endif
|
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
Loading…
Reference in a new issue