match.pd: Fix indefinite recursion during exp-log transformations [PR118490]
[gcc.git] / libstdc++-v3 / testsuite / 25_algorithms / minmax_element / constexpr.cc
blob09fa3bf4b8eb7e4d9197923610c99e73ae61e54e
1 // { dg-do compile { target c++14 } }
3 // Copyright (C) 2014-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 <utility>
24 constexpr std::initializer_list<int> test{2, 1};
25 constexpr auto x = std::minmax_element(test.begin(), test.end());
26 constexpr auto y = std::minmax_element(test.begin(), test.end(),
27 std::greater<int>());
28 static_assert(x.first == test.begin()+1, "");
29 static_assert(x.second == test.begin(), "");
30 static_assert(y.first == test.begin(), "");
31 static_assert(y.second == test.begin()+1, "");