File path: /apache-ant-1.7.0/src/org/apache/tools/ant/taskdefs/optional/jsp/JspNameMangler.java | File path: /apache-ant-1.7.0/src/org/apache/tools/ant/launch/Locator.java | |||
Method name: String mapJspToBaseName(File)
|
Method name: boolean accept(File, String)
|
|||
Number of AST nodes: 4 | Number of AST nodes: 3 | |||
1 | for (int i = 0; i < keywords.length; ++i) {↵ | 1 | for (int i = 0; i < extensions.length; ++i) {↵ | |
2 | if (className.equals(keywords[i])) {↵ | 2 | ↵ | |
3 | className += "%";↵ | |||
3 | if (name.toLowerCase().endsWith(extensions[i])) {↵ | |||
4 | return true;↵ | |||
4 | break;↵ | 5 | }↵ | |
5 | }↵ | 6 | ↵ | |
6 | } | 7 |
| |
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.3 |
Clones location | Clones are in different classes |
Number of node comparisons | 7 |
Number of mapped statements | 2 |
Number of unmapped statements in the first code fragment | 2 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 0.6 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
3 | for (int i = 0; i < keywords.length; ++i) |
| 1 | for (int i = 0; i < extensions.length; ++i) | ||||||||||||||||||
4 | if (className.equals(keywords[i])) |
| 2 | if (name.toLowerCase().endsWith(extensions[i])) | ||||||||||||||||||
|
| 3 | return true; | |||||||||||||||||||
5 | className += "%"; |
| | |||||||||||||||||||
6 | break; |
| |
Row | Violation |
---|---|
1 | Expression className.equals(keywords[i]) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Expression name.toLowerCase().endsWith(extensions[i]) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Unmatched return true; |
4 | Unmatched statement className+="%"; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
5 | Unmatched break; |