llvm-project/clang/test/SemaCXX/attribute-pack-expansion.cpp
Sirraide 4b5e0a1d12
[Clang] [Sema] Diagnose unexpanded parameter packs in attributes (#93482)
Call `DiagnoseUnexpandedParameterPack` when we parse an expression
argument to an attribute and check for implicit code in the
`CollectUnexpandedParameterPacksVisitor` so we can actually find
unexpanded packs in attributes that end up applied to lambda call
operators.

This fixes #93269.
2024-05-27 18:17:07 +02:00

21 lines
1.3 KiB
C++

// RUN: %clang_cc1 -std=c++20 -fsyntax-only -verify %s
template <bool... vals>
void f() __attribute((diagnose_if(vals, "message", "error"))) { // expected-error {{expression contains unexpanded parameter pack 'vals'}}
[] () __attribute((diagnose_if(vals, "message", "error"))) {}(); // expected-error {{expression contains unexpanded parameter pack 'vals'}}
[] () __attribute((diagnose_if(vals..., "message", "error"))) {}(); // expected-error {{attribute 'diagnose_if' does not support argument pack expansion}}
[] <bool ...inner> () __attribute((diagnose_if(inner, "message", "error"))) {}(); // expected-error {{expression contains unexpanded parameter pack 'inner'}}
([] <bool ...inner> () __attribute((diagnose_if(inner, "message", "error"))) {}(), ...); // expected-error {{expression contains unexpanded parameter pack 'inner'}} \
// expected-error {{pack expansion does not contain any unexpanded parameter packs}}
// This is fine, so check that we're actually emitting an error
// due to the 'diagnose_if'.
([] () __attribute((diagnose_if(vals, "foobar", "error"))) {}(), ...); // expected-error {{foobar}} expected-note {{from 'diagnose_if'}}
}
void g() {
f<>();
f<false>();
f<true, true>(); // expected-note {{in instantiation of}}
}