/src/llvm-project-16.0.6.build/include/c++/v1/cstddef
Line | Count | Source (jump to first uncovered line) |
1 | | // -*- C++ -*- |
2 | | //===----------------------------------------------------------------------===// |
3 | | // |
4 | | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
5 | | // See https://llvm.org/LICENSE.txt for license information. |
6 | | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
7 | | // |
8 | | //===----------------------------------------------------------------------===// |
9 | | |
10 | | #ifndef _LIBCPP_CSTDDEF |
11 | | #define _LIBCPP_CSTDDEF |
12 | | |
13 | | /* |
14 | | cstddef synopsis |
15 | | |
16 | | Macros: |
17 | | |
18 | | offsetof(type,member-designator) |
19 | | NULL |
20 | | |
21 | | namespace std |
22 | | { |
23 | | |
24 | | Types: |
25 | | |
26 | | ptrdiff_t |
27 | | size_t |
28 | | max_align_t // C++11 |
29 | | nullptr_t |
30 | | byte // C++17 |
31 | | |
32 | | } // std |
33 | | |
34 | | */ |
35 | | |
36 | | #include <__assert> // all public C++ headers provide the assertion handler |
37 | | #include <__config> |
38 | | #include <__type_traits/enable_if.h> |
39 | | #include <__type_traits/integral_constant.h> |
40 | | #include <__type_traits/is_integral.h> |
41 | | #include <version> |
42 | | |
43 | | #include <stddef.h> |
44 | | |
45 | | #ifndef _LIBCPP_STDDEF_H |
46 | | # error <cstddef> tried including <stddef.h> but didn't find libc++'s <stddef.h> header. \ |
47 | | This usually means that your header search paths are not configured properly. \ |
48 | | The header search paths should contain the C++ Standard Library headers before \ |
49 | | any C Standard Library, and you are probably using compiler flags that make that \ |
50 | | not be the case. |
51 | | #endif |
52 | | |
53 | | #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) |
54 | | # pragma GCC system_header |
55 | | #endif |
56 | | |
57 | | _LIBCPP_BEGIN_NAMESPACE_STD |
58 | | |
59 | | using ::nullptr_t; |
60 | | using ::ptrdiff_t _LIBCPP_USING_IF_EXISTS; |
61 | | using ::size_t _LIBCPP_USING_IF_EXISTS; |
62 | | |
63 | | #if !defined(_LIBCPP_CXX03_LANG) |
64 | | using ::max_align_t _LIBCPP_USING_IF_EXISTS; |
65 | | #endif |
66 | | |
67 | | _LIBCPP_END_NAMESPACE_STD |
68 | | |
69 | | #if _LIBCPP_STD_VER > 14 |
70 | | namespace std // purposefully not versioned |
71 | | { |
72 | | enum class byte : unsigned char {}; |
73 | | |
74 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator| (byte __lhs, byte __rhs) noexcept |
75 | 0 | { |
76 | 0 | return static_cast<byte>( |
77 | 0 | static_cast<unsigned char>( |
78 | 0 | static_cast<unsigned int>(__lhs) | static_cast<unsigned int>(__rhs) |
79 | 0 | )); |
80 | 0 | } |
81 | | |
82 | | _LIBCPP_HIDE_FROM_ABI constexpr byte& operator|=(byte& __lhs, byte __rhs) noexcept |
83 | 0 | { return __lhs = __lhs | __rhs; } |
84 | | |
85 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator& (byte __lhs, byte __rhs) noexcept |
86 | 0 | { |
87 | 0 | return static_cast<byte>( |
88 | 0 | static_cast<unsigned char>( |
89 | 0 | static_cast<unsigned int>(__lhs) & static_cast<unsigned int>(__rhs) |
90 | 0 | )); |
91 | 0 | } |
92 | | |
93 | | _LIBCPP_HIDE_FROM_ABI constexpr byte& operator&=(byte& __lhs, byte __rhs) noexcept |
94 | 0 | { return __lhs = __lhs & __rhs; } |
95 | | |
96 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator^ (byte __lhs, byte __rhs) noexcept |
97 | 0 | { |
98 | 0 | return static_cast<byte>( |
99 | 0 | static_cast<unsigned char>( |
100 | 0 | static_cast<unsigned int>(__lhs) ^ static_cast<unsigned int>(__rhs) |
101 | 0 | )); |
102 | 0 | } |
103 | | |
104 | | _LIBCPP_HIDE_FROM_ABI constexpr byte& operator^=(byte& __lhs, byte __rhs) noexcept |
105 | 0 | { return __lhs = __lhs ^ __rhs; } |
106 | | |
107 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator~ (byte __b) noexcept |
108 | 0 | { |
109 | 0 | return static_cast<byte>( |
110 | 0 | static_cast<unsigned char>( |
111 | 0 | ~static_cast<unsigned int>(__b) |
112 | 0 | )); |
113 | 0 | } |
114 | | |
115 | | template <class _Tp> |
116 | | using _EnableByteOverload = __enable_if_t<is_integral<_Tp>::value, byte>; |
117 | | |
118 | | template <class _Integer> |
119 | | _LIBCPP_HIDE_FROM_ABI constexpr _EnableByteOverload<_Integer> & |
120 | | operator<<=(byte& __lhs, _Integer __shift) noexcept |
121 | | { return __lhs = __lhs << __shift; } |
122 | | |
123 | | template <class _Integer> |
124 | | _LIBCPP_HIDE_FROM_ABI constexpr _EnableByteOverload<_Integer> |
125 | | operator<< (byte __lhs, _Integer __shift) noexcept |
126 | | { return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) << __shift)); } |
127 | | |
128 | | template <class _Integer> |
129 | | _LIBCPP_HIDE_FROM_ABI constexpr _EnableByteOverload<_Integer> & |
130 | | operator>>=(byte& __lhs, _Integer __shift) noexcept |
131 | | { return __lhs = __lhs >> __shift; } |
132 | | |
133 | | template <class _Integer> |
134 | | _LIBCPP_HIDE_FROM_ABI constexpr _EnableByteOverload<_Integer> |
135 | | operator>> (byte __lhs, _Integer __shift) noexcept |
136 | | { return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) >> __shift)); } |
137 | | |
138 | | template <class _Integer, class = _EnableByteOverload<_Integer> > |
139 | | _LIBCPP_NODISCARD_EXT _LIBCPP_HIDE_FROM_ABI constexpr _Integer |
140 | | to_integer(byte __b) noexcept { return static_cast<_Integer>(__b); } |
141 | | |
142 | | } // namespace std |
143 | | |
144 | | #endif |
145 | | |
146 | | #endif // _LIBCPP_CSTDDEF |