1// Copyright (C) 2013-2015 Free Software Foundation, Inc. 2// 3// This file is part of the GNU ISO C++ Library. This library is free 4// software; you can redistribute it and/or modify it under the 5// terms of the GNU General Public License as published by the 6// Free Software Foundation; either version 3, or (at your option) 7// any later version. 8 9// This library is distributed in the hope that it will be useful, 10// but WITHOUT ANY WARRANTY; without even the implied warranty of 11// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12// GNU General Public License for more details. 13 14// You should have received a copy of the GNU General Public License along 15// with this library; see the file COPYING3. If not see 16// <http://www.gnu.org/licenses/>. 17 18// { dg-options "-std=gnu++11" } 19 20#include <algorithm> 21#include <functional> 22#include <testsuite_hooks.h> 23#include <testsuite_iterators.h> 24#include <testsuite_rvalref.h> 25 26using __gnu_test::test_container; 27using __gnu_test::random_access_iterator_wrapper; 28using __gnu_test::rvalstruct; 29 30typedef test_container<rvalstruct, random_access_iterator_wrapper> container; 31 32void test01() 33{ 34 { 35 rvalstruct makeheap[1]; 36 container makecon(makeheap, makeheap + 1); 37 38 std::push_heap(makecon.begin(), makecon.end()); 39 std::pop_heap(makecon.begin(), makecon.end()); 40 } 41 42 { 43 rvalstruct makeheap[1]; 44 container makecon(makeheap, makeheap + 1); 45 46 std::push_heap(makecon.begin(), makecon.end(), std::less<rvalstruct>()); 47 std::pop_heap(makecon.begin(), makecon.end(), std::less<rvalstruct>()); 48 } 49} 50 51int main() 52{ 53 test01(); 54 return 0; 55} 56