mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-25 09:00:22 +00:00
1d8e62926f
Lines like these were getting a warning to simplify the expanded boolean expression from `!(a || b)` to `(a && b)`, but since the `!(...)` is part of the macro, that is never going to happen.
34 lines
2 KiB
C
34 lines
2 KiB
C
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <andreas@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
extern "C" __attribute__((noreturn)) void ak_verification_failed(char const*);
|
|
#define __stringify_helper(x) #x
|
|
#define __stringify(x) __stringify_helper(x)
|
|
#define VERIFY(expr) \
|
|
(__builtin_expect(/* NOLINT(readability-simplify-boolean-expr) */ !(expr), 0) \
|
|
? ak_verification_failed(#expr " at " __FILE__ ":" __stringify(__LINE__)) \
|
|
: (void)0)
|
|
#define VERIFY_NOT_REACHED() VERIFY(false) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
static constexpr bool TODO = false;
|
|
#define TODO() VERIFY(TODO) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
#define TODO_AARCH64() VERIFY(TODO) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
#define TODO_RISCV64() VERIFY(TODO) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
#define TODO_PPC64() VERIFY(TODO) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
#define TODO_PPC() VERIFY(TODO) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
|
|
extern "C" __attribute__((noreturn)) void ak_assertion_failed(char const*);
|
|
#ifndef NDEBUG
|
|
# define ASSERT(expr) \
|
|
(__builtin_expect(!(expr), 0) \
|
|
? ak_assertion_failed(#expr " at " __FILE__ ":" __stringify(__LINE__)) \
|
|
: (void)0)
|
|
# define ASSERT_NOT_REACHED ASSERT(false) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
|
|
#else
|
|
# define ASSERT(expr)
|
|
# define ASSERT_NOT_REACHED() __builtin_unreachable()
|
|
#endif
|