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 validateEGenericType_ConsistentArguments(EGenericType, DiagnosticChain, Map
|
Method name: boolean validateEGenericType_ConsistentArguments(EGenericType, DiagnosticChain, Map
|
|||
Number of AST nodes: 4 | Number of AST nodes: 4 | |||
1 | if (diagnostics == null)↵ | 1 | if (diagnostics == null)↵ | |
2 | {↵ | 2 | ↵ | |
3 | ↵ | 3 | {↵ | |
4 | return false;↵ | 4 | return false;↵ | |
5 | }↵ | 5 | ↵ | |
6 | ↵ | 6 | }↵ | |
7 | else↵ | 7 | else↵ | |
8 | {↵ | 8 | {↵ | |
9 | result = false;↵ | 9 | result = false;↵ | |
10 | diagnostics.add↵ | 10 | diagnostics.add↵ | |
11 | (createDiagnostic↵ | 11 | (createDiagnostic↵ | |
12 | (Diagnostic.ERROR,↵ | 12 | (Diagnostic.↵ | |
13 | ↵ | 13 | WARNING,↵ | |
14 | DIAGNOSTIC_SOURCE,↵ | 14 | DIAGNOSTIC_SOURCE,↵ | |
15 | CONSISTENT_ARGUMENTS_INVALID_SUBSTITUTION,↵ | 15 | CONSISTENT_ARGUMENTS_NONE,↵ | |
16 | "_UI_EGenericTypeArgumentInvalidSubstitution_diagnostic", ↵ | 16 | "_UI_EGenericTypeArgumentsNeeded_diagnostic",↵ | |
17 | ↵ | |||
18 | new Object [] ↵ | 17 | new Object [] ↵ | |
19 | { ↵ | |||
20 | getObjectLabel(eTypeArgument, context), ↵ | |||
21 | getObjectLabel(eTypeParameter, context) ↵ | |||
22 | },↵ | 18 | { eClassifier.getName(), eTypeParameterSize },↵ | |
23 | new Object[] { eGenericType, eTypeArgument, eTypeParameter },↵ | 19 | new Object[] { eGenericType },↵ | |
24 | context));↵ | 20 | context));↵ | |
25 | ↵ | |||
26 | ↵ | |||
27 | } | 21 |
| |
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.1 |
Clones location | Clones are in the same method |
Number of node comparisons | 16 |
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 | |||||||
---|---|---|---|---|---|---|---|---|---|---|
30 | if (diagnostics == null) | 15 | if (diagnostics == null) | |||||||
31 | return false; |
| 16 | return false; | ||||||
else | else | |||||||||
32 | result = false; | 17 | result = false; | |||||||
|
| 18 | diagnostics.add(createDiagnostic(Diagnostic.WARNING, DIAGNOSTIC_SOURCE, CONSISTENT_ARGUMENTS_NONE, "_UI_EGenericTypeArgumentsNeeded_diagnostic", new Object[] {eClassifier.getName(), eTypeParameterSize}, new Object[] {eGenericType}, context)); | |||||||
33 | diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, CONSISTENT_ARGUMENTS_INVALID_SUBSTITUTION, "_UI_EGenericTypeArgumentInvalidSubstitution_diagnostic", new Object[] {getObjectLabel(eTypeArgument, context), getObjectLabel(eTypeParameter, context)}, new Object[] {eGenericType, eTypeArgument, eTypeParameter}, context)); |
| |
Row | Violation |
---|---|
1 | Unmatched statement diagnostics.add(createDiagnostic(Diagnostic.WARNING,DIAGNOSTIC_SOURCE,CONSISTENT_ARGUMENTS_NONE,"_UI_EGenericTypeArgumentsNeeded_diagnostic",new Object[]{eClassifier.getName(),eTypeParameterSize},new Object[]{eGenericType},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_ARGUMENTS_INVALID_SUBSTITUTION,"_UI_EGenericTypeArgumentInvalidSubstitution_diagnostic",new Object[]{getObjectLabel(eTypeArgument,context),getObjectLabel(eTypeParameter,context)},new Object[]{eGenericType,eTypeArgument,eTypeParameter},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; |