while (iter.hasNext() && iter2.hasNext() && iter3.hasNext()) { JMenuItem start = (JMenuItem) iter.next(); JMenuItem stop = (JMenuItem) iter2.next(); JMenuItem exit = (JMenuItem) iter3.next(); if (start.getText().equals(host)) { log.info("Found start host: " + start.getText()); start.setEnabled(!running); } if (stop.getText().equals(host)) { log.info("Found stop host: " + stop.getText()); stop.setEnabled(running); } if (exit.getText().equals(host)) { log.info("Found exit host: " + exit.getText()); exit.setEnabled(true); } }
while (iter.hasNext() && iter2.hasNext() && iter3.hasNext()) { JMenuItem start = (JMenuItem) iter.next(); JMenuItem stop = (JMenuItem) iter2.next(); JMenuItem exit = (JMenuItem) iter3.next(); if (start.getText().equals(host)) { log.debug("Found start host: " + start.getText()); start.setEnabled(!running); } if (stop.getText().equals(host)) { log.debug("Found stop host: " + stop.getText()); stop.setEnabled(running); } if (exit.getText().equals(host)) { log.debug("Found exit host: " + exit.getText()); exit.setEnabled(true); } }
Clone fragments detected by clone detection tool
File path: /jakarta-jmeter-2.3.2/src/org/apache/jmeter/gui/util/ReportMenuBar.java File path: /jakarta-jmeter-2.3.2/src/org/apache/jmeter/gui/util/JMeterMenuBar.java
Method name: void setRunning(boolean, String) Method name: void setRunning(boolean, String)
Number of AST nodes: 13 Number of AST nodes: 13
1
while (iter.hasNext() && iter2.hasNext() && iter3.hasNext()) {
1
while (iter.hasNext() && iter2.hasNext() && iter3.hasNext()) {
2
			JMenuItem start = (JMenuItem) iter.next();
2
			JMenuItem start = (JMenuItem) iter.next();
3
			JMenuItem stop = (JMenuItem) iter2.next();
3
			JMenuItem stop = (JMenuItem) iter2.next();
4
			JMenuItem exit = (JMenuItem) iter3.next();
4
			JMenuItem exit = (JMenuItem) iter3.next();
5
			if (start.getText().equals(host)) {
5
			if (start.getText().equals(host)) {
6
				log.info("Found start host: " + start.getText());
6
				log.debug("Found start host: " + start.getText());
7
				start.setEnabled(!running);
7
				start.setEnabled(!running);
8
			}
8
			}
9
			if (stop.getText().equals(host)) {
9
			if (stop.getText().equals(host)) {
10
				log.info("Found stop  host: " + stop.getText());
10
				log.debug("Found stop  host: " + stop.getText());
11
				stop.setEnabled(running);
11
				stop.setEnabled(running);
12
			}
12
			}
13
			if (exit.getText().equals(host)) {
13
			if (exit.getText().equals(host)) {
14
				log.info("Found exit  host: " + exit.getText());
14
				log.debug("Found exit  host: " + exit.getText());
15
				exit.setEnabled(true);
15
				exit.setEnabled(true);
16
			}
16
			}
17
		}
17
		}
Summary
Number of common nesting structure subtrees1
Number of refactorable cases1
Number of non-refactorable cases0
Time elapsed for finding largest common nesting structure subtrees (ms)1.3
Clones locationClones are in different classes having the same super class
Number of node comparisons73
  1. {Refactorable}
    Mapping Summary
    Number of mapped statements13
    Number of unmapped statements in the first code fragment0
    Number of unmapped statements in the second code fragment0
    Time elapsed for statement mapping (ms)228.5
    Clone typeType 2
    Mapped Statements
    ID Statement ID Statement
    5
    while (iter.hasNext() && iter2.hasNext() && iter3.hasNext())
    5
    while (iter.hasNext() && iter2.hasNext() && iter3.hasNext())
    6
    JMenuItem start = (JMenuItem)iter.next();
    6
    JMenuItem start = (JMenuItem)iter.next();
    7
    JMenuItem stop = (JMenuItem)iter2.next();
    7
    JMenuItem stop = (JMenuItem)iter2.next();
    8
    JMenuItem exit = (JMenuItem)iter3.next();
    8
    JMenuItem exit = (JMenuItem)iter3.next();
    9
    if (start.getText().equals(host))
    9
    if (start.getText().equals(host))
    10
    log.info("Found start host: " + start.getText());
    10
    log.info("Found start host: " + start.getText());
    10
    log.debug("Found start host: " + start.getText());
    Differences
    Expression1Expression2Difference
    infodebugMETHOD_INVOCATION_NAME_MISMATCH
    Preondition Violations
    Expression log.info("Found start host: " + start.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.debug("Found start host: " + start.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.info("Found start host: " + start.getText()) is a void method call, and thus it cannot be parameterized
    Expression log.debug("Found start host: " + start.getText()) is a void method call, and thus it cannot be parameterized
    10
    log.debug("Found start host: " + start.getText());
    11
    start.setEnabled(!running);
    11
    start.setEnabled(!running);
    12
    if (stop.getText().equals(host))
    12
    if (stop.getText().equals(host))
    13
    log.info("Found stop  host: " + stop.getText());
    13
    log.info("Found stop host: " + stop.getText());
    13
    log.debug("Found stop host: " + stop.getText());
    Differences
    Expression1Expression2Difference
    infodebugMETHOD_INVOCATION_NAME_MISMATCH
    Preondition Violations
    Expression log.info("Found stop host: " + stop.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.debug("Found stop host: " + stop.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.info("Found stop host: " + stop.getText()) is a void method call, and thus it cannot be parameterized
    Expression log.debug("Found stop host: " + stop.getText()) is a void method call, and thus it cannot be parameterized
    13
    log.debug("Found stop  host: " + stop.getText());
    14
    stop.setEnabled(running);
    14
    stop.setEnabled(running);
    15
    if (exit.getText().equals(host))
    15
    if (exit.getText().equals(host))
    16
    log.info("Found exit  host: " + exit.getText());
    16
    log.info("Found exit host: " + exit.getText());
    16
    log.debug("Found exit host: " + exit.getText());
    Differences
    Expression1Expression2Difference
    infodebugMETHOD_INVOCATION_NAME_MISMATCH
    Preondition Violations
    Expression log.info("Found exit host: " + exit.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.debug("Found exit host: " + exit.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression log.info("Found exit host: " + exit.getText()) is a void method call, and thus it cannot be parameterized
    Expression log.debug("Found exit host: " + exit.getText()) is a void method call, and thus it cannot be parameterized
    16
    log.debug("Found exit  host: " + exit.getText());
    17
    exit.setEnabled(true);
    17
    exit.setEnabled(true);
    Precondition Violations (12)
    Row Violation
    1Expression log.info("Found start host: " + start.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    2Expression log.debug("Found start host: " + start.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    3Expression log.info("Found start host: " + start.getText()) is a void method call, and thus it cannot be parameterized
    4Expression log.debug("Found start host: " + start.getText()) is a void method call, and thus it cannot be parameterized
    5Expression log.info("Found stop host: " + stop.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    6Expression log.debug("Found stop host: " + stop.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    7Expression log.info("Found stop host: " + stop.getText()) is a void method call, and thus it cannot be parameterized
    8Expression log.debug("Found stop host: " + stop.getText()) is a void method call, and thus it cannot be parameterized
    9Expression log.info("Found exit host: " + exit.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    10Expression log.debug("Found exit host: " + exit.getText()) cannot be parameterized, because it has dependencies to/from statements that will be extracted
    11Expression log.info("Found exit host: " + exit.getText()) is a void method call, and thus it cannot be parameterized
    12Expression log.debug("Found exit host: " + exit.getText()) is a void method call, and thus it cannot be parameterized