Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java')
-rw-r--r--plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java63
1 files changed, 49 insertions, 14 deletions
diff --git a/plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java b/plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java
index d943b22b361..32937cc2b3d 100644
--- a/plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java
+++ b/plugins/uml/textedit/org.eclipse.papyrus.uml.textedit.port.xtext.ui/src/org/eclipse/papyrus/uml/textedit/port/xtext/ui/contribution/UMLPortEditorPropertyUtil.java
@@ -21,52 +21,87 @@ import org.eclipse.papyrus.uml.tools.utils.PropertyUtil;
import org.eclipse.papyrus.uml.tools.utils.TypeUtil;
import org.eclipse.papyrus.uml.xtext.integration.CompletionProposalUtils;
import org.eclipse.uml2.uml.Port;
-import org.eclipse.uml2.uml.Property;
+import org.eclipse.uml2.uml.util.UMLSwitch;
public class UMLPortEditorPropertyUtil extends PortUtil {
- public static String getLabel(Property property) {
+ public static String getLabel(Port port) {
StringBuffer buffer = new StringBuffer();
// visibility
buffer.append(" ");
- buffer.append(NamedElementUtil.getVisibilityAsSign(property));
+ buffer.append(NamedElementUtil.getVisibilityAsSign(port));
// derived property
- buffer.append(getDerived(property));
+ buffer.append(getDerived(port));
// name
buffer.append(" ");
- buffer.append(ALFIDConverter.nameToID(getName(property)));
+ buffer.append(ALFIDConverter.nameToID(getName(port)));
// is conjugated
- if (((Port) property).isConjugated()) {
+ if (port.isConjugated()) {
buffer.append(": ~");
} else {
buffer.append(": ");
}
// type
- if (property.getType() != null) {
+ if (port.getType() != null) {
- buffer.append(CompletionProposalUtils.getQualifiedNameLabelWithSufficientDepth(property.getType(),
- property.getNamespace()));
+ buffer.append(CompletionProposalUtils.getQualifiedNameLabelWithSufficientDepth(port.getType(),
+ port.getNamespace()));
} else {
buffer.append(TypeUtil.UNDEFINED_TYPE_NAME);
}
// multiplicity -> do not display [1]
- String multiplicity = MultiplicityElementUtil.getMultiplicityAsString(property);
+ String multiplicity = MultiplicityElementUtil.getMultiplicityAsString(port);
if (!multiplicity.trim().equals("[1]")) {
buffer.append(multiplicity);
}
// property modifiers
buffer.append(" ");
- buffer.append(PropertyUtil.getModifiersAsString(property, false));
+ buffer.append(PropertyUtil.getModifiersAsString(port, false));
// default value
- if (property.getDefault() != null) {
- buffer.append(" = ");
- buffer.append("\"" + property.getDefault() + "\"");
+ if (port.getDefaultValue() != null) {
+ String defaultValue = new UMLSwitch<String>() {
+ @Override
+ public String caseLiteralBoolean(org.eclipse.uml2.uml.LiteralBoolean object) {
+ return Boolean.toString(object.booleanValue());
+ }
+
+ @Override
+ public String caseLiteralInteger(org.eclipse.uml2.uml.LiteralInteger object) {
+ return Integer.toString(object.integerValue());
+ }
+
+ @Override
+ public String caseLiteralNull(org.eclipse.uml2.uml.LiteralNull object) {
+ return "null"; //$NON-NLS-1$
+ }
+
+ @Override
+ public String caseLiteralString(org.eclipse.uml2.uml.LiteralString object) {
+ return "\"" + object.stringValue() + "\"";
+ }
+
+ @Override
+ public String caseLiteralReal(org.eclipse.uml2.uml.LiteralReal object) {
+ return Double.toString(object.getValue());
+ }
+
+ @Override
+ public String caseLiteralUnlimitedNatural(org.eclipse.uml2.uml.LiteralUnlimitedNatural object) {
+ return object.getValue() < 0 ? "*" : Integer.toString(object.getValue());
+ }
+
+ }.doSwitch(port.getDefaultValue());
+
+ if (defaultValue != null) {
+ buffer.append(" = ");
+ buffer.append(defaultValue);
+ }
}
return buffer.toString();

Back to the top