File: extract-repeated-expr-duplicates.cpp

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (63 lines) | stat: -rw-r--r-- 2,427 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63

struct AClass {
  int method();
  int method2();
};
struct AWrapperClass {
  AClass &object(int x);
};

void duplicatesWithParens(AWrapperClass &wrapper) {
  wrapper.object(0).method();
// CHECK1: Initiated the 'extract-repeated-expr-into-var' action at [[@LINE-1]]:3
  ((wrapper).object((0))).method();
// CHECK2: Initiated the 'extract-repeated-expr-into-var' action at [[@LINE-1]]:4
}

// RUN: clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:11:3-20 %s | FileCheck --check-prefix=CHECK1 %s
// RUN: clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:13:4-25 %s | FileCheck --check-prefix=CHECK2 %s


void noDuplicatesWithParens(AWrapperClass &wrapper) {
  wrapper.object(- 1).method();
#ifndef DUPLICATE
  wrapper.object((- 1)).method();
#else
  (wrapper).object(- 1).method();
#endif
// CHECK3: Initiated the 'extract-repeated-expr-into-var' action at [[@LINE-6]]:3

  wrapper.object(1 + 2).method();
#ifndef DUPLICATE
  wrapper.object((1 + 2)).method();
#else
  ((wrapper)).object(1 + 2).method();
#endif
// CHECK4: Initiated the 'extract-repeated-expr-into-var' action at [[@LINE-6]]:3

  wrapper.object(true ? 0 : 1).method();
#ifndef DUPLICATE
  wrapper.object((true ? 0 : 1)).method();
#else
  ((wrapper)).object(true ? (0) : (1)).method();
#endif
// CHECK5: Initiated the 'extract-repeated-expr-into-var' action at [[@LINE-6]]:3
}

// RUN: clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:22:3-22 %s -DDUPLICATE | FileCheck --check-prefix=CHECK3 %s
// RUN: clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:30:3-24 %s -DDUPLICATE | FileCheck --check-prefix=CHECK4 %s
// RUN: clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:38:3-31 %s -DDUPLICATE | FileCheck --check-prefix=CHECK5 %s

// RUN: not clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:22:1-32 -in=%s:30:1-34 -in=%s:38:1-41 %s 2>&1 | FileCheck --check-prefix=CHECK-NO %s
// CHECK-NO: Failed to initiate the refactoring action!

void noDuplicatesWhenSemanticsChange(AWrapperClass &wrapper) {
  wrapper.object(0).method();
  if (true) {
    AWrapperClass wrapperBase;
    AWrapperClass &wrapper = wrapperBase;
    wrapper.object(0).method();
  }
}

// RUN: not clang-refactor-test initiate -action extract-repeated-expr-into-var -in=%s:55:1-30 in=%s:59:1-32 %s 2>&1 | FileCheck --check-prefix=CHECK-NO %s