No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
Constraints | Constraints are helpful when adding business rules to your application. [[Constraints|Constraints are further discussed here.]] | ||
Guards are what you set on [[UML – State machines|State machine transitions as described here]]. | Guards are what you set on [[UML – State machines|State machine transitions as described here]]. | ||
== | == GuardConstraints Explained == | ||
GuardContraints | GuardContraints let you use the Constraints definitions of the class when defining a Guard. In other words, GuardConstraints is a way to avoid the repetition of rules. You may have constraints (rules on the class) and guards (rules on a class for checking transition of state). | ||
The GuardConstraints for a guard is a way to say that one or many of the constraints work as the implementation of the guard. | The GuardConstraints for a guard is a way to say that one or many of the constraints work as the implementation of the guard. | ||
This way rules that must be valid on many transitions can be defined once as a constraint. It is also the best way to | This way, rules that must be valid on many transitions can be defined once as a constraint. It is also the best way for users to have insight into why a transition is disabled since Constraints are associated with a message – something that a guard is not. | ||
You associate Constraints with transitions to create a GuardConstraint by right clicking the transition on the state diagram – choose Edit GuardConstraints… | You associate Constraints with transitions to create a GuardConstraint by right-clicking the transition on the state diagram – choose Edit GuardConstraints… | ||
@Linus; | @Linus; Before version 2015-03-27, this was not fully implemented – but now it is. | ||
[[File:Constraints - 1.png|frameless|531x531px]] | [[File:Constraints - 1.png|frameless|531x531px]] | ||
Above I add two constraints to the “Thing” class. | Above, I add two constraints to the “Thing” class. | ||
If I | If I add a state machine now – with a transition – I can use these constraints as the guard implementation: | ||
[[File:Constraints - 2.png|frameless|594x594px]] | [[File:Constraints - 2.png|frameless|594x594px]] | ||
Having done this I get this effect: | Having done this, I get this effect: | ||
[[File:Constraints - 3.png|frameless|489x489px]] | [[File:Constraints - 3.png|frameless|489x489px]] | ||
The Constraints show | The Constraints show as a broken red – the Trigger1 is disabled (the guard does this). | ||
When I fix one of the constraints: | When I fix one of the constraints: | ||
Line 34: | Line 34: | ||
The list of errors is reduced but Trigger1 is not available yet. | The list of errors is reduced but Trigger1 is not available yet. | ||
And fixing the other constraint | And fixing the other constraint enables Trigger1: | ||
[[File:Constraints - 5.png|frameless|496x496px]] | [[File:Constraints - 5.png|frameless|496x496px]] |
Revision as of 06:33, 31 January 2023
Constraints are helpful when adding business rules to your application. Constraints are further discussed here.
Guards are what you set on State machine transitions as described here.
GuardConstraints Explained
GuardContraints let you use the Constraints definitions of the class when defining a Guard. In other words, GuardConstraints is a way to avoid the repetition of rules. You may have constraints (rules on the class) and guards (rules on a class for checking transition of state).
The GuardConstraints for a guard is a way to say that one or many of the constraints work as the implementation of the guard.
This way, rules that must be valid on many transitions can be defined once as a constraint. It is also the best way for users to have insight into why a transition is disabled since Constraints are associated with a message – something that a guard is not.
You associate Constraints with transitions to create a GuardConstraint by right-clicking the transition on the state diagram – choose Edit GuardConstraints…
@Linus; Before version 2015-03-27, this was not fully implemented – but now it is.
Above, I add two constraints to the “Thing” class.
If I add a state machine now – with a transition – I can use these constraints as the guard implementation:
Having done this, I get this effect:
The Constraints show as a broken red – the Trigger1 is disabled (the guard does this).
When I fix one of the constraints:
The list of errors is reduced but Trigger1 is not available yet.
And fixing the other constraint enables Trigger1: