One Hat Cyber Team
Your IP :
216.73.216.135
Server IP :
194.44.31.54
Server :
Linux zen.imath.kiev.ua 4.18.0-553.77.1.el8_10.x86_64 #1 SMP Fri Oct 3 14:30:23 UTC 2025 x86_64
Server Software :
Apache/2.4.37 (Rocky Linux) OpenSSL/1.1.1k
PHP Version :
5.6.40
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
include
/
llvm
/
Support
/
View File Name :
type_traits.h
//===- llvm/Support/type_traits.h - Simplfied type traits -------*- 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 // //===----------------------------------------------------------------------===// // // This file provides useful additions to the standard type_traits library. // //===----------------------------------------------------------------------===// #ifndef LLVM_SUPPORT_TYPE_TRAITS_H #define LLVM_SUPPORT_TYPE_TRAITS_H #include "llvm/Support/Compiler.h" #include <type_traits> #include <utility> namespace llvm { /// Metafunction that determines whether the given type is either an /// integral type or an enumeration type, including enum classes. /// /// Note that this accepts potentially more integral types than is_integral /// because it is based on being implicitly convertible to an integral type. /// Also note that enum classes aren't implicitly convertible to integral types, /// the value may therefore need to be explicitly converted before being used. template <typename T> class is_integral_or_enum { using UnderlyingT = std::remove_reference_t<T>; public: static const bool value = !std::is_class_v<UnderlyingT> && // Filter conversion operators. !std::is_pointer_v<UnderlyingT> && !std::is_floating_point_v<UnderlyingT> && (std::is_enum_v<UnderlyingT> || std::is_convertible_v<UnderlyingT, unsigned long long>); }; /// If T is a pointer, just return it. If it is not, return T&. template<typename T, typename Enable = void> struct add_lvalue_reference_if_not_pointer { using type = T &; }; template <typename T> struct add_lvalue_reference_if_not_pointer< T, std::enable_if_t<std::is_pointer_v<T>>> { using type = T; }; /// If T is a pointer to X, return a pointer to const X. If it is not, /// return const T. template<typename T, typename Enable = void> struct add_const_past_pointer { using type = const T; }; template <typename T> struct add_const_past_pointer<T, std::enable_if_t<std::is_pointer_v<T>>> { using type = const std::remove_pointer_t<T> *; }; template <typename T, typename Enable = void> struct const_pointer_or_const_ref { using type = const T &; }; template <typename T> struct const_pointer_or_const_ref<T, std::enable_if_t<std::is_pointer_v<T>>> { using type = typename add_const_past_pointer<T>::type; }; namespace detail { template<class T> union trivial_helper { T t; }; } // end namespace detail template <typename T> struct is_copy_assignable { template<class F> static auto get(F*) -> decltype(std::declval<F &>() = std::declval<const F &>(), std::true_type{}); static std::false_type get(...); static constexpr bool value = decltype(get((T*)nullptr))::value; }; template <typename T> struct is_move_assignable { template<class F> static auto get(F*) -> decltype(std::declval<F &>() = std::declval<F &&>(), std::true_type{}); static std::false_type get(...); static constexpr bool value = decltype(get((T*)nullptr))::value; }; } // end namespace llvm #endif // LLVM_SUPPORT_TYPE_TRAITS_H