1//  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000.
2//  Use, modification and distribution are subject to the Boost Software License,
3//  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
4//  http://www.boost.org/LICENSE_1_0.txt).
5//
6//  See http://www.boost.org/libs/type_traits for most recent version including documentation.
7
8#ifndef BOOST_TT_INTRINSICS_HPP_INCLUDED
9#define BOOST_TT_INTRINSICS_HPP_INCLUDED
10
11#ifndef BOOST_TT_CONFIG_HPP_INCLUDED
12#include <boost/type_traits/config.hpp>
13#endif
14
15//
16// Helper macros for builtin compiler support.
17// If your compiler has builtin support for any of the following
18// traits concepts, then redefine the appropriate macros to pick
19// up on the compiler support:
20//
21// (these should largely ignore cv-qualifiers)
22// BOOST_IS_UNION(T) should evaluate to true if T is a union type
23// BOOST_IS_POD(T) should evaluate to true if T is a POD type
24// BOOST_IS_EMPTY(T) should evaluate to true if T is an empty class type (and not a union)
25// BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) should evaluate to true if "T x;" has no effect
26// BOOST_HAS_TRIVIAL_COPY(T) should evaluate to true if T(t) <==> memcpy
27// BOOST_HAS_TRIVIAL_ASSIGN(T) should evaluate to true if t = u <==> memcpy
28// BOOST_HAS_TRIVIAL_DESTRUCTOR(T) should evaluate to true if ~T() has no effect
29// BOOST_HAS_NOTHROW_CONSTRUCTOR(T) should evaluate to true if "T x;" can not throw
30// BOOST_HAS_NOTHROW_COPY(T) should evaluate to true if T(t) can not throw
31// BOOST_HAS_NOTHROW_ASSIGN(T) should evaluate to true if t = u can not throw
32// BOOST_HAS_VIRTUAL_DESTRUCTOR(T) should evaluate to true T has a virtual destructor
33//
34// The following can also be defined: when detected our implementation is greatly simplified.
35//
36// BOOST_IS_ABSTRACT(T) true if T is an abstract type
37// BOOST_IS_BASE_OF(T,U) true if T is a base class of U
38// BOOST_IS_CLASS(T) true if T is a class type (and not a union)
39// BOOST_IS_CONVERTIBLE(T,U) true if T is convertible to U
40// BOOST_IS_ENUM(T) true is T is an enum
41// BOOST_IS_POLYMORPHIC(T) true if T is a polymorphic type
42// BOOST_ALIGNMENT_OF(T) should evaluate to the alignment requirements of type T.
43
44#ifdef BOOST_HAS_SGI_TYPE_TRAITS
45    // Hook into SGI's __type_traits class, this will pick up user supplied
46    // specializations as well as SGI - compiler supplied specializations.
47#   include <boost/type_traits/is_same.hpp>
48#   ifdef __NetBSD__
49      // There are two different versions of type_traits.h on NetBSD on Spark
50      // use an implicit include via algorithm instead, to make sure we get
51      // the same version as the std lib:
52#     include <algorithm>
53#   else
54#    include <type_traits.h>
55#   endif
56#   define BOOST_IS_POD(T) ::boost::is_same< typename ::__type_traits<T>::is_POD_type, ::__true_type>::value
57#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) ::boost::is_same< typename ::__type_traits<T>::has_trivial_default_constructor, ::__true_type>::value
58#   define BOOST_HAS_TRIVIAL_COPY(T) ::boost::is_same< typename ::__type_traits<T>::has_trivial_copy_constructor, ::__true_type>::value
59#   define BOOST_HAS_TRIVIAL_ASSIGN(T) ::boost::is_same< typename ::__type_traits<T>::has_trivial_assignment_operator, ::__true_type>::value
60#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) ::boost::is_same< typename ::__type_traits<T>::has_trivial_destructor, ::__true_type>::value
61
62#   ifdef __sgi
63#      define BOOST_HAS_TYPE_TRAITS_INTRINSICS
64#   endif
65#endif
66
67#if defined(__MSL_CPP__) && (__MSL_CPP__ >= 0x8000)
68    // Metrowerks compiler is acquiring intrinsic type traits support
69    // post version 8.  We hook into the published interface to pick up
70    // user defined specializations as well as compiler intrinsics as
71    // and when they become available:
72#   include <msl_utility>
73#   define BOOST_IS_UNION(T) BOOST_STD_EXTENSION_NAMESPACE::is_union<T>::value
74#   define BOOST_IS_POD(T) BOOST_STD_EXTENSION_NAMESPACE::is_POD<T>::value
75#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) BOOST_STD_EXTENSION_NAMESPACE::has_trivial_default_ctor<T>::value
76#   define BOOST_HAS_TRIVIAL_COPY(T) BOOST_STD_EXTENSION_NAMESPACE::has_trivial_copy_ctor<T>::value
77#   define BOOST_HAS_TRIVIAL_ASSIGN(T) BOOST_STD_EXTENSION_NAMESPACE::has_trivial_assignment<T>::value
78#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) BOOST_STD_EXTENSION_NAMESPACE::has_trivial_dtor<T>::value
79#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
80#endif
81
82#if defined(BOOST_MSVC) && defined(BOOST_MSVC_FULL_VER) && (BOOST_MSVC_FULL_VER >=140050215)
83#   include <boost/type_traits/is_same.hpp>
84
85#   define BOOST_IS_UNION(T) __is_union(T)
86#   define BOOST_IS_POD(T) (__is_pod(T) && __has_trivial_constructor(T))
87#   define BOOST_IS_EMPTY(T) __is_empty(T)
88#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) __has_trivial_constructor(T)
89#   define BOOST_HAS_TRIVIAL_COPY(T) (__has_trivial_copy(T)|| ( ::boost::is_pod<T>::value && !::boost::is_volatile<T>::value))
90#   define BOOST_HAS_TRIVIAL_ASSIGN(T) (__has_trivial_assign(T) || ( ::boost::is_pod<T>::value && ! ::boost::is_const<T>::value && !::boost::is_volatile<T>::value))
91#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) (__has_trivial_destructor(T) || ::boost::is_pod<T>::value)
92#   define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) (__has_nothrow_constructor(T) || ::boost::has_trivial_constructor<T>::value)
93#   define BOOST_HAS_NOTHROW_COPY(T) (__has_nothrow_copy(T) || ::boost::has_trivial_copy<T>::value)
94#   define BOOST_HAS_NOTHROW_ASSIGN(T) (__has_nothrow_assign(T) || ::boost::has_trivial_assign<T>::value)
95#   define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) __has_virtual_destructor(T)
96
97#   define BOOST_IS_ABSTRACT(T) __is_abstract(T)
98#   define BOOST_IS_BASE_OF(T,U) (__is_base_of(T,U) && !is_same<T,U>::value)
99#   define BOOST_IS_CLASS(T) __is_class(T)
100#   define BOOST_IS_CONVERTIBLE(T,U) ((__is_convertible_to(T,U) || is_same<T,U>::value) && !__is_abstract(U))
101#   define BOOST_IS_ENUM(T) __is_enum(T)
102//  This one doesn't quite always do the right thing:
103//  #   define BOOST_IS_POLYMORPHIC(T) __is_polymorphic(T)
104//  This one fails if the default alignment has been changed with /Zp:
105//  #   define BOOST_ALIGNMENT_OF(T) __alignof(T)
106
107#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
108#endif
109
110#if defined(__DMC__) && (__DMC__ >= 0x848)
111// For Digital Mars C++, www.digitalmars.com
112#   define BOOST_IS_UNION(T) (__typeinfo(T) & 0x400)
113#   define BOOST_IS_POD(T) (__typeinfo(T) & 0x800)
114#   define BOOST_IS_EMPTY(T) (__typeinfo(T) & 0x1000)
115#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) (__typeinfo(T) & 0x10)
116#   define BOOST_HAS_TRIVIAL_COPY(T) (__typeinfo(T) & 0x20)
117#   define BOOST_HAS_TRIVIAL_ASSIGN(T) (__typeinfo(T) & 0x40)
118#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) (__typeinfo(T) & 0x8)
119#   define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) (__typeinfo(T) & 0x80)
120#   define BOOST_HAS_NOTHROW_COPY(T) (__typeinfo(T) & 0x100)
121#   define BOOST_HAS_NOTHROW_ASSIGN(T) (__typeinfo(T) & 0x200)
122#   define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) (__typeinfo(T) & 0x4)
123#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
124#endif
125
126#if defined(BOOST_CLANG) && defined(__has_feature)
127#   include <cstddef>
128#   include <boost/type_traits/is_same.hpp>
129#   include <boost/type_traits/is_reference.hpp>
130#   include <boost/type_traits/is_volatile.hpp>
131
132#   if __has_feature(is_union)
133#     define BOOST_IS_UNION(T) __is_union(T)
134#   endif
135#   if (!defined(__GLIBCXX__) || (__GLIBCXX__ >= 20080306 && __GLIBCXX__ != 20080519)) && __has_feature(is_pod)
136#     define BOOST_IS_POD(T) __is_pod(T)
137#   endif
138#   if (!defined(__GLIBCXX__) || (__GLIBCXX__ >= 20080306 && __GLIBCXX__ != 20080519)) && __has_feature(is_empty)
139#     define BOOST_IS_EMPTY(T) __is_empty(T)
140#   endif
141#   if __has_feature(has_trivial_constructor)
142#     define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) __has_trivial_constructor(T)
143#   endif
144#   if __has_feature(has_trivial_copy)
145#     define BOOST_HAS_TRIVIAL_COPY(T) (__has_trivial_copy(T) && !is_reference<T>::value && !is_volatile<T>::value)
146#   endif
147#   if __has_feature(has_trivial_assign)
148#     define BOOST_HAS_TRIVIAL_ASSIGN(T) (__has_trivial_assign(T) && !is_volatile<T>::value)
149#   endif
150#   if __has_feature(has_trivial_destructor)
151#     define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) __has_trivial_destructor(T)
152#   endif
153#   if __has_feature(has_nothrow_constructor)
154#     define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) __has_nothrow_constructor(T)
155#   endif
156#   if __has_feature(has_nothrow_copy)
157#     define BOOST_HAS_NOTHROW_COPY(T) (__has_nothrow_copy(T) && !is_volatile<T>::value && !is_reference<T>::value)
158#   endif
159#   if __has_feature(has_nothrow_assign)
160#     define BOOST_HAS_NOTHROW_ASSIGN(T) (__has_nothrow_assign(T) && !is_volatile<T>::value)
161#   endif
162#   if __has_feature(has_virtual_destructor)
163#     define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) __has_virtual_destructor(T)
164#   endif
165#   if __has_feature(is_abstract)
166#     define BOOST_IS_ABSTRACT(T) __is_abstract(T)
167#   endif
168#   if __has_feature(is_base_of)
169#     define BOOST_IS_BASE_OF(T,U) (__is_base_of(T,U) && !is_same<T,U>::value)
170#   endif
171#   if __has_feature(is_class)
172#     define BOOST_IS_CLASS(T) __is_class(T)
173#   endif
174#   if __has_feature(is_convertible_to)
175#     include <boost/type_traits/is_abstract.hpp>
176#     define BOOST_IS_CONVERTIBLE(T,U) (__is_convertible_to(T,U) && !::boost::is_abstract<U>::value)
177#   endif
178#   if __has_feature(is_enum)
179#     define BOOST_IS_ENUM(T) __is_enum(T)
180#   endif
181#   if __has_feature(is_polymorphic)
182#     define BOOST_IS_POLYMORPHIC(T) __is_polymorphic(T)
183#   endif
184#   define BOOST_ALIGNMENT_OF(T) __alignof(T)
185
186#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
187#endif
188
189#if defined(__GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 3) && !defined(__GCCXML__))) && !defined(BOOST_CLANG)
190#   include <boost/type_traits/is_same.hpp>
191#   include <boost/type_traits/is_reference.hpp>
192#   include <boost/type_traits/is_volatile.hpp>
193
194#ifdef BOOST_INTEL
195#  define BOOST_INTEL_TT_OPTS || is_pod<T>::value
196#else
197#  define BOOST_INTEL_TT_OPTS
198#endif
199
200#   define BOOST_IS_UNION(T) __is_union(T)
201#   define BOOST_IS_POD(T) __is_pod(T)
202#   define BOOST_IS_EMPTY(T) __is_empty(T)
203#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) ((__has_trivial_constructor(T) BOOST_INTEL_TT_OPTS) && ! ::boost::is_volatile<T>::value)
204#   define BOOST_HAS_TRIVIAL_COPY(T) ((__has_trivial_copy(T) BOOST_INTEL_TT_OPTS) && !is_reference<T>::value && ! ::boost::is_volatile<T>::value)
205#   define BOOST_HAS_TRIVIAL_ASSIGN(T) ((__has_trivial_assign(T) BOOST_INTEL_TT_OPTS) && ! ::boost::is_volatile<T>::value && ! ::boost::is_const<T>::value)
206#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) (__has_trivial_destructor(T) BOOST_INTEL_TT_OPTS)
207#   define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) (__has_nothrow_constructor(T) BOOST_INTEL_TT_OPTS)
208#   define BOOST_HAS_NOTHROW_COPY(T) ((__has_nothrow_copy(T) BOOST_INTEL_TT_OPTS) && !is_volatile<T>::value && !is_reference<T>::value)
209#   define BOOST_HAS_NOTHROW_ASSIGN(T) ((__has_nothrow_assign(T) BOOST_INTEL_TT_OPTS) && !is_volatile<T>::value && !is_const<T>::value)
210#   define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) __has_virtual_destructor(T)
211
212#   define BOOST_IS_ABSTRACT(T) __is_abstract(T)
213#   define BOOST_IS_BASE_OF(T,U) (__is_base_of(T,U) && !is_same<T,U>::value)
214#   define BOOST_IS_CLASS(T) __is_class(T)
215#   define BOOST_IS_ENUM(T) __is_enum(T)
216#   define BOOST_IS_POLYMORPHIC(T) __is_polymorphic(T)
217#   if (!defined(unix) && !defined(__unix__)) || defined(__LP64__)
218      // GCC sometimes lies about alignment requirements
219      // of type double on 32-bit unix platforms, use the
220      // old implementation instead in that case:
221#     define BOOST_ALIGNMENT_OF(T) __alignof__(T)
222#   endif
223
224#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
225#endif
226
227#if defined(__ghs__) && (__GHS_VERSION_NUMBER >= 600)
228#   include <boost/type_traits/is_same.hpp>
229#   include <boost/type_traits/is_reference.hpp>
230#   include <boost/type_traits/is_volatile.hpp>
231
232#   define BOOST_IS_UNION(T) __is_union(T)
233#   define BOOST_IS_POD(T) __is_pod(T)
234#   define BOOST_IS_EMPTY(T) __is_empty(T)
235#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) __has_trivial_constructor(T)
236#   define BOOST_HAS_TRIVIAL_COPY(T) (__has_trivial_copy(T) && !is_reference<T>::value && !is_volatile<T>::value)
237#   define BOOST_HAS_TRIVIAL_ASSIGN(T) (__has_trivial_assign(T) && !is_volatile<T>::value)
238#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) __has_trivial_destructor(T)
239#   define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) __has_nothrow_constructor(T)
240#   define BOOST_HAS_NOTHROW_COPY(T) (__has_nothrow_copy(T) && !is_volatile<T>::value && !is_reference<T>::value)
241#   define BOOST_HAS_NOTHROW_ASSIGN(T) (__has_nothrow_assign(T) && !is_volatile<T>::value)
242#   define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) __has_virtual_destructor(T)
243
244#   define BOOST_IS_ABSTRACT(T) __is_abstract(T)
245#   define BOOST_IS_BASE_OF(T,U) (__is_base_of(T,U) && !is_same<T,U>::value)
246#   define BOOST_IS_CLASS(T) __is_class(T)
247#   define BOOST_IS_ENUM(T) __is_enum(T)
248#   define BOOST_IS_POLYMORPHIC(T) __is_polymorphic(T)
249#   define BOOST_ALIGNMENT_OF(T) __alignof__(T)
250
251#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
252#endif
253
254# if defined(__CODEGEARC__)
255#   include <boost/type_traits/is_same.hpp>
256#   include <boost/type_traits/is_reference.hpp>
257#   include <boost/type_traits/is_volatile.hpp>
258#   include <boost/type_traits/is_void.hpp>
259
260#   define BOOST_IS_UNION(T) __is_union(T)
261#   define BOOST_IS_POD(T) __is_pod(T)
262#   define BOOST_IS_EMPTY(T) __is_empty(T)
263#   define BOOST_HAS_TRIVIAL_CONSTRUCTOR(T) (__has_trivial_default_constructor(T))
264#   define BOOST_HAS_TRIVIAL_COPY(T) (__has_trivial_copy_constructor(T) && !is_volatile<T>::value && !is_reference<T>::value)
265#   define BOOST_HAS_TRIVIAL_ASSIGN(T) (__has_trivial_assign(T) && !is_volatile<T>::value)
266#   define BOOST_HAS_TRIVIAL_DESTRUCTOR(T) (__has_trivial_destructor(T))
267#   define BOOST_HAS_NOTHROW_CONSTRUCTOR(T) (__has_nothrow_default_constructor(T))
268#   define BOOST_HAS_NOTHROW_COPY(T) (__has_nothrow_copy_constructor(T) && !is_volatile<T>::value && !is_reference<T>::value)
269#   define BOOST_HAS_NOTHROW_ASSIGN(T) (__has_nothrow_assign(T) && !is_volatile<T>::value)
270#   define BOOST_HAS_VIRTUAL_DESTRUCTOR(T) __has_virtual_destructor(T)
271
272#   define BOOST_IS_ABSTRACT(T) __is_abstract(T)
273#   define BOOST_IS_BASE_OF(T,U) (__is_base_of(T,U) && !is_void<T>::value && !is_void<U>::value)
274#   define BOOST_IS_CLASS(T) __is_class(T)
275#   define BOOST_IS_CONVERTIBLE(T,U) (__is_convertible(T,U) || is_void<U>::value)
276#   define BOOST_IS_ENUM(T) __is_enum(T)
277#   define BOOST_IS_POLYMORPHIC(T) __is_polymorphic(T)
278#   define BOOST_ALIGNMENT_OF(T) alignof(T)
279
280#   define BOOST_HAS_TYPE_TRAITS_INTRINSICS
281#endif
282
283#endif // BOOST_TT_INTRINSICS_HPP_INCLUDED
284
285
286
287
288
289
290