llvm-project/clang/test/Parser/cxx2c-pack-indexing.cpp
Aaron Ballman 9eef4d1c5f
Remove delayed typo expressions (#143423)
This removes the delayed typo correction functionality from Clang
(regular typo correction still remains) due to fragility of the
solution.

An RFC was posted here:
https://discourse.llvm.org/t/rfc-removing-support-for-delayed-typo-correction/86631
and while that RFC was asking for folks to consider stepping up to be
maintainers, and we did have a few new contributors show some interest,
experiments show that it's likely worth it to remove this functionality
entirely and focus efforts on improving regular typo correction.

This removal fixes ~20 open issues (quite possibly more), improves
compile time performance by roughly .3-.4%
(https://llvm-compile-time-tracker.com/?config=Overview&stat=instructions%3Au&remote=AaronBallman&sortBy=date),
and does not appear to regress diagnostic behavior in a way we wouldn't
find acceptable.

Fixes #142457
Fixes #139913
Fixes #138850
Fixes #137867
Fixes #137860
Fixes #107840
Fixes #93308
Fixes #69470
Fixes #59391
Fixes #58172
Fixes #46215
Fixes #45915
Fixes #45891
Fixes #44490
Fixes #36703
Fixes #32903
Fixes #23312
Fixes #69874
2025-06-13 06:45:40 -04:00

86 lines
2.4 KiB
C++

// RUN: %clang_cc1 -std=c++2c -verify -fsyntax-only %s
template<typename... T>
struct S {
T...1; // expected-error{{expected member name or ';' after declaration specifiers}}
T...[; // expected-error{{expected expression}} \
// expected-error{{expected ']'}} \
// expected-note {{to match this '['}} \
// expected-warning{{declaration does not declare anything}}
T...[1; // expected-error{{expected ']'}} \
// expected-note {{to match this '['}} \
// expected-warning{{declaration does not declare anything}}
T...[]; // expected-error{{expected member name or ';' after declaration specifiers}}
void f(auto... v) {
decltype(v...[1]) a = v...[1];
decltype(v...[1]) b = v...[]; // expected-error{{expected expression}}
decltype(v...[1]) c = v...[ ; // expected-error{{expected expression}}\
// expected-error{{expected ']'}} \
// expected-note {{to match this '['}}
}
};
template <typename...>
struct typelist{};
template <typename... T>
requires requires(T...[0]) { {T...[0](0)}; }
struct SS : T...[1] {
[[maybe_unused]] T...[1] base = {};
using foo = T...[1];
SS()
: T...[1]()
{}
typelist<T...[0]> a;
const T...[0] f(T...[0] && p) noexcept((T...[0])0) {
T...[0] (*test)(const volatile T...[0]**);
thread_local T...[0] d;
[[maybe_unused]] T...[0] a = p;
auto ptr = new T...[0](0);
(*ptr).~T...[0]();
return T...[0](0);
typename T...[1]::foo b = 0;
T...[1]::i = 0;
return (T...[0])(a);
new T...[0];
[[maybe_unused]] auto l = []<T...[0]>(T...[0][1]) -> T...[0]{return{};};
[[maybe_unused]] auto _ = l.template operator()<T...[0]{}>({0});
}
operator T...[0]() const{}
};
struct base {
using foo = int;
static inline int i = 42;
};
int main() {
SS<int, base>().f(0);
}
namespace GH111460 {
template <typename... T>
requires( ); // expected-error {{expected expression}}
struct SS {
void f( ) {
(*p).~T...[](); // expected-error {{use of undeclared identifier 'p'}} \
expected-error {{undeclared identifier 'T' in destructor name}}
}
};
}
namespace GH119072 {
template<typename... Ts>
void foo() {
decltype(Ts...[0]::t) value;
}
}