| // Copyright (C) 2005-2023 Free Software Foundation, Inc. |
| // |
| // This file is part of the GNU ISO C++ Library. This library is free |
| // software; you can redistribute it and/or modify it under the |
| // terms of the GNU General Public License as published by the |
| // Free Software Foundation; either version 3, or (at your option) |
| // any later version. |
| |
| // This library is distributed in the hope that it will be useful, |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| // GNU General Public License for more details. |
| |
| // You should have received a copy of the GNU General Public License along |
| // with this library; see the file COPYING3. If not see |
| // <http://www.gnu.org/licenses/>. |
| |
| // 25.3.5.2 [lib.set.union] |
| |
| #include <algorithm> |
| #include <testsuite_hooks.h> |
| #include <testsuite_iterators.h> |
| |
| using __gnu_test::test_container; |
| using __gnu_test::input_iterator_wrapper; |
| using __gnu_test::output_iterator_wrapper; |
| using std::set_union; |
| |
| typedef test_container<int, input_iterator_wrapper> Icontainer; |
| typedef test_container<int, output_iterator_wrapper> Ocontainer; |
| |
| void |
| test1() |
| { |
| int array1[1], array2[1]; |
| Icontainer con1(array1, array1); |
| Icontainer con2(array1, array1); |
| Ocontainer con3(array2, array2); |
| VERIFY(set_union(con1.begin(), con1.end(), con2.begin(), con2.end(), |
| con3.begin()).ptr == array2); |
| } |
| |
| void |
| test2() |
| { |
| int array1[] = {1}; |
| int array2[] = {0}; |
| Icontainer con1(array1, array1); |
| Icontainer con2(array1, array1 + 1); |
| Ocontainer con3(array2, array2 + 1); |
| VERIFY(set_union(con1.begin(), con1.end(), con2.begin(), con2.end(), |
| con3.begin()).ptr == array2 + 1); |
| VERIFY(array2[0] == 1); |
| } |
| |
| void |
| test3() |
| { |
| int array1[] = {1}; |
| int array2[] = {0}; |
| Icontainer con1(array1, array1 + 1); |
| Icontainer con2(array1, array1); |
| Ocontainer con3(array2, array2 + 1); |
| VERIFY(set_union(con1.begin(), con1.end(), con2.begin(), con2.end(), |
| con3.begin()).ptr == array2 + 1); |
| VERIFY(array2[0] == 1); |
| } |
| |
| void |
| test4() |
| { |
| int array1[]={0,1,1,2,4}; |
| int array2[]={1,2,3}; |
| int array3[6]; |
| Icontainer con1(array1, array1 + 5); |
| Icontainer con2(array2, array2 + 3); |
| Ocontainer con3(array3, array3 + 6); |
| VERIFY(set_union(con1.begin(), con1.end(), con2.begin(), con2.end(), |
| con3.begin()).ptr == array3 + 6); |
| VERIFY(array3[0] == 0 && array3[1] == 1 && array3[2] == 1 && |
| array3[3] == 2 && array3[4] == 3 && array3[5] == 4); |
| } |
| |
| struct S |
| { |
| int i; |
| int j; |
| S() {} |
| S(int in) |
| { |
| if(in > 0) |
| { |
| i = in; |
| j = 1; |
| } |
| else |
| { |
| i = -in; |
| j = 0; |
| } |
| } |
| }; |
| |
| bool |
| operator<(const S& s1, const S& s2) |
| { return s1.i < s2.i; } |
| |
| typedef test_container<S, input_iterator_wrapper> SIcontainer; |
| typedef test_container<S, output_iterator_wrapper> SOcontainer; |
| |
| void |
| test5() |
| { |
| S array1[] = { -1, -1, -1, -2, -2, -4}; |
| S array2[] = { 1, 1, 1, 1, 2, 3, 4, 4}; |
| S array3[9]; |
| SIcontainer con1(array1, array1 + 6); |
| SIcontainer con2(array2, array2 + 8); |
| SOcontainer con3(array3, array3 + 9); |
| VERIFY(set_union(con1.begin(), con1.end(), con2.begin(), con2.end(), |
| con3.begin()).ptr == array3 + 9); |
| VERIFY(array3[0].j == 0 && array3[1].j == 0 && array3[2].j == 0 && |
| array3[3].j == 1 && array3[4].j == 0 && array3[5].j == 0 && |
| array3[6].j == 1 && array3[7].j == 0 && array3[8].j == 1); |
| } |
| |
| int |
| main() |
| { |
| test1(); |
| test2(); |
| test3(); |
| test4(); |
| test5(); |
| } |
| |