forked from OSchip/llvm-project
3204b152b5
If the type isn't trivially moveable emplace can skip a potentially expensive move. It also saves a couple of characters. Call sites were found with the ASTMatcher + some semi-automated cleanup. memberCallExpr( argumentCountIs(1), callee(methodDecl(hasName("push_back"))), on(hasType(recordDecl(has(namedDecl(hasName("emplace_back")))))), hasArgument(0, bindTemporaryExpr( hasType(recordDecl(hasNonTrivialDestructor())), has(constructExpr()))), unless(isInTemplateInstantiation())) No functional change intended. llvm-svn: 238601 |
||
---|---|---|
.. | ||
ARCMT.cpp | ||
ARCMTActions.cpp | ||
CMakeLists.txt | ||
FileRemapper.cpp | ||
Internals.h | ||
Makefile | ||
ObjCMT.cpp | ||
PlistReporter.cpp | ||
TransAPIUses.cpp | ||
TransARCAssign.cpp | ||
TransAutoreleasePool.cpp | ||
TransBlockObjCVariable.cpp | ||
TransEmptyStatementsAndDealloc.cpp | ||
TransGCAttrs.cpp | ||
TransGCCalls.cpp | ||
TransProperties.cpp | ||
TransProtectedScope.cpp | ||
TransRetainReleaseDealloc.cpp | ||
TransUnbridgedCasts.cpp | ||
TransUnusedInitDelegate.cpp | ||
TransZeroOutPropsInDealloc.cpp | ||
TransformActions.cpp | ||
Transforms.cpp | ||
Transforms.h |