forked from OSchip/llvm-project
A little more lambda capture initialization diagnostics cleanup
llvm-svn: 150589
This commit is contained in:
parent
19666fb1aa
commit
02267a8e48
|
@ -1141,24 +1141,24 @@ def err_temp_copy_no_viable : Error<
|
|||
"no viable constructor %select{copying variable|copying parameter|"
|
||||
"returning object|throwing object|copying member subobject|copying array "
|
||||
"element|allocating object|copying temporary|initializing base subobject|"
|
||||
"initializing vector element}0 of type %1">;
|
||||
"initializing vector element|capturing value}0 of type %1">;
|
||||
def ext_rvalue_to_reference_temp_copy_no_viable : ExtWarn<
|
||||
"no viable constructor %select{copying variable|copying parameter|"
|
||||
"returning object|throwing object|copying member subobject|copying array "
|
||||
"element|allocating object|copying temporary|initializing base subobject|"
|
||||
"initializing vector element}0 of type %1; C++98 requires a copy "
|
||||
"initializing vector element|capturing value}0 of type %1; C++98 requires a copy "
|
||||
"constructor when binding a reference to a temporary">,
|
||||
InGroup<BindToTemporaryCopy>;
|
||||
def err_temp_copy_ambiguous : Error<
|
||||
"ambiguous constructor call when %select{copying variable|copying "
|
||||
"parameter|returning object|throwing object|copying member subobject|copying "
|
||||
"array element|allocating object|copying temporary|initializing base subobject|"
|
||||
"initializing vector element}0 of type %1">;
|
||||
"initializing vector element|capturing value}0 of type %1">;
|
||||
def err_temp_copy_deleted : Error<
|
||||
"%select{copying variable|copying parameter|returning object|throwing "
|
||||
"object|copying member subobject|copying array element|allocating object|"
|
||||
"copying temporary|initializing base subobject|initializing vector element}0 "
|
||||
"of type %1 invokes deleted constructor">;
|
||||
"of type %1 invokes deleted constructor|capturing value">;
|
||||
def err_temp_copy_incomplete : Error<
|
||||
"copying a temporary object of incomplete type %0">;
|
||||
def warn_cxx98_compat_temp_copy : Warning<
|
||||
|
|
|
@ -8,11 +8,18 @@ public:
|
|||
void foo() const;
|
||||
};
|
||||
|
||||
void capture_by_copy(NonCopyable nc, NonCopyable &ncr) {
|
||||
class NonConstCopy {
|
||||
public:
|
||||
NonConstCopy(NonConstCopy&); // expected-note{{would lose const}}
|
||||
};
|
||||
|
||||
void capture_by_copy(NonCopyable nc, NonCopyable &ncr, const NonConstCopy nco) {
|
||||
(void)[nc] { }; // expected-error{{capture of variable 'nc' as type 'NonCopyable' calls private copy constructor}}
|
||||
(void)[=] {
|
||||
ncr.foo(); // expected-error{{capture of variable 'ncr' as type 'NonCopyable' calls private copy constructor}}
|
||||
}();
|
||||
|
||||
[nco] {}(); // expected-error{{no matching constructor for initialization of 'const NonConstCopy'}}
|
||||
}
|
||||
|
||||
struct NonTrivial {
|
||||
|
|
Loading…
Reference in New Issue