File path: /jfreechart-1.0.10/src/org/jfree/chart/block/ColumnArrangement.java | File path: /jfreechart-1.0.10/src/org/jfree/chart/block/FlowArrangement.java | |||
Method name: Size2D arrangeNF(BlockContainer, Graphics2D, RectangleConstraint)
|
Method name: Size2D arrangeFN(BlockContainer, Graphics2D, RectangleConstraint)
|
|||
Number of AST nodes: 11 | Number of AST nodes: 11 | |||
1 | if (itemsInColumn.isEmpty()) {↵ | 1 | if (itemsInRow.isEmpty()) {↵ | |
2 | // place in this column (truncated) anyway↵ | 2 | // place in this row (truncated) anyway↵ | |
3 | block.setBounds(↵ | 3 | block.setBounds(↵ | |
4 | new Rectangle2D.Double(↵ | 4 | new Rectangle2D.Double(↵ | |
5 | x, y, size.width, Math.min(size.height, height - y)↵ | 5 | x, y, Math.min(size.width, width - x), size.height↵ | |
6 | )↵ | 6 | )↵ | |
7 | );↵ | 7 | );↵ | |
8 | y = 0.0;↵ | 8 | x = 0.0;↵ | |
9 | x = x + size.width + this.horizontalGap;↵ | 9 | y = y + size.height + this.verticalGap;↵ | |
10 | }↵ | 10 | }↵ | |
11 | else {↵ | 11 | else {↵ | |
12 | // start new column↵ | 12 | // start new row↵ | |
13 | itemsInColumn.clear();↵ | 13 | itemsInRow.clear();↵ | |
14 | x = x + maxWidth + this.horizontalGap;↵ | 14 | x = ↵ | |
15 | y = 0.0↵ | 15 | 0.0;↵ | |
16 | ;↵ | 16 | y = y + maxHeight + this.verticalGap;↵ | |
17 | maxWidth = size.width;↵ | 17 | maxHeight = size.height;↵ | |
18 | block.setBounds(↵ | 18 | block.setBounds(↵ | |
19 | new Rectangle2D.Double(↵ | 19 | new Rectangle2D.Double(↵ | |
20 | x, y, size.width, Math.min(size.height, height)↵ | 20 | x, y, Math.min(size.width, width), size.height↵ | |
21 | )↵ | 21 | )↵ | |
22 | );↵ | 22 | );↵ | |
23 | y = size.height + this.verticalGap;↵ | 23 | x = size.width + this.horizontalGap;↵ | |
24 | itemsInColumn.add(block);↵ | 24 | itemsInRow.add(block);↵ | |
25 | } | 25 |
| |
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 | 123 |
Number of mapped statements | 10 |
Number of unmapped statements in the first code fragment | 1 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 62.5 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
17 | if (itemsInColumn.isEmpty()) |
| 15 | if (itemsInRow.isEmpty()) | ||||||||||||||||
18 | block.setBounds(new Rectangle2D.Double(x, y, size.width, Math.min(size.height, height - y))); |
| 16 | block.setBounds(new Rectangle2D.Double(x, y, Math.min(size.width, width - x), size.height)); | ||||||||||||||||
19 | y = 0.0; |
| 18 | y = y + size.height + this.verticalGap; | ||||||||||||||||
20 | x = x + size.width + this.horizontalGap; |
| 17 | x = 0.0; | ||||||||||||||||
else | else | |||||||||||||||||||
21 | itemsInColumn.clear(); |
| 19 | itemsInRow.clear(); | ||||||||||||||||
22 | x = x + maxWidth + this.horizontalGap; |
| 20 | x = 0.0; | ||||||||||||||||
23 | y = 0.0; |
| 21 | y = y + maxHeight + this.verticalGap; | ||||||||||||||||
|
| 22 | maxHeight = size.height; | |||||||||||||||||
24 | maxWidth = size.width; |
| | |||||||||||||||||
25 | block.setBounds(new Rectangle2D.Double(x, y, size.width, Math.min(size.height, height))); |
| 23 | block.setBounds(new Rectangle2D.Double(x, y, Math.min(size.width, width), size.height)); | ||||||||||||||||
26 | y = size.height + this.verticalGap; |
| 24 | x = size.width + this.horizontalGap; | ||||||||||||||||
27 | itemsInColumn.add(block); |
| 25 | itemsInRow.add(block); |
Row | Violation |
---|---|
1 | Expression Math.min(size.width,width - x) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Expression Math.min(size.height,height - y) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Expression y + size.height + this.verticalGap cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression x + size.width + this.horizontalGap cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Expression x + maxWidth + this.horizontalGap cannot be parameterized, because it has dependencies to/from statements that will be extracted |
6 | Expression y + maxHeight + this.verticalGap cannot be parameterized, because it has dependencies to/from statements that will be extracted |
7 | Unmatched statement maxHeight=size.height; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
8 | Unmatched statement maxWidth=size.width; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Clone fragment #1 returns variables y, x , while Clone fragment #2 returns variables x, y |