match.pd: Fix indefinite recursion during exp-log transformations [PR118490]
[gcc.git] / libstdc++-v3 / testsuite / 25_algorithms / min / 4.cc
blob27f2cfae0fbef9b0653d30e466ff74cb10ff47fc
1 // { dg-do run { target c++11 } }
3 // Copyright (C) 2008-2025 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
9 // any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING3. If not see
18 // <http://www.gnu.org/licenses/>.
20 #include <algorithm>
21 #include <functional>
22 #include <testsuite_hooks.h>
24 void test01()
26 const int& z = std::min({1, 2, 3, 4, 5, 6, 7});
27 const double& w = std::min({2.0, 1.0, 3.2, 4.5, 5.0, 6.0, 7.0});
28 const int& y = std::min({2, 3, 1, 4, 5, 6, 7});
29 const float& x = std::min({2.0f, 3.0f, 5.0f, 1.0f, 7.0f, 6.0f});
30 VERIFY( z == 1 );
31 VERIFY( w == 1.0 );
32 VERIFY( y == 1 );
33 VERIFY( x == 1.0f );
36 const int& zc = std::min({1, 2, 3, 4, 5, 6, 7}, std::greater<int>());
37 const double& wc = std::min({2.0, 1.0, 3.2, 4.5, 5.0, 6.0, 7.0},
38 std::greater<double>());
39 const int& yc = std::min({2, 7, 1, 4, 5, 6, 3}, std::greater<int>());
40 const float& xc = std::min({2.0f, 3.0f, 5.0f, 1.0f, 7.0f, 6.0f},
41 std::greater<float>());
43 VERIFY( zc == 7 );
44 VERIFY( wc == 7.0 );
45 VERIFY( yc == 7 );
46 VERIFY( xc == 7.0f );
49 int main()
51 test01();
52 return 0;