forked from OSchip/llvm-project
[ObjC++] Don't warn about pessimizing move for __block variables
rdar://33316951 llvm-svn: 317620
This commit is contained in:
parent
b9a2832874
commit
bbe51d86ec
|
@ -6422,6 +6422,10 @@ static void CheckMoveOnConstruction(Sema &S, const Expr *InitExpr,
|
|||
if (!VD || !VD->hasLocalStorage())
|
||||
return;
|
||||
|
||||
// __block variables are not moved implicitly.
|
||||
if (VD->hasAttr<BlocksAttr>())
|
||||
return;
|
||||
|
||||
QualType SourceType = VD->getType();
|
||||
if (!SourceType->isRecordType())
|
||||
return;
|
||||
|
|
|
@ -0,0 +1,43 @@
|
|||
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -fobjc-arc -verify -fblocks -Wpessimizing-move -Wredundant-move %s
|
||||
|
||||
// definitions for std::move
|
||||
namespace std {
|
||||
inline namespace foo {
|
||||
template <class T> struct remove_reference { typedef T type; };
|
||||
template <class T> struct remove_reference<T&> { typedef T type; };
|
||||
template <class T> struct remove_reference<T&&> { typedef T type; };
|
||||
|
||||
template <class T> typename remove_reference<T>::type &&move(T &&t);
|
||||
}
|
||||
}
|
||||
|
||||
class MoveOnly {
|
||||
public:
|
||||
MoveOnly() { }
|
||||
MoveOnly(MoveOnly &&) = default; // expected-note 2 {{copy constructor is implicitly deleted}}
|
||||
MoveOnly &operator=(MoveOnly &&) = default;
|
||||
~MoveOnly();
|
||||
};
|
||||
|
||||
void copyInit() {
|
||||
__block MoveOnly temp;
|
||||
MoveOnly temp2 = temp; // expected-error {{call to implicitly-deleted copy constructor of 'MoveOnly'}}
|
||||
MoveOnly temp3 = std::move(temp); // ok
|
||||
}
|
||||
|
||||
MoveOnly errorOnCopy() {
|
||||
__block MoveOnly temp;
|
||||
return temp; // expected-error {{call to implicitly-deleted copy constructor of 'MoveOnly'}}
|
||||
}
|
||||
|
||||
MoveOnly dontWarnOnMove() {
|
||||
__block MoveOnly temp;
|
||||
return std::move(temp); // ok
|
||||
}
|
||||
|
||||
class MoveOnlySub : public MoveOnly {};
|
||||
|
||||
MoveOnly dontWarnOnMoveSubclass() {
|
||||
__block MoveOnlySub temp;
|
||||
return std::move(temp); // ok
|
||||
}
|
Loading…
Reference in New Issue