source: trunk/src/corelib/statemachine/qfinalstate.cpp@ 794

Last change on this file since 794 was 651, checked in by Dmitry A. Kuminov, 15 years ago

trunk: Merged in qt 4.6.2 sources.

  • Property svn:eol-style set to native
File size: 3.8 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation ([email protected])
6**
7** This file is part of the QtCore module of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL$
10** Commercial Usage
11** Licensees holding valid Qt Commercial licenses may use this file in
12** accordance with the Qt Commercial License Agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and Nokia.
15**
16** GNU Lesser General Public License Usage
17** Alternatively, this file may be used under the terms of the GNU Lesser
18** General Public License version 2.1 as published by the Free Software
19** Foundation and appearing in the file LICENSE.LGPL included in the
20** packaging of this file. Please review the following information to
21** ensure the GNU Lesser General Public License version 2.1 requirements
22** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23**
24** In addition, as a special exception, Nokia gives you certain additional
25** rights. These rights are described in the Nokia Qt LGPL Exception
26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you have questions regarding the use of this file, please contact
37** Nokia at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include "qfinalstate.h"
43
44#ifndef QT_NO_STATEMACHINE
45
46#include "qabstractstate_p.h"
47
48QT_BEGIN_NAMESPACE
49
50/*!
51 \class QFinalState
52
53 \brief The QFinalState class provides a final state.
54
55 \since 4.6
56 \ingroup statemachine
57
58 A final state is used to communicate that (part of) a QStateMachine has
59 finished its work. When a final top-level state is entered, the state
60 machine's \l{QStateMachine::finished()}{finished}() signal is emitted. In
61 general, when a final substate (a child of a QState) is entered, the parent
62 state's \l{QState::finished()}{finished}() signal is emitted. QFinalState
63 is part of \l{The State Machine Framework}.
64
65 To use a final state, you create a QFinalState object and add a transition
66 to it from another state. Example:
67
68 \code
69 QPushButton button;
70
71 QStateMachine machine;
72 QState *s1 = new QState();
73 QFinalState *s2 = new QFinalState();
74 s1->addTransition(&button, SIGNAL(clicked()), s2);
75 machine.addState(s1);
76 machine.addState(s2);
77
78 QObject::connect(&machine, SIGNAL(finished()), QApplication::instance(), SLOT(quit()));
79 machine.setInitialState(s1);
80 machine.start();
81 \endcode
82
83 \sa QStateMachine::finished(), QState::finished()
84*/
85
86class QFinalStatePrivate : public QAbstractStatePrivate
87{
88 Q_DECLARE_PUBLIC(QFinalState)
89
90public:
91 QFinalStatePrivate();
92};
93
94QFinalStatePrivate::QFinalStatePrivate()
95 : QAbstractStatePrivate(FinalState)
96{
97}
98
99/*!
100 Constructs a new QFinalState object with the given \a parent state.
101*/
102QFinalState::QFinalState(QState *parent)
103 : QAbstractState(*new QFinalStatePrivate, parent)
104{
105}
106
107/*!
108 Destroys this final state.
109*/
110QFinalState::~QFinalState()
111{
112}
113
114/*!
115 \reimp
116*/
117void QFinalState::onEntry(QEvent *event)
118{
119 Q_UNUSED(event);
120}
121
122/*!
123 \reimp
124*/
125void QFinalState::onExit(QEvent *event)
126{
127 Q_UNUSED(event);
128}
129
130/*!
131 \reimp
132*/
133bool QFinalState::event(QEvent *e)
134{
135 return QAbstractState::event(e);
136}
137
138QT_END_NAMESPACE
139
140#endif //QT_NO_STATEMACHINE
Note: See TracBrowser for help on using the repository browser.