File path: /emf-2.4.1/src/org/eclipse/emf/ecore/plugin/ContentParserRegistryReader.java | File path: /emf-2.4.1/src/org/eclipse/emf/ecore/plugin/DynamicPackageRegistryReader.java | |||
Method name: boolean readElement(IConfigurationElement, boolean)
|
Method name: boolean readElement(IConfigurationElement, boolean)
|
|||
Number of AST nodes: 13 | Number of AST nodes: 13 | |||
1 | String contentTypeIdentifier = element.getAttribute(ATT_CONTENT_TYPE_IDENTIFIER);↵ | 1 | String packageURI = element.getAttribute(ATT_↵ | |
2 | if (contentTypeIdentifier↵ | 2 | URI);↵ | |
3 | == null)↵ | 3 | if (packageURI == null)↵ | |
4 | {↵ | 4 | {↵ | |
5 | logMissingAttribute(element, ATT_CONTENT_TYPE_IDENTIFIER);↵ | 5 | logMissingAttribute(element, ATT_URI);↵ | |
6 | }↵ | 6 | }↵ | |
7 | else if (element.getAttribute(ATT_CLASS) == null)↵ | 7 | else if (element.getAttribute(ATT_LOCATION) == null)↵ | |
8 | {↵ | 8 | {↵ | |
9 | logMissingAttribute(element, ATT_CLASS);↵ | 9 | logMissingAttribute(element, ATT_LOCATION);↵ | |
10 | }↵ | 10 | }↵ | |
11 | else if (add)↵ | 11 | else if (add)↵ | |
12 | {↵ | 12 | {↵ | |
13 | Object previous = Resource.Factory.Registry.INSTANCE.getContentTypeToFactoryMap().put(contentTypeIdentifier, new ResourceFactoryDescriptor(element, ATT_CLASS));↵ | 13 | Object previous = EPackage.Registry.INSTANCE.put(packageURI, new EPackageDescriptor.Dynamic(element, ATT_LOCATION));↵ | |
14 | if (previous instanceof ResourceFactoryDescriptor)↵ | 14 | if (previous instanceof PluginClassDescriptor)↵ | |
15 | {↵ | 15 | {↵ | |
16 | ResourceFactoryDescriptor descriptor = (ResourceFactoryDescriptor)previous;↵ | 16 | PluginClassDescriptor descriptor = (PluginClassDescriptor)previous;↵ | |
17 | EcorePlugin.INSTANCE.log↵ | 17 | EcorePlugin.INSTANCE.log↵ | |
18 | ("Both '" + descriptor.element.getContributor().getName() + "' and '" + element.getContributor().getName() + "' register a content parser for '" + contentTypeIdentifier + "'");↵ | 18 | ("Both '" + descriptor.element.getContributor().getName() + "' and '" + element.getContributor().getName() + "' register a package for '" + packageURI + "'");↵ | |
19 | }↵ | 19 | }↵ | |
20 | ↵ | |||
20 | return true;↵ | 21 | return true;↵ | |
21 | }↵ | 22 | }↵ | |
22 | else↵ | 23 | else↵ | |
23 | {↵ | 24 | {↵ | |
24 | Resource.Factory.Registry.INSTANCE.getContentTypeToFactoryMap().remove(contentTypeIdentifier);↵ | 25 | EPackage.Registry.INSTANCE.remove(packageURI);↵ | |
25 | return true;↵ | 26 | return true;↵ | |
26 | } | 27 |
| |
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.5 |
Clones location | Clones are in different classes having the same super class |
Number of node comparisons | 49 |
Number of mapped statements | 11 |
Number of unmapped statements in the first code fragment | 2 |
Number of unmapped statements in the second code fragment | 2 |
Time elapsed for statement mapping (ms) | 4.7 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
2 | String contentTypeIdentifier = element.getAttribute(ATT_CONTENT_TYPE_IDENTIFIER); |
| 2 | String packageURI = element.getAttribute(ATT_URI); | ||||||||||||||||
3 | if (contentTypeIdentifier == null) |
| 3 | if (packageURI == null) | ||||||||||||||||
4 | logMissingAttribute(element, ATT_CONTENT_TYPE_IDENTIFIER); |
| 4 | logMissingAttribute(element, ATT_URI); | ||||||||||||||||
5 | else if (element.getAttribute(ATT_CLASS) == null) |
| 5 | else if (element.getAttribute(ATT_LOCATION) == null) | ||||||||||||||||
6 | logMissingAttribute(element, ATT_CLASS); |
| 6 | logMissingAttribute(element, ATT_LOCATION); | ||||||||||||||||
7 | else if (add) | 7 | else if (add) | |||||||||||||||||
|
| 8 | Object previous = EPackage.Registry.INSTANCE.put(packageURI, new EPackageDescriptor.Dynamic(element, ATT_LOCATION)); | |||||||||||||||||
8 | Object previous = Resource.Factory.Registry.INSTANCE.getContentTypeToFactoryMap().put(contentTypeIdentifier, new ResourceFactoryDescriptor(element, ATT_CLASS)); |
| | |||||||||||||||||
9 | if (previous instanceof ResourceFactoryDescriptor) |
| 9 | if (previous instanceof PluginClassDescriptor) | ||||||||||||||||
10 | ResourceFactoryDescriptor descriptor = (ResourceFactoryDescriptor)previous; |
| 10 | PluginClassDescriptor descriptor = (PluginClassDescriptor)previous; | ||||||||||||||||
11 | EcorePlugin.INSTANCE.log("Both '" + descriptor.element.getContributor().getName() + "' and '" + element.getContributor().getName() + "' register a content parser for '" + contentTypeIdentifier + "'"); |
| 11 | EcorePlugin.INSTANCE.log("Both '" + descriptor.element.getContributor().getName() + "' and '" + element.getContributor().getName() + "' register a package for '" + packageURI + "'"); | ||||||||||||||||
12 | return true; | 12 | return true; | |||||||||||||||||
else | else | |||||||||||||||||||
| 13 | EPackage.Registry.INSTANCE.remove(packageURI); | ||||||||||||||||||
13 | Resource.Factory.Registry.INSTANCE.getContentTypeToFactoryMap().remove(contentTypeIdentifier); | | ||||||||||||||||||
14 | return true; | 14 | return true; |
Row | Violation |
---|---|
1 | Unmatched statement Object previous=EPackage.Registry.INSTANCE.put(packageURI,new EPackageDescriptor.Dynamic(element,ATT_LOCATION)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement Object previous=Resource.Factory.Registry.INSTANCE.getContentTypeToFactoryMap().put(contentTypeIdentifier,new ResourceFactoryDescriptor(element,ATT_CLASS)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |