File path: /emf-2.4.1/src/org/eclipse/emf/ecore/util/EcoreValidator.java | File path: /emf-2.4.1/src/org/eclipse/emf/ecore/util/EcoreValidator.java | |||
Method name: boolean validateEReference_ConsistentOpposite(EReference, DiagnosticChain, Map
|
Method name: boolean validateEClass_ConsistentSuperTypes(EClass, DiagnosticChain, Map
|
|||
Number of AST nodes: 4 | Number of AST nodes: 4 | |||
1 | if (diagnostics == null)↵ | 1 | if (diagnostics == null)↵ | |
2 | {↵ | 2 | {↵ | |
3 | return false;↵ | 3 | return false;↵ | |
4 | }↵ | 4 | }↵ | |
5 | else↵ | 5 | else↵ | |
6 | {↵ | 6 | {↵ | |
7 | result = false;↵ | 7 | result = false;↵ | |
8 | diagnostics.add↵ | 8 | diagnostics.add↵ | |
9 | (createDiagnostic↵ | 9 | (createDiagnostic↵ | |
10 | (Diagnostic.ERROR,↵ | 10 | (Diagnostic.ERROR,↵ | |
11 | DIAGNOSTIC_SOURCE,↵ | 11 | DIAGNOSTIC_SOURCE,↵ | |
12 | CONSISTENT_OPPOSITE_NOT_FROM_TYPE,↵ | 12 | CONSISTENT_SUPER_TYPES_CONFLICT,↵ | |
13 | "_UI_EReferenceOppositeNotFeatureOfType_diagnostic",↵ | 13 | "_UI_EClassConsistentSuperTypes_diagnostic",↵ | |
14 | null,↵ | 14 | new Object [] { getObjectLabel(eClassifier, context) },↵ | |
15 | new Object[] { eReference, eOpposite, eType },↵ | 15 | new Object[] { eClass, eGenericSuperType, eAllGenericSuperTypes.get(index) },↵ | |
16 | context));↵ | 16 | context));↵ | |
17 | } | 17 |
| |
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.2 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 17 |
Number of mapped statements | 3 |
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) | 1.4 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||
---|---|---|---|---|---|---|---|---|---|---|
15 | if (diagnostics == null) | 22 | if (diagnostics == null) | |||||||
16 | return false; |
| 23 | return false; | ||||||
else | else | |||||||||
17 | result = false; | 24 | result = false; | |||||||
18 | diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, CONSISTENT_OPPOSITE_NOT_FROM_TYPE, "_UI_EReferenceOppositeNotFeatureOfType_diagnostic", null, new Object[] {eReference, eOpposite, eType}, context)); |
| | |||||||
|
| 25 | diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, CONSISTENT_SUPER_TYPES_CONFLICT, "_UI_EClassConsistentSuperTypes_diagnostic", new Object[] {getObjectLabel(eClassifier, context)}, new Object[] {eClass, eGenericSuperType, eAllGenericSuperTypes.get(index)}, context)); |
Row | Violation |
---|---|
1 | Unmatched statement diagnostics.add(createDiagnostic(Diagnostic.ERROR,DIAGNOSTIC_SOURCE,CONSISTENT_OPPOSITE_NOT_FROM_TYPE,"_UI_EReferenceOppositeNotFeatureOfType_diagnostic",null,new Object[]{eReference,eOpposite,eType},context)); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
2 | Unmatched statement diagnostics.add(createDiagnostic(Diagnostic.ERROR,DIAGNOSTIC_SOURCE,CONSISTENT_SUPER_TYPES_CONFLICT,"_UI_EClassConsistentSuperTypes_diagnostic",new Object[]{getObjectLabel(eClassifier,context)},new Object[]{eClass,eGenericSuperType,eAllGenericSuperTypes.get(index)},context)); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
3 | Conditional return false; |
4 | Conditional return false; |