diff options
author | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2021-08-03 18:42:39 +0900 |
---|---|---|
committer | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2021-08-06 19:32:38 +0900 |
commit | be4f78978faba3d3ceb88df02a7f93a2e09ff1e0 (patch) | |
tree | 1f3f1a96251ac4f655c8a96fc33d5d4ee779cd06 /rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend | |
parent | 71ca7c6cab863767ef30c8bd05b2bbfda8731cb5 (diff) |
Initial commit
Bug-AGL: SPEC-4033
Signed-off-by: Kenji Hosokawa <khosokawa@jp.adit-jv.com>
Diffstat (limited to 'rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend')
-rw-r--r-- | rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend b/rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend new file mode 100644 index 0000000..9df27ec --- /dev/null +++ b/rba.tool.editor/src/rba/tool/editor/validation/validators/AreaValidator.xtend @@ -0,0 +1,74 @@ +package rba.tool.editor.validation.validators + +import java.util.function.Consumer +import org.eclipse.xtext.validation.Check +import org.eclipse.xtext.validation.EValidatorRegistrar +import rba.core.ExpressionType +import rba.core.RBACorePackage +import rba.tool.editor.messages.Messages +import rba.tool.editor.rbaEditorModel.CTag +import rba.tool.editor.validation.AbstractRBAModelValidator +import rba.view.Area +import rba.view.RBAViewPackage + +class AreaValidator extends AbstractRBAModelValidator { + + + private String AREA_VISIBILITY_TYPE = Messages.AREA_VISIBILITY_TYPE; + + private String AREA_ZORDER_TYPE = Messages.AREA_ZORDER_TYPE; + + override register(EValidatorRegistrar registrar) { + // not needed for classes used as ComposedCheck + } + + private Consumer<String> errorToName = [msg|error(msg, RBACorePackage.Literals.NAMED_ELEMENT__NAME, 0)]; + + @Check(NORMAL) + def checkArea(Area area) { +// for (var index = 0; index < area.tags.size; index.operator_plusPlus()) { +// val Tag tag = area.tags.get(index); +// if (!tag.stereotype.targetModelName.equals(Area.simpleName)) { +// error(String.format(TARGET_MODEL_NAME_MISMATCH, Area.simpleName, tag.stereotype.targetModelName), RBACorePackage.Literals.TAG__STEREOTYPE); +// return; +// } +// } + } + + @Check(NORMAL) + def check0RequiredFields(Area area) { +// println(this.class.simpleName) + val tags = area.tags; + + if(tags.isNullOrEmpty || !tags.filter(CTag).isEmpty) { + if(!doRequiredFieldsCheck(area)) return; + } + } + + def protected doRequiredFieldsCheck(Area area) { + var passed = false; + passed = ValidatorUtils.mustHaveVisibility(area, errorToName) + if(!passed) { + return false; + } + if(area.visibility.type != ExpressionType.VALUE) { + error(String.format(AREA_VISIBILITY_TYPE, area.name), RBACorePackage.Literals.ALLOCATABLE__VISIBILITY); + return false; + } + passed = ValidatorUtils.mustHaveZorder(area, errorToName); + if(!passed) { + return false; + } + if(area.zorder.type != ExpressionType.VALUE) { + error(String.format(AREA_ZORDER_TYPE, area.name), RBAViewPackage.Literals.AREA__ZORDER); + return false; + } + passed = ValidatorUtils.mustHaveLeastOneSize(area, errorToName); + if(!passed) { + return false; + } + + return true; + } + +} |