blob: d781c574b685650bc91b89af5ba195228ddbd082 [file] [log] [blame]
// { dg-options "-std=gnu++1y" }
// Copyright (C) 2013-2014 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.2.12 [alg.is_permutation] Is permutation
#include <algorithm>
#include <functional>
#include <testsuite_hooks.h>
struct my_equal_to
{
bool
operator()(int __x, int __y) const
{ return __x % 10 == __y % 10; }
};
const int arr0[] = { 11, 22, 33, 44, 55 };
void
do_test(int arr1[5], bool np = true, unsigned N = 5)
{
bool test __attribute__((unused)) = true;
do
VERIFY( std::is_permutation(arr1, arr1 + 5, arr0, arr0 + N) == np );
while (std::next_permutation(arr1, arr1 + 5));
}
template<typename Predicate>
void
do_test(int arr1[5], Predicate pred, bool np = true, unsigned N = 5)
{
bool test __attribute__((unused)) = true;
do
VERIFY( std::is_permutation(arr1, arr1 + 5, arr0, arr0 + N, pred) == np );
while (std::next_permutation(arr1, arr1 + 5));
}
void test01()
{
int arr1[] = { 11, 22, 33, 44, 55 };
do_test(arr1);
do_test(arr1, false, 4);
int arr2[] = { 11, 33, 33, 44, 55 };
do_test(arr2, false);
int arr3[] = { 33, 33, 33, 44, 44 };
do_test(arr3, false);
int arr4[] = { 11, 22, 33, 44, 55 };
do_test(arr4, std::equal_to<int>());
do_test(arr4, std::equal_to<int>(), false, 4);
int arr5[] = { 11, 33, 33, 44, 55 };
do_test(arr5, std::equal_to<int>(), false);
int arr6[] = { 33, 33, 33, 44, 44 };
do_test(arr6, std::equal_to<int>(), false);
int arr7[] = { 1, 2, 3, 4, 5 };
do_test(arr7, my_equal_to());
do_test(arr7, my_equal_to(), false, 4);
int arr8[] = { 1, 3, 3, 4, 5 };
do_test(arr8, my_equal_to(), false);
int arr9[] = { 3, 3, 3, 4, 4 };
do_test(arr9, my_equal_to(), false);
int arr10[] = { 111, 222, 333, 444, 555 };
do_test(arr10, my_equal_to());
do_test(arr10, my_equal_to(), false, 4);
int arr11[] = { 1, 222, 33, 4, 55 };
do_test(arr11, my_equal_to());
int arr12[] = { 111, 333, 333, 444, 555 };
do_test(arr12, my_equal_to(), false);
int arr13[] = { 333, 333, 333, 444, 444 };
do_test(arr13, my_equal_to(), false);
}
bool thrower(int, int) { throw 1; }
void test02()
{
int arr[] = { 11, 22, 33 };
using namespace std;
is_permutation(begin(arr0), end(arr0), begin(arr), end(arr), thrower);
}
int main()
{
test01();
test02();
}