ScxmlStateMachine QML Type

Provides an interface to the state machines created from SCXML files. More...

Import Statement: import QtScxml 5.8
Since: Qt 5.7
Instantiates: QScxmlStateMachine

Properties

Signals

Methods

Detailed Description

The ScxmlStateMachine type is an implementation of the State Chart XML (SCXML).

All states that are defined in the SCXML file are accessible as properties of this type. These properties are boolean values and indicate whether the state is active or inactive.

Property Documentation

dataModel : ScxmlDataModel

The data model to be used for this state machine.

SCXML data models are described in SCXML Specification - 5 Data Model and Data Manipulation. For more information about supported data models, see SCXML Compliance.

Changing the data model when the state machine has been initialized is not specified in the SCXML standard and leads to undefined behavior.

See also QScxmlDataModel, QScxmlNullDataModel, QScxmlEcmaScriptDataModel, and QScxmlCppDataModel.


initialValues : var

The initial values to be used for setting up the data model.


initialized : bool

This read-only property is set to true if the state machine has been initialized, false otherwise.


invoked : bool

Whether the state machine was invoked from an outer state machine.

This read-only property is set to true when the state machine was started as a service with the <invoke> element, false otherwise.


invokedServices : list

A list of SCXML services that were invoked from the main state machine (possibly recursively).


loader : Loader

The loader that is currently used to resolve and load URIs for the state machine.


name : string

The name of the state machine as set by the name attribute of the <scxml> tag.


parseErrors : var

The list of parse errors that occurred while creating a state machine from an SCXML file.


running : bool

The running state of this state machine.


sessionId : string

The session ID of the current state machine.

The session ID is used for message routing between parent and child state machines. If a state machine is started by an <invoke> element, any event it sends will have the invokeid field set to the session ID. The state machine will use the origin of an event (which is set by the target or targetexpr attribute in a <send> element) to dispatch messages to the correct child state machine.


Signal Documentation

finished()

This signal is emitted when the state machine reaches a top-level final state.

The corresponding signal handler is onFinished().


log(string label, string msg)

This signal is emitted if a <log> tag is used in the SCXML. label is the value of the label attribute of the <log> tag. msg is the value of the evaluated expr attribute of the <log> tag. If there is no expr attribute, a null string will be returned.

The corresponding signal handler is onLog().


reachedStableState()

This signal is emitted when the event queue is empty at the end of a macro step or when a final state is reached.

The corresponding signal handler is onreachedStableState().


Method Documentation

activeStateNames(bool compress)

Retrieves a list of state names of all active states.

When a state is active, all its parent states are active by definition. When compress is true (the default), the parent states are filtered out and only the leaf states are returned. When it is false, the full list of active states is returned.


cancelDelayedEvent(string sendId)

Cancels a delayed event with the specified sendId.


init()

Initializes the state machine by setting the initial values for <data> elements and executing any <script> tags of the <scxml> tag. The initial data values are taken from the initialValues property.

Returns false if parse errors occur or if any of the initialization steps fail. Returns true otherwise.


isActive(string scxmlStateName)

Returns true if the state specified by scxmlStateName is active, false otherwise.


isDispatchableTarget(string target)

Returns true if a message to target can be dispatched by this state machine.

Valid targets are:

  • #_parent for the parent state machine if the current state machine is started by <invoke>
  • #_internal for the current state machine
  • #_scxml_sessionid, where sessionid is the session ID of the current state machine
  • #_servicename, where servicename is the ID or name of a service started with <invoke> by this state machine

start()

Starts this state machine. The machine resets its configuration and transitions to the initial state. When a final top-level state is entered, the machine emits the finished() signal.

See also stop() and finished().


stateNames(bool compress)

Retrieves a list of state names of all states.

When compress is true (the default), the states that contain child states is filtered out and only the leaf states is returned. When it is false, the full list of all states is returned.

The returned list does not contain the states of possible nested state machines.

Note: The order of the state names in the list is the order in which the states occurred in the SCXML document.


stop()

Stops this state machine. The machine will not execute any further state transitions. Its running property is set to false.

See also start() and finished().


submitEvent(event)

Submits the SCXML event event to the internal or external event queue depending on the priority of the event.

When a delay is set, the event will be queued for delivery after the timeout has passed. The state machine takes ownership of the event and deletes it after processing.

See also QScxmlEvent.


submitEvent(string eventName, var data)

A utility method to create and submit an external event with the specified eventName as the name and data as the payload data (optional).


© 2019 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.