llvm-project/libcxx/test/std/depr/depr.c.headers/signal_h.compile.pass.cpp
Louis Dionne 9dfb142ce0 [libc++] Use ASSERT_SAME_TYPE instead of <type_traits> in depr tests
Whenever, possible, use ASSERT_SAME_TYPE instead of static_assert along
with std::is_same in the depr header tests. This prevents dragging in
multiple headers unrelated to the header being tested, which can (and
has) hidden issues.

Also, add a couple of tests to ensure that basic declarations in
<stddef.h> and <stdint.h> are available when including just those
headers, since the rest of the tests for those types require pulling
in additional dependencies.

Differential Revision: https://reviews.llvm.org/D145116
2023-03-02 12:37:03 -05:00

55 lines
1.0 KiB
C++

//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// test <signal.h>
#include <signal.h>
#include "test_macros.h"
#ifndef SIG_DFL
#error SIG_DFL not defined
#endif
#ifndef SIG_ERR
#error SIG_ERR not defined
#endif
#ifndef SIG_IGN
#error SIG_IGN not defined
#endif
#ifndef SIGABRT
#error SIGABRT not defined
#endif
#ifndef SIGFPE
#error SIGFPE not defined
#endif
#ifndef SIGILL
#error SIGILL not defined
#endif
#ifndef SIGINT
#error SIGINT not defined
#endif
#ifndef SIGSEGV
#error SIGSEGV not defined
#endif
#ifndef SIGTERM
#error SIGTERM not defined
#endif
sig_atomic_t sig;
typedef void (*func)(int);
ASSERT_SAME_TYPE(func, decltype(signal(0, (func)0)));
ASSERT_SAME_TYPE(int, decltype(raise(0)));