This patch improves the preservation of qualifiers and loss of type sugar in TemplateNames. This problem is analogous to https://reviews.llvm.org/D112374 and this patch takes a very similar approach to that patch, except the impact here is much lesser. When a TemplateName was written bare, without qualifications, we wouldn't produce a QualifiedTemplate which could be used to disambiguate it from a Canonical TemplateName. This had effects in the TemplateName printer, which had workarounds to deal with this, and wouldn't print the TemplateName as-written in most situations. There are also some related fixes to help preserve this type sugar along the way into diagnostics, so that this patch can be properly tested. - Fix dropping the template keyword. - Fix type deduction to preserve sugar in TST TemplateNames.
32 lines
1.1 KiB
C++
32 lines
1.1 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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
|
|
|
|
// template<class R>
|
|
// explicit join_view(R&&) -> join_view<views::all_t<R>>;
|
|
|
|
// Tests that the deduction guide is explicit.
|
|
|
|
#include <ranges>
|
|
|
|
#include "test_iterators.h"
|
|
|
|
template<class T>
|
|
struct Range {
|
|
friend T* begin(Range&) { return nullptr; }
|
|
friend T* begin(Range const&) { return nullptr; }
|
|
friend sentinel_wrapper<T*> end(Range&) { return sentinel_wrapper<T*>(nullptr); }
|
|
friend sentinel_wrapper<T*> end(Range const&) { return sentinel_wrapper<T*>(nullptr); }
|
|
};
|
|
|
|
void testExplicitCTAD() {
|
|
Range<Range<int>> r;
|
|
std::ranges::join_view v = r; // expected-error-re {{no viable constructor or deduction guide for deduction of template arguments of '{{(std::ranges::)?}}join_view'}}
|
|
}
|