xref: /llvm-project/libcxx/test/std/utilities/meta/meta.unary/meta.unary.cat/is_rvalue_reference.pass.cpp (revision 87cf92d9cb9379f7d3f1a601fc17d56bb2d18d80)
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 // type_traits
10 
11 // is_rvalue_reference
12 
13 #include <type_traits>
14 #include <cstddef>        // for std::nullptr_t
15 #include "test_macros.h"
16 
17 template <class T>
test_is_rvalue_reference()18 void test_is_rvalue_reference()
19 {
20     static_assert( std::is_rvalue_reference<T>::value, "");
21     static_assert( std::is_rvalue_reference<const T>::value, "");
22     static_assert( std::is_rvalue_reference<volatile T>::value, "");
23     static_assert( std::is_rvalue_reference<const volatile T>::value, "");
24 #if TEST_STD_VER > 14
25     static_assert( std::is_rvalue_reference_v<T>, "");
26     static_assert( std::is_rvalue_reference_v<const T>, "");
27     static_assert( std::is_rvalue_reference_v<volatile T>, "");
28     static_assert( std::is_rvalue_reference_v<const volatile T>, "");
29 #endif
30 }
31 
32 template <class T>
test_is_not_rvalue_reference()33 void test_is_not_rvalue_reference()
34 {
35     static_assert(!std::is_rvalue_reference<T>::value, "");
36     static_assert(!std::is_rvalue_reference<const T>::value, "");
37     static_assert(!std::is_rvalue_reference<volatile T>::value, "");
38     static_assert(!std::is_rvalue_reference<const volatile T>::value, "");
39 #if TEST_STD_VER > 14
40     static_assert(!std::is_rvalue_reference_v<T>, "");
41     static_assert(!std::is_rvalue_reference_v<const T>, "");
42     static_assert(!std::is_rvalue_reference_v<volatile T>, "");
43     static_assert(!std::is_rvalue_reference_v<const volatile T>, "");
44 #endif
45 }
46 
47 class Empty
48 {
49 };
50 
51 class NotEmpty
52 {
53     virtual ~NotEmpty();
54 };
55 
56 union Union {};
57 
58 struct bit_zero
59 {
60     int :  0;
61 };
62 
63 class Abstract
64 {
65     virtual ~Abstract() = 0;
66 };
67 
68 enum Enum {zero, one};
69 struct incomplete_type;
70 
71 typedef void (*FunctionPtr)();
72 
main(int,char **)73 int main(int, char**)
74 {
75     test_is_rvalue_reference<int&&>();
76 
77     test_is_not_rvalue_reference<std::nullptr_t>();
78     test_is_not_rvalue_reference<void>();
79     test_is_not_rvalue_reference<int>();
80     test_is_not_rvalue_reference<int*>();
81     test_is_not_rvalue_reference<int&>();
82     test_is_not_rvalue_reference<double>();
83     test_is_not_rvalue_reference<const int*>();
84     test_is_not_rvalue_reference<char[3]>();
85     test_is_not_rvalue_reference<char[]>();
86     test_is_not_rvalue_reference<Union>();
87     test_is_not_rvalue_reference<Enum>();
88     test_is_not_rvalue_reference<FunctionPtr>();
89     test_is_not_rvalue_reference<Empty>();
90     test_is_not_rvalue_reference<bit_zero>();
91     test_is_not_rvalue_reference<NotEmpty>();
92     test_is_not_rvalue_reference<Abstract>();
93     test_is_not_rvalue_reference<incomplete_type>();
94 
95   return 0;
96 }
97