//===----------------------------------------------------------------------===// // // 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++98, c++03, c++11, c++14 // UNSUPPORTED: libcpp-no-deduction-guides // XFAIL: clang-6, apple-clang-9.0, apple-clang-9.1, apple-clang-10.0.0 // clang-6 gives different error messages. // template>, // class Allocator = allocator>> // map(InputIterator, InputIterator, // Compare = Compare(), Allocator = Allocator()) // -> map, Compare, Allocator>; // template, class Allocator = allocator> // map(initializer_list, Compare = Compare(), Allocator = Allocator()) // -> map; // template // map(InputIterator, InputIterator, Allocator) // -> map, less>, Allocator>; // template // map(initializer_list, Allocator) // -> map, Allocator>; #include // INT_MAX #include #include #include struct NotAnAllocator { friend bool operator<(NotAnAllocator, NotAnAllocator) { return false; } }; using P = std::pair; using PC = std::pair; int main(int, char**) { { // cannot deduce Key and T from nothing std::map m; // expected-error{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce Key and T from just (Compare) std::map m(std::less{}); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce Key and T from just (Compare, Allocator) std::map m(std::less{}, std::allocator{}); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce Key and T from just (Allocator) std::map m(std::allocator{}); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // refuse to rebind the allocator if Allocator::value_type is not exactly what we expect const P arr[] = { {1,1L}, {2,2L}, {3,3L} }; std::map m(arr, arr + 3, std::allocator

()); // expected-error-re@map:* {{static_assert failed{{( due to requirement '.*')?}} "Allocator::value_type must be same type as value_type"}} } { // cannot convert from some arbitrary unrelated type NotAnAllocator a; std::map m(a); // expected-error{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce that the inner braced things should be std::pair and not something else std::map m{ {1,1L}, {2,2L}, {3,3L} }; // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce that the inner braced things should be std::pair and not something else std::map m({ {1,1L}, {2,2L}, {3,3L} }, std::less()); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce that the inner braced things should be std::pair and not something else std::map m({ {1,1L}, {2,2L}, {3,3L} }, std::less(), std::allocator()); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // cannot deduce that the inner braced things should be std::pair and not something else std::map m({ {1,1L}, {2,2L}, {3,3L} }, std::allocator()); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // since we have parens, not braces, this deliberately does not find the initializer_list constructor std::map m(P{1,1L}); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } { // since we have parens, not braces, this deliberately does not find the initializer_list constructor std::map m(PC{1,1L}); // expected-error@-1{{no viable constructor or deduction guide for deduction of template arguments of 'map'}} } return 0; }