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/OffsetValidator.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/OffsetValidator.xtend')
-rw-r--r-- | rba.tool.editor/src/rba/tool/editor/validation/validators/OffsetValidator.xtend | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/rba.tool.editor/src/rba/tool/editor/validation/validators/OffsetValidator.xtend b/rba.tool.editor/src/rba/tool/editor/validation/validators/OffsetValidator.xtend new file mode 100644 index 0000000..57ea7b4 --- /dev/null +++ b/rba.tool.editor/src/rba/tool/editor/validation/validators/OffsetValidator.xtend @@ -0,0 +1,64 @@ +package rba.tool.editor.validation.validators + +import org.eclipse.xtext.validation.Check +import org.eclipse.xtext.validation.EValidatorRegistrar +import rba.tool.editor.messages.Messages +import rba.tool.editor.validation.AbstractRBAModelValidator +import rba.view.Area +import rba.view.Offset +import rba.view.PositionContainer +import rba.view.RBAViewPackage +import rba.view.SizeIdentifier +import rba.view.SizeReference + +class OffsetValidator extends AbstractRBAModelValidator { + + private String OFFSET_SIZE_DUPLICATE = Messages.OFFSET_SIZE_DUPLICATE; + + private String OFFSET_SIZE_AREA_REF = Messages.OFFSET_SIZE_AREA_REF; + + override register(EValidatorRegistrar registrar) { + // not needed for classes used as ComposedCheck + } + + @Check(NORMAL) + def checkOffset(Offset offset) { + var parent = offset.eContainer as PositionContainer + for (Offset target : parent.offset) { + if (target != offset) { + if (target.size.size == offset.size.size) { + warning(OFFSET_SIZE_DUPLICATE, RBAViewPackage.Literals.OFFSET__SIZE); + return; + } + } + } + + if (!hasSameSizeInArea(parent, offset)) { + warning(OFFSET_SIZE_AREA_REF, RBAViewPackage.Literals.OFFSET__SIZE); + return; + } + } + + def hasSameSizeInArea(PositionContainer parent, Offset offset) { + var chk = false; + + if (!(parent.area instanceof Area)) { + return false + } + + var area = parent.area as Area + for (SizeIdentifier sizeId : area.size) { + if (sizeId instanceof SizeReference) { + var sizeRef = sizeId as SizeReference + if (sizeRef.size == offset.size.size) { + chk = true + } + } + } + if (chk == true) { + return true; + } + + return false; + } +} |