if (this.rowRenderingOrder == SortOrder.ASCENDING) {
for (int row = 0; row < rowCount; row++) {
renderer.drawItem(g2, state, dataArea, this,
domainAxis, rangeAxis, currentDataset,
row, column, pass);
}
}
else {
for (int row = rowCount - 1; row >= 0; row--) {
renderer.drawItem(g2, state, dataArea, this,
domainAxis, rangeAxis, currentDataset,
row, column, pass);
}
}
if (this.rowRenderingOrder == SortOrder.ASCENDING) {
for (int row = 0; row < rowCount; row++) {
renderer.drawItem(g2, state, dataArea, this,
domainAxis, rangeAxis, currentDataset,
row, column, pass);
}
}
else {
for (int row = rowCount - 1; row >= 0; row--) {
renderer.drawItem(g2, state, dataArea, this,
domainAxis, rangeAxis, currentDataset,
row, column, pass);
}
}
Clone fragments detected by clone detection tool
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: boolean render(Graphics2D, Rectangle2D, int, PlotRenderingInfo)
|
|
Method name: boolean render(Graphics2D, Rectangle2D, int, PlotRenderingInfo)
|
Number of AST nodes: 5
|
|
Number of AST nodes: 5
|
|
1 | if (this.rowRenderingOrder == SortOrder.ASCENDING) {↵ | | 1 | if (this.rowRenderingOrder == SortOrder.ASCENDING) {↵
|
2 | for (int row = 0; row < rowCount; row++) {↵ | | 2 | for (int row = 0; row < rowCount; row++) {↵
|
3 | renderer.drawItem(g2, state, dataArea, this,↵ | | 3 | renderer.drawItem(g2, state, dataArea, this,↵
|
4 | domainAxis, rangeAxis, currentDataset,↵ | | 4 | domainAxis, rangeAxis, currentDataset,↵
|
5 | row, column, pass);↵ | | 5 | row, column, pass);↵
|
6 | }↵ | | 6 | }↵
|
7 | }↵ | | 7 | }↵
|
8 | else {↵ | | 8 | else {↵
|
9 | for (int row = rowCount - 1; row >= 0; row--) {↵ | | 9 | for (int row = rowCount - 1; row >= 0; row--) {↵
|
10 | renderer.drawItem(g2, state, dataArea, this,↵ | | 10 | renderer.drawItem(g2, state, dataArea, this,↵
|
11 | domainAxis, rangeAxis, currentDataset,↵ | | 11 | domainAxis, rangeAxis, currentDataset,↵
|
12 | row, column, pass);↵ | | 12 | row, column, pass);↵
|
13 | }↵ | | 13 | }↵
|
14 | } | | 14 | }
|
See real code fragment |
|
See real code fragment |
Summary
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 1 |
Number of non-refactorable cases | 0 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 2.1 |
Clones location | Clones are in the same method |
Number of node comparisons | 23 |
-
{Refactorable}
Mapping Summary
Number of mapped statements | 5 |
Number of unmapped statements in the first code fragment | 0 |
Number of unmapped statements in the second code fragment | 0 |
Time elapsed for statement mapping (ms) | 472.0 |
Clone type | Type 1 |
Mapped Statements
ID |
Statement |
|
ID |
Statement |
16 | if (this.rowRenderingOrder == SortOrder.ASCENDING) | | 22 | if (this.rowRenderingOrder == SortOrder.ASCENDING) |
17 | for (int row = 0; row < rowCount; row++) | | 23 | for (int row = 0; row < rowCount; row++) |
18 | renderer.drawItem(g2, state, dataArea, this, domainAxis, rangeAxis, currentDataset, row, column, pass); | | 24 | renderer.drawItem(g2, state, dataArea, this, domainAxis, rangeAxis, currentDataset, row, column, pass); |
| | | | |
19 | for (int row = rowCount - 1; row >= 0; row--) | | 25 | for (int row = rowCount - 1; row >= 0; row--) |
20 | renderer.drawItem(g2, state, dataArea, this, domainAxis, rangeAxis, currentDataset, row, column, pass); | | 26 | renderer.drawItem(g2, state, dataArea, this, domainAxis, rangeAxis, currentDataset, row, column, pass); |
Precondition Violations (0)
Row |
Violation |