File path: /jfreechart-1.0.10/src/org/jfree/chart/plot/CategoryPlot.java | File path: /jfreechart-1.0.10/src/org/jfree/chart/plot/CategoryPlot.java | |||
Method name: void drawRangeGridlines(Graphics2D, Rectangle2D, List)
|
Method name: Range getDataRange(ValueAxis)
|
|||
Number of AST nodes: 5 | Number of AST nodes: 5 | |||
1 | while (iterator.hasNext()) {↵ | 1 | while (iterator.hasNext()) {↵ | |
2 | ValueTick tick = (ValueTick) iterator.next();↵ | 2 | CategoryDataset d = (CategoryDataset) iterator.next();↵ | |
3 | CategoryItemRenderer renderer1 = getRenderer();↵ | 3 | CategoryItemRenderer r = getRenderer↵ | |
4 | ↵ | 4 | ForDataset(d);↵ | |
5 | if (renderer1 != null) {↵ | 5 | if (r != null) {↵ | |
6 | renderer1.drawRangeGridline(g2, this,↵ | 6 | ↵ | |
7 | getRangeAxis(), dataArea, tick.getValue());↵ | |||
8 | }↵ | |||
9 | ↵ | 7 | result = Range.combine(result, r.findRangeBounds(d));↵ | |
8 | }↵ | |||
10 | } | 9 |
| |
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 declared in the same class |
Number of node comparisons | 13 |
Number of mapped statements | 3 |
Number of unmapped statements in the first code fragment | 2 |
Number of unmapped statements in the second code fragment | 2 |
Time elapsed for statement mapping (ms) | 13.7 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
8 | while (iterator.hasNext()) | 9 | while (iterator.hasNext()) | |||||||||||||||||||
9 | ValueTick tick = (ValueTick)iterator.next(); |
| | |||||||||||||||||||
|
| 10 | CategoryDataset d = (CategoryDataset)iterator.next(); | |||||||||||||||||||
10 | CategoryItemRenderer renderer1 = getRenderer(); |
| 11 | CategoryItemRenderer r = getRendererForDataset(d); | ||||||||||||||||||
11 | if (renderer1 != null) |
| 12 | if (r != null) | ||||||||||||||||||
12 | renderer1.drawRangeGridline(g2, this, getRangeAxis(), dataArea, tick.getValue()); |
| | |||||||||||||||||||
|
| 13 | result = Range.combine(result, r.findRangeBounds(d)); |
Row | Violation |
---|---|
1 | Unmatched statement ValueTick tick=(ValueTick)iterator.next(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement CategoryDataset d=(CategoryDataset)iterator.next(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Expression getRendererForDataset(d) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression getRendererForDataset(d) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Unmatched statement renderer1.drawRangeGridline(g2,this,getRangeAxis(),dataArea,tick.getValue()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement result=Range.combine(result,r.findRangeBounds(d)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
7 | Unmatched statement result=Range.combine(result,r.findRangeBounds(d)); 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 |