Skip to content

Commit

Permalink
[ObjC++] Don't warn about pessimizing move for __block variables
Browse files Browse the repository at this point in the history
rdar://33316951


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@317620 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
hyp committed Nov 7, 2017
1 parent 94ae19d commit 16669a7
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 0 deletions.
4 changes: 4 additions & 0 deletions lib/Sema/SemaInit.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down
43 changes: 43 additions & 0 deletions test/SemaObjCXX/block-variable-move.mm
Original file line number Diff line number Diff line change
@@ -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
}

0 comments on commit 16669a7

Please sign in to comment.