llvm-project/clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp
Mital Ashok 482c41e992
[Clang] [Sema] Diagnose unknown std::initializer_list layout in SemaInit (#95580)
This checks if the layout of `std::initializer_list` is something Clang
can handle much earlier and deduplicates the checks in
CodeGen/CGExprAgg.cpp and AST/ExprConstant.cpp

Also now diagnose `union initializer_list` (Fixes #95495), bit-field for
the size (Fixes a crash that would happen during codegen if it were
unnamed), base classes (that wouldn't be initialized) and polymorphic
classes (whose vtable pointer wouldn't be initialized).
2024-06-20 19:44:06 +02:00

40 lines
1.1 KiB
C++

// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
namespace std {
template<class _Ep> class initializer_list { const _Ep *a, *b; };
}
namespace cva {
template <class VT, unsigned int ROWS = 0, unsigned int COLS = 0>
class Matrix {
public:
typedef VT value_type;
inline __attribute__((always_inline)) value_type& at();
};
template <class VT, unsigned int SIZE> using Vector = Matrix<VT, SIZE, 1>;
template <class VT>
using RGBValue = Vector<VT, 3>;
using RGBFValue = RGBValue<float>;
template <class VT> class Matrix<VT, 0, 0> { // expected-note {{passing argument to parameter here}}
public:
typedef VT value_type;
Matrix(const unsigned int nRows, const unsigned int nColumns, const value_type* data = nullptr);
Matrix(const std::initializer_list<value_type>& list) = delete; // expected-note {{'Matrix' has been explicitly marked deleted here}}
};
void getLaplacianClosedForm()
{
Matrix<double> winI(0, 3);
RGBFValue* inputPreL;
winI = { inputPreL->at() }; // expected-error {{call to deleted constructor of 'Matrix<double> &&'}}
}
}