forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			166 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			166 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
// -*- C++ -*-
 | 
						|
//===--------------------------- cstddef ----------------------------------===//
 | 
						|
//
 | 
						|
// 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
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#ifndef _LIBCPP_CSTDDEF
 | 
						|
#define _LIBCPP_CSTDDEF
 | 
						|
 | 
						|
/*
 | 
						|
    cstddef synopsis
 | 
						|
 | 
						|
Macros:
 | 
						|
 | 
						|
    offsetof(type,member-designator)
 | 
						|
    NULL
 | 
						|
 | 
						|
namespace std
 | 
						|
{
 | 
						|
 | 
						|
Types:
 | 
						|
 | 
						|
    ptrdiff_t
 | 
						|
    size_t
 | 
						|
    max_align_t
 | 
						|
    nullptr_t
 | 
						|
    byte // C++17
 | 
						|
 | 
						|
}  // std
 | 
						|
 | 
						|
*/
 | 
						|
 | 
						|
#include <__config>
 | 
						|
#include <version>
 | 
						|
 | 
						|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
 | 
						|
#pragma GCC system_header
 | 
						|
#endif
 | 
						|
 | 
						|
// Don't include our own <stddef.h>; we don't want to declare ::nullptr_t.
 | 
						|
#include_next <stddef.h>
 | 
						|
#include <__nullptr>
 | 
						|
 | 
						|
_LIBCPP_BEGIN_NAMESPACE_STD
 | 
						|
 | 
						|
using ::ptrdiff_t;
 | 
						|
using ::size_t;
 | 
						|
 | 
						|
#if defined(__CLANG_MAX_ALIGN_T_DEFINED) || defined(_GCC_MAX_ALIGN_T) || \
 | 
						|
    defined(__DEFINED_max_align_t) || defined(__NetBSD__)
 | 
						|
// Re-use the compiler's <stddef.h> max_align_t where possible.
 | 
						|
using ::max_align_t;
 | 
						|
#else
 | 
						|
typedef long double max_align_t;
 | 
						|
#endif
 | 
						|
 | 
						|
template <class _Tp> struct __libcpp_is_integral                     { enum { value = 0 }; };
 | 
						|
template <>          struct __libcpp_is_integral<bool>               { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<char>               { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<signed char>        { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<unsigned char>      { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<wchar_t>            { enum { value = 1 }; };
 | 
						|
#ifndef _LIBCPP_NO_HAS_CHAR8_T
 | 
						|
template <>          struct __libcpp_is_integral<char8_t>            { enum { value = 1 }; };
 | 
						|
#endif
 | 
						|
#ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
 | 
						|
template <>          struct __libcpp_is_integral<char16_t>           { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<char32_t>           { enum { value = 1 }; };
 | 
						|
#endif  // _LIBCPP_HAS_NO_UNICODE_CHARS
 | 
						|
template <>          struct __libcpp_is_integral<short>              { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<unsigned short>     { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<int>                { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<unsigned int>       { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<long>               { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<unsigned long>      { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<long long>          { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<unsigned long long> { enum { value = 1 }; };
 | 
						|
#ifndef _LIBCPP_HAS_NO_INT128
 | 
						|
template <>          struct __libcpp_is_integral<__int128_t>         { enum { value = 1 }; };
 | 
						|
template <>          struct __libcpp_is_integral<__uint128_t>        { enum { value = 1 }; };
 | 
						|
#endif
 | 
						|
 | 
						|
_LIBCPP_END_NAMESPACE_STD
 | 
						|
 | 
						|
#if _LIBCPP_STD_VER > 14
 | 
						|
namespace std  // purposefully not versioned
 | 
						|
{
 | 
						|
enum class byte : unsigned char {};
 | 
						|
 | 
						|
 | 
						|
template <bool> struct __enable_if_integral_imp {};
 | 
						|
template <> struct __enable_if_integral_imp<true> { using type = byte; };
 | 
						|
template <class _Tp> using _EnableByteOverload = typename __enable_if_integral_imp<__libcpp_is_integral<_Tp>::value>::type;
 | 
						|
 | 
						|
constexpr byte  operator| (byte  __lhs, byte __rhs) noexcept
 | 
						|
{
 | 
						|
    return static_cast<byte>(
 | 
						|
      static_cast<unsigned char>(
 | 
						|
         static_cast<unsigned int>(__lhs) | static_cast<unsigned int>(__rhs)
 | 
						|
    ));
 | 
						|
}
 | 
						|
 | 
						|
constexpr byte& operator|=(byte& __lhs, byte __rhs) noexcept
 | 
						|
{ return __lhs = __lhs | __rhs; }
 | 
						|
 | 
						|
constexpr byte  operator& (byte  __lhs, byte __rhs) noexcept
 | 
						|
{
 | 
						|
    return static_cast<byte>(
 | 
						|
      static_cast<unsigned char>(
 | 
						|
         static_cast<unsigned int>(__lhs) & static_cast<unsigned int>(__rhs)
 | 
						|
    ));
 | 
						|
}
 | 
						|
 | 
						|
constexpr byte& operator&=(byte& __lhs, byte __rhs) noexcept
 | 
						|
{ return __lhs = __lhs & __rhs; }
 | 
						|
 | 
						|
constexpr byte  operator^ (byte  __lhs, byte __rhs) noexcept
 | 
						|
{
 | 
						|
    return static_cast<byte>(
 | 
						|
      static_cast<unsigned char>(
 | 
						|
         static_cast<unsigned int>(__lhs) ^ static_cast<unsigned int>(__rhs)
 | 
						|
    ));
 | 
						|
}
 | 
						|
 | 
						|
constexpr byte& operator^=(byte& __lhs, byte __rhs) noexcept
 | 
						|
{ return __lhs = __lhs ^ __rhs; }
 | 
						|
 | 
						|
constexpr byte  operator~ (byte __b) noexcept
 | 
						|
{
 | 
						|
    return static_cast<byte>(
 | 
						|
      static_cast<unsigned char>(
 | 
						|
        ~static_cast<unsigned int>(__b)
 | 
						|
    ));
 | 
						|
}
 | 
						|
template <class _Integer>
 | 
						|
  constexpr _EnableByteOverload<_Integer> &
 | 
						|
  operator<<=(byte& __lhs, _Integer __shift) noexcept
 | 
						|
  { return __lhs = __lhs << __shift; }
 | 
						|
 | 
						|
template <class _Integer>
 | 
						|
  constexpr _EnableByteOverload<_Integer>
 | 
						|
  operator<< (byte  __lhs, _Integer __shift) noexcept
 | 
						|
  { return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) << __shift)); }
 | 
						|
 | 
						|
template <class _Integer>
 | 
						|
  constexpr _EnableByteOverload<_Integer> &
 | 
						|
  operator>>=(byte& __lhs, _Integer __shift) noexcept
 | 
						|
  { return __lhs = __lhs >> __shift; }
 | 
						|
 | 
						|
template <class _Integer>
 | 
						|
  constexpr _EnableByteOverload<_Integer>
 | 
						|
  operator>> (byte  __lhs, _Integer __shift) noexcept
 | 
						|
  { return static_cast<byte>(static_cast<unsigned char>(static_cast<unsigned int>(__lhs) >> __shift)); }
 | 
						|
 | 
						|
template <class _Integer, class = _EnableByteOverload<_Integer> >
 | 
						|
  constexpr _Integer
 | 
						|
  to_integer(byte __b) noexcept { return static_cast<_Integer>(__b); }
 | 
						|
}
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#endif  // _LIBCPP_CSTDDEF
 |