You can combine entry, during, and
exit actions that execute the same tasks in a state.
By combining state actions that execute the same tasks, you eliminate redundant code. For example:
| Separate Actions | Equivalent Combined Actions |
|---|---|
entry: y = 0; y=y+1; during: y=y+1; |
entry: y = 0; entry, during: y=y+1; |
en: fcn1(); fcn2(); du: fcn1(); ex: fcn1(); |
en, du, ex: fcn1(); en: fcn2(); |
Combining state actions this way produces the same chart execution behavior (semantics) and generates the same code as the equivalent separate actions.
Combine a set of entry, during, and/or
exit actions that perform the same task as a comma-separated list in a
state. Here is the syntax:
entry, during, exit: task1; task2;...taskN;
You can also use the equivalent abbreviations:
en, du, ex: task1; task2;...taskN;
You can use any combination of the three actions. For example, the following combinations are valid:
en, du:
en, ex:
du, ex:
en, du, ex:
You can combine actions in any order in the comma-separated list. For example,
en, du: gives the same result as du, en:.
You cannot combine two or more actions of the same type. For example, the following combinations are invalid:
en, en:
ex, en, ex:
du, du, ex:
If you combine multiple actions of the same type, you receive a warning that the chart executes the action only once.
States execute combined actions in the same order as they execute separate actions:
Entry actions first, from top to bottom in the order they appear
in the state
During actions second, from top to bottom
Exit actions last, from top to bottom
The order in which you combine actions does not affect state execution behavior. For example:
| This state... | Executes actions in this order... |
|---|---|
|
|
|
|
|
|
|
|
Do not combine multiple actions of the same type.
Do not create data, events, or messages that have the same name as the action
keywords: entry, en, during,
du, exit, ex.