// Copyright David Abrahams 2006. Distributed under the Boost // Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifndef BOOST_CONCEPT_CHECK_MSVC_DWA2006429_HPP # define BOOST_CONCEPT_CHECK_MSVC_DWA2006429_HPP # include # include # include # ifdef BOOST_OLD_CONCEPT_SUPPORT # include # include # endif # ifdef BOOST_MSVC # pragma warning(push) # pragma warning(disable:4100) # endif namespace lslboost { namespace concepts { template struct check { virtual void failed(Model* x) { x->~Model(); } }; # ifndef BOOST_NO_PARTIAL_SPECIALIZATION struct failed {}; template struct check { virtual void failed(Model* x) { x->~Model(); } }; # endif # ifdef BOOST_OLD_CONCEPT_SUPPORT namespace detail { // No need for a virtual function here, since evaluating // not_satisfied below will have already instantiated the // constraints() member. struct constraint {}; } template struct require : lslboost::conditional< not_satisfied::value , detail::constraint # ifndef BOOST_NO_PARTIAL_SPECIALIZATION , check # else , check # endif >::type {}; # else template struct require # ifndef BOOST_NO_PARTIAL_SPECIALIZATION : check # else : check # endif {}; # endif # if BOOST_WORKAROUND(BOOST_MSVC, == 1310) // // The iterator library sees some really strange errors unless we // do things this way. // template struct require { virtual void failed(Model*) { require(); } }; # define BOOST_CONCEPT_ASSERT_FN( ModelFnPtr ) \ enum \ { \ BOOST_PP_CAT(boost_concept_check,__LINE__) = \ sizeof(::lslboost::concepts::require) \ } # else // Not vc-7.1 template require require_(void(*)(Model)); # define BOOST_CONCEPT_ASSERT_FN( ModelFnPtr ) \ enum \ { \ BOOST_PP_CAT(boost_concept_check,__LINE__) = \ sizeof(::lslboost::concepts::require_((ModelFnPtr)0)) \ } # endif }} # ifdef BOOST_MSVC # pragma warning(pop) # endif #endif // BOOST_CONCEPT_CHECK_MSVC_DWA2006429_HPP