2 /* Copyright 2002, The libsigc++ Development Team
3 * Assigned to public domain. Use as you wish without restriction.
6 #include "testutilities.h"
7 #include <sigc++/sigc++.h>
11 //TODO: put something like #ifndef FORTE (some older version, I think) or AIX xlC... #else ... #endif around:
12 #define ENABLE_TEST_OF_OVERLOADED_FUNCTIONS 0
16 std::ostringstream result_stream;
22 result_stream << "test::foo(short " << i1 << ')';
25 void foo_const(int i1) const
27 result_stream << "test::foo_const(int " << i1 << ')';
30 void foo_volatile(float i1) volatile
32 result_stream << "test::foo_volatile(float " << i1 << ')';
35 void foo_const_volatile(double i1) const volatile
37 result_stream << "test::foo_const_volatile(double " << i1 << ')';
40 void foo_overloaded(char i1)
42 result_stream << "test::foo_overloaded(char " << int(i1) << ')';
45 #if ENABLE_TEST_OF_OVERLOADED_FUNCTIONS
46 void foo_overloaded(short i1)
48 result_stream << "test::foo_overloaded(short " << (int)i1 << ')';
52 double foo_overloaded(int i1, int i2)
54 result_stream << "test::foo_overloaded(int " << i1 << ", int " << i2 << ')';
59 } // end anonymous namespace
61 int main(int argc, char* argv[])
63 auto util = TestUtilities::get_instance();
65 if (!util->check_command_args(argc, argv))
66 return util->get_result_and_delete_instance() ? EXIT_SUCCESS : EXIT_FAILURE;
68 { /* test non-const */
70 sigc::mem_fun(&test::foo)(t, 1);
71 util->check_result(result_stream, "test::foo(short 1)");
75 sigc::mem_fun(&test::foo_const)(t, 2);
76 util->check_result(result_stream, "test::foo_const(int 2)");
78 { /* test const with const object */
79 const auto t = test();
80 sigc::mem_fun(&test::foo_const)(t, 3);
81 util->check_result(result_stream, "test::foo_const(int 3)");
83 { /* test non-const volatile */
85 sigc::mem_fun(&test::foo_volatile)(t, 4);
86 util->check_result(result_stream, "test::foo_volatile(float 4)");
88 { /* test const volatile */
90 sigc::mem_fun(&test::foo_const_volatile)(t, 5);
91 util->check_result(result_stream, "test::foo_const_volatile(double 5)");
93 { /* test const volatile with const object */
94 const auto t = test();
95 sigc::mem_fun(&test::foo_const_volatile)(t, 6);
96 util->check_result(result_stream, "test::foo_const_volatile(double 6)");
98 #if ENABLE_TEST_OF_OVERLOADED_FUNCTIONS
99 { /* test overloaded */
101 sigc::mem_fun<char>(&test::foo_overloaded)(t, 7);
102 util->check_result(result_stream, "test::foo_overloaded(char 7)");
104 sigc::mem_fun<short>(&test::foo_overloaded)(t, 7);
105 util->check_result(result_stream, "test::foo_overloaded(short 7)");
107 //sigc::mem_fun(&test::foo_overloaded)(t, 7);
108 //util->check_result(result_stream, "test::foo_overloaded(short 7)");
110 sigc::mem_fun(&test::foo_overloaded)(t, 7, 8);
111 util->check_result(result_stream, "test::foo_overloaded(int 7, int 8)");
116 sigc::mem_fun(t, &test::foo)(9);
117 util->check_result(result_stream, "test::foo(short 9)");
119 sigc::mem_fun(t, &test::foo)(9);
120 util->check_result(result_stream, "test::foo(short 9)");
122 sigc::mem_fun(t, &test::foo_const)(9);
123 util->check_result(result_stream, "test::foo_const(int 9)");
125 sigc::mem_fun(t, &test::foo_const)(9);
126 util->check_result(result_stream, "test::foo_const(int 9)");
128 sigc::mem_fun(t, &test::foo_volatile)(9);
129 util->check_result(result_stream, "test::foo_volatile(float 9)");
131 sigc::mem_fun(t, &test::foo_volatile)(9);
132 util->check_result(result_stream, "test::foo_volatile(float 9)");
134 #if ENABLE_TEST_OF_OVERLOADED_FUNCTIONS
135 sigc::mem_fun(t, &test::foo_overloaded)(9, 10);
136 util->check_result(result_stream, "test::foo_overloaded(int 9, int 10)");
138 sigc::mem_fun(t, &test::foo_overloaded)(9, 10);
139 util->check_result(result_stream, "test::foo_overloaded(int 9, int 10)");
143 return util->get_result_and_delete_instance() ? EXIT_SUCCESS : EXIT_FAILURE;