llvm-project/clang/test/Parser/cxx2c-binding-pack.cpp
foxfromabyss 32cb4b2c6d
[Clang][Diagnostics] Use "structured binding" instead of "decomposition" (#163101)
[P0615R0](https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/p0615r0.html)
changed the term "decomposition" to "structured binding". Some
diagnostic messages were created before this paper. These messages
should be updated using "structured binding" to avoid making users
confused.

Closes #157880

---------

Co-authored-by: foxfromabyss <foxfromabyss@foxfromabyss.com>
Co-authored-by: Sirraide <aeternalmail@gmail.com>
2025-10-16 18:28:38 +02:00

26 lines
1.2 KiB
C++

// RUN: %clang_cc1 -std=c++2c -verify -fsyntax-only %s
template <unsigned N>
void decompose_array() {
int arr[4] = {1, 2, 3, 5};
auto [x, ... // #1
rest, ...more_rest] = arr; // expected-error{{multiple packs in structured binding declaration}}
// expected-note@#1{{previous binding pack specified here}}
auto [y...] = arr; // expected-error{{'...' must immediately precede declared identifier}}
auto [...] = arr; // #2
// expected-error@#2{{expected identifier}}
// expected-error@#2{{{no names were provided}}}
// expected-warning@#2{{{does not allow a structured binding group to be empty}}}
auto [a, ..., b] = arr; // #3
// expected-error@#3{{expected identifier}}
// expected-error@#3{{{only 1 name was provided}}}
auto [a1, ...] = arr; // #4
// expected-error@#4{{expected identifier}}
// expected-error@#4{{{only 1 name was provided}}}
auto [..., b] = arr; // #5
// expected-error@#5{{expected identifier}}
// expected-error@#5{{{no names were provided}}}
}