/src/llvm-project-18.1.8.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 >= 17 |
70 | | namespace std // purposefully not versioned |
71 | | { |
72 | | enum class byte : unsigned char {}; |
73 | | |
74 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte operator|(byte __lhs, byte __rhs) noexcept { |
75 | 0 | return static_cast<byte>( |
76 | 0 | static_cast<unsigned char>(static_cast<unsigned int>(__lhs) | static_cast<unsigned int>(__rhs))); |
77 | 0 | } |
78 | | |
79 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte& operator|=(byte& __lhs, byte __rhs) noexcept { |
80 | 0 | return __lhs = __lhs | __rhs; |
81 | 0 | } |
82 | | |
83 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte operator&(byte __lhs, byte __rhs) noexcept { |
84 | 0 | return static_cast<byte>( |
85 | 0 | static_cast<unsigned char>(static_cast<unsigned int>(__lhs) & static_cast<unsigned int>(__rhs))); |
86 | 0 | } |
87 | | |
88 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte& operator&=(byte& __lhs, byte __rhs) noexcept { |
89 | 0 | return __lhs = __lhs & __rhs; |
90 | 0 | } |
91 | | |
92 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte operator^(byte __lhs, byte __rhs) noexcept { |
93 | 0 | return static_cast<byte>( |
94 | 0 | static_cast<unsigned char>(static_cast<unsigned int>(__lhs) ^ static_cast<unsigned int>(__rhs))); |
95 | 0 | } |
96 | | |
97 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte& operator^=(byte& __lhs, byte __rhs) noexcept { |
98 | 0 | return __lhs = __lhs ^ __rhs; |
99 | 0 | } |
100 | | |
101 | 0 | _LIBCPP_HIDE_FROM_ABI inline constexpr byte operator~(byte __b) noexcept { |
102 | 0 | return static_cast<byte>(static_cast<unsigned char>(~static_cast<unsigned int>(__b))); |
103 | 0 | } |
104 | | |
105 | | template <class _Integer, __enable_if_t<is_integral<_Integer>::value, int> = 0> |
106 | | _LIBCPP_HIDE_FROM_ABI constexpr byte& operator<<=(byte& __lhs, _Integer __shift) noexcept { |
107 | | return __lhs = __lhs << __shift; |
108 | | } |
109 | | |
110 | | template <class _Integer, __enable_if_t<is_integral<_Integer>::value, int> = 0> |
111 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator<<(byte __lhs, _Integer __shift) noexcept { |
112 | | return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) << __shift)); |
113 | | } |
114 | | |
115 | | template <class _Integer, __enable_if_t<is_integral<_Integer>::value, int> = 0> |
116 | | _LIBCPP_HIDE_FROM_ABI constexpr byte& operator>>=(byte& __lhs, _Integer __shift) noexcept { |
117 | | return __lhs = __lhs >> __shift; |
118 | | } |
119 | | |
120 | | template <class _Integer, __enable_if_t<is_integral<_Integer>::value, int> = 0> |
121 | | _LIBCPP_HIDE_FROM_ABI constexpr byte operator>>(byte __lhs, _Integer __shift) noexcept { |
122 | | return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) >> __shift)); |
123 | | } |
124 | | |
125 | | template <class _Integer, __enable_if_t<is_integral<_Integer>::value, int> = 0> |
126 | | _LIBCPP_NODISCARD_EXT _LIBCPP_HIDE_FROM_ABI constexpr _Integer to_integer(byte __b) noexcept { |
127 | | return static_cast<_Integer>(__b); |
128 | | } |
129 | | |
130 | | } // namespace std |
131 | | |
132 | | #endif |
133 | | |
134 | | #endif // _LIBCPP_CSTDDEF |