blob: 789ce1e34d7832b9889f18612b3e008012f53fe4 [file] [log] [blame]
//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// REQUIRES: has-unix-headers
// UNSUPPORTED: c++03, c++11, c++14, c++17, libcpp-has-no-incomplete-ranges
// XFAIL: use_system_cxx_lib && target={{.+}}-apple-macosx{{10.9|10.10|10.11|10.12|10.13|10.14|10.15|11.0|12.0}}
// ADDITIONAL_COMPILE_FLAGS: -D_LIBCPP_ENABLE_ASSERTIONS=1
// <algorithm>
// In a call to `ranges::clamp(val, low, high)`, `low` must be `<= high`.
#include <algorithm>
#include <functional>
#include "check_assertion.h"
int main(int, char**) {
std::ranges::clamp(1, 2, 0, std::ranges::greater{});
TEST_LIBCPP_ASSERT_FAILURE(std::ranges::clamp(1, 2, 0), "Bad bounds passed to std::ranges::clamp");
std::ranges::clamp(1, 0, 2);
TEST_LIBCPP_ASSERT_FAILURE(std::ranges::clamp(1, 0, 2, std::ranges::greater{}),
"Bad bounds passed to std::ranges::clamp");
std::ranges::clamp(1, 1, 1); // Equal bounds should be fine.
return 0;
}