for (int i = originalMapSize; i < size; ++i) { EClassifier eClassifier = eClassifiers.get(i); String eClassifierName = getName(eClassifier); EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier); if (conflictingEClassifier != null && conflictingEClassifier != eClassifier) { nameToClassifierMap.put(eClassifierName, conflictingEClassifier); } }
for (int i = 0; i < originalMapSize; ++i) { EClassifier eClassifier = eClassifiers.get(i); String eClassifierName = getName(eClassifier); EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier); if (conflictingEClassifier != null && conflictingEClassifier != eClassifier) { nameToClassifierMap.put(eClassifierName, conflictingEClassifier); } }
Clone fragments detected by clone detection tool
File path: /emf-2.4.1/src/org/eclipse/emf/ecore/util/BasicExtendedMetaData.java File path: /emf-2.4.1/src/org/eclipse/emf/ecore/util/BasicExtendedMetaData.java
Method name: EClassifier getType(String) Method name: EClassifier getType(String)
Number of AST nodes: 6 Number of AST nodes: 6
1
for (int i = originalMapSize; i < size; ++i)
1
for (int i = 0; i < originalMapSize; ++i)
2
          {
2
            {
3
            EClassifier eClassifier = eClassifiers.get(i);
3
              EClassifier eClassifier = eClassifiers.get(i);
4
            String eClassifierName = getName(eClassifier);
4
              String eClassifierName = getName(eClassifier);
5
            EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier);
5
              EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier);
6
            if (conflictingEClassifier != null && conflictingEClassifier != eClassifier)
6
              if (conflictingEClassifier != null && conflictingEClassifier != eClassifier)
7
            {
7
              {
8
              nameToClassifierMap.put(eClassifierName, conflictingEClassifier);
8
                nameToClassifierMap.put(eClassifierName, conflictingEClassifier);
9
            }
9
            
10
  }
10
          }
11
            }
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)0.4
Clones locationClones are in the same method
Number of node comparisons22
  1. {Refactorable}
    Mapping Summary
    Number of mapped statements6
    Number of unmapped statements in the first code fragment0
    Number of unmapped statements in the second code fragment0
    Time elapsed for statement mapping (ms)27.4
    Clone typeType 2
    Mapped Statements
    ID Statement ID Statement
    12
    for (int i = originalMapSize; i < size; ++i)
    12
    for (int i = originalMapSize; i < size; ++i)
    19
    for (int i = 0; i < originalMapSize; ++i)
    Differences
    Expression1Expression2Difference
    originalMapSize0TYPE_COMPATIBLE_REPLACEMENT
    sizeoriginalMapSizeVARIABLE_NAME_MISMATCH
    19
    for (int i = 0; i < originalMapSize; ++i)
    13
    EClassifier eClassifier = eClassifiers.get(i);
    20
    EClassifier eClassifier = eClassifiers.get(i);
    14
    String eClassifierName = getName(eClassifier);
    21
    String eClassifierName = getName(eClassifier);
    15
    EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier);
    22
    EClassifier conflictingEClassifier = nameToClassifierMap.put(eClassifierName, eClassifier);
    16
    if (conflictingEClassifier != null && conflictingEClassifier != eClassifier)
    23
    if (conflictingEClassifier != null && conflictingEClassifier != eClassifier)
    17
    nameToClassifierMap.put(eClassifierName, conflictingEClassifier);
    24
    nameToClassifierMap.put(eClassifierName, conflictingEClassifier);
    Precondition Violations (0)
    Row Violation