[libcxx-commits] [libcxx] 4098e20 - [libc++] Add test for algorithm result type alias declarations

Nikolas Klauser via libcxx-commits libcxx-commits at lists.llvm.org
Thu Jul 7 14:05:10 PDT 2022


Author: Nikolas Klauser
Date: 2022-07-07T23:05:05+02:00
New Revision: 4098e2085d2916469246e14e1fa9cc96cf5c7a5e

URL: https://github.com/llvm/llvm-project/commit/4098e2085d2916469246e14e1fa9cc96cf5c7a5e
DIFF: https://github.com/llvm/llvm-project/commit/4098e2085d2916469246e14e1fa9cc96cf5c7a5e.diff

LOG: [libc++] Add test for algorithm result type alias declarations

Reviewed By: var-const, #libc

Spies: libcxx-commits, jeroen.dobbelaere

Differential Revision: https://reviews.llvm.org/D129189

Added: 
    libcxx/test/std/algorithms/ranges_result_alias_declarations.compile.pass.cpp

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/libcxx/test/std/algorithms/ranges_result_alias_declarations.compile.pass.cpp b/libcxx/test/std/algorithms/ranges_result_alias_declarations.compile.pass.cpp
new file mode 100644
index 0000000000000..5e518b3378933
--- /dev/null
+++ b/libcxx/test/std/algorithms/ranges_result_alias_declarations.compile.pass.cpp
@@ -0,0 +1,62 @@
+//===----------------------------------------------------------------------===//
+//
+// 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
+//
+//===----------------------------------------------------------------------===//
+
+// UNSUPPORTED: c++03, c++11, c++14, c++17
+// UNSUPPORTED: libcpp-has-no-incomplete-ranges
+
+// <algorithm>
+
+// ensure that all result alias declarations are defined
+
+#include <algorithm>
+#include <type_traits>
+
+using namespace std::ranges;
+
+static_assert(std::is_same_v<in_fun_result<int, long>, for_each_result<int, long>>);
+static_assert(std::is_same_v<in_fun_result<int, long>, for_each_n_result<int, long>>);
+
+static_assert(std::is_same_v<in_in_result<int, long>, mismatch_result<int, long>>);
+static_assert(std::is_same_v<in_in_result<int, long>, swap_ranges_result<int, long>>);
+
+static_assert(std::is_same_v<in_out_result<int, long>, copy_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, copy_n_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, copy_if_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, copy_backward_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, move_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, move_backward_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, partial_sort_copy_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, remove_copy_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, remove_copy_if_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, replace_copy_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, replace_copy_if_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, reverse_copy_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, rotate_copy_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, set_
diff erence_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, unary_transform_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, uninitialized_copy_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, uninitialized_copy_n_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, uninitialized_move_result<int, long>>);
+static_assert(std::is_same_v<in_out_result<int, long>, uninitialized_move_n_result<int, long>>);
+// static_assert(std::is_same_v<in_out_result<int, long>, unique_copy_result<int, long>>);
+
+static_assert(std::is_same_v<in_in_out_result<int, long, char>, binary_transform_result<int, long, char>>);
+static_assert(std::is_same_v<in_in_out_result<int, long, char>, merge_result<int, long, char>>);
+// static_assert(std::is_same_v<in_in_out_result<int, long, char>, set_symmetric_
diff erence_result<int, long, char>>);
+// static_assert(std::is_same_v<in_in_out_result<int, long, char>, set_union_result<int, long, char>>);
+// static_assert(std::is_same_v<in_in_out_result<int, long, char>, set_intersection_result<int, long, char>>);
+
+// static_assert(std::is_same_v<in_out_out_result<int, long, char>, partition_copy_result<int, long, char>>);
+
+static_assert(std::is_same_v<min_max_result<int>, minmax_result<int>>);
+static_assert(std::is_same_v<min_max_result<int>, minmax_element_result<int>>);
+
+// static_assert(std::is_same_v<in_found_result<int>, next_permutation_result<int>>);
+// static_assert(std::is_same_v<in_found_result<int>, prev_permutation_result<int>>);
+
+// static_assert(std::is_same_v<out_value_result<int>, iota_result<int>>);


        


More information about the libcxx-commits mailing list