From d09fb9fa4b12eb4736f944307b8b151f94d6c20d Mon Sep 17 00:00:00 2001 From: Robert von Burg Date: Tue, 27 Aug 2019 08:33:40 +0200 Subject: [PATCH] [New] Added StringParameter(Enum) and .setValue(Enum) --- .../model/parameter/StringParameter.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/li.strolch.model/src/main/java/li/strolch/model/parameter/StringParameter.java b/li.strolch.model/src/main/java/li/strolch/model/parameter/StringParameter.java index 32d77b776..071282a85 100644 --- a/li.strolch.model/src/main/java/li/strolch/model/parameter/StringParameter.java +++ b/li.strolch.model/src/main/java/li/strolch/model/parameter/StringParameter.java @@ -15,6 +15,9 @@ */ package li.strolch.model.parameter; +import java.text.MessageFormat; + +import li.strolch.exception.StrolchException; import li.strolch.model.StrolchValueType; import li.strolch.model.visitor.StrolchElementVisitor; import li.strolch.utils.dbc.DBC; @@ -48,6 +51,21 @@ public class StringParameter extends AbstractParameter { setValue(value); } + /** + * Default constructor + * + * @param id + * the id + * @param name + * the name + * @param value + * the value + */ + public StringParameter(String id, String name, Enum value) { + super(id, name); + setValueE(value); + } + @Override public String getType() { return StrolchValueType.STRING.getType(); @@ -76,6 +94,17 @@ public class StringParameter extends AbstractParameter { this.value = value; } + public void setValueE(Enum value) { + assertNotReadonly(); + if (value == null) { + String msg = "Can not set null value on Parameter {0}"; //$NON-NLS-1$ + msg = MessageFormat.format(msg, getLocator()); + throw new StrolchException(msg); + } + validateValue(value.name()); + this.value = value.name(); + } + @Override public void setValueFrom(Parameter parameter) { assertNotReadonly();