diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2015-04-14 17:21:58 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2015-04-14 17:21:58 +0000 |
| commit | dcf06f42324a38d43f40147028d9d4273a2d6ef2 (patch) | |
| tree | 95fa846f893d6005b86264a81d29dce7a59adbb6 /clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp | |
| parent | 5f7095ee4f8d1fdf1da9e7c9984c998b2b5cfa8b (diff) | |
| download | bcm5719-llvm-dcf06f42324a38d43f40147028d9d4273a2d6ef2.tar.gz bcm5719-llvm-dcf06f42324a38d43f40147028d9d4273a2d6ef2.zip | |
[SemaCXX patch] Patch to fix a crash when a 'delete' constructor
is being accessed. Reviewed by Richard Smith.
rdar://20281011
llvm-svn: 234912
Diffstat (limited to 'clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp')
| -rw-r--r-- | clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp b/clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp new file mode 100644 index 00000000000..dd043452816 --- /dev/null +++ b/clang/test/SemaCXX/cxx11-call-to-deleted-constructor.cpp @@ -0,0 +1,40 @@ +// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s +// rdar://20281011 + +namespace std { +template<class _Ep> class initializer_list { }; +} + +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 'cva::Matrix<double, 0, 0> &&'}} +} + +} |

