| #include <algorithm> |
| #include <functional> |
| |
| #include "cppunit/cppunit_proxy.h" |
| |
| #if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES) |
| using namespace std; |
| #endif |
| |
| // |
| // TestCase class |
| // |
| class BindTest : public CPPUNIT_NS::TestCase |
| { |
| CPPUNIT_TEST_SUITE(BindTest); |
| CPPUNIT_TEST(bind1st1); |
| CPPUNIT_TEST(bind2nd1); |
| CPPUNIT_TEST(bind2nd2); |
| #if !defined (STLPORT) || \ |
| defined (_STLP_NO_EXTENSIONS) || !defined (_STLP_CLASS_PARTIAL_SPECIALIZATION) |
| CPPUNIT_IGNORE; |
| #endif |
| CPPUNIT_TEST(bind2nd3); |
| CPPUNIT_TEST(bind_memfn); |
| CPPUNIT_TEST_SUITE_END(); |
| |
| protected: |
| void bind1st1(); |
| void bind2nd1(); |
| void bind2nd2(); |
| void bind2nd3(); |
| void bind_memfn(); |
| }; |
| |
| CPPUNIT_TEST_SUITE_REGISTRATION(BindTest); |
| |
| class pre_increment : public binary_function<int, int, int> { |
| public: |
| int operator()(int incr, int& val) const |
| { return val += incr; } |
| }; |
| |
| class post_increment : public binary_function<int, int, int> { |
| public: |
| int operator()(int& val, int incr) const |
| { return val += incr; } |
| }; |
| |
| |
| // |
| // tests implementation |
| // |
| void BindTest::bind1st1() |
| { |
| int array [3] = { 1, 2, 3 }; |
| int* p = remove_if((int*)array, (int*)array + 3, bind1st(less<int>(), 2)); |
| |
| CPPUNIT_ASSERT(p == &array[2]); |
| CPPUNIT_ASSERT(array[0] == 1); |
| CPPUNIT_ASSERT(array[1] == 2); |
| |
| for_each((int*)array, (int*)array + 3, bind1st(pre_increment(), 1)); |
| CPPUNIT_ASSERT(array[0] == 2); |
| CPPUNIT_ASSERT(array[1] == 3); |
| CPPUNIT_ASSERT(array[2] == 4); |
| |
| for_each((int*)array, (int*)array + 3, bind2nd(post_increment(), 1)); |
| CPPUNIT_ASSERT(array[0] == 3); |
| CPPUNIT_ASSERT(array[1] == 4); |
| CPPUNIT_ASSERT(array[2] == 5); |
| } |
| |
| void BindTest::bind2nd1() |
| { |
| int array [3] = { 1, 2, 3 }; |
| replace_if(array, array + 3, binder2nd<greater<int> >(greater<int>(), 2), 4); |
| |
| CPPUNIT_ASSERT(array[0]==1); |
| CPPUNIT_ASSERT(array[1]==2); |
| CPPUNIT_ASSERT(array[2]==4); |
| } |
| void BindTest::bind2nd2() |
| { |
| int array [3] = { 1, 2, 3 }; |
| replace_if(array, array + 3, bind2nd(greater<int>(), 2), 4); |
| CPPUNIT_ASSERT(array[0]==1); |
| CPPUNIT_ASSERT(array[1]==2); |
| CPPUNIT_ASSERT(array[2]==4); |
| } |
| |
| int test_func1 (const int ¶m1, const int ¶m2) { |
| return param1 + param2; |
| } |
| |
| int test_func2 (int ¶m1, int param2) { |
| param1 += param2; |
| return param1 + param2; |
| } |
| |
| void BindTest::bind2nd3() |
| { |
| #if defined (STLPORT) && \ |
| !defined (_STLP_NO_EXTENSIONS) && defined (_STLP_CLASS_PARTIAL_SPECIALIZATION) |
| int array[3] = { 1, 2, 3 }; |
| transform(array, array + 3, array, bind2nd(ptr_fun(test_func1), 1)); |
| transform(array, array + 3, array, bind1st(ptr_fun(test_func1), -1)); |
| CPPUNIT_ASSERT(array[0] == 1); |
| CPPUNIT_ASSERT(array[1] == 2); |
| CPPUNIT_ASSERT(array[2] == 3); |
| |
| transform(array, array + 3, array, bind2nd(ptr_fun(test_func2), 10)); |
| CPPUNIT_ASSERT(array[0] == 21); |
| CPPUNIT_ASSERT(array[1] == 22); |
| CPPUNIT_ASSERT(array[2] == 23); |
| #endif |
| } |
| |
| class A |
| { |
| public: |
| A() : m_n( 0 ) |
| {} |
| |
| void f( int n ) const { |
| #if defined (STLPORT) |
| _STLP_MUTABLE(A, m_n) = n; |
| #else |
| m_n = n; |
| #endif |
| } |
| |
| int v() const |
| { return m_n; } |
| |
| private: |
| mutable int m_n; |
| }; |
| |
| void BindTest::bind_memfn() |
| { |
| #if defined (STLPORT) && \ |
| !defined (_STLP_NO_EXTENSIONS) && defined (_STLP_CLASS_PARTIAL_SPECIALIZATION) |
| A array[3]; |
| |
| for_each( array, array + 3, bind2nd( mem_fun_ref(&A::f), 12 ) ); |
| |
| CPPUNIT_CHECK( array[0].v() == 12 ); |
| #endif |
| } |