summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/corelib/statemachine/qstatemachine.cpp13
-rw-r--r--tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp12
2 files changed, 24 insertions, 1 deletions
diff --git a/src/corelib/statemachine/qstatemachine.cpp b/src/corelib/statemachine/qstatemachine.cpp
index f1ca421de2..6412d7a0a9 100644
--- a/src/corelib/statemachine/qstatemachine.cpp
+++ b/src/corelib/statemachine/qstatemachine.cpp
@@ -1341,6 +1341,9 @@ void QStateMachinePrivate::_q_start()
#ifndef QT_NO_ANIMATION
QList<QAbstractAnimation*> selectedAnimations = selectAnimations(transitions);
#endif
+ // enterStates() will set stopProcessingReason to Finished if a final
+ // state is entered.
+ stopProcessingReason = EventQueueEmpty;
enterStates(&nullEvent, exitedStates, enteredStates, statesForDefaultEntry,
assignmentsForEnteredStates
#ifndef QT_NO_ANIMATION
@@ -1355,7 +1358,15 @@ void QStateMachinePrivate::_q_start()
emit q->started();
- _q_process();
+ if (stopProcessingReason == Finished) {
+ // The state machine immediately reached a final state.
+ processingScheduled = false;
+ state = NotRunning;
+ unregisterAllTransitions();
+ emit q->finished();
+ } else {
+ _q_process();
+ }
}
void QStateMachinePrivate::_q_process()
diff --git a/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp b/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
index b048f9c2f0..64f8d3aa9b 100644
--- a/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
+++ b/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
@@ -193,6 +193,7 @@ private slots:
void setPropertyAfterRestore();
void transitionWithNoTarget_data();
void transitionWithNoTarget();
+ void initialStateIsFinal();
void restorePropertiesSimple();
void restoreProperties2();
@@ -4196,6 +4197,17 @@ void tst_QStateMachine::transitionWithNoTarget()
delete object;
}
+void tst_QStateMachine::initialStateIsFinal()
+{
+ QStateMachine machine;
+ QFinalState *f = new QFinalState(&machine);
+ machine.setInitialState(f);
+ QSignalSpy finishedSpy(&machine, SIGNAL(finished()));
+ machine.start();
+ QTRY_VERIFY(machine.configuration().contains(f));
+ QTRY_COMPARE(finishedSpy.count(), 1);
+}
+
class PropertyObject : public QObject
{
Q_OBJECT