blob: 44ee72b6c8a9f625425e6b6b325b0c8cda727174 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
/*****************************************************************************
* Copyright (c) 2011 CEA LIST.
*
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Amine EL KOUHEN (CEA LIST/LIFL) - Amine.Elkouhen@cea.fr
*****************************************************************************/
package org.eclipse.papyrus.infra.services.markerlistener.util;
import java.util.Map;
import java.util.MissingResourceException;
import org.eclipse.core.resources.IMarker;
import org.eclipse.emf.common.util.URI;
import org.eclipse.emf.common.util.WrappedException;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.ecore.EValidator;
import org.eclipse.emf.ecore.resource.Resource;
import org.eclipse.emf.edit.domain.EditingDomain;
/**
* The Class MarkerListenerUtils.
*/
public class MarkerListenerUtils {
/**
* E object from marker or map.
*
* @param marker
* the marker
* @param attributes
* the attributes
* @param domain
* the domain
* @return the e object
*/
public static EObject eObjectFromMarkerOrMap(IMarker marker, @SuppressWarnings("rawtypes") Map attributes, EditingDomain domain) {
String uriAttribute;
if(domain == null) {
return null;
}
if(marker != null) {
uriAttribute = marker.getAttribute(EValidator.URI_ATTRIBUTE, null);
} else {
uriAttribute = (String)attributes.get(EValidator.URI_ATTRIBUTE);
}
if(uriAttribute != null) {
URI uriOfMarker = URI.createURI(uriAttribute);
try {
return domain.getResourceSet().getEObject(uriOfMarker, true);
} catch (MissingResourceException e) {
// happens after renaming of the file containing the marker (or a parent folder)
// try to retrieve eObject via fragment only (assuming that no two elements within resource-set share
// the same fragment).
return eObjectOfFragment(uriOfMarker, domain);
} catch (WrappedException e) {
// same as above, seems to depend on context which exception is thrown.
return eObjectOfFragment(uriOfMarker, domain);
}
}
return null;
}
/**
* E object of fragment.
*
* @param uri
* the uri
* @param domain
* the domain
* @return the e object
*/
public static EObject eObjectOfFragment(URI uri, EditingDomain domain) {
try {
for(Resource resource : domain.getResourceSet().getResources()) {
if(uri.fragment() == null) {
continue;
}
EObject eObjectOfMarker = resource.getEObject(uri.fragment());
if(eObjectOfMarker != null) {
return eObjectOfMarker;
}
}
} catch (WrappedException e) {
}
return null;
}
}
|