aboutsummaryrefslogtreecommitdiffstats
path: root/rba.tool.editor/src/rba/tool/editor/validation/validators/ThatOfOperatorValidator.xtend
blob: e6092c41f4874ddd3d72bc442d3a2b67b85acf9e (plain)
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
package rba.tool.editor.validation.validators

import org.eclipse.emf.ecore.EObject
import org.eclipse.xtext.validation.Check
import org.eclipse.xtext.validation.EValidatorRegistrar
import rba.core.Allocatable
import rba.core.ContentState
import rba.core.ExpressionType
import rba.core.ObjectReference
import rba.core.RBACorePackage
import rba.core.ThatOfOperator
import rba.core.impl.OperatorImpl
import rba.tool.editor.messages.Messages
import rba.tool.editor.validation.AbstractRBAModelValidator

class ThatOfOperatorValidator extends AbstractRBAModelValidator {

	private String THATOF_OPERAND_SIZE = Messages.THATOF_OPERAND_SIZE;

	private String THATOF_OPERAND_OBJECTREFERENCE = Messages.THATOF_OPERAND_OBJECTREFERENCE;

	private String THATOF_OPERAND_OBJECTREFERENCE_EQUAL = Messages.THATOF_OPERAND_OBJECTREFERENCE_EQUAL;

	private String THATOF_OPERAND_EXPRESSIONTYPE = Messages.THATOF_OPERAND_EXPRESSIONTYPE;

	override register(EValidatorRegistrar registrar) {
		// not needed for classes used as ComposedCheck
	}

	@Check(NORMAL)
	def checkThatOfOperator(ThatOfOperator thatOfOperator) {
		if (thatOfOperator.operand.size != 1) {
			error(THATOF_OPERAND_SIZE, RBACorePackage.Literals.OPERATOR__OPERAND);
			return;
		}
		for (operand : thatOfOperator.operand) {
			if (operand.type != ExpressionType.AREA && operand.type != ExpressionType.CONTENT_STATE && operand.type != ExpressionType.ZONE) {
				error(THATOF_OPERAND_EXPRESSIONTYPE, RBACorePackage.Literals.OPERATOR__OPERAND)
				return;
			}
		}
		var thatOfoperand = thatOfOperator.operand.get(0)
		if (thatOfoperand instanceof ObjectReference) {
			var objRef = thatOfoperand as ObjectReference
			if (objRef.refObject.name !== null) {
				var parent = getParent(thatOfOperator)
				if ((parent instanceof ContentState && objRef.refObject instanceof ContentState) || (parent instanceof Allocatable && objRef.refObject instanceof Allocatable)) {
				} else {
					error(THATOF_OPERAND_OBJECTREFERENCE_EQUAL, RBACorePackage.Literals.OPERATOR__OPERAND)
					return;
				}
			} else {
				error(THATOF_OPERAND_OBJECTREFERENCE, RBACorePackage.Literals.OPERATOR__OPERAND);
				return;
			}
		} else {
			error(THATOF_OPERAND_OBJECTREFERENCE, RBACorePackage.Literals.OPERATOR__OPERAND);
			return;
		}
	}

	def EObject getParent(ThatOfOperator thatOfOperator) {
		var parent = thatOfOperator.eContainer
		while (parent instanceof OperatorImpl) {
			parent = parent.eContainer
		}
		return parent;
	}
}