switch (featureID) { case XMLTypePackage.ANY_TYPE__MIXED: return ((InternalEList<?>)getMixed()).basicRemove(otherEnd, msgs); case XMLTypePackage.ANY_TYPE__ANY: return ((InternalEList<?>)getAny()).basicRemove(otherEnd, msgs); case XMLTypePackage.ANY_TYPE__ANY_ATTRIBUTE: return ((InternalEList<?>)getAnyAttribute()).basicRemove(otherEnd, msgs); } return eDynamicInverseRemove(otherEnd, featureID, msgs);
switch (featureID) { case ChangePackage.CHANGE_DESCRIPTION__OBJECT_CHANGES: return ((InternalEList<?>)getObjectChanges()).basicRemove(otherEnd, msgs); case ChangePackage.CHANGE_DESCRIPTION__OBJECTS_TO_ATTACH: return ((InternalEList<?>)getObjectsToAttach()).basicRemove(otherEnd, msgs); case ChangePackage.CHANGE_DESCRIPTION__RESOURCE_CHANGES: return ((InternalEList<?>)getResourceChanges()).basicRemove(otherEnd, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs);
Clone fragments detected by clone detection tool
File path: /emf-2.4.1/src/org/eclipse/emf/ecore/xml/type/impl/AnyTypeImpl.java File path: /emf-2.4.1/src/org/eclipse/emf/ecore/change/impl/ChangeDescriptionImpl.java
Method name: NotificationChain eInverseRemove(InternalEObject, int, NotificationChain) Method name: NotificationChain eInverseRemove(InternalEObject, int, NotificationChain)
Number of AST nodes: 8 Number of AST nodes: 8
1
switch (featureID)
1
switch (featureID)
2
    {
2
    {
3
      case XMLTypePackage.ANY_TYPE__MIXED:
3
      case ChangePackage.CHANGE_DESCRIPTION__OBJECT_CHANGES:
4
        return ((InternalEList<?>)getMixed()).basicRemove(otherEnd, msgs);
4
        return ((InternalEList<?>)getObjectChanges()).basicRemove(otherEnd, msgs);
5
      case XMLTypePackage.ANY_TYPE__ANY:
5
      case ChangePackage.CHANGE_DESCRIPTION__OBJECTS_TO_ATTACH:
6
        return ((InternalEList<?>)getAny()).basicRemove(otherEnd, msgs);
6
        return ((InternalEList<?>)getObjectsToAttach()).basicRemove(otherEnd, msgs);
7
      case XMLTypePackage.ANY_TYPE__ANY_ATTRIBUTE:
7
      case ChangePackage.CHANGE_DESCRIPTION__RESOURCE_CHANGES:
8
        return ((InternalEList<?>)getAnyAttribute()).basicRemove(otherEnd, msgs);
8
        return ((InternalEList<?>)getResourceChanges()).basicRemove(otherEnd, msgs);
9
    }
9
    }
10
    return eDynamicInverseRemove(otherEnd, featureID, msgs);
10
    return super.eInverseRemove(otherEnd, featureID, msgs);
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 having the same super class
Number of node comparisons26
  1. {Non-refactorable}
    Mapping Summary
    Number of mapped statements8
    Number of unmapped statements in the first code fragment0
    Number of unmapped statements in the second code fragment0
    Time elapsed for statement mapping (ms)2.6
    Clone typeType 2
    Mapped Statements
    ID Statement ID Statement
    1
    switch (featureID)
    1
    switch (featureID)
    2
    case XMLTypePackage.ANY_TYPE__MIXED:
    2
    case XMLTypePackage.ANY_TYPE__MIXED:
    2
    case ChangePackage.CHANGE_DESCRIPTION__OBJECT_CHANGES:
    Differences
    Expression1Expression2Difference
    org.eclipse.emf.ecore.xml.type.XMLTypePackageorg.eclipse.emf.ecore.change.ChangePackageVARIABLE_TYPE_MISMATCH
    ANY_TYPE__MIXEDCHANGE_DESCRIPTION__OBJECT_CHANGESVARIABLE_NAME_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    • Make classes org.eclipse.emf.ecore.xml.type.XMLTypePackage and org.eclipse.emf.ecore.change.ChangePackage extend a common superclass
    2
    case ChangePackage.CHANGE_DESCRIPTION__OBJECT_CHANGES:
    3
    return ((InternalEList<?>)getMixed()).basicRemove(otherEnd, msgs);
    3
    return ((InternalEList<?>)getMixed()).basicRemove(otherEnd, msgs);
    3
    return ((InternalEList<?>)getObjectChanges()).basicRemove(otherEnd, msgs);
    Differences
    Expression1Expression2Difference
    getMixedgetObjectChangesMETHOD_INVOCATION_NAME_MISMATCH
    org.eclipse.emf.ecore.util.FeatureMaporg.eclipse.emf.common.util.EMap>VARIABLE_TYPE_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.util.FeatureMap of variable getMixed() does not match with type org.eclipse.emf.common.util.EMap<org.eclipse.emf.ecore.EObject,org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.change.FeatureChange>> of variable getObjectChanges()
    • Make classes org.eclipse.emf.ecore.util.FeatureMap and org.eclipse.emf.common.util.EMap> extend a common superclass
    3
    return ((InternalEList<?>)getObjectChanges()).basicRemove(otherEnd, msgs);
    4
    case XMLTypePackage.ANY_TYPE__ANY:
    4
    case XMLTypePackage.ANY_TYPE__ANY:
    4
    case ChangePackage.CHANGE_DESCRIPTION__OBJECTS_TO_ATTACH:
    Differences
    Expression1Expression2Difference
    org.eclipse.emf.ecore.xml.type.XMLTypePackageorg.eclipse.emf.ecore.change.ChangePackageVARIABLE_TYPE_MISMATCH
    ANY_TYPE__ANYCHANGE_DESCRIPTION__OBJECTS_TO_ATTACHVARIABLE_NAME_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    • Make classes org.eclipse.emf.ecore.xml.type.XMLTypePackage and org.eclipse.emf.ecore.change.ChangePackage extend a common superclass
    4
    case ChangePackage.CHANGE_DESCRIPTION__OBJECTS_TO_ATTACH:
    5
    return ((InternalEList<?>)getAny()).basicRemove(otherEnd, msgs);
    5
    return ((InternalEList<?>)getAny()).basicRemove(otherEnd, msgs);
    5
    return ((InternalEList<?>)getObjectsToAttach()).basicRemove(otherEnd, msgs);
    Differences
    Expression1Expression2Difference
    getAnygetObjectsToAttachMETHOD_INVOCATION_NAME_MISMATCH
    org.eclipse.emf.ecore.util.FeatureMaporg.eclipse.emf.common.util.EListVARIABLE_TYPE_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.util.FeatureMap of variable getAny() does not match with type org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.EObject> of variable getObjectsToAttach()
    • Make classes org.eclipse.emf.ecore.util.FeatureMap and org.eclipse.emf.common.util.EList extend a common superclass
    5
    return ((InternalEList<?>)getObjectsToAttach()).basicRemove(otherEnd, msgs);
    6
    case XMLTypePackage.ANY_TYPE__ANY_ATTRIBUTE:
    6
    case XMLTypePackage.ANY_TYPE__ANY_ATTRIBUTE:
    6
    case ChangePackage.CHANGE_DESCRIPTION__RESOURCE_CHANGES:
    Differences
    Expression1Expression2Difference
    org.eclipse.emf.ecore.xml.type.XMLTypePackageorg.eclipse.emf.ecore.change.ChangePackageVARIABLE_TYPE_MISMATCH
    ANY_TYPE__ANY_ATTRIBUTECHANGE_DESCRIPTION__RESOURCE_CHANGESVARIABLE_NAME_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    • Make classes org.eclipse.emf.ecore.xml.type.XMLTypePackage and org.eclipse.emf.ecore.change.ChangePackage extend a common superclass
    6
    case ChangePackage.CHANGE_DESCRIPTION__RESOURCE_CHANGES:
    7
    return ((InternalEList<?>)getAnyAttribute()).basicRemove(otherEnd, msgs);
    7
    return ((InternalEList<?>)getAnyAttribute()).basicRemove(otherEnd, msgs);
    7
    return ((InternalEList<?>)getResourceChanges()).basicRemove(otherEnd, msgs);
    Differences
    Expression1Expression2Difference
    getAnyAttributegetResourceChangesMETHOD_INVOCATION_NAME_MISMATCH
    org.eclipse.emf.ecore.util.FeatureMaporg.eclipse.emf.common.util.EListVARIABLE_TYPE_MISMATCH
    Preondition Violations
    Type org.eclipse.emf.ecore.util.FeatureMap of variable getAnyAttribute() does not match with type org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.change.ResourceChange> of variable getResourceChanges()
    • Make classes org.eclipse.emf.ecore.util.FeatureMap and org.eclipse.emf.common.util.EList extend a common superclass
    7
    return ((InternalEList<?>)getResourceChanges()).basicRemove(otherEnd, msgs);
    8
    return eDynamicInverseRemove(otherEnd, featureID, msgs);
    8
    return eDynamicInverseRemove(otherEnd, featureID, msgs);
    8
    return super.eInverseRemove(otherEnd, featureID, msgs);
    Differences
    Expression1Expression2Difference
    eDynamicInverseRemove(otherEnd,featureID,msgs)super.eInverseRemove(otherEnd,featureID,msgs)TYPE_COMPATIBLE_REPLACEMENT
    8
    return super.eInverseRemove(otherEnd, featureID, msgs);
    Precondition Violations (6)
    Row Violation
    1Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    2Type org.eclipse.emf.ecore.util.FeatureMap of variable getMixed() does not match with type org.eclipse.emf.common.util.EMap<org.eclipse.emf.ecore.EObject,org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.change.FeatureChange>> of variable getObjectChanges()
    3Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    4Type org.eclipse.emf.ecore.util.FeatureMap of variable getAny() does not match with type org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.EObject> of variable getObjectsToAttach()
    5Type org.eclipse.emf.ecore.xml.type.XMLTypePackage of variable XMLTypePackage does not match with type org.eclipse.emf.ecore.change.ChangePackage of variable ChangePackage
    6Type org.eclipse.emf.ecore.util.FeatureMap of variable getAnyAttribute() does not match with type org.eclipse.emf.common.util.EList<org.eclipse.emf.ecore.change.ResourceChange> of variable getResourceChanges()