From 461a67fa15370a9ec88f8f8a240bf7c123bb2029 Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Mon, 18 Dec 2017 20:11:37 +0000 Subject: Vendor import of clang trunk r321017: https://llvm.org/svn/llvm-project/cfe/trunk@321017 --- test/Refactor/Extract/FromMethodToFunction.cpp | 42 ++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 test/Refactor/Extract/FromMethodToFunction.cpp (limited to 'test/Refactor/Extract/FromMethodToFunction.cpp') diff --git a/test/Refactor/Extract/FromMethodToFunction.cpp b/test/Refactor/Extract/FromMethodToFunction.cpp new file mode 100644 index 000000000000..86bec16edfd1 --- /dev/null +++ b/test/Refactor/Extract/FromMethodToFunction.cpp @@ -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 -- cgit v1.2.3