//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // template , class Pred = equal_to, // class Alloc = allocator>> // class unordered_multimap // template // pair equal_range(const K& k); // UNSUPPORTED: c++03, c++11, c++14, c++17 #include #include "test_transparent_unordered.h" int main(int, char**) { using key_type = StoredType; { // Make sure conversions don't happen for transparent non-final hasher and key_equal using M = unord_map_type>; test_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); test_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); } { // Make sure conversions don't happen for transparent final hasher and key_equal using M = unord_map_type; test_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); test_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); } { // Make sure conversions do happen for non-transparent hasher using M = unord_map_type>; test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); } { // Make sure conversions do happen for non-transparent key_equal using M = unord_map_type>; test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); } { // Make sure conversions do happen for both non-transparent hasher and key_equal using M = unord_map_type>; test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); test_non_transparent_equal_range({{1, 2}, {1, 3}, {2, 3}}); } return 0; }