1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- //===----------------------------------------------------------------------===//
- //
- // The LLVM Compiler Infrastructure
- //
- // This file is distributed under the University of Illinois Open Source
- // License. See LICENSE.TXT for details.
- //
- //===----------------------------------------------------------------------===//
- // <algorithm>
- // template<class T, StrictWeakOrder<auto, T> Compare>
- // requires !SameType<T, Compare> && CopyConstructible<Compare>
- // pair<const T&, const T&>
- // minmax(const T& a, const T& b, Compare comp);
- #include <algorithm>
- #include <functional>
- #include <cassert>
- template <class T, class C>
- void
- test(const T& a, const T& b, C c, const T& x, const T& y)
- {
- std::pair<const T&, const T&> p = std::minmax(a, b, c);
- assert(&p.first == &x);
- assert(&p.second == &y);
- }
- int main()
- {
- {
- int x = 0;
- int y = 0;
- test(x, y, std::greater<int>(), x, y);
- test(y, x, std::greater<int>(), y, x);
- }
- {
- int x = 0;
- int y = 1;
- test(x, y, std::greater<int>(), y, x);
- test(y, x, std::greater<int>(), y, x);
- }
- {
- int x = 1;
- int y = 0;
- test(x, y, std::greater<int>(), x, y);
- test(y, x, std::greater<int>(), x, y);
- }
- }
|