blob: fe4dc3446d9dc3c8e71a29a7a47b61c6c75a27e0 (
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
|
package rba.tool.editor.validation.validators
import org.eclipse.xtext.validation.Check
import org.eclipse.xtext.validation.EValidatorRegistrar
import rba.core.ExpressionType
import rba.core.RBACorePackage
import rba.sound.MuteLowerPriority
import rba.tool.editor.messages.Messages
import rba.tool.editor.validation.AbstractRBAModelValidator
class MuteLowerPriorityValidator extends AbstractRBAModelValidator {
private static final String OperatorName = MuteLowerPriority.simpleName
override register(EValidatorRegistrar registrar) {
// not needed for classes used as ComposedCheck
}
@Check(NORMAL)
def checkMuteLowerPriority(MuteLowerPriority muteLowerPriority) {
if (muteLowerPriority.operand.size != 2) {
error(String.format(Messages.OPERAND_SIZE_TWO, OperatorName), RBACorePackage.Literals.OPERATOR__OPERAND, 0)
return;
}
var firstArgument = muteLowerPriority.operand.get(0)
if (firstArgument.type != ExpressionType::ZONE) {
error(String.format(Messages.ARGUMENT_MUST_ZONE, OperatorName),
RBACorePackage.Literals.OPERATOR__OPERAND, 0)
return;
}
var secondArgument = muteLowerPriority.operand.get(1)
if (secondArgument.type != ExpressionType::ZONE) {
error(String.format(Messages.ARGUMENT_MUST_ZONE, OperatorName),
RBACorePackage.Literals.OPERATOR__OPERAND, 1)
return;
}
}
}
|