List nodeList = new LinkedList(); traverseAndFind(type, (ReportTreeNode) this.getRoot(), nodeList); return nodeList;
Image result = graph.createImage(graph.getWidth(), graph.getHeight()); graph.paintComponent(result.getGraphics()); return result;
Clone fragments detected by clone detection tool
File path: /jakarta-jmeter-2.3.2/src/org/apache/jmeter/report/gui/tree/ReportTreeModel.java File path: /jakarta-jmeter-2.3.2/src/org/apache/jmeter/visualizers/DistributionGraphVisualizer.java
Method name: List getNodesOfType(Class) Method name: Image getImage()
Number of AST nodes: 3 Number of AST nodes: 3
1
List nodeList = new LinkedList();
1
Image result = graph.createImage(graph.getWidth(), graph.getHeight());
2
		traverseAndFind(type, (ReportTreeNode) this.getRoot(), nodeList);
2
		graph.paintComponent(result.getGraphics());
3
		return nodeList;
3
		return result;
Summary
Number of common nesting structure subtrees1
Number of refactorable cases0
Number of non-refactorable cases1
Time elapsed for finding largest common nesting structure subtrees (ms)0.0
Clones locationClones are in different classes
Number of node comparisons9
  1. {Non-refactorable}
    Mapping Summary
    Number of mapped statements1
    Number of unmapped statements in the first code fragment2
    Number of unmapped statements in the second code fragment2
    Time elapsed for statement mapping (ms)0.0
    Clone typeType 2
    Mapped Statements
    ID Statement ID Statement
                                                                                                                                                
    1
    Image result = graph.createImage(graph.getWidth(), graph.getHeight());
    1
    List nodeList = new LinkedList();
                                                                        
    2
    traverseAndFind(type, (ReportTreeNode)this.getRoot(), nodeList);
    2
    traverseAndFind(type, (ReportTreeNode)this.getRoot(), nodeList);
    2
    graph.paintComponent(result.getGraphics());
    Differences
    Expression1Expression2Difference
    traverseAndFindpaintComponentMETHOD_INVOCATION_NAME_MISMATCH
    traverseAndFind(type,(ReportTreeNode)this.getRoot(),nodeList)graph.paintComponent(result.getGraphics())ARGUMENT_NUMBER_MISMATCH
    graphMISSING_METHOD_INVOCATION_EXPRESSION
    Preondition Violations
    Expression traverseAndFind(type,(ReportTreeNode)this.getRoot(),nodeList) is a void method call, and thus it cannot be parameterized
    Expression graph.paintComponent(result.getGraphics()) is a void method call, and thus it cannot be parameterized
    Expression traverseAndFind(type,(ReportTreeNode)this.getRoot(),nodeList) is a void method call, and thus it cannot be parameterized
    Expression graph.paintComponent(result.getGraphics()) is a void method call, and thus it cannot be parameterized
    2
    graph.paintComponent(result.getGraphics());
                                      
    3
    return result;
    Preondition Violations
    Unmatched return result;
    3
    return result;
    3
    return nodeList;
    3
    return nodeList;
    Preondition Violations
    Unmatched return nodeList;
                                          
    Precondition Violations (6)
    Row Violation
    1Expression traverseAndFind(type,(ReportTreeNode)this.getRoot(),nodeList) is a void method call, and thus it cannot be parameterized
    2Expression graph.paintComponent(result.getGraphics()) is a void method call, and thus it cannot be parameterized
    3Expression traverseAndFind(type,(ReportTreeNode)this.getRoot(),nodeList) is a void method call, and thus it cannot be parameterized
    4Expression graph.paintComponent(result.getGraphics()) is a void method call, and thus it cannot be parameterized
    5Unmatched return result;
    6Unmatched return nodeList;