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
121
122
123
124
125
|
/*****************************************************************************
* 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:
* Vincent Lorenzo (CEA LIST) vincent.lorenzo@cea.fr - Initial API and implementation
*
*****************************************************************************/
package org.eclipse.papyrus.sysml.facets.query.value.setter;
import java.util.List;
import org.eclipse.core.runtime.Assert;
import org.eclipse.emf.common.util.EList;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.edit.domain.EditingDomain;
import org.eclipse.emf.facet.infra.query.core.exception.ModelQueryExecutionException;
import org.eclipse.emf.facet.infra.query.core.java.IJavaModelQueryWithEditingDomain;
import org.eclipse.emf.facet.infra.query.core.java.ParameterValueList;
import org.eclipse.emf.facet.infra.query.runtime.ModelQueryParameterValue;
import org.eclipse.gmf.runtime.common.core.command.CompositeCommand;
import org.eclipse.gmf.runtime.common.core.command.ICommand;
import org.eclipse.gmf.runtime.emf.type.core.requests.CreateRelationshipRequest;
import org.eclipse.gmf.runtime.emf.type.core.requests.DestroyElementRequest;
import org.eclipse.papyrus.commands.wrappers.GMFtoEMFCommandWrapper;
import org.eclipse.papyrus.gmf.diagram.common.commands.IdentityCommandWithNotification;
import org.eclipse.papyrus.infra.services.edit.service.ElementEditServiceUtils;
import org.eclipse.papyrus.infra.services.edit.service.IElementEditService;
import org.eclipse.papyrus.infra.widgets.toolbox.notification.Type;
import org.eclipse.papyrus.sysml.facets.messages.Messages;
import org.eclipse.papyrus.sysml.requirements.Requirement;
import org.eclipse.papyrus.sysml.util.ElementUtil;
import org.eclipse.papyrus.uml.service.types.element.UMLElementTypes;
import org.eclipse.uml2.uml.Dependency;
import org.eclipse.uml2.uml.DirectedRelationship;
import org.eclipse.uml2.uml.NamedElement;
import org.eclipse.uml2.uml.profile.l2.L2Package;
import org.eclipse.uml2.uml.profile.l2.Refine;
import org.eclipse.uml2.uml.util.UMLUtil;
/** Query to set the derived attribute "refinedBy" of the requirement */
public class SetRequirementRefinedByQuery implements IJavaModelQueryWithEditingDomain<NamedElement, EObject> {
/**
*
* @see org.eclipse.emf.facet.infra.query.core.java.IJavaModelQuery#evaluate(org.eclipse.emf.ecore.EObject,
* org.eclipse.emf.facet.infra.query.core.java.ParameterValueList)
*
* @param context
* @param parameterValues
* @return
* @throws ModelQueryExecutionException
*/
public EObject evaluate(final NamedElement context, final ParameterValueList parameterValues) throws ModelQueryExecutionException {
//nothing to do
return null;
}
/**
*
* @see org.eclipse.emf.facet.infra.query.core.java.IJavaModelQueryWithEditingDomain#evaluate(org.eclipse.emf.ecore.EObject,
* org.eclipse.emf.facet.infra.query.core.java.ParameterValueList, org.eclipse.emf.edit.domain.EditingDomain)
*
* @param context
* @param parameterValues
* @param editingDomain
* @return
* @throws ModelQueryExecutionException
*/
public EObject evaluate(NamedElement context, ParameterValueList parameterValues, EditingDomain editingDomain) throws ModelQueryExecutionException {
CompositeCommand cmd = new CompositeCommand("Edit the feature /refinedBy"); //$NON-NLS-1$
if(ElementUtil.getStereotypeApplication(context, Requirement.class) != null) {
if(!context.getNearestPackage().isProfileApplied(UMLUtil.getProfile(L2Package.eINSTANCE))) {
cmd.add(new IdentityCommandWithNotification(Messages.SetRequirementTextQuery_AssignmentCantBeDone, Messages.SetRequirementRefinedByQuery_StandardIsNotAppliedOnTheModel, Type.ERROR));
} else {
Requirement req = UMLUtil.getStereotypeApplication(context, Requirement.class);
EList<DirectedRelationship> dependencies = context.getTargetDirectedRelationships();
EList<NamedElement> currentRefinedBy = req.getRefinedBy();
ModelQueryParameterValue object = parameterValues.get(0);
Object values = object.getValue();
Assert.isTrue(values instanceof List<?>);
List<?> newRefinedBy = (List<?>)values;
//we destroy the unnecessary Refine
for(DirectedRelationship current : dependencies) {
if(UMLUtil.getStereotypeApplication(current, Refine.class) != null) {
EList<NamedElement> clients = ((Dependency)current).getClients();
//we assume that there is only one client
if(clients.size() == 1) {
NamedElement client = clients.get(0);
if(!newRefinedBy.contains(client)) {//we destroy this dependencies
IElementEditService provider = ElementEditServiceUtils.getCommandProvider(current);
DestroyElementRequest request = new DestroyElementRequest(current, false);
ICommand destroyCommand = provider.getEditCommand(request);
cmd.add(destroyCommand);
}
}
}
}
for(Object current : (List<?>)values) {
//we create the Trace only if it doesn't exist
Assert.isTrue(current instanceof NamedElement);
if(!currentRefinedBy.contains(current)) {
IElementEditService provider = ElementEditServiceUtils.getCommandProvider(context);
CreateRelationshipRequest createRequest = new CreateRelationshipRequest(context.getNearestPackage(), (NamedElement)current, context, UMLElementTypes.REFINE);
cmd.add(provider.getEditCommand(createRequest));
}
}
}
} else {
cmd.add(new IdentityCommandWithNotification(Messages.SetRequirementTextQuery_AssignmentCantBeDone, Messages.SetRequirementTextQuery_NotASysMLRequirement, Type.ERROR));
}
editingDomain.getCommandStack().execute(new GMFtoEMFCommandWrapper(cmd));
return null;
}
}
|