annotate DEPENDENCIES/generic/include/boost/python/detail/destroy.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents 2665513ce2d3
children
rev   line source
Chris@16 1 // Copyright David Abrahams 2002.
Chris@16 2 // Distributed under the Boost Software License, Version 1.0. (See
Chris@16 3 // accompanying file LICENSE_1_0.txt or copy at
Chris@16 4 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 5 #ifndef DESTROY_DWA2002221_HPP
Chris@16 6 # define DESTROY_DWA2002221_HPP
Chris@16 7
Chris@16 8 # include <boost/type_traits/is_array.hpp>
Chris@16 9 # include <boost/detail/workaround.hpp>
Chris@16 10 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 11 # include <boost/type_traits/is_enum.hpp>
Chris@16 12 # endif
Chris@16 13 namespace boost { namespace python { namespace detail {
Chris@16 14
Chris@16 15 template <
Chris@16 16 bool array
Chris@16 17 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 18 , bool enum_ // vc7 has a problem destroying enums
Chris@16 19 # endif
Chris@16 20 > struct value_destroyer;
Chris@16 21
Chris@16 22 template <>
Chris@16 23 struct value_destroyer<
Chris@16 24 false
Chris@16 25 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 26 , false
Chris@16 27 # endif
Chris@16 28 >
Chris@16 29 {
Chris@16 30 template <class T>
Chris@16 31 static void execute(T const volatile* p)
Chris@16 32 {
Chris@16 33 p->~T();
Chris@16 34 }
Chris@16 35 };
Chris@16 36
Chris@16 37 template <>
Chris@16 38 struct value_destroyer<
Chris@16 39 true
Chris@16 40 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 41 , false
Chris@16 42 # endif
Chris@16 43 >
Chris@16 44 {
Chris@16 45 template <class A, class T>
Chris@16 46 static void execute(A*, T const volatile* const first)
Chris@16 47 {
Chris@16 48 for (T const volatile* p = first; p != first + sizeof(A)/sizeof(T); ++p)
Chris@16 49 {
Chris@16 50 value_destroyer<
Chris@16 51 boost::is_array<T>::value
Chris@16 52 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 53 , boost::is_enum<T>::value
Chris@16 54 # endif
Chris@16 55 >::execute(p);
Chris@16 56 }
Chris@16 57 }
Chris@16 58
Chris@16 59 template <class T>
Chris@16 60 static void execute(T const volatile* p)
Chris@16 61 {
Chris@16 62 execute(p, *p);
Chris@16 63 }
Chris@16 64 };
Chris@16 65
Chris@16 66 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 67 template <>
Chris@16 68 struct value_destroyer<true,true>
Chris@16 69 {
Chris@16 70 template <class T>
Chris@16 71 static void execute(T const volatile*)
Chris@16 72 {
Chris@16 73 }
Chris@16 74 };
Chris@16 75
Chris@16 76 template <>
Chris@16 77 struct value_destroyer<false,true>
Chris@16 78 {
Chris@16 79 template <class T>
Chris@16 80 static void execute(T const volatile*)
Chris@16 81 {
Chris@16 82 }
Chris@16 83 };
Chris@16 84 # endif
Chris@16 85 template <class T>
Chris@16 86 inline void destroy_referent_impl(void* p, T& (*)())
Chris@16 87 {
Chris@16 88 // note: cv-qualification needed for MSVC6
Chris@16 89 // must come *before* T for metrowerks
Chris@16 90 value_destroyer<
Chris@16 91 (boost::is_array<T>::value)
Chris@16 92 # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
Chris@16 93 , (boost::is_enum<T>::value)
Chris@16 94 # endif
Chris@16 95 >::execute((const volatile T*)p);
Chris@16 96 }
Chris@16 97
Chris@16 98 template <class T>
Chris@16 99 inline void destroy_referent(void* p, T(*)() = 0)
Chris@16 100 {
Chris@16 101 destroy_referent_impl(p, (T(*)())0);
Chris@16 102 }
Chris@16 103
Chris@16 104 }}} // namespace boost::python::detail
Chris@16 105
Chris@16 106 #endif // DESTROY_DWA2002221_HPP