mirror of
https://github.com/boostorg/phoenix.git
synced 2026-01-19 16:32:14 +00:00
129 lines
2.9 KiB
C++
129 lines
2.9 KiB
C++
/*=============================================================================
|
|
Copyright (c) 2001-2007 Joel de Guzman
|
|
|
|
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)
|
|
==============================================================================*/
|
|
#include <iostream>
|
|
#include <cmath>
|
|
#include <boost/detail/lightweight_test.hpp>
|
|
#include <boost/phoenix/core.hpp>
|
|
#include <boost/phoenix/operator.hpp>
|
|
#include <boost/phoenix/function.hpp>
|
|
|
|
using namespace boost::phoenix;
|
|
using namespace boost::phoenix::arg_names;
|
|
using namespace std;
|
|
|
|
struct test_impl
|
|
{
|
|
typedef void result_type;
|
|
void operator()() const
|
|
{
|
|
cout << "Test lazy functions...\n";
|
|
}
|
|
};
|
|
|
|
function<test_impl> test;
|
|
|
|
struct sqr_impl
|
|
{
|
|
template<typename Signature>
|
|
struct result;
|
|
|
|
template <typename This, typename Arg>
|
|
struct result<This(Arg &)>
|
|
{
|
|
typedef Arg type;
|
|
};
|
|
|
|
template <typename Arg>
|
|
Arg operator()(Arg n) const
|
|
{
|
|
return n * n;
|
|
}
|
|
};
|
|
|
|
function<sqr_impl> sqr;
|
|
|
|
struct fact_impl
|
|
{
|
|
template<typename Signature>
|
|
struct result;
|
|
|
|
template <typename This, typename Arg>
|
|
struct result<This(Arg &)>
|
|
{
|
|
typedef Arg type;
|
|
};
|
|
|
|
template <typename Arg>
|
|
Arg operator()(Arg n) const
|
|
{
|
|
return (n <= 0) ? 1 : n * (*this)(n-1);
|
|
}
|
|
};
|
|
|
|
function<fact_impl> fact;
|
|
|
|
struct pow_impl
|
|
{
|
|
|
|
template<typename Sig>
|
|
struct result;
|
|
|
|
template <typename This, typename Arg1, typename Arg2>
|
|
struct result<This(Arg1 &, Arg2 &)>
|
|
{
|
|
typedef Arg1 type;
|
|
};
|
|
|
|
template <typename Arg1, typename Arg2>
|
|
Arg1 operator()(Arg1 a, Arg2 b) const
|
|
{
|
|
return pow(a, b);
|
|
}
|
|
};
|
|
|
|
function<pow_impl> power;
|
|
|
|
/*
|
|
struct add_impl
|
|
{
|
|
template <typename Arg1, typename Arg2, typename Arg3, typename Arg4>
|
|
struct result
|
|
{
|
|
typedef Arg1 type;
|
|
};
|
|
|
|
template <typename Arg1, typename Arg2, typename Arg3, typename Arg4>
|
|
Arg1 operator()(Arg1 a, Arg2 b, Arg3 c, Arg4 d) const
|
|
{
|
|
return a + b + c + d;
|
|
}
|
|
};
|
|
|
|
function<add_impl> add;
|
|
*/
|
|
|
|
int
|
|
main()
|
|
{
|
|
int i5 = 5;
|
|
double d5 = 5, d3 = 3;
|
|
|
|
test()(0);
|
|
BOOST_TEST(sqr(arg1)(i5) == (i5*i5));
|
|
BOOST_TEST(fact(4)() == 24);
|
|
BOOST_TEST(fact(arg1)(i5) == 120);
|
|
BOOST_TEST((int)power(arg1, arg2)(d5, d3) == (int)pow(d5, d3));
|
|
BOOST_TEST((sqr(arg1) + 5)(i5) == ((i5*i5)+5));
|
|
//BOOST_TEST(add(arg1, arg1, arg1, arg1)(i5) == (5+5+5+5));
|
|
|
|
int const ic5 = 5;
|
|
// testing consts
|
|
BOOST_TEST(sqr(arg1)(ic5) == (ic5*ic5));
|
|
|
|
return boost::report_errors();
|
|
}
|