forked from OSchip/llvm-project
[refactor][extract] code extracted from inline method should be placed
in a function defined before the outer class llvm-svn: 317062
This commit is contained in:
parent
df00e89cdc
commit
61f2c3f58c
|
@ -15,6 +15,7 @@
|
|||
|
||||
#include "clang/Tooling/Refactoring/Extract/Extract.h"
|
||||
#include "clang/AST/ASTContext.h"
|
||||
#include "clang/AST/DeclCXX.h"
|
||||
#include "clang/AST/Expr.h"
|
||||
#include "clang/AST/ExprObjC.h"
|
||||
#include "clang/Rewrite/Core/Rewriter.h"
|
||||
|
@ -44,8 +45,12 @@ bool isSimpleExpression(const Expr *E) {
|
|||
}
|
||||
|
||||
SourceLocation computeFunctionExtractionLocation(const Decl *D) {
|
||||
// FIXME (Alex L): Method -> function extraction should place function before
|
||||
// C++ record if the method is defined inside the record.
|
||||
if (isa<CXXMethodDecl>(D)) {
|
||||
// Code from method that is defined in class body should be extracted to a
|
||||
// function defined just before the class.
|
||||
while (const auto *RD = dyn_cast<CXXRecordDecl>(D->getLexicalDeclContext()))
|
||||
D = RD;
|
||||
}
|
||||
return D->getLocStart();
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,42 @@
|
|||
// RUN: clang-refactor extract -selection=test:%s %s -- -std=c++11 2>&1 | grep -v CHECK | FileCheck --check-prefixes=CHECK,CHECK-INNER %s
|
||||
// RUN: clang-refactor extract -selection=test:%s %s -- -std=c++11 -DMULTIPLE 2>&1 | grep -v CHECK | FileCheck --check-prefixes=CHECK,CHECK-OUTER %s
|
||||
|
||||
#ifdef MULTIPLE
|
||||
class OuterClass {
|
||||
#define PREFIX OuterClass ::
|
||||
#else
|
||||
#define PREFIX
|
||||
#endif
|
||||
|
||||
class AClass {
|
||||
|
||||
int method(int x) {
|
||||
return /*range inner=->+0:38*/1 + 2 * 2;
|
||||
}
|
||||
// CHECK-INNER: 1 'inner' results:
|
||||
// CHECK-INNER: static int extracted() {
|
||||
// CHECK-INNER-NEXT: return 1 + 2 * 2;{{$}}
|
||||
// CHECK-INNER-NEXT: }{{[[:space:]].*}}
|
||||
// CHECK-INNER-NEXT: class AClass {
|
||||
|
||||
// CHECK-OUTER: 1 'inner' results:
|
||||
// CHECK-OUTER: static int extracted() {
|
||||
// CHECK-OUTER-NEXT: return 1 + 2 * 2;{{$}}
|
||||
// CHECK-OUTER-NEXT: }{{[[:space:]].*}}
|
||||
// CHECK-OUTER-NEXT: class OuterClass {
|
||||
|
||||
int otherMethod(int x);
|
||||
};
|
||||
|
||||
#ifdef MULTIPLE
|
||||
};
|
||||
#endif
|
||||
|
||||
int PREFIX AClass::otherMethod(int x) {
|
||||
return /*range outofline=->+0:46*/2 * 2 - 1;
|
||||
}
|
||||
// CHECK: 1 'outofline' results:
|
||||
// CHECK: static int extracted() {
|
||||
// CHECK-NEXT: return 2 * 2 - 1;{{$}}
|
||||
// CHECK-NEXT: }{{[[:space:]].*}}
|
||||
// CHECK-NEXT: int PREFIX AClass::otherMethod
|
Loading…
Reference in New Issue