File path: /columba-1.4-src/core/src/main/java/org/columba/core/command/Worker.java | File path: /columba-1.4-src/contact/src/main/java/org/columba/addressbook/main/AddressbookExitWorker.java | |||
Method name: void finished()
|
Method name: void saveAddressbookFolder(AbstractFolder)
|
|||
Number of AST nodes: 4 | Number of AST nodes: 3 | |||
1 | if (child instanceof AddressbookFolder) {↵ | |||
1 | try {↵ | 2 | try {↵ | |
2 | op.finish();↵ | 3 | ↵ | |
3 | ↵ | 4 | child.save();↵ | |
4 | } catch (Exception e) {↵ | 5 | } catch (Exception ex) {↵ | |
5 | // Must create a ExceptionProcessor↵ | |||
6 | e.printStackTrace();↵ | 6 | ex.printStackTrace();↵ | |
7 | }↵ | |||
8 | unregister();↵ | |||
9 | boss.operationFinished(op, this); | 7 | }↵ | |
8 |
| |||
See real code fragment | See real code fragment |
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 0 |
Number of non-refactorable cases | 1 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 0.2 |
Clones location | Clones are in different classes |
Number of node comparisons | 4 |
Number of mapped statements | 1 |
Number of unmapped statements in the first code fragment | 3 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 1.0 |
Clone type | Type 3 |
ID | Statement | ID | Statement | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | try |
| 6 | try | |||||||||||||
2 | op.finish(); |
| | ||||||||||||||
|
| 7 | child.save(); | ||||||||||||||
3 | unregister(); |
| | ||||||||||||||
4 | boss.operationFinished(op, this); |
| |
Row | Violation |
---|---|
1 | Unmatched statement op.finish(); cannot be moved before or after the extracted code, because it throws exception(s) that should be caught by a try block that will be extracted |
2 | Unmatched statement child.save(); cannot be moved before or after the extracted code, because it throws exception(s) that should be caught by a try block that will be extracted |
3 | Unmatched statement unregister(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
4 | Unmatched statement boss.operationFinished(op,this); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |