diff options
Diffstat (limited to 'test/unit/bind_test.cpp')
-rw-r--r-- | test/unit/bind_test.cpp | 149 |
1 files changed, 0 insertions, 149 deletions
diff --git a/test/unit/bind_test.cpp b/test/unit/bind_test.cpp deleted file mode 100644 index 8773baa..0000000 --- a/test/unit/bind_test.cpp +++ /dev/null @@ -1,149 +0,0 @@ -#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 -} |