Skip to main content
aboutsummaryrefslogtreecommitdiffstats
blob: 8d40a11bb9947271cdc06ab94fdb7e8c9a668ecb (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
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
/******************************************************************************
 * Copyright (c) 2006, 2020 Borland Software Corporation, CEA LIST, Artal and others
 * 
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License 2.0
 * which accompanies this distribution, and is available at
 * https://www.eclipse.org/legal/epl-2.0/ 
 * 
 * SPDX-License-Identifier: EPL-2.0
 *
 * Contributors: 
 *    Dmitry Stadnik (Borland) - initial API and implementation
 *    Alexander Shatalin (Borland) - initial API and implementation
 *    Aurelien Didier (ARTAL) - aurelien.didier51@gmail.com - Bug 569174
 *****************************************************************************/

«IMPORT 'http://www.eclipse.org/papyrus/gmf/2020/GenModel'»
«IMPORT 'http://www.eclipse.org/papyrus/gmf/2020/GraphicalDefinition'»

«DEFINE _constructor FOR gmfgen::GenLink-»
	«EXPAND xpt::Common::generatedMemberComment»
	public «editPartClassName»(org.eclipse.gmf.runtime.notation.View view) {
		super(view);
	}
«ENDDEFINE»

«DEFINE createDefaultEditPoliciesBody FOR gmfgen::GenLink-»
	super.createDefaultEditPolicies();
	«IF null = modelFacet-»
		installEditPolicy(org.eclipse.gef.EditPolicy.COMPONENT_ROLE, new org.eclipse.gmf.runtime.diagram.ui.editpolicies.ViewComponentEditPolicy());
	«ENDIF-»
	«EXPAND xpt::diagram::editparts::Common::installSemanticEditPolicy-»
	«EXPAND installGraphicalNodeEditPolicy-»
	«EXPAND xpt::diagram::editparts::Common::behaviour FOR self-»
	«EXPAND additionalEditPolicies-»
«ENDDEFINE»

«DEFINE installGraphicalNodeEditPolicy FOR gmfgen::GenLink-»
«ENDDEFINE»

«DEFINE additionalEditPolicies FOR gmfgen::GenLink»«ENDDEFINE»

«DEFINE addFixedChild FOR gmfgen::GenLink-»
«IF labels->notEmpty() and (labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ParentAssignedViewmap)) 
	or labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ModeledViewmap))) -»
	«EXPAND xpt::Common::generatedMemberComment»
	protected boolean addFixedChild(org.eclipse.gef.EditPart childEditPart) {
		«FOREACH labels AS label-»
			«EXPAND addLabel(label) FOR label.viewmap-»
		«ENDFOREACH-»
		return false;
	}
«ENDIF»
«ENDDEFINE»

// Note, condition in addFixedChild template above should be changed if addLabel support added for Viewmaps other than ParentAssignedViewmap
«DEFINE addLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::Viewmap»«ENDDEFINE»
«DEFINE addLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::ParentAssignedViewmap-»
	«EXPAND addLabelCommonCode(getterName, label)-»
«ENDDEFINE»

«DEFINE addLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::ModeledViewmap-»
	«LET figureModel.oclAsType(gmfgraph::DiagramLabel).accessor AS labelAccessor-»
		«IF not labelAccessor.oclIsUndefined() and not labelAccessor.accessor.oclIsUndefined()-»
			«EXPAND addLabelCommonCode(labelAccessor.accessor, label)-»
		«ENDIF-»
	«ENDLET-»
«ENDDEFINE»

«DEFINE addLabelCommonCode(getterName : String, label : gmfgen::GenLinkLabel) FOR gmfgen::Viewmap-»
 	if (childEditPart instanceof «label.getEditPartQualifiedClassName()») {
 		((«label.getEditPartQualifiedClassName()») childEditPart).«EXPAND impl::diagram::editparts::TextAware::labelSetterName»(
 				getPrimaryShape().«getterName»());
 				return true;
 	}
«ENDDEFINE»

«DEFINE removeFixedChild FOR gmfgen::GenLink-»
«IF labels->notEmpty() and (labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ParentAssignedViewmap)) 
	or labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ModeledViewmap))) -»
	«EXPAND xpt::Common::generatedMemberComment»
	protected boolean removeFixedChild(org.eclipse.gef.EditPart childEditPart) {
		«FOREACH labels AS label-»
			«EXPAND removeLabel(label) FOR label.viewmap-»
		«ENDFOREACH-»
		return false;
	}
«ENDIF»
«ENDDEFINE»

// Note, condition in removeFixedChild template above should be changed if removeLabel support added for Viewmaps other than ParentAssignedViewmap
«DEFINE removeLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::Viewmap»«ENDDEFINE»
«DEFINE removeLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::ParentAssignedViewmap-»
	«EXPAND removeLabelCommonCode FOR label-»
«ENDDEFINE»

«DEFINE removeLabel(label : gmfgen::GenLinkLabel) FOR gmfgen::ModeledViewmap-»
	«EXPAND removeLabelCommonCode FOR label-»
«ENDDEFINE»

«DEFINE removeLabelCommonCode FOR gmfgen::GenLinkLabel-»
	if (childEditPart instanceof «getEditPartQualifiedClassName()») {
 		return true;
 	}
«ENDDEFINE»

«DEFINE addChildVisual FOR gmfgen::GenLink-»
«IF labels->notEmpty() and (labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ParentAssignedViewmap))
	or labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ModeledViewmap)))-»
	«EXPAND xpt::Common::generatedMemberComment»
	protected void addChildVisual(org.eclipse.gef.EditPart childEditPart, int index) {
		if (addFixedChild(childEditPart)) {
			return;
		}
		super.addChildVisual(childEditPart, index);
	}
«ENDIF»
«ENDDEFINE»

«DEFINE removeChildVisual FOR gmfgen::GenLink-»
«IF labels->notEmpty() and (labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ParentAssignedViewmap))
	or labels->exists(l | l.viewmap.oclIsKindOf(gmfgen::ModeledViewmap)))-»
	«EXPAND xpt::Common::generatedMemberComment»
	protected void removeChildVisual(org.eclipse.gef.EditPart childEditPart) {
		if (removeFixedChild(childEditPart)) {
			return;
		}
		super.removeChildVisual(childEditPart);
	}
«ENDIF»
«ENDDEFINE»

«DEFINE createLinkFigure FOR gmfgen::GenLink-»
	«EXPAND xpt::Common::generatedMemberComment(
		'Creates figure for this edit part.\n' + 
		'\n' + 
		'Body of this method does not depend on settings in generation model\n' + 
		'so you may safely remove <i>generated</i> tag and modify it.\n'
	)»
	«EXPAND createLinkFigure(self) FOR viewmap-»
«ENDDEFINE»

«DEFINE createLinkFigure(link : gmfgen::GenLink) FOR gmfgen::Viewmap-»
	«ERROR 'Unknown viewmap: ' + self.repr()-»
«ENDDEFINE»

«DEFINE createLinkFigure(link : gmfgen::GenLink) FOR gmfgen::ModeledViewmap-»
		protected org.eclipse.draw2d.Connection createConnectionFigure() {
			return new «EXPAND _modeledViewmapFigureFQN»();
		}
		
		«EXPAND xpt::Common::generatedMemberComment»
		public «EXPAND _modeledViewmapFigureFQN» getPrimaryShape() {
			return («EXPAND _modeledViewmapFigureFQN») getFigure();
		}
		
		«EXPAND impl::diagram::editparts::viewmaps::modeledViewmapProducer::viewmapClassBody-»
«ENDDEFINE»

«DEFINE _modeledViewmapFigureFQN FOR gmfgen::ModeledViewmap-»
«EXPAND impl::diagram::editparts::viewmaps::modeledViewmapProducer::viewmapFigureFQN FOR self-»
«ENDDEFINE»

«DEFINE createLinkFigure(link : gmfgen::GenLink) FOR gmfgen::FigureViewmap-»
	«LET (if figureQualifiedClassName = null then 'org.eclipse.gmf.runtime.draw2d.ui.figures.PolylineConnectionEx' else figureQualifiedClassName endif) AS fqn-»
		protected org.eclipse.draw2d.Connection createConnectionFigure() {
			return new «fqn»();
		}

		«EXPAND xpt::Common::generatedMemberComment»
		public «fqn» getPrimaryShape() {
			return («fqn») getFigure();
		}
	«ENDLET-»
«ENDDEFINE»

«DEFINE createLinkFigure(link : gmfgen::GenLink) FOR gmfgen::SnippetViewmap»
	protected org.eclipse.draw2d.Connection createConnectionFigure() {
		return «body»;
	}
«ENDDEFINE»

«DEFINE createLinkFigure(link : gmfgen::GenLink) FOR gmfgen::InnerClassViewmap»
	protected org.eclipse.draw2d.Connection createConnectionFigure() {
		return new «className»();
	}

	«EXPAND xpt::Common::generatedMemberComment»
	public «className» getPrimaryShape() {
		return («className») getFigure();
	}

	«classBody»
«ENDDEFINE»

Back to the top