⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 unfused_generic.cpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 CPP
字号:
/*=============================================================================    Copyright (c) 2006-2007 Tobias Schwinger      Use modification and distribution are subject to 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).==============================================================================*/#include <boost/fusion/functional/adapter/unfused_generic.hpp>#include <boost/detail/lightweight_test.hpp>#include <boost/type_traits/is_same.hpp>#include <boost/noncopyable.hpp>#include <boost/blank.hpp>#include <boost/mpl/identity.hpp>#include <boost/utility/result_of.hpp>#include <boost/fusion/algorithm/iteration/fold.hpp>namespace fusion = boost::fusion;namespace mpl = boost::mpl;using boost::noncopyable;typedef mpl::true_ no_nullary_call;template <class Base = boost::blank>struct test_func    : Base{    template <typename Sig>    struct result;    template <class Self, class Seq>    struct result< Self (Seq) >        : mpl::identity<long>    { };    template <typename Seq>    long operator()(Seq const & seq) const    {        long state = 0;        return fusion::fold(seq, state, fold_op());    }    template <typename Seq>    long operator()(Seq const & seq)     {        long state = 100;        return fusion::fold(seq, state, fold_op());    }  private:    struct fold_op    {        template <typename T>        long operator()(T const & elem, long value) const        {          return value + sizeof(T) * elem;        }        template <typename T>        long operator()(T & elem, long value) const        {          elem += sizeof(T);          return value;        }        template <typename Sig>        struct result;        template <class Self, typename T0, typename T1> struct result< Self(T0,T1) >            : mpl::identity<long>        { };    };};void result_type_tests(){    using boost::is_same;    typedef fusion::unfused_generic< test_func<> > t;    BOOST_TEST(( is_same< boost::result_of< t () >::type, long >::value ));    BOOST_TEST(( is_same< boost::result_of< t (int) >::type, long >::value ));}int main(){    result_type_tests();    test_func<noncopyable> f;    fusion::unfused_generic< test_func<> > unfused_func;    fusion::unfused_generic< test_func<noncopyable> & > unfused_func_ref(f);    fusion::unfused_generic< test_func<> const > unfused_func_c;    fusion::unfused_generic< test_func<> > const unfused_func_c2;    fusion::unfused_generic< test_func<noncopyable> const & > unfused_func_c_ref(f);    BOOST_TEST(unfused_func() == 100);    BOOST_TEST(unfused_func_ref() == 100);    BOOST_TEST(unfused_func_c() == 0);    BOOST_TEST(unfused_func_c2() == 0);    BOOST_TEST(unfused_func_c_ref() == 0);    long lvalue = 12;    // also test const lvalues to pick up compiler deficiencies in that area    int const clvalue_1 = 1;    long const clvalue_2 = 2;     static const long expected = 1*sizeof(int) + 2*sizeof(long) + 7*sizeof(char);    BOOST_TEST(unfused_func(lvalue,lvalue,clvalue_1,clvalue_2,'\007') == 100 + expected);     BOOST_TEST(lvalue == 12 + 2*sizeof(long));    BOOST_TEST(unfused_func_ref(lvalue,lvalue,1,2l,'\007') == 100 + expected);     BOOST_TEST(lvalue == 12 + 4*sizeof(long));    BOOST_TEST(unfused_func_c(lvalue,lvalue,1,2l,'\007') == 0 + expected);     BOOST_TEST(lvalue == 12 + 6*sizeof(long));    BOOST_TEST(unfused_func_c2(lvalue,lvalue,1,2l,'\007') == 0 + expected);     BOOST_TEST(lvalue == 12 + 8*sizeof(long));    BOOST_TEST(unfused_func_c_ref(lvalue,lvalue,1,2l,'\007') == 0 + expected);     BOOST_TEST(lvalue == 12 + 10*sizeof(long));    return boost::report_errors();}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -