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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
/*****************************************************************************
* Copyright (c) 2013 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:
* CEA LIST - Initial API and implementation
*
*****************************************************************************/
package org.eclipse.papyrus.views.search.results;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.papyrus.infra.core.services.ServiceException;
import org.eclipse.papyrus.infra.services.openelement.service.OpenElementService;
import org.eclipse.papyrus.views.search.scope.ScopeEntry;
import org.eclipse.ui.PartInitException;
/**
*
* A match raised by the value of an attribute
*
*/
public class AttributeMatch extends ModelMatch {
/**
* The element containing the value of the attribute that matches
*/
protected Object target;
/**
* Similar to {@link AbstractResultEntry} but adds an information about which attribute raised the match and which element contains the value of
* the attribute that matches
*
* @param offset
* @param lenght
* @param target
* the element containing the value of the attribute that matches
* @param scopeEntry
* @param attribute
* the attribute that raised the match
*/
public AttributeMatch(int offset, int lenght, Object target, ScopeEntry scopeEntry, Object attribute) {
super(offset, lenght, attribute, scopeEntry);
this.target = target;
this.parent = new ResultEntry(target, scopeEntry);
recursiveHierarchy((AbstractResultEntry)parent, scopeEntry);
}
/**
*
* @see org.eclipse.papyrus.views.search.results.AbstractResultEntry#equals(java.lang.Object)
* In addition, it checks if target is the same as well.
*
* @param obj
* @return
*/
@Override
public boolean equals(Object obj) {
if(obj instanceof AttributeMatch) {
if(super.equals(obj)) {
if(((AttributeMatch)obj).getTarget().equals(this.target)) {
return true;
}
}
return false;
} else {
return false;
}
}
public Object getTarget() {
return target;
}
public void setTarget(Object target) {
this.target = target;
}
/**
*
* @see org.eclipse.papyrus.views.search.results.AbstractResultEntry#elementToDisplay()
*
* @return
*/
@Override
public Object elementToDisplay() {
return this;
}
/**
*
* @see org.eclipse.papyrus.views.search.results.AbstractResultEntry#elementToCheckFilterFor()
*
* @return
*/
@Override
public Object elementToCheckFilterFor() {
return target;
}
/**
*
* @see org.eclipse.papyrus.views.search.results.AbstractResultEntry#openElement()
*
* @return
*/
@Override
public Object openElement(OpenElementService service) throws ServiceException, PartInitException {
if(target instanceof EObject) {
return service.openSemanticElement((EObject)target);
}
return null;
}
}
|