summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorKent Hansen <khansen@trolltech.com>2009-05-22 12:09:21 (GMT)
committerKent Hansen <khansen@trolltech.com>2009-05-22 12:09:21 (GMT)
commit64cc2368d230c6f0996a6311767bd1704b4cf322 (patch)
tree7082cfb21a22c702b978db0daf93ddff03fb836b /src
parent7c00cc50fc41a7c7b9c04e258a9eb03ff187c574 (diff)
downloadQt-64cc2368d230c6f0996a6311767bd1704b4cf322.zip
Qt-64cc2368d230c6f0996a6311767bd1704b4cf322.tar.gz
Qt-64cc2368d230c6f0996a6311767bd1704b4cf322.tar.bz2
Revert "Say hello to animation API & state machine API"
This reverts commit 1a709fbe25a2446a9b311ded88aec5565258f3ac.
Diffstat (limited to 'src')
-rw-r--r--src/3rdparty/easing/easing.cpp670
-rw-r--r--src/3rdparty/easing/legal.qdoc35
-rw-r--r--src/corelib/animation/animation.pri25
-rw-r--r--src/corelib/animation/qabstractanimation.cpp759
-rw-r--r--src/corelib/animation/qabstractanimation.h137
-rw-r--r--src/corelib/animation/qabstractanimation_p.h136
-rw-r--r--src/corelib/animation/qanimationgroup.cpp309
-rw-r--r--src/corelib/animation/qanimationgroup.h88
-rw-r--r--src/corelib/animation/qanimationgroup_p.h79
-rw-r--r--src/corelib/animation/qparallelanimationgroup.cpp316
-rw-r--r--src/corelib/animation/qparallelanimationgroup.h86
-rw-r--r--src/corelib/animation/qparallelanimationgroup_p.h85
-rw-r--r--src/corelib/animation/qpauseanimation.cpp154
-rw-r--r--src/corelib/animation/qpauseanimation.h84
-rw-r--r--src/corelib/animation/qpropertyanimation.cpp316
-rw-r--r--src/corelib/animation/qpropertyanimation.h90
-rw-r--r--src/corelib/animation/qpropertyanimation_p.h89
-rw-r--r--src/corelib/animation/qsequentialanimationgroup.cpp594
-rw-r--r--src/corelib/animation/qsequentialanimationgroup.h96
-rw-r--r--src/corelib/animation/qsequentialanimationgroup_p.h111
-rw-r--r--src/corelib/animation/qvariantanimation.cpp644
-rw-r--r--src/corelib/animation/qvariantanimation.h130
-rw-r--r--src/corelib/animation/qvariantanimation_p.h130
-rw-r--r--src/corelib/corelib.pro2
-rw-r--r--src/corelib/kernel/kernel.pri8
-rw-r--r--src/corelib/kernel/qcoreevent.cpp2
-rw-r--r--src/corelib/kernel/qcoreevent.h8
-rw-r--r--src/corelib/statemachine/qabstractstate.cpp202
-rw-r--r--src/corelib/statemachine/qabstractstate.h90
-rw-r--r--src/corelib/statemachine/qabstractstate_p.h84
-rw-r--r--src/corelib/statemachine/qabstracttransition.cpp342
-rw-r--r--src/corelib/statemachine/qabstracttransition.h111
-rw-r--r--src/corelib/statemachine/qabstracttransition_p.h91
-rw-r--r--src/corelib/statemachine/qeventtransition.cpp282
-rw-r--r--src/corelib/statemachine/qeventtransition.h96
-rw-r--r--src/corelib/statemachine/qeventtransition_p.h78
-rw-r--r--src/corelib/statemachine/qfinalstate.cpp134
-rw-r--r--src/corelib/statemachine/qfinalstate.h76
-rw-r--r--src/corelib/statemachine/qhistorystate.cpp223
-rw-r--r--src/corelib/statemachine/qhistorystate.h91
-rw-r--r--src/corelib/statemachine/qhistorystate_p.h79
-rw-r--r--src/corelib/statemachine/qsignalevent.h77
-rw-r--r--src/corelib/statemachine/qsignaleventgenerator_p.h78
-rw-r--r--src/corelib/statemachine/qsignaltransition.cpp257
-rw-r--r--src/corelib/statemachine/qsignaltransition.h89
-rw-r--r--src/corelib/statemachine/qsignaltransition_p.h78
-rw-r--r--src/corelib/statemachine/qstate.cpp497
-rw-r--r--src/corelib/statemachine/qstate.h113
-rw-r--r--src/corelib/statemachine/qstate_p.h108
-rw-r--r--src/corelib/statemachine/qstatemachine.cpp2216
-rw-r--r--src/corelib/statemachine/qstatemachine.h166
-rw-r--r--src/corelib/statemachine/qstatemachine_p.h217
-rw-r--r--src/corelib/statemachine/qwrappedevent.h76
-rw-r--r--src/corelib/statemachine/statemachine.pri30
-rw-r--r--src/corelib/tools/qeasingcurve.cpp846
-rw-r--r--src/corelib/tools/qeasingcurve.h114
-rw-r--r--src/corelib/tools/qtimeline.cpp114
-rw-r--r--src/corelib/tools/qtimeline.h5
-rw-r--r--src/corelib/tools/tools.pri2
-rw-r--r--src/gui/animation/animation.pri3
-rw-r--r--src/gui/animation/qguivariantanimation.cpp75
-rw-r--r--src/gui/graphicsview/qgraphicsitem_p.h12
-rw-r--r--src/gui/graphicsview/qgraphicsproxywidget.cpp2
-rw-r--r--src/gui/graphicsview/qgraphicsproxywidget.h2
-rw-r--r--src/gui/gui.pro2
-rw-r--r--src/gui/kernel/qapplication.cpp6
-rw-r--r--src/gui/painting/qdrawhelper.cpp8
-rw-r--r--src/gui/statemachine/qbasickeyeventtransition.cpp203
-rw-r--r--src/gui/statemachine/qbasickeyeventtransition_p.h93
-rw-r--r--src/gui/statemachine/qbasicmouseeventtransition.cpp208
-rw-r--r--src/gui/statemachine/qbasicmouseeventtransition_p.h98
-rw-r--r--src/gui/statemachine/qguistatemachine.cpp559
-rw-r--r--src/gui/statemachine/qkeyeventtransition.cpp186
-rw-r--r--src/gui/statemachine/qkeyeventtransition.h87
-rw-r--r--src/gui/statemachine/qmouseeventtransition.cpp216
-rw-r--r--src/gui/statemachine/qmouseeventtransition.h92
-rw-r--r--src/gui/statemachine/statemachine.pri13
77 files changed, 63 insertions, 14047 deletions
diff --git a/src/3rdparty/easing/easing.cpp b/src/3rdparty/easing/easing.cpp
deleted file mode 100644
index 81af40f..0000000
--- a/src/3rdparty/easing/easing.cpp
+++ /dev/null
@@ -1,670 +0,0 @@
-/*
-Disclaimer for Robert Penner's Easing Equations license:
-
-TERMS OF USE - EASING EQUATIONS
-
-Open source under the BSD License.
-
-Copyright © 2001 Robert Penner
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
- * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- * Neither the name of the author nor the names of contributors may be used to endorse or promote products derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-*/
-
-#include <QtCore/qmath.h>
-#include <math.h>
-#ifndef M_PI
-#define M_PI 3.14159265358979323846
-#endif
-#ifndef M_PI_2
-#define M_PI_2 (M_PI / 2)
-#endif
-
-QT_USE_NAMESPACE
-
-/**
- * Easing equation function for a simple linear tweening, with no easing.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeNone(qreal progress)
-{
- return progress;
-}
-
-/**
- * Easing equation function for a quadratic (t^2) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInQuad(qreal t)
-{
- return t*t;
-}
-
-/**
-* Easing equation function for a quadratic (t^2) easing out: decelerating to zero velocity.
-*
-* @param t Current time (in frames or seconds).
-* @return The correct value.
-*/
-static qreal easeOutQuad(qreal t)
-{
- return -t*(t-2);
-}
-
-/**
- * Easing equation function for a quadratic (t^2) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutQuad(qreal t)
-{
- t*=2.0;
- if (t < 1) {
- return t*t/qreal(2);
- } else {
- --t;
- return -0.5 * (t*(t-2) - 1);
- }
-}
-
-/**
- * Easing equation function for a quadratic (t^2) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInQuad(qreal t)
-{
- if (t < 0.5) return easeOutQuad (t*2)/2;
- return easeInQuad((2*t)-1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a cubic (t^3) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInCubic(qreal t)
-{
- return t*t*t;
-}
-
-/**
- * Easing equation function for a cubic (t^3) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutCubic(qreal t)
-{
- t-=1.0;
- return t*t*t + 1;
-}
-
-/**
- * Easing equation function for a cubic (t^3) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutCubic(qreal t)
-{
- t*=2.0;
- if(t < 1) {
- return 0.5*t*t*t;
- } else {
- t -= qreal(2.0);
- return 0.5*(t*t*t + 2);
- }
-}
-
-/**
- * Easing equation function for a cubic (t^3) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInCubic(qreal t)
-{
- if (t < 0.5) return easeOutCubic (2*t)/2;
- return easeInCubic(2*t - 1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a quartic (t^4) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInQuart(qreal t)
-{
- return t*t*t*t;
-}
-
-/**
- * Easing equation function for a quartic (t^4) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutQuart(qreal t)
-{
- t-= qreal(1.0);
- return - (t*t*t*t- 1);
-}
-
-/**
- * Easing equation function for a quartic (t^4) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutQuart(qreal t)
-{
- t*=2;
- if (t < 1) return 0.5*t*t*t*t;
- else {
- t -= 2.0f;
- return -0.5 * (t*t*t*t- 2);
- }
-}
-
-/**
- * Easing equation function for a quartic (t^4) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInQuart(qreal t)
-{
- if (t < 0.5) return easeOutQuart (2*t)/2;
- return easeInQuart(2*t-1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a quintic (t^5) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInQuint(qreal t)
-{
- return t*t*t*t*t;
-}
-
-/**
- * Easing equation function for a quintic (t^5) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutQuint(qreal t)
-{
- t-=1.0;
- return t*t*t*t*t + 1;
-}
-
-/**
- * Easing equation function for a quintic (t^5) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutQuint(qreal t)
-{
- t*=2.0;
- if (t < 1) return 0.5*t*t*t*t*t;
- else {
- t -= 2.0;
- return 0.5*(t*t*t*t*t + 2);
- }
-}
-
-/**
- * Easing equation function for a quintic (t^5) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInQuint(qreal t)
-{
- if (t < 0.5) return easeOutQuint (2*t)/2;
- return easeInQuint(2*t - 1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a sinusoidal (sin(t)) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInSine(qreal t)
-{
- return (t == 1.0) ? 1.0 : -::cos(t * M_PI_2) + 1.0;
-}
-
-/**
- * Easing equation function for a sinusoidal (sin(t)) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutSine(qreal t)
-{
- return ::sin(t* M_PI_2);
-}
-
-/**
- * Easing equation function for a sinusoidal (sin(t)) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutSine(qreal t)
-{
- return -0.5 * (::cos(M_PI*t) - 1);
-}
-
-/**
- * Easing equation function for a sinusoidal (sin(t)) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInSine(qreal t)
-{
- if (t < 0.5) return easeOutSine (2*t)/2;
- return easeInSine(2*t - 1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for an exponential (2^t) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInExpo(qreal t)
-{
- return (t==0 || t == 1.0) ? t : ::qPow(2.0, 10 * (t - 1)) - qreal(0.001);
-}
-
-/**
- * Easing equation function for an exponential (2^t) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutExpo(qreal t)
-{
- return (t==1.0) ? 1.0 : 1.001 * (-::qPow(2.0f, -10 * t) + 1);
-}
-
-/**
- * Easing equation function for an exponential (2^t) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutExpo(qreal t)
-{
- if (t==0.0) return qreal(0.0);
- if (t==1.0) return qreal(1.0);
- t*=2.0;
- if (t < 1) return 0.5 * ::qPow(qreal(2.0), 10 * (t - 1)) - 0.0005;
- return 0.5 * 1.0005 * (-::qPow(qreal(2.0), -10 * (t - 1)) + 2);
-}
-
-/**
- * Easing equation function for an exponential (2^t) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInExpo(qreal t)
-{
- if (t < 0.5) return easeOutExpo (2*t)/2;
- return easeInExpo(2*t - 1)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a circular (sqrt(1-t^2)) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInCirc(qreal t)
-{
- return -(::sqrt(1 - t*t) - 1);
-}
-
-/**
- * Easing equation function for a circular (sqrt(1-t^2)) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutCirc(qreal t)
-{
- t-= qreal(1.0);
- return ::sqrt(1 - t* t);
-}
-
-/**
- * Easing equation function for a circular (sqrt(1-t^2)) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeInOutCirc(qreal t)
-{
- t*=qreal(2.0);
- if (t < 1) {
- return -0.5 * (::sqrt(1 - t*t) - 1);
- } else {
- t -= qreal(2.0);
- return 0.5 * (::sqrt(1 - t*t) + 1);
- }
-}
-
-/**
- * Easing equation function for a circular (sqrt(1-t^2)) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @return The correct value.
- */
-static qreal easeOutInCirc(qreal t)
-{
- if (t < 0.5) return easeOutCirc (2*t)/2;
- return easeInCirc(2*t - 1)/2 + 0.5;
-}
-
-static qreal easeInElastic_helper(qreal t, qreal b, qreal c, qreal d, qreal a, qreal p)
-{
- if (t==0) return b;
- qreal t_adj = (qreal)t / (qreal)d;
- if (t_adj==1) return b+c;
-
- qreal s;
- if(a < ::fabs(c)) {
- a = c;
- s = p / 4.0f;
- } else {
- s = p / (2 * M_PI) * ::asin(c / a);
- }
-
- t_adj -= 1.0f;
- return -(a*::qPow(2.0f,10*t_adj) * ::sin( (t_adj*d-s)*(2*M_PI)/p )) + b;
-}
-
-/**
- * Easing equation function for an elastic (exponentially decaying sine wave) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @param p Period.
- * @return The correct value.
- */
-static qreal easeInElastic(qreal t, qreal a, qreal p)
-{
- return easeInElastic_helper(t, 0, 1, 1, a, p);
-}
-
-static qreal easeOutElastic_helper(qreal t, qreal /*b*/, qreal c, qreal /*d*/, qreal a, qreal p)
-{
- if (t==0) return 0;
- if (t==1) return c;
-
- qreal s;
- if(a < c) {
- a = c;
- s = p / 4.0f;
- } else {
- s = p / (2 * M_PI) * ::asin(c / a);
- }
-
- return (a*::qPow(2.0f,-10*t) * ::sin( (t-s)*(2*M_PI)/p ) + c);
-}
-
-/**
- * Easing equation function for an elastic (exponentially decaying sine wave) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @param p Period.
- * @return The correct value.
- */
-static qreal easeOutElastic(qreal t, qreal a, qreal p)
-{
- return easeOutElastic_helper(t, 0, 1, 1, a, p);
-}
-
-/**
- * Easing equation function for an elastic (exponentially decaying sine wave) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @param p Period.
- * @return The correct value.
- */
-static qreal easeInOutElastic(qreal t, qreal a, qreal p)
-{
- if (t==0) return 0.0;
- t*=2.0;
- if (t==2) return 1.0;
-
- qreal s;
- if(a < 1.0) {
- a = 1.0;
- s = p / 4.0f;
- } else {
- s = p / (2 * M_PI) * ::asin(1.0 / a);
- }
-
- if (t < 1) return -.5*(a*::qPow(2.0f,10*(t-1)) * ::sin( (t-1-s)*(2*M_PI)/p ));
- return a*::qPow(2.0f,-10*(t-1)) * ::sin( (t-1-s)*(2*M_PI)/p )*.5 + 1.0;
-}
-
-/**
- * Easing equation function for an elastic (exponentially decaying sine wave) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @param p Period.
- * @return The correct value.
- */
-static qreal easeOutInElastic(qreal t, qreal a, qreal p)
-{
- if (t < 0.5) return easeOutElastic_helper(t*2, 0, 0.5, 1.0, a, p);
- return easeInElastic_helper(2*t - 1.0, 0.5, 0.5, 1.0, a, p);
-}
-
-/**
- * Easing equation function for a back (overshooting cubic easing: (s+1)*t^3 - s*t^2) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param s Overshoot ammount: higher s means greater overshoot (0 produces cubic easing with no overshoot, and the default value of 1.70158 produces an overshoot of 10 percent).
- * @return The correct value.
- */
-static qreal easeInBack(qreal t, qreal s)
-{
- return t*t*((s+1)*t - s);
-}
-
-/**
- * Easing equation function for a back (overshooting cubic easing: (s+1)*t^3 - s*t^2) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param s Overshoot ammount: higher s means greater overshoot (0 produces cubic easing with no overshoot, and the default value of 1.70158 produces an overshoot of 10 percent).
- * @return The correct value.
- */
-static qreal easeOutBack(qreal t, qreal s)
-{
- t-= qreal(1.0);
- return t*t*((s+1)*t+ s) + 1;
-}
-
-/**
- * Easing equation function for a back (overshooting cubic easing: (s+1)*t^3 - s*t^2) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param s Overshoot ammount: higher s means greater overshoot (0 produces cubic easing with no overshoot, and the default value of 1.70158 produces an overshoot of 10 percent).
- * @return The correct value.
- */
-static qreal easeInOutBack(qreal t, qreal s)
-{
- t *= 2.0;
- if (t < 1) {
- s *= 1.525f;
- return 0.5*(t*t*((s+1)*t - s));
- } else {
- t -= 2;
- s *= 1.525f;
- return 0.5*(t*t*((s+1)*t+ s) + 2);
- }
-}
-
-/**
- * Easing equation function for a back (overshooting cubic easing: (s+1)*t^3 - s*t^2) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param s Overshoot ammount: higher s means greater overshoot (0 produces cubic easing with no overshoot, and the default value of 1.70158 produces an overshoot of 10 percent).
- * @return The correct value.
- */
-static qreal easeOutInBack(qreal t, qreal s)
-{
- if (t < 0.5) return easeOutBack (2*t, s)/2;
- return easeInBack(2*t - 1, s)/2 + 0.5;
-}
-
-static qreal easeOutBounce_helper(qreal t, qreal c, qreal a)
-{
- if (t == 1.0) return c;
- if (t < (4/11.0)) {
- return c*(7.5625*t*t);
- } else if (t < (8/11.0)) {
- t -= (6/11.0);
- return -a * (1. - (7.5625*t*t + .75)) + c;
- } else if (t < (10/11.0)) {
- t -= (9/11.0);
- return -a * (1. - (7.5625*t*t + .9375)) + c;
- } else {
- t -= (21/22.0);
- return -a * (1. - (7.5625*t*t + .984375)) + c;
- }
-}
-
-/**
- * Easing equation function for a bounce (exponentially decaying parabolic bounce) easing out: decelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @return The correct value.
- */
-static qreal easeOutBounce(qreal t, qreal a)
-{
- return easeOutBounce_helper(t, 1, a);
-}
-
-/**
- * Easing equation function for a bounce (exponentially decaying parabolic bounce) easing in: accelerating from zero velocity.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @return The correct value.
- */
-static qreal easeInBounce(qreal t, qreal a)
-{
- return 1.0 - easeOutBounce_helper(1.0-t, 1.0, a);
-}
-
-
-/**
- * Easing equation function for a bounce (exponentially decaying parabolic bounce) easing in/out: acceleration until halfway, then deceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @return The correct value.
- */
-static qreal easeInOutBounce(qreal t, qreal a)
-{
- if (t < 0.5) return easeInBounce (2*t, a)/2;
- else return (t == 1.0) ? 1.0 : easeOutBounce (2*t - 1, a)/2 + 0.5;
-}
-
-/**
- * Easing equation function for a bounce (exponentially decaying parabolic bounce) easing out/in: deceleration until halfway, then acceleration.
- *
- * @param t Current time (in frames or seconds).
- * @param a Amplitude.
- * @return The correct value.
- */
-static qreal easeOutInBounce(qreal t, qreal a)
-{
- if (t < 0.5) return easeOutBounce_helper(t*2, 0.5, a);
- return 1.0 - easeOutBounce_helper (2.0-2*t, 0.5, a);
-}
-
-static inline qreal qt_sinProgress(qreal value)
-{
- return qSin((value * M_PI) - M_PI_2) / 2 + qreal(0.5);
-}
-
-static inline qreal qt_smoothBeginEndMixFactor(qreal value)
-{
- return qMin(qMax(1 - value * 2 + qreal(0.3), qreal(0.0)), qreal(1.0));
-}
-
-// SmoothBegin blends Smooth and Linear Interpolation.
-// Progress 0 - 0.3 : Smooth only
-// Progress 0.3 - ~ 0.5 : Mix of Smooth and Linear
-// Progress ~ 0.5 - 1 : Linear only
-
-/**
- * Easing function that starts growing slowly, then increases in speed. At the end of the curve the speed will be constant.
- */
-static qreal easeInCurve(qreal t)
-{
- const qreal sinProgress = qt_sinProgress(t);
- const qreal mix = qt_smoothBeginEndMixFactor(t);
- return sinProgress * mix + t * (1 - mix);
-}
-
-/**
- * Easing function that starts growing steadily, then ends slowly. The speed will be constant at the beginning of the curve.
- */
-static qreal easeOutCurve(qreal t)
-{
- const qreal sinProgress = qt_sinProgress(t);
- const qreal mix = qt_smoothBeginEndMixFactor(1 - t);
- return sinProgress * mix + t * (1 - mix);
-}
-
-/**
- * Easing function where the value grows sinusoidally. Note that the calculated end value will be 0 rather than 1.
- */
-static qreal easeSineCurve(qreal t)
-{
- return (qSin(((t * M_PI * 2)) - M_PI_2) + 1) / 2;
-}
-
-/**
- * Easing function where the value grows cosinusoidally. Note that the calculated start value will be 0.5 and the end value will be 0.5
- * contrary to the usual 0 to 1 easing curve.
- */
-static qreal easeCosineCurve(qreal t)
-{
- return (qCos(((t * M_PI * 2)) - M_PI_2) + 1) / 2;
-}
-
diff --git a/src/3rdparty/easing/legal.qdoc b/src/3rdparty/easing/legal.qdoc
deleted file mode 100644
index 25f67e1..0000000
--- a/src/3rdparty/easing/legal.qdoc
+++ /dev/null
@@ -1,35 +0,0 @@
-/*!
-\page legal-easing.html
-\title Easing Equations by Robert Penner
-\ingroup animation
-
-\legalese
-\code
-Copyright (c) 2001 Robert Penner
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification,
-are permitted provided that the following conditions are met:
-
- * Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright notice,
- this list of conditions and the following disclaimer in the documentation
- and/or other materials provided with the distribution.
- * Neither the name of the author nor the names of contributors may be used
- to endorse or promote products derived from this software without specific
- prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
-ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
-DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
-ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
-(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
-LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
-ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
-SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-\endcode
-\endlegalese
-*/
diff --git a/src/corelib/animation/animation.pri b/src/corelib/animation/animation.pri
deleted file mode 100644
index cb7850c..0000000
--- a/src/corelib/animation/animation.pri
+++ /dev/null
@@ -1,25 +0,0 @@
-# Qt core animation module
-
-HEADERS += \
- animation/qabstractanimation.h \
- animation/qabstractanimation_p.h \
- animation/qvariantanimation.h \
- animation/qvariantanimation_p.h \
- animation/qpropertyanimation.h \
- animation/qpropertyanimation_p.h \
- animation/qanimationgroup.h \
- animation/qanimationgroup_p.h \
- animation/qsequentialanimationgroup.h \
- animation/qsequentialanimationgroup_p.h \
- animation/qparallelanimationgroup.h \
- animation/qparallelanimationgroup_p.h \
- animation/qpauseanimation.h
-
-SOURCES += \
- animation/qabstractanimation.cpp \
- animation/qvariantanimation.cpp \
- animation/qpropertyanimation.cpp \
- animation/qanimationgroup.cpp \
- animation/qsequentialanimationgroup.cpp \
- animation/qparallelanimationgroup.cpp \
- animation/qpauseanimation.cpp
diff --git a/src/corelib/animation/qabstractanimation.cpp b/src/corelib/animation/qabstractanimation.cpp
deleted file mode 100644
index 94a94d1..0000000
--- a/src/corelib/animation/qabstractanimation.cpp
+++ /dev/null
@@ -1,759 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QAbstractAnimation
- \ingroup animation
- \brief The QAbstractAnimation class is the base of all animations.
- \since 4.6
-
- The class defines the functions for the functionality shared by
- all animations. By inheriting this class, you can create custom
- animations that plug into the rest of the animation framework.
-
- The progress of an animation is given by its current time
- (currentTime()), which is measured in milliseconds from the start
- of the animation (0) to its end (duration()). The value is updated
- automatically while the animation is running. It can also be set
- directly with setCurrentTime().
-
- At any point an animation is in one of three states:
- \l{QAbstractAnimation::}{Running},
- \l{QAbstractAnimation::}{Stopped}, or
- \l{QAbstractAnimation::}{Paused}--as defined by the
- \l{QAbstractAnimation::}{State} enum. The current state can be
- changed by calling start(), stop(), pause(), or resume(). An
- animation will always reset its \l{currentTime()}{current time}
- when it is started. If paused, it will continue with the same
- current time when resumed. When an animation is stopped, it cannot
- be resumed, but will keep its current time (until started again).
- QAbstractAnimation will emit stateChanged() whenever its state
- changes.
-
- An animation can loop any number of times by setting the loopCount
- property. When an animation's current time reaches its duration(),
- it will reset the current time and keep running. A loop count of 1
- (the default value) means that the animation will run one time.
- Note that a duration of -1 means that the animation will run until
- stopped; the current time will increase indefinitely. When the
- current time equals duration() and the animation is in its
- final loop, the \l{QAbstractAnimation::}{Stopped} state is
- entered, and the finished() signal is emitted.
-
- QAbstractAnimation provides pure virtual functions used by
- subclasses to track the progress of the animation: duration() and
- updateCurrentTime(). The duration() function lets you report a
- duration for the animation (as discussed above). The current time
- is delivered by the animation framework through calls to
- updateCurrentTime(). By reimplementing this function, you can
- track the animation progress. Note that neither the interval
- between calls nor the number of calls to this function are
- defined; though, it will normally be 60 updates per second.
-
- By reimplementing updateState(), you can track the animation's
- state changes, which is particularly useful for animations that
- are not driven by time.
-
- \sa QVariantAnimation, QPropertyAnimation, QAnimationGroup, {The Animation Framework}
-*/
-
-/*!
- \enum QAbstractAnimation::DeletionPolicy
-
- \value KeepWhenStopped The animation will not be deleted when stopped.
- \value DeleteWhenStopped The animation will be automatically deleted when
- stopped.
-*/
-
-/*!
- \fn QAbstractAnimation::finished()
-
- QAbstractAnimation emits this signal after the animation has stopped and
- has reached the end.
-
- This signal is emitted after stateChanged().
-
- \sa stateChanged()
-*/
-
-/*!
- \fn QAbstractAnimation::stateChanged(QAbstractAnimation::State oldState, QAbstractAnimation::State newState)
-
- QAbstractAnimation emits this signal whenever the state of the animation has
- changed from \a oldState to \a newState. This signal is emitted after the virtual
- updateState() function is called.
-
- \sa updateState()
-*/
-
-/*!
- \fn QAbstractAnimation::currentLoopChanged(int currentLoop)
-
- QAbstractAnimation emits this signal whenever the current loop
- changes. \a currentLoop is the current loop.
-
- \sa currentLoop(), loopCount()
-*/
-
-/*!
- \fn QAbstractAnimation::directionChanged(QAbstractAnimation::Direction newDirection);
-
- QAbstractAnimation emits this signal whenever the direction has been
- changed. \a newDirection is the new direction.
-
- \sa direction
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qabstractanimation.h"
-#include "qanimationgroup.h"
-#include <QtCore/qdebug.h>
-
-#include "qabstractanimation_p.h"
-
-#include <QtCore/qmath.h>
-#include <QtCore/qthreadstorage.h>
-#include <QtCore/qcoreevent.h>
-#include <QtCore/qpointer.h>
-
-#define DEFAULT_TIMER_INTERVAL 16
-
-QT_BEGIN_NAMESPACE
-
-Q_GLOBAL_STATIC(QThreadStorage<QUnifiedTimer *>, unifiedTimer);
-
-QUnifiedTimer::QUnifiedTimer() : QObject(), lastTick(0), timingInterval(DEFAULT_TIMER_INTERVAL), consistentTiming(false)
-{
-}
-
-QUnifiedTimer *QUnifiedTimer::instance()
-{
- QUnifiedTimer *inst;
- if (!unifiedTimer()->hasLocalData()) {
- inst = new QUnifiedTimer;
- unifiedTimer()->setLocalData(inst);
- } else {
- inst = unifiedTimer()->localData();
- }
- return inst;
-}
-
-void QUnifiedTimer::updateRecentlyStartedAnimations()
-{
- if (animationsToStart.isEmpty())
- return;
-
- animations += animationsToStart;
- updateTimer(); //we make sure we start the timer there
-
- animationsToStart.clear();
-}
-
-/*
- defines the timing interval. Default is DEFAULT_TIMER_INTERVAL
-*/
-void QUnifiedTimer::setTimingInterval(int interval)
-{
- timingInterval = interval;
- if (animationTimer.isActive()) {
- //we changed the timing interval
- animationTimer.start(timingInterval, this);
- }
-}
-
-/*
- this allows to have a consistent timer interval at each tick from the timer
- not taking the real time that passed into account.
-*/
-void QUnifiedTimer::setConsistentTiming(bool b)
-{
- consistentTiming = b;
-}
-
-int QUnifiedTimer::elapsedTime() const
-{
- return lastTick;
-}
-
-void QUnifiedTimer::timerEvent(QTimerEvent *event)
-{
- //this is simply the time we last received a tick
- const int oldLastTick = lastTick;
- if (time.isValid())
- lastTick = consistentTiming ? oldLastTick + timingInterval : time.elapsed();
-
- //we transfer the waiting animations into the "really running" state
- updateRecentlyStartedAnimations();
-
- if (event->timerId() == startStopAnimationTimer.timerId()) {
- startStopAnimationTimer.stop();
- if (animations.isEmpty()) {
- animationTimer.stop();
- time = QTime();
- } else {
- animationTimer.start(timingInterval, this);
- lastTick = 0;
- time.start();
- }
- } else if (event->timerId() == animationTimer.timerId()) {
- const int delta = lastTick - oldLastTick;
- for (int i = 0; i < animations.count(); ++i) {
- QAbstractAnimation *animation = animations.at(i);
- int elapsed = QAbstractAnimationPrivate::get(animation)->totalCurrentTime
- + (animation->direction() == QAbstractAnimation::Forward ? delta : -delta);
- animation->setCurrentTime(elapsed);
- }
- }
-}
-
-void QUnifiedTimer::updateTimer()
-{
- //we delay the call to start and stop for the animation timer so that if you
- //stop and start animations in batch you don't stop/start the timer too often.
- if (!startStopAnimationTimer.isActive())
- startStopAnimationTimer.start(0, this); // we delay the actual start of the animation
-}
-
-void QUnifiedTimer::registerAnimation(QAbstractAnimation *animation)
-{
- if (animations.contains(animation) ||animationsToStart.contains(animation))
- return;
- animationsToStart << animation;
- updateTimer();
-}
-
-void QUnifiedTimer::unregisterAnimation(QAbstractAnimation *animation)
-{
- animations.removeAll(animation);
- animationsToStart.removeAll(animation);
- updateTimer();
-}
-
-
-void QAbstractAnimationPrivate::setState(QAbstractAnimation::State newState)
-{
- Q_Q(QAbstractAnimation);
- if (state == newState)
- return;
-
- QAbstractAnimation::State oldState = state;
- int oldCurrentTime = currentTime;
- int oldCurrentLoop = currentLoop;
- QAbstractAnimation::Direction oldDirection = direction;
-
- state = newState;
-
- QPointer<QAbstractAnimation> guard(q);
-
- guard->updateState(oldState, newState);
-
- //this is to be safe if updateState changes the state
- if (state == oldState)
- return;
-
- // Notify state change
- if (guard)
- emit guard->stateChanged(oldState, newState);
-
- // Enter running state.
- switch (state)
- {
- case QAbstractAnimation::Paused:
- case QAbstractAnimation::Running:
- {
- // Rewind
- if (oldState == QAbstractAnimation::Stopped) {
- if (guard) {
- if (direction == QAbstractAnimation::Forward)
- q->setCurrentTime(0);
- else
- q->setCurrentTime(loopCount == -1 ? q->duration() : q->totalDuration());
- }
-
- // Check if the setCurrentTime() function called stop().
- // This can happen for a 0-duration animation
- if (state == QAbstractAnimation::Stopped)
- return;
- }
-
- // Register timer if our parent is not running.
- if (state == QAbstractAnimation::Running && guard) {
- if (!group || group->state() == QAbstractAnimation::Stopped) {
- QUnifiedTimer::instance()->registerAnimation(q);
- }
- } else {
- //new state is paused
- QUnifiedTimer::instance()->unregisterAnimation(q);
- }
- }
- break;
- case QAbstractAnimation::Stopped:
- // Leave running state.
- int dura = q->duration();
- if (deleteWhenStopped && guard)
- q->deleteLater();
-
- QUnifiedTimer::instance()->unregisterAnimation(q);
-
- if (dura == -1 || loopCount < 0
- || (oldDirection == QAbstractAnimation::Forward && (oldCurrentTime * (oldCurrentLoop + 1)) == (dura * loopCount))
- || (oldDirection == QAbstractAnimation::Backward && oldCurrentTime == 0)) {
- if (guard)
- emit q->finished();
- }
- break;
- }
-
-}
-
-/*!
- Constructs the QAbstractAnimation base class, and passes \a parent to
- QObject's constructor.
-
- \sa QVariantAnimation, QAnimationGroup
-*/
-QAbstractAnimation::QAbstractAnimation(QObject *parent)
- : QObject(*new QAbstractAnimationPrivate, 0)
-{
- // Allow auto-add on reparent
- setParent(parent);
-}
-
-/*!
- \internal
-*/
-QAbstractAnimation::QAbstractAnimation(QAbstractAnimationPrivate &dd, QObject *parent)
- : QObject(dd, 0)
-{
- // Allow auto-add on reparent
- setParent(parent);
-}
-
-/*!
- Stops the animation if it's running, then destroys the
- QAbstractAnimation. If the animation is part of a QAnimationGroup, it is
- automatically removed before it's destroyed.
-*/
-QAbstractAnimation::~QAbstractAnimation()
-{
- Q_D(QAbstractAnimation);
- //we can't call stop here. Otherwise we get pure virtual calls
- if (d->state != Stopped) {
- QAbstractAnimation::State oldState = d->state;
- d->state = Stopped;
- emit stateChanged(oldState, d->state);
- QUnifiedTimer::instance()->unregisterAnimation(this);
- }
-}
-
-/*!
- \property QAbstractAnimation::state
- \brief state of the animation.
-
- This property describes the current state of the animation. When the
- animation state changes, QAbstractAnimation emits the stateChanged()
- signal.
-*/
-QAbstractAnimation::State QAbstractAnimation::state() const
-{
- Q_D(const QAbstractAnimation);
- return d->state;
-}
-
-/*!
- If this animation is part of a QAnimationGroup, this function returns a
- pointer to the group; otherwise, it returns 0.
-
- \sa QAnimationGroup::addAnimation()
-*/
-QAnimationGroup *QAbstractAnimation::group() const
-{
- Q_D(const QAbstractAnimation);
- return d->group;
-}
-
-/*!
- \enum QAbstractAnimation::State
-
- This enum describes the state of the animation.
-
- \value Stopped The animation is not running. This is the initial state
- of QAbstractAnimation, and the state QAbstractAnimation reenters when finished. The current
- time remain unchanged until either setCurrentTime() is
- called, or the animation is started by calling start().
-
- \value Paused The animation is paused (i.e., temporarily
- suspended). Calling resume() will resume animation activity.
-
- \value Running The animation is running. While control is in the event
- loop, QAbstractAnimation will update its current time at regular intervals,
- calling updateCurrentTime() when appropriate.
-
- \sa state(), stateChanged()
-*/
-
-/*!
- \enum QAbstractAnimation::Direction
-
- This enum describes the direction of the animation when in \l Running state.
-
- \value Forward The current time of the animation increases with time (i.e.,
- moves from 0 and towards the end / duration).
-
- \value Backward The current time of the animation decreases with time (i.e.,
- moves from the end / duration and towards 0).
-
- \sa direction
-*/
-
-/*!
- \property QAbstractAnimation::direction
- \brief the direction of the animation when it is in \l Running
- state.
-
- This direction indicates whether the time moves from 0 towards the
- animation duration, or from the value of the duration and towards 0 after
- start() has been called.
-
- By default, this property is set to \l Forward.
-*/
-QAbstractAnimation::Direction QAbstractAnimation::direction() const
-{
- Q_D(const QAbstractAnimation);
- return d->direction;
-}
-void QAbstractAnimation::setDirection(Direction direction)
-{
- Q_D(QAbstractAnimation);
- if (d->direction == direction)
- return;
-
- d->direction = direction;
- if (state() == Stopped) {
- if (direction == Backward) {
- d->currentTime = duration();
- d->currentLoop = d->loopCount - 1;
- } else {
- d->currentTime = 0;
- d->currentLoop = 0;
- }
- }
- updateDirection(direction);
- emit directionChanged(direction);
-}
-
-/*!
- \property QAbstractAnimation::duration
- \brief the duration of the animation.
-
- If the duration is -1, it means that the duration is undefined.
- In this case, loopCount is ignored.
-*/
-
-/*!
- \property QAbstractAnimation::loopCount
- \brief the loop count of the animation
-
- This property describes the loop count of the animation as an integer.
- By default this value is 1, indicating that the animation
- should run once only, and then stop. By changing it you can let the
- animation loop several times. With a value of 0, the animation will not
- run at all, and with a value of -1, the animation will loop forever
- until stopped.
- It is not supported to have loop on an animation that has an undefined
- duration. It will only run once.
-*/
-int QAbstractAnimation::loopCount() const
-{
- Q_D(const QAbstractAnimation);
- return d->loopCount;
-}
-void QAbstractAnimation::setLoopCount(int loopCount)
-{
- Q_D(QAbstractAnimation);
- d->loopCount = loopCount;
-}
-
-/*!
- \property QAbstractAnimation::currentLoop
- \brief the current loop of the animation
-
- This property describes the current loop of the animation. By default,
- the animation's loop count is 1, and so the current loop will
- always be 0. If the loop count is 2 and the animation runs past its
- duration, it will automatically rewind and restart at current time 0, and
- current loop 1, and so on.
-
- When the current loop changes, QAbstractAnimation emits the
- currentLoopChanged() signal.
-*/
-int QAbstractAnimation::currentLoop() const
-{
- Q_D(const QAbstractAnimation);
- return d->currentLoop;
-}
-
-/*!
- \fn virtual int QAbstractAnimation::duration() const = 0
-
- This pure virtual function returns the duration of the animation, and
- defines for how long QAbstractAnimation should update the current
- time. This duration is local, and does not include the loop count.
-
- A return value of -1 indicates that the animation has no defined duration;
- the animation should run forever until stopped. This is useful for
- animations that are not time driven, or where you cannot easily predict
- its duration (e.g., event driven audio playback in a game).
-
- If the animation is a parallel QAnimationGroup, the duration will be the longest
- duration of all its animations. If the animation is a sequential QAnimationGroup,
- the duration will be the sum of the duration of all its animations.
- \sa loopCount
-*/
-
-/*!
- Returns the total and effective duration of the animation, including the
- loop count.
-
- \sa duration(), currentTime
-*/
-int QAbstractAnimation::totalDuration() const
-{
- Q_D(const QAbstractAnimation);
- if (d->loopCount < 0)
- return -1;
- int dura = duration();
- if (dura == -1)
- return -1;
- return dura * d->loopCount;
-}
-
-/*!
- \property QAbstractAnimation::currentTime
- \brief the current time and progress of the animation
-
- This property describes the animation's current time. You can change the
- current time by calling setCurrentTime, or you can call start() and let
- the animation run, setting the current time automatically as the animation
- progresses.
-
- The animation's current time starts at 0, and ends at duration(). If the
- animation's loopCount is larger than 1, the current time will rewind and
- start at 0 again for the consecutive loops. If the animation has a pause.
- currentTime will also include the duration of the pause.
-
- \sa loopCount
- */
-int QAbstractAnimation::currentTime() const
-{
- Q_D(const QAbstractAnimation);
- return d->currentTime;
-}
-void QAbstractAnimation::setCurrentTime(int msecs)
-{
- Q_D(QAbstractAnimation);
- msecs = qMax(msecs, 0);
-
- // Calculate new time and loop.
- int dura = duration();
- int totalDura = (d->loopCount < 0 || dura == -1) ? -1 : dura * d->loopCount;
- if (totalDura != -1)
- msecs = qMin(totalDura, msecs);
- d->totalCurrentTime = msecs;
-
- // Update new values.
- int oldLoop = d->currentLoop;
- d->currentLoop = ((dura <= 0) ? 0 : (msecs / dura));
- if (d->currentLoop == d->loopCount) {
- //we're at the end
- d->currentTime = qMax(0, dura);
- d->currentLoop = qMax(0, d->loopCount - 1);
- } else {
- if (d->direction == Forward) {
- d->currentTime = (dura <= 0) ? msecs : (msecs % dura);
- } else {
- d->currentTime = (dura <= 0) ? msecs : ((msecs - 1) % dura) + 1;
- if (d->currentTime == dura)
- --d->currentLoop;
- }
- }
-
- updateCurrentTime(msecs);
- if (d->currentLoop != oldLoop)
- emit currentLoopChanged(d->currentLoop);
-
- // All animations are responsible for stopping the animation when their
- // own end state is reached; in this case the animation is time driven,
- // and has reached the end.
- if ((d->direction == Forward && d->totalCurrentTime == totalDura)
- || (d->direction == Backward && d->totalCurrentTime == 0)) {
- stop();
- }
-}
-
-/*!
- Starts the animation. The \a policy argument says whether or not the
- animation should be deleted when it's done. When the animation starts, the
- stateChanged() signal is emitted, and state() returns Running. When control
- reaches the event loop, the animation will run by itself, periodically
- calling updateCurrentTime() as the animation progresses.
-
- If the animation is currently stopped or has already reached the end,
- calling start() will rewind the animation and start again from the beginning.
- When the animation reaches the end, the animation will either stop, or
- if the loop level is more than 1, it will rewind and continue from the beginning.
-
- If the animation is already running, this function does nothing.
-
- \sa stop(), state()
-*/
-void QAbstractAnimation::start(DeletionPolicy policy)
-{
- Q_D(QAbstractAnimation);
- if (d->state == Running)
- return;
- d->setState(Running);
- d->deleteWhenStopped = policy;
-}
-
-/*!
- Stops the animation. When the animation is stopped, it emits the stateChanged()
- signal, and state() returns Stopped. The current time is not changed.
-
- If the animation stops by itself after reaching the end (i.e.,
- currentTime() == duration() and currentLoop() > loopCount() - 1), the
- finished() signal is emitted.
-
- \sa start(), state()
- */
-void QAbstractAnimation::stop()
-{
- Q_D(QAbstractAnimation);
-
- d->setState(Stopped);
-}
-
-/*!
- Pauses the animation. When the animation is paused, state() returns Paused.
- The currenttime will remain unchanged until resume() or start() is called.
- If you want to continue from the current time, call resume().
-
-
- \sa start(), state(), resume()
- */
-void QAbstractAnimation::pause()
-{
- Q_D(QAbstractAnimation);
- if (d->state == Stopped) {
- qWarning("QAbstractAnimation::pause: Cannot pause a stopped animation");
- return;
- }
-
- d->setState(Paused);
-}
-
-/*!
- Resumes the animation after it was paused. When the animation is resumed,
- it emits the resumed() and stateChanged() signals. The currenttime is not
- changed.
-
- \sa start(), pause(), state()
- */
-void QAbstractAnimation::resume()
-{
- Q_D(QAbstractAnimation);
- if (d->state != Paused) {
- qWarning("QAbstractAnimation::resume: "
- "Cannot resume an animation that is not paused");
- return;
- }
-
- d->setState(Running);
-}
-
-/*!
- \reimp
-*/
-bool QAbstractAnimation::event(QEvent *event)
-{
- return QObject::event(event);
-}
-
-/*!
- \fn virtual void QAbstractAnimation::updateCurrentTime(int msecs) = 0;
-
- This pure virtual function is called every time the animation's current
- time changes. The \a msecs argument is the current time.
-
- \sa updateState()
-*/
-
-/*!
- This virtual function is called by QAbstractAnimation when the state
- of the animation is changed from \a oldState to \a newState.
-
- \sa start(), stop(), pause(), resume()
-*/
-void QAbstractAnimation::updateState(QAbstractAnimation::State oldState,
- QAbstractAnimation::State newState)
-{
- Q_UNUSED(oldState);
- Q_UNUSED(newState);
-}
-
-/*!
- This virtual function is called by QAbstractAnimation when the direction
- of the animation is changed. The \a direction argument is the new direction.
-
- \sa setDirection(), direction()
-*/
-void QAbstractAnimation::updateDirection(QAbstractAnimation::Direction direction)
-{
- Q_UNUSED(direction);
-}
-
-
-QT_END_NAMESPACE
-
-#include "moc_qabstractanimation.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qabstractanimation.h b/src/corelib/animation/qabstractanimation.h
deleted file mode 100644
index d6d50dc..0000000
--- a/src/corelib/animation/qabstractanimation.h
+++ /dev/null
@@ -1,137 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTANIMATION_H
-#define QABSTRACTANIMATION_H
-
-#include <QtCore/qobject.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QAnimationGroup;
-class QSequentialAnimationGroup;
-
-class QAbstractAnimationPrivate;
-class Q_CORE_EXPORT QAbstractAnimation : public QObject
-{
- Q_OBJECT
- Q_PROPERTY(State state READ state NOTIFY stateChanged)
- Q_PROPERTY(int loopCount READ loopCount WRITE setLoopCount)
- Q_PROPERTY(int currentTime READ currentTime WRITE setCurrentTime)
- Q_PROPERTY(int currentLoop READ currentLoop NOTIFY currentLoopChanged)
- Q_PROPERTY(Direction direction READ direction WRITE setDirection NOTIFY directionChanged)
- Q_PROPERTY(int duration READ duration)
-
-public:
- enum Direction {
- Forward,
- Backward
- };
-
- enum State {
- Stopped,
- Paused,
- Running
- };
-
- enum DeletionPolicy {
- KeepWhenStopped = 0,
- DeleteWhenStopped
- };
-
- QAbstractAnimation(QObject *parent = 0);
- virtual ~QAbstractAnimation();
-
- State state() const;
-
- QAnimationGroup *group() const;
-
- Direction direction() const;
- void setDirection(Direction direction);
-
- int loopCount() const;
- void setLoopCount(int loopCount);
- int currentLoop() const;
-
- virtual int duration() const = 0;
- int totalDuration() const;
-
- int currentTime() const;
-
-Q_SIGNALS:
- void finished();
- void stateChanged(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
- void currentLoopChanged(int currentLoop);
- void directionChanged(QAbstractAnimation::Direction);
-
-public Q_SLOTS:
- void start(QAbstractAnimation::DeletionPolicy policy = KeepWhenStopped);
- void pause();
- void resume();
- void stop();
- void setCurrentTime(int msecs);
-
-protected:
- QAbstractAnimation(QAbstractAnimationPrivate &dd, QObject *parent = 0);
- bool event(QEvent *event);
-
- virtual void updateCurrentTime(int msecs) = 0;
- virtual void updateState(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
- virtual void updateDirection(QAbstractAnimation::Direction direction);
-
-private:
- Q_DISABLE_COPY(QAbstractAnimation)
- Q_DECLARE_PRIVATE(QAbstractAnimation)
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif // QABSTRACTANIMATION_H
diff --git a/src/corelib/animation/qabstractanimation_p.h b/src/corelib/animation/qabstractanimation_p.h
deleted file mode 100644
index e64554c..0000000
--- a/src/corelib/animation/qabstractanimation_p.h
+++ /dev/null
@@ -1,136 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTANIMATION_P_H
-#define QABSTRACTANIMATION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <QtCore/qbasictimer.h>
-#include <QtCore/qdatetime.h>
-#include <QtCore/qtimer.h>
-#include <private/qobject_p.h>
-
-QT_BEGIN_NAMESPACE
-
-class QAnimationGroup;
-class QAbstractAnimation;
-class QAbstractAnimationPrivate : public QObjectPrivate
-{
-public:
- QAbstractAnimationPrivate()
- : state(QAbstractAnimation::Stopped),
- direction(QAbstractAnimation::Forward),
- deleteWhenStopped(false),
- totalCurrentTime(0),
- currentTime(0),
- loopCount(1),
- currentLoop(0),
- group(0)
- {
- }
-
- virtual ~QAbstractAnimationPrivate() {}
-
- static QAbstractAnimationPrivate *get(QAbstractAnimation *q)
- {
- return q->d_func();
- }
-
- QAbstractAnimation::State state;
- QAbstractAnimation::Direction direction;
- bool deleteWhenStopped;
- void setState(QAbstractAnimation::State state);
-
- int totalCurrentTime;
- int currentTime;
- int loopCount;
- int currentLoop;
-
- QAnimationGroup *group;
-
-private:
- Q_DECLARE_PUBLIC(QAbstractAnimation)
-};
-
-
-class Q_CORE_EXPORT QUnifiedTimer : public QObject
-{
-private:
- QUnifiedTimer();
-
-public:
- static QUnifiedTimer *instance();
-
- void registerAnimation(QAbstractAnimation *animation);
- void unregisterAnimation(QAbstractAnimation *animation);
-
- void setTimingInterval(int interval);
- void setConsistentTiming(bool consistent);
-
- int elapsedTime() const;
-
-protected:
- void timerEvent(QTimerEvent *);
- void updateTimer();
-
-private:
- void updateRecentlyStartedAnimations();
-
- QBasicTimer animationTimer, startStopAnimationTimer;
- QTime time;
- int lastTick;
- int timingInterval;
- bool consistentTiming;
- QList<QAbstractAnimation*> animations, animationsToStart;
-};
-
-QT_END_NAMESPACE
-#endif
diff --git a/src/corelib/animation/qanimationgroup.cpp b/src/corelib/animation/qanimationgroup.cpp
deleted file mode 100644
index ed06eff..0000000
--- a/src/corelib/animation/qanimationgroup.cpp
+++ /dev/null
@@ -1,309 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QAnimationGroup
- \brief The QAnimationGroup class is an abstract base class for groups of animations.
- \since 4.6
- \ingroup animation
-
- An animation group is a container for animations (subclasses of
- QAbstractAnimation). A group is usually responsible for managing
- the \l{QAbstractAnimation::State}{state} of its animations, i.e.,
- it decides when to start, stop, resume, and pause them. Currently,
- Qt provides two such groups: QParallelAnimationGroup and
- QSequentialAnimationGroup. Look up their class descriptions for
- details.
-
- Since QAnimationGroup inherits from QAbstractAnimation, you can
- combine groups, and easily construct complex animation graphs.
- You can query QAbstractAnimation for the group it belongs to
- (using the \l{QAbstractAnimation::}{group()} function).
-
- To start a top-level animation group, you simply use the
- \l{QAbstractAnimation::}{start()} function from
- QAbstractAnimation. By a top-level animation group, we think of a
- group that itself is not contained within another group. Starting
- sub groups directly is not supported, and may lead to unexpected
- behavior.
-
- \omit OK, we'll put in a snippet on this here \endomit
-
- QAnimationGroup provides methods for adding and retrieving
- animations. Besides that, you can remove animations by calling
- remove(), and clear the animation group by calling
- clearAnimations(). You may keep track of changes in the group's
- animations by listening to QEvent::ChildAdded and
- QEvent::ChildRemoved events.
-
- \omit OK, let's find a snippet here as well. \endomit
-
- QAnimationGroup takes ownership of the animations it manages, and
- ensures that they are deleted when the animation group is deleted.
-
- You can also use a \l{The State Machine Framework}{state machine}
- to create complex animations. The framework provides a special
- state, QAnimationState, that plays an animation upon entry and
- transitions to a new state when the animation has finished
- playing. This technique can also be combined with using animation
- groups.
-
- \sa QAbstractAnimation, QVariantAnimation, {The Animation Framework}
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qanimationgroup.h"
-#include <QtCore/qdebug.h>
-#include <QtCore/qcoreevent.h>
-#include "qanimationgroup_p.h"
-
-QT_BEGIN_NAMESPACE
-
-
-/*!
- Constructs a QAnimationGroup.
- \a parent is passed to QObject's constructor.
-*/
-QAnimationGroup::QAnimationGroup(QObject *parent)
- : QAbstractAnimation(*new QAnimationGroupPrivate, parent)
-{
-}
-
-/*!
- \internal
-*/
-QAnimationGroup::QAnimationGroup(QAnimationGroupPrivate &dd, QObject *parent)
- : QAbstractAnimation(dd, parent)
-{
-}
-
-/*!
- Destroys the animation group. It will also destroy all its animations.
-*/
-QAnimationGroup::~QAnimationGroup()
-{
-}
-
-/*!
- Returns a pointer to the animation at \a index in this group. This
- function is useful when you need access to a particular animation. \a
- index is between 0 and animationCount() - 1.
-
- \sa animationCount(), indexOfAnimation()
-*/
-QAbstractAnimation *QAnimationGroup::animationAt(int index) const
-{
- Q_D(const QAnimationGroup);
-
- if (index < 0 || index >= d->animations.size()) {
- qWarning("QAnimationGroup::animationAt: index is out of bounds");
- return 0;
- }
-
- return d->animations.at(index);
-}
-
-
-/*!
- Returns the number of animations managed by this group.
-
- \sa indexOfAnimation(), addAnimation(), animationAt()
-*/
-int QAnimationGroup::animationCount() const
-{
- Q_D(const QAnimationGroup);
- return d->animations.size();
-}
-
-/*!
- Returns the index of \a animation. The returned index can be passed
- to the other functions that take an index as an argument.
-
- \sa insertAnimationAt(), animationAt(), takeAnimationAt()
-*/
-int QAnimationGroup::indexOfAnimation(QAbstractAnimation *animation) const
-{
- Q_D(const QAnimationGroup);
- return d->animations.indexOf(animation);
-}
-
-/*!
- Adds \a animation to this group. This will call insertAnimationAt with
- index equals to animationCount().
-
- \note The group takes ownership of the animation.
-
- \sa removeAnimation()
-*/
-void QAnimationGroup::addAnimation(QAbstractAnimation *animation)
-{
- Q_D(QAnimationGroup);
- insertAnimationAt(d->animations.count(), animation);
-}
-
-/*!
- Inserts \a animation into this animation group at \a index.
- If \a index is 0 the animation is inserted at the beginning.
- If \a index is animationCount(), the animation is inserted at the end.
-
- \note The group takes ownership of the animation.
-
- \sa takeAnimationAt(), addAnimation(), indexOfAnimation(), removeAnimation()
-*/
-void QAnimationGroup::insertAnimationAt(int index, QAbstractAnimation *animation)
-{
- Q_D(QAnimationGroup);
-
- if (index < 0 || index > d->animations.size()) {
- qWarning("QAnimationGroup::insertAnimationAt: index is out of bounds");
- return;
- }
-
- if (QAnimationGroup *oldGroup = animation->group())
- oldGroup->removeAnimation(animation);
-
- d->animations.insert(index, animation);
- QAbstractAnimationPrivate::get(animation)->group = this;
- // this will make sure that ChildAdded event is sent to 'this'
- animation->setParent(this);
- d->animationInsertedAt(index);
-}
-
-/*!
- Removes \a animation from this group. The ownership of \a animation is
- transferred to the caller.
-
- \sa takeAnimationAt(), insertAnimationAt(), addAnimation()
-*/
-void QAnimationGroup::removeAnimation(QAbstractAnimation *animation)
-{
- Q_D(QAnimationGroup);
-
- if (!animation) {
- qWarning("QAnimationGroup::remove: cannot remove null animation");
- return;
- }
- int index = d->animations.indexOf(animation);
- if (index == -1) {
- qWarning("QAnimationGroup::remove: animation is not part of this group");
- return;
- }
-
- takeAnimationAt(index);
-}
-
-/*!
- Returns the animation at \a index and removes it from the animation group.
-
- \note The ownership of the animation is transferred to the caller.
-
- \sa removeAnimation(), addAnimation(), insertAnimation(), indexOfAnimation()
-*/
-QAbstractAnimation *QAnimationGroup::takeAnimationAt(int index)
-{
- Q_D(QAnimationGroup);
- if (index < 0 || index >= d->animations.size()) {
- qWarning("QAnimationGroup::takeAnimationAt: no animation at index %d", index);
- return 0;
- }
- QAbstractAnimation *animation = d->animations.at(index);
- QAbstractAnimationPrivate::get(animation)->group = 0;
- // ### removing from list before doing setParent to avoid inifinite recursion
- // in ChildRemoved event
- d->animations.removeAt(index);
- animation->setParent(0);
- d->animationRemovedAt(index);
- return animation;
-}
-
-/*!
- Removes and deletes all animations in this animation group, and resets the current
- time to 0.
-
- \sa addAnimation(), removeAnimation()
-*/
-void QAnimationGroup::clearAnimations()
-{
- Q_D(QAnimationGroup);
- qDeleteAll(d->animations);
-}
-
-/*!
- \reimp
-*/
-bool QAnimationGroup::event(QEvent *event)
-{
- Q_D(QAnimationGroup);
- if (event->type() == QEvent::ChildAdded) {
- QChildEvent *childEvent = static_cast<QChildEvent *>(event);
- if (QAbstractAnimation *a = qobject_cast<QAbstractAnimation *>(childEvent->child())) {
- if (a->group() != this)
- addAnimation(a);
- }
- } else if (event->type() == QEvent::ChildRemoved) {
- QChildEvent *childEvent = static_cast<QChildEvent *>(event);
- QAbstractAnimation *a = static_cast<QAbstractAnimation *>(childEvent->child());
- // You can only rely on the child being a QObject because in the QEvent::ChildRemoved
- // case it might be called from the destructor.
- int index = d->animations.indexOf(a);
- if (index != -1)
- takeAnimationAt(index);
- }
- return QAbstractAnimation::event(event);
-}
-
-
-void QAnimationGroupPrivate::animationRemovedAt(int index)
-{
- Q_Q(QAnimationGroup);
- Q_UNUSED(index);
- if (animations.isEmpty()) {
- currentTime = 0;
- q->stop();
- }
-}
-
-QT_END_NAMESPACE
-
-#include "moc_qanimationgroup.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qanimationgroup.h b/src/corelib/animation/qanimationgroup.h
deleted file mode 100644
index 263bc38..0000000
--- a/src/corelib/animation/qanimationgroup.h
+++ /dev/null
@@ -1,88 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QANIMATIONGROUP_H
-#define QANIMATIONGROUP_H
-
-#include <QtCore/qabstractanimation.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QAnimationGroupPrivate;
-class Q_CORE_EXPORT QAnimationGroup : public QAbstractAnimation
-{
- Q_OBJECT
-
-public:
- QAnimationGroup(QObject *parent = 0);
- ~QAnimationGroup();
-
- QAbstractAnimation *animationAt(int index) const;
- int animationCount() const;
- int indexOfAnimation(QAbstractAnimation *animation) const;
- void addAnimation(QAbstractAnimation *animation);
- void insertAnimationAt(int index, QAbstractAnimation *animation);
- void removeAnimation(QAbstractAnimation *animation);
- QAbstractAnimation *takeAnimationAt(int index);
- void clearAnimations();
-
-protected:
- QAnimationGroup(QAnimationGroupPrivate &dd, QObject *parent);
- bool event(QEvent *event);
-
-private:
- Q_DISABLE_COPY(QAnimationGroup)
- Q_DECLARE_PRIVATE(QAnimationGroup)
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif //QANIMATIONGROUP_H
diff --git a/src/corelib/animation/qanimationgroup_p.h b/src/corelib/animation/qanimationgroup_p.h
deleted file mode 100644
index a7bd0fa..0000000
--- a/src/corelib/animation/qanimationgroup_p.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QANIMATIONGROUP_P_H
-#define QANIMATIONGROUP_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qanimationgroup.h"
-
-#include <QtCore/qlist.h>
-
-#include "qabstractanimation_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QAnimationGroupPrivate : public QAbstractAnimationPrivate
-{
- Q_DECLARE_PUBLIC(QAnimationGroup)
-public:
- QAnimationGroupPrivate()
- { }
-
- virtual void animationInsertedAt(int index) { Q_UNUSED(index) };
- virtual void animationRemovedAt(int index);
-
- QList<QAbstractAnimation *> animations;
-};
-
-QT_END_NAMESPACE
-
-#endif //QANIMATIONGROUP_P_H
diff --git a/src/corelib/animation/qparallelanimationgroup.cpp b/src/corelib/animation/qparallelanimationgroup.cpp
deleted file mode 100644
index 13f6073..0000000
--- a/src/corelib/animation/qparallelanimationgroup.cpp
+++ /dev/null
@@ -1,316 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QParallelAnimationGroup
- \brief The QParallelAnimationGroup class provides a parallel group of animations.
- \since 4.6
- \ingroup animation
-
- QParallelAnimationGroup--a \l{QAnimationGroup}{container for
- animations}--starts all its animations when it is
- \l{QAbstractAnimation::start()}{started} itself, i.e., runs all
- animations in parallel. The animation group finishes when the
- longest lasting animation has finished.
-
- You can treat QParallelAnimation as any other QAbstractAnimation,
- e.g., pause, resume, or add it to other animation groups.
-
- \code
- QParallelAnimationGroup *group = new QParallelAnimationGroup;
- group->addAnimation(anim1);
- group->addAnimation(anim2);
-
- group->start();
- \endcode
-
- In this example, \c anim1 and \c anim2 are two
- \l{QPropertyAnimation}s that have already been set up.
-
- \sa QAnimationGroup, QPropertyAnimation, {The Animation Framework}
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qparallelanimationgroup.h"
-#include "qparallelanimationgroup_p.h"
-//#define QANIMATION_DEBUG
-QT_BEGIN_NAMESPACE
-
-/*!
- Constructs a QParallelAnimationGroup.
- \a parent is passed to QObject's constructor.
-*/
-QParallelAnimationGroup::QParallelAnimationGroup(QObject *parent)
- : QAnimationGroup(*new QParallelAnimationGroupPrivate, parent)
-{
-}
-
-/*!
- \internal
-*/
-QParallelAnimationGroup::QParallelAnimationGroup(QParallelAnimationGroupPrivate &dd,
- QObject *parent)
- : QAnimationGroup(dd, parent)
-{
-}
-
-/*!
- Destroys the animation group. It will also destroy all its animations.
-*/
-QParallelAnimationGroup::~QParallelAnimationGroup()
-{
-}
-
-/*!
- \reimp
-*/
-int QParallelAnimationGroup::duration() const
-{
- Q_D(const QParallelAnimationGroup);
- int ret = 0;
-
- for (int i = 0; i < d->animations.size(); ++i) {
- QAbstractAnimation *animation = d->animations.at(i);
- const int currentDuration = animation->totalDuration();
- if (currentDuration == -1)
- return -1; // Undetermined length
-
- ret = qMax(ret, currentDuration);
- }
-
- return ret;
-}
-
-/*!
- \reimp
-*/
-void QParallelAnimationGroup::updateCurrentTime(int)
-{
- Q_D(QParallelAnimationGroup);
- if (d->animations.isEmpty())
- return;
-
- if (d->currentLoop > d->lastLoop) {
- // simulate completion of the loop
- int dura = duration();
- if (dura > 0) {
- foreach (QAbstractAnimation *animation, d->animations) {
- animation->setCurrentTime(dura); // will stop
- }
- }
- } else if (d->currentLoop < d->lastLoop) {
- // simulate completion of the loop seeking backwards
- foreach (QAbstractAnimation *animation, d->animations) {
- animation->setCurrentTime(0);
- animation->stop();
- }
- }
-
- bool timeFwd = ((d->currentLoop == d->lastLoop && d->currentTime >= d->lastCurrentTime)
- || d->currentLoop > d->lastLoop);
-#ifdef QANIMATION_DEBUG
- qDebug("QParallellAnimationGroup %5d: setCurrentTime(%d), loop:%d, last:%d, timeFwd:%d, lastcurrent:%d, %d",
- __LINE__, d->currentTime, d->currentLoop, d->lastLoop, timeFwd, d->lastCurrentTime, state());
-#endif
- // finally move into the actual time of the current loop
- foreach (QAbstractAnimation *animation, d->animations) {
- const int dura = animation->totalDuration();
- if (dura == -1 && d->isUncontrolledAnimationFinished(animation))
- continue;
- if (dura == -1 || (d->currentTime <= dura && dura != 0)
- || (dura == 0 && d->currentLoop != d->lastLoop)) {
- switch (state()) {
- case Running:
- animation->start();
- break;
- case Paused:
- animation->pause();
- break;
- case Stopped:
- default:
- break;
- }
- }
-
- if (dura <= 0) {
- if (dura == -1)
- animation->setCurrentTime(d->currentTime);
- continue;
- }
-
- if ((timeFwd && d->lastCurrentTime <= dura)
- || (!timeFwd && d->currentTime <= dura))
- animation->setCurrentTime(d->currentTime);
- if (d->currentTime > dura)
- animation->stop();
- }
- d->lastLoop = d->currentLoop;
- d->lastCurrentTime = d->currentTime;
-}
-
-/*!
- \reimp
-*/
-void QParallelAnimationGroup::updateState(QAbstractAnimation::State oldState,
- QAbstractAnimation::State newState)
-{
- Q_D(QParallelAnimationGroup);
- QAnimationGroup::updateState(oldState, newState);
-
- switch (newState) {
- case Stopped:
- foreach (QAbstractAnimation *animation, d->animations)
- animation->stop();
- d->disconnectUncontrolledAnimations();
- break;
- case Paused:
- foreach (QAbstractAnimation *animation, d->animations)
- animation->pause();
- break;
- case Running:
- d->connectUncontrolledAnimations();
- foreach (QAbstractAnimation *animation, d->animations) {
- animation->stop();
- animation->setDirection(d->direction);
- animation->start();
- }
- break;
- }
-}
-
-void QParallelAnimationGroupPrivate::_q_uncontrolledAnimationFinished()
-{
- Q_Q(QParallelAnimationGroup);
-
- QAbstractAnimation *animation = qobject_cast<QAbstractAnimation *>(q->sender());
- Q_ASSERT(animation);
-
- int uncontrolledRunningCount = 0;
- if (animation->duration() == -1 || animation->loopCount() < 0) {
- QHash<QAbstractAnimation *, int>::iterator it = uncontrolledFinishTime.begin();
- while (it != uncontrolledFinishTime.end()) {
- if (it.key() == animation) {
- *it = animation->currentTime();
- }
- if (it.value() == -1)
- ++uncontrolledRunningCount;
- ++it;
- }
- }
-
- if (uncontrolledRunningCount > 0)
- return;
-
- int maxDuration = 0;
- foreach (QAbstractAnimation *a, animations)
- maxDuration = qMax(maxDuration, a->totalDuration());
-
- if (currentTime >= maxDuration)
- q->stop();
-}
-
-void QParallelAnimationGroupPrivate::disconnectUncontrolledAnimations()
-{
- Q_Q(QParallelAnimationGroup);
-
- QHash<QAbstractAnimation *, int>::iterator it = uncontrolledFinishTime.begin();
- while (it != uncontrolledFinishTime.end()) {
- QObject::disconnect(it.key(), SIGNAL(finished()), q, SLOT(_q_uncontrolledAnimationFinished()));
- ++it;
- }
-
- uncontrolledFinishTime.clear();
-}
-
-void QParallelAnimationGroupPrivate::connectUncontrolledAnimations()
-{
- Q_Q(QParallelAnimationGroup);
-
- foreach (QAbstractAnimation *animation, animations) {
- if (animation->duration() == -1 || animation->loopCount() < 0) {
- uncontrolledFinishTime[animation] = -1;
- QObject::connect(animation, SIGNAL(finished()), q, SLOT(_q_uncontrolledAnimationFinished()));
- }
- }
-}
-
-bool QParallelAnimationGroupPrivate::isUncontrolledAnimationFinished(QAbstractAnimation *anim) const
-{
- return uncontrolledFinishTime.value(anim, -1) >= 0;
-}
-
-/*!
- \reimp
-*/
-void QParallelAnimationGroup::updateDirection(QAbstractAnimation::Direction direction)
-{
- Q_D(QParallelAnimationGroup);
- //we need to update the direction of the current animation
- if (state() != Stopped) {
- foreach(QAbstractAnimation *anim, d->animations) {
- anim->setDirection(direction);
- }
- } else {
- if (direction == Forward) {
- d->lastLoop = 0;
- d->lastCurrentTime = 0;
- } else {
- // Looping backwards with loopCount == -1 does not really work well...
- d->lastLoop = (d->loopCount == -1 ? 0 : d->loopCount - 1);
- d->lastCurrentTime = duration();
- }
- }
-}
-
-/*!
- \reimp
-*/
-bool QParallelAnimationGroup::event(QEvent *event)
-{
- return QAnimationGroup::event(event);
-}
-
-QT_END_NAMESPACE
-
-#include "moc_qparallelanimationgroup.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qparallelanimationgroup.h b/src/corelib/animation/qparallelanimationgroup.h
deleted file mode 100644
index 57a8146..0000000
--- a/src/corelib/animation/qparallelanimationgroup.h
+++ /dev/null
@@ -1,86 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QPARALLELANIMATIONGROUP_H
-#define QPARALLELANIMATIONGROUP_H
-
-#include <QtCore/qanimationgroup.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QParallelAnimationGroupPrivate;
-class Q_CORE_EXPORT QParallelAnimationGroup : public QAnimationGroup
-{
- Q_OBJECT
-
-public:
- QParallelAnimationGroup(QObject *parent = 0);
- ~QParallelAnimationGroup();
-
- int duration() const;
-
-protected:
- QParallelAnimationGroup(QParallelAnimationGroupPrivate &dd, QObject *parent);
- bool event(QEvent *event);
-
- void updateCurrentTime(int msecs);
- void updateState(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
- void updateDirection(QAbstractAnimation::Direction direction);
-
-private:
- Q_DISABLE_COPY(QParallelAnimationGroup)
- Q_DECLARE_PRIVATE(QParallelAnimationGroup)
- Q_PRIVATE_SLOT(d_func(), void _q_uncontrolledAnimationFinished())
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif // QPARALLELANIMATIONGROUP
diff --git a/src/corelib/animation/qparallelanimationgroup_p.h b/src/corelib/animation/qparallelanimationgroup_p.h
deleted file mode 100644
index f36d972..0000000
--- a/src/corelib/animation/qparallelanimationgroup_p.h
+++ /dev/null
@@ -1,85 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QPARALLELANIMATIONGROUP_P_H
-#define QPARALLELANIMATIONGROUP_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qparallelanimationgroup.h"
-#include "qanimationgroup_p.h"
-#include <QtCore/QHash>
-
-QT_BEGIN_NAMESPACE
-
-class QParallelAnimationGroupPrivate : public QAnimationGroupPrivate
-{
- Q_DECLARE_PUBLIC(QParallelAnimationGroup)
-public:
- QParallelAnimationGroupPrivate()
- : lastLoop(0), lastCurrentTime(0)
- {
- }
-
- QHash<QAbstractAnimation*, int> uncontrolledFinishTime;
- int lastLoop;
- int lastCurrentTime;
-
- bool isUncontrolledAnimationFinished(QAbstractAnimation *anim) const;
- void connectUncontrolledAnimations();
- void disconnectUncontrolledAnimations();
-
- // private slot
- void _q_uncontrolledAnimationFinished();
-};
-
-QT_END_NAMESPACE
-
-#endif //QPARALLELANIMATIONGROUP_P_H
diff --git a/src/corelib/animation/qpauseanimation.cpp b/src/corelib/animation/qpauseanimation.cpp
deleted file mode 100644
index b175f0c..0000000
--- a/src/corelib/animation/qpauseanimation.cpp
+++ /dev/null
@@ -1,154 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QPauseAnimation
- \brief The QPauseAnimation class provides a pause for QSequentialAnimationGroup.
- \since 4.6
- \ingroup animation
-
- If you wish to introduce a delay between animations in a
- QSequentialAnimationGroup, you can insert a QPauseAnimation. This
- class does not animate anything, but does not
- \l{QAbstractAnimation::finished()}{finish} before a specified
- number of milliseconds have elapsed from when it was started. You
- specify the duration of the pause in the constructor. It can also
- be set directly with setDuration().
-
- It is not necessary to construct a QPauseAnimation yourself.
- QSequentialAnimationGroup provides the convenience functions
- \l{QSequentialAnimationGroup::}{addPause()} and
- \l{QSequentialAnimationGroup::}{insertPauseAt()}. These functions
- simply take the number of milliseconds the pause should last.
-
- \sa QSequentialAnimationGroup
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qpauseanimation.h"
-#include "qabstractanimation_p.h"
-
-
-QT_BEGIN_NAMESPACE
-
-class QPauseAnimationPrivate : public QAbstractAnimationPrivate
-{
-public:
- QPauseAnimationPrivate() : QAbstractAnimationPrivate(), duration(0)
- {
- }
-
- int duration;
-};
-
-/*!
- Constructs a QPauseAnimation.
- \a parent is passed to QObject's constructor.
- The default duration is 0.
-*/
-
-QPauseAnimation::QPauseAnimation(QObject *parent) : QAbstractAnimation(*new QPauseAnimationPrivate, parent)
-{
-}
-
-/*!
- Constructs a QPauseAnimation.
- \a msecs is the duration of the pause.
- \a parent is passed to QObject's constructor.
-*/
-
-QPauseAnimation::QPauseAnimation(int msecs, QObject *parent) : QAbstractAnimation(*new QPauseAnimationPrivate, parent)
-{
- setDuration(msecs);
-}
-
-/*!
- Destroys the pause animation.
-*/
-QPauseAnimation::~QPauseAnimation()
-{
-}
-
-/*!
- \property QPauseAnimation::duration
- \brief the duration of the pause.
-
- The duration of the pause. The duration should not be negative.
-*/
-int QPauseAnimation::duration() const
-{
- Q_D(const QPauseAnimation);
- return d->duration;
-}
-
-void QPauseAnimation::setDuration(int msecs)
-{
- if (msecs < 0) {
- qWarning("QPauseAnimation::setDuration: cannot set a negative duration");
- return;
- }
- Q_D(QPauseAnimation);
- d->duration = msecs;
-}
-
-/*!
- \reimp
- */
-bool QPauseAnimation::event(QEvent *e)
-{
- return QAbstractAnimation::event(e);
-}
-
-/*!
- \reimp
- */
-void QPauseAnimation::updateCurrentTime(int msecs)
-{
- Q_UNUSED(msecs);
-}
-
-
-QT_END_NAMESPACE
-
-#include "moc_qpauseanimation.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qpauseanimation.h b/src/corelib/animation/qpauseanimation.h
deleted file mode 100644
index cb6e041..0000000
--- a/src/corelib/animation/qpauseanimation.h
+++ /dev/null
@@ -1,84 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QPAUSEANIMATION_P_H
-#define QPAUSEANIMATION_P_H
-
-#include <QtCore/qanimationgroup.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QPauseAnimationPrivate;
-
-class Q_CORE_EXPORT QPauseAnimation : public QAbstractAnimation
-{
- Q_OBJECT
- Q_PROPERTY(int duration READ duration WRITE setDuration)
-public:
- QPauseAnimation(QObject *parent = 0);
- QPauseAnimation(int msecs, QObject *parent = 0);
- ~QPauseAnimation();
-
- int duration() const;
- void setDuration(int msecs);
-
-protected:
- bool event(QEvent *e);
- void updateCurrentTime(int msecs);
-
-private:
- Q_DISABLE_COPY(QPauseAnimation)
- Q_DECLARE_PRIVATE(QPauseAnimation)
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif // QPAUSEANIMATION_P_H
diff --git a/src/corelib/animation/qpropertyanimation.cpp b/src/corelib/animation/qpropertyanimation.cpp
deleted file mode 100644
index 9a17049..0000000
--- a/src/corelib/animation/qpropertyanimation.cpp
+++ /dev/null
@@ -1,316 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QPropertyAnimation
- \brief The QPropertyAnimation class animates Qt properties
- \since 4.6
- \ingroup animation
-
- QPropertyAnimation interpolates over \l{Qt's Property System}{Qt
- properties}. As property values are stored in \l{QVariant}s, the
- class inherits QVariantAnimation, and supports animation of the
- same \l{QVariant::Type}{variant types} as its super class.
-
- A class declaring properties must be a QObject. To make it
- possible to animate a property, it must provide a setter (so that
- QPropertyAnimation can set the property's value). Note that this
- makes it possible to animate many of Qt's widgets. Let's look at
- an example:
-
- \code
- QPropertyAnimation animation(myWidget, "geometry");
- animation.setDuration(10000);
- animation.setStartValue(QRect(0, 0, 100, 30));
- animation.setEndValue(QRect(250, 250, 100, 30));
-
- animation.start();
- \endcode
-
- The property name and the QObject instance of which property
- should be animated are passed to the constructor. You can then
- specify the start and end value of the property. The procedure is
- equal for properties in classes you have implemented
- yourself--just check with QVariantAnimation that your QVariant
- type is supported.
-
- The QVariantAnimation class description explains how to set up the
- animation in detail. Note, however, that if a start value is not
- set, the property will start at the value it had when the
- QPropertyAnimation instance was created.
-
- QPropertyAnimation works like a charm on its own. For complex
- animations that, for instance, contain several objects,
- QAnimationGroup is provided. An animation group is an animation
- that can contain other animations, and that can manage when its
- animations are played. Look at QParallelAnimationGroup for an
- example.
-
- \sa QVariantAnimation, QAnimationGroup, {The Animation Framework}
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qpropertyanimation.h"
-#include "qanimationgroup.h"
-#include <QtCore/qdebug.h>
-
-#include "qpropertyanimation_p.h"
-
-#include <QtCore/qmath.h>
-#include <QtCore/qmutex.h>
-
-QT_BEGIN_NAMESPACE
-
-typedef QPair<QObject *, QByteArray> QPropertyAnimationPair;
-typedef QHash<QPropertyAnimationPair, QPropertyAnimation*> QPropertyAnimationHash;
-Q_GLOBAL_STATIC(QPropertyAnimationHash, _q_runningAnimations);
-Q_GLOBAL_STATIC_WITH_ARGS(QMutex, guardHashLock, (QMutex::Recursive) )
-
-void QPropertyAnimationPrivate::updateMetaProperty()
-{
- if (!target || propertyName.isEmpty())
- return;
-
- if (hasMetaProperty == 0 && !property.isValid()) {
- const QMetaObject *mo = target->metaObject();
- propertyIndex = mo->indexOfProperty(propertyName);
- if (propertyIndex != -1) {
- hasMetaProperty = 1;
- property = mo->property(propertyIndex);
- propertyType = property.userType();
- } else {
- if (!target->dynamicPropertyNames().contains(propertyName))
- qWarning("QPropertyAnimation: you're trying to animate a non-existing property %s of your QObject", propertyName.constData());
- hasMetaProperty = 2;
- }
- }
-
- if (property.isValid())
- convertValues(propertyType);
-}
-
-void QPropertyAnimationPrivate::updateProperty(const QVariant &newValue)
-{
- if (!target || state == QAbstractAnimation::Stopped)
- return;
-
- if (hasMetaProperty == 1) {
- if (newValue.userType() == propertyType) {
- //no conversion is needed, we directly call the QObject::qt_metacall
- void *data = const_cast<void*>(newValue.constData());
- target->qt_metacall(QMetaObject::WriteProperty, propertyIndex, &data);
- } else {
- property.write(target, newValue);
- }
- } else {
- target->setProperty(propertyName.constData(), newValue);
- }
-}
-
-void QPropertyAnimationPrivate::_q_targetDestroyed()
-{
- Q_Q(QPropertyAnimation);
- //we stop here so that this animation is removed from the global hash
- q->stop();
- target = 0;
-}
-
-/*!
- Construct a QPropertyAnimation object. \a parent is passed to QObject's
- constructor.
-*/
-QPropertyAnimation::QPropertyAnimation(QObject *parent)
- : QVariantAnimation(*new QPropertyAnimationPrivate, parent)
-{
-}
-
-/*!
- Construct a QPropertyAnimation object. \a parent is passed to QObject's
- constructor. The animation changes the property \a propertyName on \a
- target. The default duration is 250ms.
-
- \sa targetObject, propertyName
-*/
-QPropertyAnimation::QPropertyAnimation(QObject *target, const QByteArray &propertyName, QObject *parent)
- : QVariantAnimation(*new QPropertyAnimationPrivate, parent)
-{
- setTargetObject(target);
- setPropertyName(propertyName);
-}
-
-/*!
- Destroys the QPropertyAnimation instance.
- */
-QPropertyAnimation::~QPropertyAnimation()
-{
- stop();
-}
-
-/*!
- \property QPropertyAnimation::targetObject
- \brief the target QObject for this animation.
-
- This property defines the target QObject for this animation.
- */
-QObject *QPropertyAnimation::targetObject() const
-{
- Q_D(const QPropertyAnimation);
- return d->target;
-}
-
-void QPropertyAnimation::setTargetObject(QObject *target)
-{
- Q_D(QPropertyAnimation);
- if (d->target == target)
- return;
-
- if (d->state != QAbstractAnimation::Stopped) {
- qWarning("QPropertyAnimation::setTargetObject: you can't change the target of a running animation");
- return;
- }
-
- //we need to get notified when the target is destroyed
- if (d->target)
- disconnect(d->target, SIGNAL(destroyed()), this, SLOT(_q_targetDestroyed()));
-
- if (target)
- connect(target, SIGNAL(destroyed()), SLOT(_q_targetDestroyed()));
-
- d->target = target;
- d->hasMetaProperty = 0;
- d->updateMetaProperty();
-}
-
-/*!
- \property QPropertyAnimation::propertyName
- \brief the target property name for this animation
-
- This property defines the target property name for this animation. The
- property name is required for the animation to operate.
- */
-QByteArray QPropertyAnimation::propertyName() const
-{
- Q_D(const QPropertyAnimation);
- return d->propertyName;
-}
-
-void QPropertyAnimation::setPropertyName(const QByteArray &propertyName)
-{
- Q_D(QPropertyAnimation);
- if (d->state != QAbstractAnimation::Stopped) {
- qWarning("QPropertyAnimation::setPropertyName: you can't change the property name of a running animation");
- return;
- }
-
- d->propertyName = propertyName;
- d->hasMetaProperty = 0;
- d->updateMetaProperty();
-}
-
-
-/*!
- \reimp
- */
-bool QPropertyAnimation::event(QEvent *event)
-{
- return QVariantAnimation::event(event);
-}
-
-/*!
- This virtual function is called by QVariantAnimation whenever the current value
- changes. \a value is the new, updated value. It updates the current value
- of the property on the target object.
-
- \sa currentValue, currentTime
- */
-void QPropertyAnimation::updateCurrentValue(const QVariant &value)
-{
- Q_D(QPropertyAnimation);
- d->updateProperty(value);
-}
-
-/*!
- \reimp
-
- If the startValue is not defined when the state of the animation changes from Stopped to Running,
- the current property value is used as the initial value for the animation.
-*/
-void QPropertyAnimation::updateState(QAbstractAnimation::State oldState,
- QAbstractAnimation::State newState)
-{
- Q_D(QPropertyAnimation);
-
- if (!d->target) {
- qWarning("QPropertyAnimation::updateState: Changing state of an animation without target");
- return;
- }
-
- QVariantAnimation::updateState(oldState, newState);
- QMutexLocker locker(guardHashLock());
- QPropertyAnimationHash * hash = _q_runningAnimations();
- QPropertyAnimationPair key(d->target, d->propertyName);
- if (newState == Running) {
- d->updateMetaProperty();
- QPropertyAnimation *oldAnim = hash->value(key, 0);
- if (oldAnim) {
- // try to stop the top level group
- QAbstractAnimation *current = oldAnim;
- while (current->group() && current->state() != Stopped)
- current = current->group();
- current->stop();
- }
- hash->insert(key, this);
-
- // update the default start value
- if (oldState == Stopped) {
- d->setDefaultStartValue(d->target->property(d->propertyName.constData()));
- }
- } else if (hash->value(key) == this) {
- hash->remove(key);
- }
-}
-
-#include "moc_qpropertyanimation.cpp"
-
-QT_END_NAMESPACE
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qpropertyanimation.h b/src/corelib/animation/qpropertyanimation.h
deleted file mode 100644
index 5b06bd2..0000000
--- a/src/corelib/animation/qpropertyanimation.h
+++ /dev/null
@@ -1,90 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QPROPERTYANIMATION_H
-#define QPROPERTYANIMATION_H
-
-#include <QtCore/qvariantanimation.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QPropertyAnimationPrivate;
-class Q_CORE_EXPORT QPropertyAnimation : public QVariantAnimation
-{
- Q_OBJECT
- Q_PROPERTY(QByteArray propertyName READ propertyName WRITE setPropertyName)
- Q_PROPERTY(QObject* targetObject READ targetObject WRITE setTargetObject)
-
-public:
- QPropertyAnimation(QObject *parent = 0);
- QPropertyAnimation(QObject *target, const QByteArray &propertyName, QObject *parent = 0);
- ~QPropertyAnimation();
-
- QObject *targetObject() const;
- void setTargetObject(QObject *target);
-
- QByteArray propertyName() const;
- void setPropertyName(const QByteArray &propertyName);
-
-protected:
- bool event(QEvent *event);
-
- void updateCurrentValue(const QVariant &value);
- void updateState(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
- Q_PRIVATE_SLOT(d_func(), void _q_targetDestroyed());
-private:
- Q_DISABLE_COPY(QPropertyAnimation)
- Q_DECLARE_PRIVATE(QPropertyAnimation)
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif // QPROPERTYANIMATION_H
diff --git a/src/corelib/animation/qpropertyanimation_p.h b/src/corelib/animation/qpropertyanimation_p.h
deleted file mode 100644
index b51d039..0000000
--- a/src/corelib/animation/qpropertyanimation_p.h
+++ /dev/null
@@ -1,89 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QPROPERTYANIMATION_P_H
-#define QPROPERTYANIMATION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qpropertyanimation.h"
-#include <QtCore/qmetaobject.h>
-
-#include "qvariantanimation_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QPropertyAnimationPrivate : public QVariantAnimationPrivate
-{
- Q_DECLARE_PUBLIC(QPropertyAnimation)
-public:
- QPropertyAnimationPrivate()
- : target(0), propertyType(0), propertyIndex(0), hasMetaProperty(false)
- {
- }
-
- void _q_targetDestroyed();
-
- QObject *target;
-
- //for the QProperty
- QMetaProperty property;
- int propertyType;
- int propertyIndex;
-
- int hasMetaProperty;
- QByteArray propertyName;
- void updateProperty(const QVariant &);
- void updateMetaProperty();
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/animation/qsequentialanimationgroup.cpp b/src/corelib/animation/qsequentialanimationgroup.cpp
deleted file mode 100644
index 14814a7..0000000
--- a/src/corelib/animation/qsequentialanimationgroup.cpp
+++ /dev/null
@@ -1,594 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*!
- \class QSequentialAnimationGroup
- \brief The QSequentialAnimationGroup class provides a sequential group of animations.
- \since 4.6
- \ingroup animation
-
- QSequentialAnimationGroup is a QAnimationGroup that runs its
- animations in sequence, i.e., it starts one animation after
- another has finished playing. The animations are played in the
- order they are added to the group (using
- \l{QAnimationGroup::}{addAnimation()} or
- \l{QAnimationGroup::}{insertAnimationAt()}). The animation group
- finishes when its last animation has finished.
-
- At each moment there is at most one animation that is active in
- the group; it is returned by currentAnimation(). An empty group
- has no current animation.
-
- A sequential animation group can be treated as any other
- animation, i.e., it can be started, stopped, and added to other
- groups. You can also call addPause() or insertPauseAt() to add a
- pause to a sequential animation group.
-
- \code
- QSequentialAnimationGroup group;
-
- group.addAnimation(anim1);
- group.addAnimation(anim2);
-
- group.start();
- \endcode
-
- In this example, \c anim1 and \c anim2 are two already set up
- \l{QPropertyAnimation}s.
-
- \sa QAnimationGroup, QAbstractAnimation, {The Animation Framework}
-*/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qsequentialanimationgroup.h"
-#include "qsequentialanimationgroup_p.h"
-
-#include "qpauseanimation.h"
-
-#include <QtCore/qdebug.h>
-
-QT_BEGIN_NAMESPACE
-
-
-
-bool QSequentialAnimationGroupPrivate::atEnd() const
-{
- // we try to detect if we're at the end of the group
- //this is true if the following conditions are true:
- // 1. we're in the last loop
- // 2. the direction is forward
- // 3. the current animation is the last one
- // 4. the current animation has reached its end
- const int animTotalCurrentTime = QAbstractAnimationPrivate::get(currentAnimation)->totalCurrentTime;
- return (currentLoop == loopCount - 1
- && direction == QAbstractAnimation::Forward
- && currentAnimation == animations.last()
- && animTotalCurrentTime == animationActualTotalDuration(currentAnimationIndex));
-}
-
-int QSequentialAnimationGroupPrivate::animationActualTotalDuration(int index) const
-{
- QAbstractAnimation *anim = animations.at(index);
- int ret = anim->totalDuration();
- if (ret == -1 && actualDuration.size() > index)
- ret = actualDuration.at(index); //we can try the actual duration there
- return ret;
-}
-
-QSequentialAnimationGroupPrivate::AnimationIndex QSequentialAnimationGroupPrivate::indexForTime(int msecs) const
-{
- Q_Q(const QSequentialAnimationGroup);
- Q_ASSERT(!animations.isEmpty());
-
- AnimationIndex ret;
- int duration = 0;
-
- // in case duration is -1, currentLoop will always be 0
- ret.timeOffset = currentLoop * q->duration();
-
- for (int i = 0; i < animations.size(); ++i) {
- duration = animationActualTotalDuration(i);
-
- // 'animation' is the current animation if one of these reasons is true:
- // 1. it's duration is undefined
- // 2. it ends after msecs
- // 3. it is the last animation (this can happen in case there is at least 1 uncontrolled animation)
- // 4. it ends exactly in msecs and the direction is backwards
- if (duration == -1 || msecs < (ret.timeOffset + duration)
- || (msecs == (ret.timeOffset + duration) && direction == QAbstractAnimation::Backward)) {
- ret.index = i;
- return ret;
- }
-
- // 'animation' has a non-null defined duration and is not the one at time 'msecs'.
- ret.timeOffset += duration;
- }
-
- // this can only happen when one of those conditions is true:
- // 1. the duration of the group is undefined and we passed its actual duration
- // 2. there are only 0-duration animations in the group
- ret.timeOffset -= duration;
- ret.index = animations.size() - 1;
- return ret;
-}
-
-void QSequentialAnimationGroupPrivate::restart()
-{
- // restarting the group by making the first/last animation the current one
- if (direction == QAbstractAnimation::Forward) {
- lastLoop = 0;
- if (currentAnimationIndex == 0)
- activateCurrentAnimation();
- else
- setCurrentAnimation(0);
- } else { // direction == QAbstractAnimation::Backward
- lastLoop = loopCount - 1;
- int index = animations.size() - 1;
- if (currentAnimationIndex == index)
- activateCurrentAnimation();
- else
- setCurrentAnimation(index);
- }
-}
-
-/*!
- \internal
- This manages advancing the execution of a group running forwards (time has gone forward),
- which is the same behaviour for rewinding the execution of a group running backwards
- (time has gone backward).
-*/
-void QSequentialAnimationGroupPrivate::advanceForwards(const AnimationIndex &newAnimationIndex)
-{
- if (lastLoop < currentLoop) {
- // we need to fast forward to the end
- for (int i = currentAnimationIndex; i < animations.size(); ++i) {
- QAbstractAnimation *anim = animations.at(i);
- setCurrentAnimation(i, true);
- anim->setCurrentTime(animationActualTotalDuration(i));
- }
- // this will make sure the current animation is reset to the beginning
- if (animations.size() == 1)
- // we need to force activation because setCurrentAnimation will have no effect
- activateCurrentAnimation();
- else
- setCurrentAnimation(0, true);
- }
-
- // and now we need to fast forward from the current position to
- for (int i = currentAnimationIndex; i < newAnimationIndex.index; ++i) { //### WRONG,
- QAbstractAnimation *anim = animations.at(i);
- setCurrentAnimation(i, true);
- anim->setCurrentTime(animationActualTotalDuration(i));
- }
- // setting the new current animation will happen later
-}
-
-/*!
- \internal
- This manages rewinding the execution of a group running forwards (time has gone forward),
- which is the same behaviour for advancing the execution of a group running backwards
- (time has gone backward).
-*/
-void QSequentialAnimationGroupPrivate::rewindForwards(const AnimationIndex &newAnimationIndex)
-{
- if (lastLoop > currentLoop) {
- // we need to fast rewind to the beginning
- for (int i = currentAnimationIndex; i >= 0 ; --i) {
- QAbstractAnimation *anim = animations.at(i);
- setCurrentAnimation(i, true);
- anim->setCurrentTime(0);
- }
- // this will make sure the current animation is reset to the end
- if (animations.size() == 1)
- // we need to force activation because setCurrentAnimation will have no effect
- activateCurrentAnimation();
- else
- setCurrentAnimation(animations.count() - 1, true);
- }
-
- // and now we need to fast rewind from the current position to
- for (int i = currentAnimationIndex; i > newAnimationIndex.index; --i) {
- QAbstractAnimation *anim = animations.at(i);
- setCurrentAnimation(i, true);
- anim->setCurrentTime(0);
- }
- // setting the new current animation will happen later
-}
-
-/*!
- \fn QSequentialAnimationGroup::currentAnimationChanged(QAbstractAnimation *current)
-
- QSequentialAnimationGroup emits this signal when currentAnimation
- has been changed. \a current is the current animation.
-
- \sa currentAnimation()
-*/
-
-
-/*!
- Constructs a QSequentialAnimationGroup.
- \a parent is passed to QObject's constructor.
-*/
-QSequentialAnimationGroup::QSequentialAnimationGroup(QObject *parent)
- : QAnimationGroup(*new QSequentialAnimationGroupPrivate, parent)
-{
-}
-
-/*!
- \internal
-*/
-QSequentialAnimationGroup::QSequentialAnimationGroup(QSequentialAnimationGroupPrivate &dd,
- QObject *parent)
- : QAnimationGroup(dd, parent)
-{
-}
-
-/*!
- Destroys the animation group. It will also destroy all its animations.
-*/
-QSequentialAnimationGroup::~QSequentialAnimationGroup()
-{
-}
-
-/*!
- Adds a pause of \a msecs to this animation group.
- The pause is considered as a special type of animation, thus count() will be
- increased by one.
- \sa insertPauseAt(), QAnimationGroup::addAnimation()
-*/
-QPauseAnimation *QSequentialAnimationGroup::addPause(int msecs)
-{
- QPauseAnimation *pause = new QPauseAnimation(msecs);
- addAnimation(pause);
- return pause;
-}
-
-/*!
- Inserts a pause of \a msecs milliseconds at \a index in this animation
- group.
-
- \sa addPause(), QAnimationGroup::insertAnimationAt()
-*/
-QPauseAnimation *QSequentialAnimationGroup::insertPauseAt(int index, int msecs)
-{
- Q_D(const QSequentialAnimationGroup);
-
- if (index < 0 || index > d->animations.size()) {
- qWarning("QSequentialAnimationGroup::insertPauseAt: index is out of bounds");
- return 0;
- }
-
- QPauseAnimation *pause = new QPauseAnimation(msecs);
- insertAnimationAt(index, pause);
- return pause;
-}
-
-
-/*!
- \property QSequentialAnimationGroup::currentAnimation
- Returns the animation in the current time.
-
- \sa currentAnimationChanged()
-*/
-QAbstractAnimation *QSequentialAnimationGroup::currentAnimation() const
-{
- Q_D(const QSequentialAnimationGroup);
- return d->currentAnimation;
-}
-
-/*!
- \reimp
-*/
-int QSequentialAnimationGroup::duration() const
-{
- Q_D(const QSequentialAnimationGroup);
- int ret = 0;
-
- for (int i = 0; i < d->animations.size(); ++i) {
- QAbstractAnimation *animation = d->animations.at(i);
- const int currentDuration = animation->totalDuration();
- if (currentDuration == -1)
- return -1; // Undetermined length
-
- ret += currentDuration;
- }
-
- return ret;
-}
-
-/*!
- \reimp
-*/
-void QSequentialAnimationGroup::updateCurrentTime(int msecs)
-{
- Q_D(QSequentialAnimationGroup);
- if (!d->currentAnimation)
- return;
-
- const QSequentialAnimationGroupPrivate::AnimationIndex newAnimationIndex = d->indexForTime(msecs);
-
- // remove unneeded animations from actualDuration list
- while (newAnimationIndex.index < d->actualDuration.size())
- d->actualDuration.removeLast();
-
- // newAnimationIndex.index is the new current animation
- if (d->lastLoop < d->currentLoop
- || (d->lastLoop == d->currentLoop && d->currentAnimationIndex < newAnimationIndex.index)) {
- // advancing with forward direction is the same as rewinding with backwards direction
- d->advanceForwards(newAnimationIndex);
- } else if (d->lastLoop > d->currentLoop
- || (d->lastLoop == d->currentLoop && d->currentAnimationIndex > newAnimationIndex.index)) {
- // rewinding with forward direction is the same as advancing with backwards direction
- d->rewindForwards(newAnimationIndex);
- }
-
- d->setCurrentAnimation(newAnimationIndex.index);
-
- const int newCurrentTime = msecs - newAnimationIndex.timeOffset;
-
- if (d->currentAnimation) {
- d->currentAnimation->setCurrentTime(newCurrentTime);
- if (d->atEnd()) {
- //we make sure that we don't exceed the duration here
- d->currentTime += QAbstractAnimationPrivate::get(d->currentAnimation)->totalCurrentTime - newCurrentTime;
- stop();
- }
- } else {
- //the only case where currentAnimation could be null
- //is when all animations have been removed
- Q_ASSERT(d->animations.isEmpty());
- d->currentTime = 0;
- stop();
- }
-
- d->lastLoop = d->currentLoop;
-}
-
-/*!
- \reimp
-*/
-void QSequentialAnimationGroup::updateState(QAbstractAnimation::State oldState,
- QAbstractAnimation::State newState)
-{
- Q_D(QSequentialAnimationGroup);
- QAnimationGroup::updateState(oldState, newState);
-
- if (!d->currentAnimation)
- return;
-
- switch (newState) {
- case Stopped:
- d->currentAnimation->stop();
- break;
- case Paused:
- if (oldState == d->currentAnimation->state()
- && oldState == QSequentialAnimationGroup::Running) {
- d->currentAnimation->pause();
- }
- else
- d->restart();
- break;
- case Running:
- if (oldState == d->currentAnimation->state()
- && oldState == QSequentialAnimationGroup::Paused)
- d->currentAnimation->start();
- else
- d->restart();
- break;
- }
-}
-
-/*!
- \reimp
-*/
-void QSequentialAnimationGroup::updateDirection(QAbstractAnimation::Direction direction)
-{
- Q_D(QSequentialAnimationGroup);
- // we need to update the direction of the current animation
- if (state() != Stopped && d->currentAnimation)
- d->currentAnimation->setDirection(direction);
-}
-
-/*!
- \reimp
-*/
-bool QSequentialAnimationGroup::event(QEvent *event)
-{
- return QAnimationGroup::event(event);
-}
-
-void QSequentialAnimationGroupPrivate::setCurrentAnimation(int index, bool intermediate)
-{
- Q_Q(QSequentialAnimationGroup);
-
- index = qMin(index, animations.count() - 1);
-
- if (index == -1) {
- Q_ASSERT(animations.isEmpty());
- currentAnimationIndex = -1;
- currentAnimation = 0;
- return;
- }
-
- // need these two checks below because this func can be called after the current animation
- // has been removed
- if (index == currentAnimationIndex && animations.at(index) == currentAnimation)
- return;
-
- // stop the old current animation
- if (currentAnimation)
- currentAnimation->stop();
-
- currentAnimation = animations.at(index);
- currentAnimationIndex = index;
-
- emit q->currentAnimationChanged(currentAnimation);
-
- activateCurrentAnimation(intermediate);
-}
-
-void QSequentialAnimationGroupPrivate::activateCurrentAnimation(bool intermediate)
-{
- Q_Q(QSequentialAnimationGroup);
-
- if (!currentAnimation)
- return;
-
- if (state == QSequentialAnimationGroup::Stopped)
- return;
-
- currentAnimation->stop();
-
- // we ensure the direction is consistent with the group's direction
- currentAnimation->setDirection(direction);
-
- // connects to the finish signal of uncontrolled animations
- if (currentAnimation->totalDuration() == -1)
- QObject::connect(currentAnimation, SIGNAL(finished()), q, SLOT(_q_uncontrolledAnimationFinished()));
-
- currentAnimation->start();
- if (!intermediate && state == QSequentialAnimationGroup::Paused)
- currentAnimation->pause();
-}
-
-void QSequentialAnimationGroupPrivate::_q_uncontrolledAnimationFinished()
-{
- Q_Q(QSequentialAnimationGroup);
- Q_ASSERT(qobject_cast<QAbstractAnimation *>(q->sender()) == currentAnimation);
-
- // we trust the duration returned by the animation
- while (actualDuration.size() < (currentAnimationIndex + 1))
- actualDuration.append(-1);
- actualDuration[currentAnimationIndex] = currentAnimation->currentTime();
-
- QObject::disconnect(currentAnimation, SIGNAL(finished()), q, SLOT(_q_uncontrolledAnimationFinished()));
-
- if ((direction == QAbstractAnimation::Forward && currentAnimation == animations.last())
- || (direction == QAbstractAnimation::Backward && currentAnimationIndex == 0)) {
- // we don't handle looping of a group with undefined duration
- q->stop();
- } else if (direction == QAbstractAnimation::Forward) {
- // set the current animation to be the next one
- setCurrentAnimation(currentAnimationIndex + 1);
- } else {
- // set the current animation to be the previous one
- setCurrentAnimation(currentAnimationIndex - 1);
- }
-}
-
-/*!
- \internal
- This method is called whenever an animation is added to
- the group at index \a index.
- Note: We only support insertion after the current animation
-*/
-void QSequentialAnimationGroupPrivate::animationInsertedAt(int index)
-{
- if (currentAnimation == 0)
- setCurrentAnimation(0); // initialize the current animation
-
- if (currentAnimationIndex == index
- && currentAnimation->currentTime() == 0 && currentAnimation->currentLoop() == 0) {
- //in this case we simply insert an animation before the current one has actually started
- setCurrentAnimation(index);
- }
-
- //we update currentAnimationIndex in case it has changed (the animation pointer is still valid)
- currentAnimationIndex = animations.indexOf(currentAnimation);
-
- if (index < currentAnimationIndex || currentLoop != 0) {
- qWarning("QSequentialGroup::insertAnimationAt only supports to add animations after the current one.");
- return; //we're not affected because it is added after the current one
- }
-}
-
-/*!
- \internal
- This method is called whenever an animation is removed from
- the group at index \a index. The animation is no more listed when this
- method is called.
-*/
-void QSequentialAnimationGroupPrivate::animationRemovedAt(int index)
-{
- Q_Q(QSequentialAnimationGroup);
- QAnimationGroupPrivate::animationRemovedAt(index);
-
- Q_ASSERT(currentAnimation); // currentAnimation should always be set
-
- if (actualDuration.size() > index)
- actualDuration.removeAt(index);
-
- const int currentIndex = animations.indexOf(currentAnimation);
- if (currentIndex == -1) {
- //we're removing the current animation, let's update it to another one
- if (index < animations.count())
- setCurrentAnimation(index); //let's try to take the next one
- else if (index > 0)
- setCurrentAnimation(index - 1);
- else// case all animations were removed
- setCurrentAnimation(-1);
- } else if (currentAnimationIndex > index) {
- currentAnimationIndex--;
- }
-
- // duration of the previous animations up to the current animation
- currentTime = 0;
- for (int i = 0; i < currentAnimationIndex; ++i) {
- const int current = animationActualTotalDuration(i);
- currentTime += current;
- }
-
- if (currentIndex != -1) {
- //the current animation is not the one being removed
- //so we add its current time to the current time of this group
- currentTime += QAbstractAnimationPrivate::get(currentAnimation)->totalCurrentTime;
- }
-
- //let's also update the total current time
- totalCurrentTime = currentTime + loopCount * q->duration();
-}
-
-QT_END_NAMESPACE
-
-#include "moc_qsequentialanimationgroup.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qsequentialanimationgroup.h b/src/corelib/animation/qsequentialanimationgroup.h
deleted file mode 100644
index 4701a76..0000000
--- a/src/corelib/animation/qsequentialanimationgroup.h
+++ /dev/null
@@ -1,96 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSEQUENTIALANIMATIONGROUP_H
-#define QSEQUENTIALANIMATIONGROUP_H
-
-#include <QtCore/qanimationgroup.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QPauseAnimation;
-class QSequentialAnimationGroupPrivate;
-
-class Q_CORE_EXPORT QSequentialAnimationGroup : public QAnimationGroup
-{
- Q_OBJECT
- Q_PROPERTY(QAbstractAnimation* currentAnimation READ currentAnimation NOTIFY currentAnimationChanged)
-
-public:
- QSequentialAnimationGroup(QObject *parent = 0);
- ~QSequentialAnimationGroup();
-
- QPauseAnimation *addPause(int msecs);
- QPauseAnimation *insertPauseAt(int index, int msecs);
-
- QAbstractAnimation *currentAnimation() const;
- int duration() const;
-
-Q_SIGNALS:
- void currentAnimationChanged(QAbstractAnimation *current);
-
-protected:
- QSequentialAnimationGroup(QSequentialAnimationGroupPrivate &dd, QObject *parent);
- bool event(QEvent *event);
-
- void updateCurrentTime(int msecs);
- void updateState(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
- void updateDirection(QAbstractAnimation::Direction direction);
-
-private:
- Q_DISABLE_COPY(QSequentialAnimationGroup)
- Q_DECLARE_PRIVATE(QSequentialAnimationGroup)
- Q_PRIVATE_SLOT(d_func(), void _q_uncontrolledAnimationFinished())
-};
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif //QSEQUENTIALANIMATIONGROUP_H
diff --git a/src/corelib/animation/qsequentialanimationgroup_p.h b/src/corelib/animation/qsequentialanimationgroup_p.h
deleted file mode 100644
index 3ac90f8..0000000
--- a/src/corelib/animation/qsequentialanimationgroup_p.h
+++ /dev/null
@@ -1,111 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSEQUENTIALANIMATIONGROUP_P_H
-#define QSEQUENTIALANIMATIONGROUP_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qsequentialanimationgroup.h"
-#include "qanimationgroup_p.h"
-
-
-QT_BEGIN_NAMESPACE
-
-class QSequentialAnimationGroupPrivate : public QAnimationGroupPrivate
-{
- Q_DECLARE_PUBLIC(QSequentialAnimationGroup)
-public:
- QSequentialAnimationGroupPrivate()
- : currentAnimation(0), currentAnimationIndex(-1), lastLoop(0)
- { }
-
-
- struct AnimationIndex
- {
- AnimationIndex() : index(0), timeOffset(0) {}
- // index points to the animation at timeOffset, skipping 0 duration animations.
- // Note that the index semantic is slightly different depending on the direction.
- int index; // the index of the animation in timeOffset
- int timeOffset; // time offset when the animation at index starts.
- };
-
- int animationActualTotalDuration(int index) const;
- AnimationIndex indexForTime(int msecs) const;
-
- void setCurrentAnimation(int index, bool intermediate = false);
- void activateCurrentAnimation(bool intermediate = false);
-
- void animationInsertedAt(int index);
- void animationRemovedAt(int index);
-
- bool atEnd() const;
-
- QAbstractAnimation *currentAnimation;
- int currentAnimationIndex;
-
- // this is the actual duration of uncontrolled animations
- // it helps seeking and even going forward
- QList<int> actualDuration;
-
- void restart();
- int lastLoop;
-
- // handle time changes
- void rewindForwards(const AnimationIndex &newAnimationIndex);
- void advanceForwards(const AnimationIndex &newAnimationIndex);
-
- // private slot
- void _q_uncontrolledAnimationFinished();
-};
-
-QT_END_NAMESPACE
-
-#endif //QSEQUENTIALANIMATIONGROUP_P_H
diff --git a/src/corelib/animation/qvariantanimation.cpp b/src/corelib/animation/qvariantanimation.cpp
deleted file mode 100644
index a6834bb..0000000
--- a/src/corelib/animation/qvariantanimation.cpp
+++ /dev/null
@@ -1,644 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QT_NO_ANIMATION
-
-#include "qvariantanimation.h"
-#include "qvariantanimation_p.h"
-
-#include <QtCore/QRect>
-#include <QtCore/QLineF>
-#include <QtCore/QLine>
-#include <QtCore/QReadWriteLock>
-#include <QtCore/qdebug.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QVariantAnimation
- \ingroup animation
- \brief The QVariantAnimation class provides an abstract base class for animations.
- \since 4.6
-
- This class is part of \l{The Animation Framework}. It serves as a
- base class for property and item animations, with functions for
- shared functionality.
-
- QVariantAnimation cannot be used directly as it is an abstract
- class; it does not implement
- \l{QAbstractAnimation::}{updateCurrentValue()} from
- QAbstractAnimation. The class performs interpolation over
- \l{QVariant}s, but leaves using the interpolated values to its
- subclasses. Currently, Qt provides QPropertyAnimation, which
- animates Qt \l{Qt's Property System}{properties}. See the
- QPropertyAnimation class description if you wish to animate such
- properties.
-
- You can then set start and end values for the property by calling
- setStartValue() and setEndValue(), and finally call start() to
- start the animation. QVariantAnimation will interpolate the
- property of the target object and emit valueChanged(). To react to
- a change in the current value you have to reimplement the
- updateCurrentValue() virtual function.
-
- It is also possible to set values at specified steps situated
- between the start and end value. The interpolation will then
- touch these points at the specified steps. Note that the start and
- end values are defined as the key values at 0.0 and 1.0.
-
- There are two ways to affect how QVariantAnimation interpolates
- the values. You can set an easing curve by calling
- setEasingCurve(), and configure the duration by calling
- setDuration(). You can change how the QVariants are interpolated
- by creating a subclass of QVariantAnimation, and reimplementing
- the virtual interpolated() function.
-
- Subclassing QVariantAnimation can be an alternative if you have
- \l{QVariant}s that you do not wish to declare as Qt properties.
- Note, however, that you in most cases will be better off declaring
- your QVariant as a property.
-
- Not all QVariant types are supported. Below is a list of currently
- supported QVariant types:
-
- \list
- \o \l{QMetaType::}{Int}
- \o \l{QMetaType::}{Double}
- \o \l{QMetaType::}{Float}
- \o \l{QMetaType::}{QLine}
- \o \l{QMetaType::}{QLineF}
- \o \l{QMetaType::}{QPoint}
- \o \l{QMetaType::}{QSize}
- \o \l{QMetaType::}{QSizeF}
- \o \l{QMetaType::}{QRect}
- \o \l{QMetaType::}{QRectF}
- \endlist
-
- If you need to interpolate other variant types, including custom
- types, you have to implement interpolation for these yourself.
- You do this by reimplementing interpolated(), which returns
- interpolation values for the value being interpolated.
-
- \omit We need some snippets around here. \endomit
-
- \sa QPropertyAnimation, QAbstractAnimation, {The Animation Framework}
-*/
-
-/*!
- \fn void QVariantAnimation::valueChanged(const QVariant &value)
-
- QVariantAnimation emits this signal whenever the current \a value changes.
-
- \sa currentValue, startValue, endValue
-*/
-
-static bool animationValueLessThan(const QVariantAnimation::KeyValue &p1, const QVariantAnimation::KeyValue &p2)
-{
- return p1.first < p2.first;
-}
-
-template<> Q_INLINE_TEMPLATE QRect _q_interpolate(const QRect &f, const QRect &t, qreal progress)
-{
- QRect ret;
- ret.setCoords(_q_interpolate(f.left(), t.left(), progress),
- _q_interpolate(f.top(), t.top(), progress),
- _q_interpolate(f.right(), t.right(), progress),
- _q_interpolate(f.bottom(), t.bottom(), progress));
- return ret;
-}
-
-template<> Q_INLINE_TEMPLATE QRectF _q_interpolate(const QRectF &f, const QRectF &t, qreal progress)
-{
- qreal x1, y1, w1, h1;
- f.getRect(&x1, &y1, &w1, &h1);
- qreal x2, y2, w2, h2;
- t.getRect(&x2, &y2, &w2, &h2);
- return QRectF(_q_interpolate(x1, x2, progress), _q_interpolate(y1, y2, progress),
- _q_interpolate(w1, w2, progress), _q_interpolate(h1, h2, progress));
-}
-
-template<> Q_INLINE_TEMPLATE QLine _q_interpolate(const QLine &f, const QLine &t, qreal progress)
-{
- return QLine( _q_interpolate(f.p1(), t.p1(), progress), _q_interpolate(f.p2(), t.p2(), progress));
-}
-
-template<> Q_INLINE_TEMPLATE QLineF _q_interpolate(const QLineF &f, const QLineF &t, qreal progress)
-{
- return QLineF( _q_interpolate(f.p1(), t.p1(), progress), _q_interpolate(f.p2(), t.p2(), progress));
-}
-
-void QVariantAnimationPrivate::convertValues(int t)
-{
- //this ensures that all the keyValues are of type t
- for (int i = 0; i < keyValues.count(); ++i) {
- QVariantAnimation::KeyValue &pair = keyValues[i];
- if (pair.second.userType() != t)
- pair.second.convert(static_cast<QVariant::Type>(t));
- }
- interpolator = 0; // if the type changed we need to update the interpolator
-}
-
-/*!
- \internal
- The goal of this function is to update the currentInterval member. As a consequence, we also
- need to update the currentValue.
- Set \a force to true to always recalculate the interval.
-*/
-void QVariantAnimationPrivate::recalculateCurrentInterval(bool force/*=false*/)
-{
- // can't interpolate if we have only 1 key value
- if (keyValues.count() <= 1)
- return;
-
- const qreal progress = easing.valueForProgress(((duration == 0) ? qreal(1) : qreal(currentTime) / qreal(duration)));
-
- if (force || progress < currentInterval.start.first || progress > currentInterval.end.first) {
- //let's update currentInterval
- QVariantAnimation::KeyValues::const_iterator itStart = qLowerBound(keyValues.constBegin(),
- keyValues.constEnd(),
- qMakePair(progress, QVariant()),
- animationValueLessThan);
- QVariantAnimation::KeyValues::const_iterator itEnd = itStart;
-
- // If we are at the end we should continue to use the last keyValues in case of extrapolation (progress > 1.0).
- // This is because the easing function can return a value slightly outside the range [0, 1]
- if (itStart != keyValues.constEnd()) {
- // this can't happen because we always prepend the default start value there
- if (itStart == keyValues.constBegin()) {
- ++itEnd;
- } else {
- --itStart;
- }
-
- // update all the values of the currentInterval
- currentInterval.start = *itStart;
- currentInterval.end = *itEnd;
- }
- }
- setCurrentValueForProgress(progress);
-}
-
-void QVariantAnimationPrivate::setCurrentValueForProgress(const qreal progress)
-{
- Q_Q(QVariantAnimation);
-
- const qreal startProgress = currentInterval.start.first;
- const qreal endProgress = currentInterval.end.first;
- const qreal localProgress = (progress - startProgress) / (endProgress - startProgress);
-
- QVariant ret = q->interpolated(currentInterval.start.second,
- currentInterval.end.second,
- localProgress);
- qSwap(currentValue, ret);
- q->updateCurrentValue(currentValue);
- if ((connectedSignals & changedSignalMask) && currentValue != ret) {
- //the value has changed
- emit q->valueChanged(currentValue);
- }
-}
-
-QVariant QVariantAnimationPrivate::valueAt(qreal step) const
-{
- QVariantAnimation::KeyValues::const_iterator result =
- qBinaryFind(keyValues.begin(), keyValues.end(), qMakePair(step, QVariant()), animationValueLessThan);
- if (result != keyValues.constEnd())
- return result->second;
-
- return QVariant();
-}
-
-void QVariantAnimationPrivate::setValueAt(qreal step, const QVariant &value)
-{
- if (step < qreal(0.0) || step > qreal(1.0)) {
- qWarning("QVariantAnimation::setValueAt: invalid step = %f", step);
- return;
- }
-
- QVariantAnimation::KeyValue pair(step, value);
-
- QVariantAnimation::KeyValues::iterator result = qLowerBound(keyValues.begin(), keyValues.end(), pair, animationValueLessThan);
- if (result == keyValues.end() || result->first != step) {
- keyValues.insert(result, pair);
- } else {
- if (value.isValid())
- result->second = value; // replaces the previous value
- else if (step == 0 && !hasStartValue && defaultStartValue.isValid())
- result->second = defaultStartValue; // resets to the default start value
- else
- keyValues.erase(result); // removes the previous value
- }
-
- recalculateCurrentInterval(/*force=*/true);
-}
-
-void QVariantAnimationPrivate::setDefaultStartValue(const QVariant &value)
-{
- defaultStartValue = value;
- if (!hasStartValue)
- setValueAt(0, value);
-}
-
-/*!
- Construct a QVariantAnimation object. \a parent is passed to QAbstractAnimation's
- constructor.
-*/
-QVariantAnimation::QVariantAnimation(QObject *parent) : QAbstractAnimation(*new QVariantAnimationPrivate, parent)
-{
- d_func()->init();
-}
-
-/*!
- \internal
-*/
-QVariantAnimation::QVariantAnimation(QVariantAnimationPrivate &dd, QObject *parent) : QAbstractAnimation(dd, parent)
-{
- d_func()->init();
-}
-
-/*!
- Destroys the animation.
-*/
-QVariantAnimation::~QVariantAnimation()
-{
-}
-
-/*!
- \property QVariantAnimation::easingCurve
- \brief the easing curve of the animation
-
- This property defines the easing curve of the animation. By
- default, a linear easing curve is used, resulting in linear
- interpolation. Other curves are provided, for instance,
- QEasingCurve::InCirc, which provides a circular entry curve.
- Another example is QEasingCurve::InOutElastic, which provides an
- elastic effect on the values of the interpolated variant.
-
- The easing curve is used with the interpolator, the interpolated()
- virtual function, the animation's duration, and iterationCount, to
- control how the current value changes as the animation progresses.
-*/
-QEasingCurve QVariantAnimation::easingCurve() const
-{
- Q_D(const QVariantAnimation);
- return d->easing;
-}
-
-void QVariantAnimation::setEasingCurve(const QEasingCurve &easing)
-{
- Q_D(QVariantAnimation);
- d->easing = easing;
- d->recalculateCurrentInterval();
-}
-
-Q_GLOBAL_STATIC(QVector<QVariantAnimation::Interpolator>, registeredInterpolators)
-Q_GLOBAL_STATIC(QReadWriteLock, registeredInterpolatorsLock)
-
-/*!
- \fn void qRegisterAnimationInterpolator(QVariant (*func)(const T &from, const T &to, qreal progress))
- \relates QVariantAnimation
- \threadsafe
-
- Registers a custom interpolator \a func for the template type \c{T}.
- The interpolator has to be registered before the animation is constructed.
- To unregister (and use the default interpolator) set \a func to 0.
- */
-
-/*!
- \internal
- \typedef QVariantAnimation::Interpolator
-
- This is a typedef for a pointer to a function with the following
- signature:
- \code
- QVariant myInterpolator(const QVariant &from, const QVariant &to, qreal progress);
- \endcode
-
-*/
-
-/*! \internal
- * Registers a custom interpolator \a func for the specific \a interpolationType.
- * The interpolator has to be registered before the animation is constructed.
- * To unregister (and use the default interpolator) set \a func to 0.
- */
-void QVariantAnimation::registerInterpolator(QVariantAnimation::Interpolator func, int interpolationType)
-{
- // will override any existing interpolators
- QWriteLocker locker(registeredInterpolatorsLock());
- if (int(interpolationType) >= registeredInterpolators()->count())
- registeredInterpolators()->resize(int(interpolationType) + 1);
- registeredInterpolators()->replace(interpolationType, func);
-}
-
-
-template<typename T> static inline QVariantAnimation::Interpolator castToInterpolator(QVariant (*func)(const T &from, const T &to, qreal progress))
-{
- return reinterpret_cast<QVariantAnimation::Interpolator>(func);
-}
-
-QVariantAnimation::Interpolator QVariantAnimationPrivate::getInterpolator(int interpolationType)
-{
- QReadLocker locker(registeredInterpolatorsLock());
- QVariantAnimation::Interpolator ret = 0;
- if (interpolationType < registeredInterpolators()->count()) {
- ret = registeredInterpolators()->at(interpolationType);
- if (ret) return ret;
- }
-
- switch(interpolationType)
- {
- case QMetaType::Int:
- return castToInterpolator(_q_interpolateVariant<int>);
- case QMetaType::Double:
- return castToInterpolator(_q_interpolateVariant<double>);
- case QMetaType::Float:
- return castToInterpolator(_q_interpolateVariant<float>);
- case QMetaType::QLine:
- return castToInterpolator(_q_interpolateVariant<QLine>);
- case QMetaType::QLineF:
- return castToInterpolator(_q_interpolateVariant<QLineF>);
- case QMetaType::QPoint:
- return castToInterpolator(_q_interpolateVariant<QPoint>);
- case QMetaType::QPointF:
- return castToInterpolator(_q_interpolateVariant<QPointF>);
- case QMetaType::QSize:
- return castToInterpolator(_q_interpolateVariant<QSize>);
- case QMetaType::QSizeF:
- return castToInterpolator(_q_interpolateVariant<QSizeF>);
- case QMetaType::QRect:
- return castToInterpolator(_q_interpolateVariant<QRect>);
- case QMetaType::QRectF:
- return castToInterpolator(_q_interpolateVariant<QRectF>);
- default:
- return 0; //this type is not handled
- }
-}
-
-/*!
- \property QVariantAnimation::duration
- \brief the duration of the animation
-
- This property describes the duration in milliseconds of the
- animation. The default duration is 250 milliseconds.
-
- \sa QAbstractAnimation::duration()
- */
-int QVariantAnimation::duration() const
-{
- Q_D(const QVariantAnimation);
- return d->duration;
-}
-
-void QVariantAnimation::setDuration(int msecs)
-{
- Q_D(QVariantAnimation);
- if (msecs < 0) {
- qWarning("QVariantAnimation::setDuration: cannot set a negative duration");
- return;
- }
- if (d->duration == msecs)
- return;
- d->duration = msecs;
- d->recalculateCurrentInterval();
-}
-
-/*!
- \property QVariantAnimation::startValue
- \brief the optional start value of the animation
-
- This property describes the optional start value of the animation. If
- omitted, or if a null QVariant is assigned as the start value, the
- animation will use the current position of the end when the animation
- is started.
-
- \sa endValue
-*/
-QVariant QVariantAnimation::startValue() const
-{
- return keyValueAt(0);
-}
-
-void QVariantAnimation::setStartValue(const QVariant &value)
-{
- setKeyValueAt(0, value);
-}
-
-/*!
- \property QVariantAnimation::endValue
- \brief the end value of the animation
-
- This property describes the end value of the animation.
-
- \sa startValue
- */
-QVariant QVariantAnimation::endValue() const
-{
- return keyValueAt(1);
-}
-
-void QVariantAnimation::setEndValue(const QVariant &value)
-{
- setKeyValueAt(1, value);
-}
-
-
-/*!
- Returns the key frame value for the given \a step. The given \a step
- must be in the range 0 to 1. If there is no KeyValue for \a step,
- it returns an invalid QVariant.
-
- \sa keyValues(), setKeyValueAt()
-*/
-QVariant QVariantAnimation::keyValueAt(qreal step) const
-{
- Q_D(const QVariantAnimation);
- if (step == 0 && !d->hasStartValue)
- return QVariant(); //special case where we don't have an explicit startValue
-
- return d->valueAt(step);
-}
-
-/*!
- \typedef QVariantAnimation::KeyValue
-
- This is a typedef for QPair<qreal, QVariant>.
-*/
-/*!
- \typedef QVariantAnimation::KeyValues
-
- This is a typedef for QVector<KeyValue>
-*/
-
-/*!
- Creates a key frame at the given \a step with the given \a value.
- The given \a step must be in the range 0 to 1.
-
- \sa setKeyValues(), keyValueAt()
-*/
-void QVariantAnimation::setKeyValueAt(qreal step, const QVariant &value)
-{
- Q_D(QVariantAnimation);
- if (step == 0)
- d->hasStartValue = value.isValid();
- d->setValueAt(step, value);
-}
-
-/*!
- Returns the key frames of this animation.
-
- \sa keyValueAt(), setKeyValues()
-*/
-QVariantAnimation::KeyValues QVariantAnimation::keyValues() const
-{
- Q_D(const QVariantAnimation);
- QVariantAnimation::KeyValues ret = d->keyValues;
- //in case we added the default start value, we remove it
- if (!d->hasStartValue && !ret.isEmpty() && ret.at(0).first == 0)
- ret.remove(0);
- return ret;
-}
-
-/*!
- Replaces the current set of key frames with the given \a keyValues.
- the step of the key frames must be in the range 0 to 1.
-
- \sa keyValues(), keyValueAt()
-*/
-void QVariantAnimation::setKeyValues(const KeyValues &keyValues)
-{
- Q_D(QVariantAnimation);
- d->keyValues = keyValues;
- qSort(d->keyValues.begin(), d->keyValues.end(), animationValueLessThan);
- d->hasStartValue = !d->keyValues.isEmpty() && d->keyValues.at(0).first == 0;
- d->recalculateCurrentInterval(/*force=*/true);
-}
-
-/*!
- \property QVariantAnimation::currentValue
- \brief the current value of the animation.
-
- This property describes the current value; an interpolated value
- between the \l{startValue}{start value} and the \l{endValue}{end
- value}, using the current time for progress. The value itself is
- obtained from interpolated(), which is called repeatedly as the
- animation is running.
-
- QVariantAnimation calls the virtual updateCurrentValue() function
- when the current value changes. This is particularly useful for
- subclasses that need to track updates. For example,
- QPropertyAnimation uses this function to animate Qt \l{Qt's
- Property System}{properties}.
-
- \sa startValue, endValue
-*/
-QVariant QVariantAnimation::currentValue() const
-{
- Q_D(const QVariantAnimation);
- if (!d->currentValue.isValid())
- const_cast<QVariantAnimationPrivate*>(d)->recalculateCurrentInterval();
- return d->currentValue;
-}
-
-/*!
- \reimp
- */
-bool QVariantAnimation::event(QEvent *event)
-{
- return QAbstractAnimation::event(event);
-}
-
-/*!
- \reimp
-*/
-void QVariantAnimation::updateState(QAbstractAnimation::State oldState,
- QAbstractAnimation::State newState)
-{
- Q_UNUSED(oldState);
- Q_UNUSED(newState);
-}
-
-/*!
-
- This virtual function returns the linear interpolation between
- variants \a from and \a to, at \a progress, usually a value
- between 0 and 1. You can reimplement this function in a subclass
- of QVariantAnimation to provide your own interpolation algorithm.
-
- Note that in order for the interpolation to work with a
- QEasingCurve that return a value smaller than 0 or larger than 1
- (such as QEasingCurve::InBack) you should make sure that it can
- extrapolate. If the semantic of the datatype does not allow
- extrapolation this function should handle that gracefully.
-
- You should call the QVariantAnimation implementation of this
- function if you want your class to handle the types already
- supported by Qt (see class QVariantAnimation description for a
- list of supported types).
-
- \sa QEasingCurve
- */
-QVariant QVariantAnimation::interpolated(const QVariant &from, const QVariant &to, qreal progress) const
-{
- Q_D(const QVariantAnimation);
- if (d->interpolator == 0) {
- if (from.userType() == to.userType())
- d->interpolator = QVariantAnimationPrivate::getInterpolator(from.userType());
- if (d->interpolator == 0) //no interpolator found
- return QVariant();
- }
-
- return d->interpolator(from.constData(), to.constData(), progress);
-}
-
-/*!
- \reimp
- */
-void QVariantAnimation::updateCurrentTime(int msecs)
-{
- Q_D(QVariantAnimation);
- Q_UNUSED(msecs);
- d->recalculateCurrentInterval();
-}
-
-QT_END_NAMESPACE
-
-#include "moc_qvariantanimation.cpp"
-
-#endif //QT_NO_ANIMATION
diff --git a/src/corelib/animation/qvariantanimation.h b/src/corelib/animation/qvariantanimation.h
deleted file mode 100644
index 5b90930..0000000
--- a/src/corelib/animation/qvariantanimation.h
+++ /dev/null
@@ -1,130 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QANIMATION_H
-#define QANIMATION_H
-
-#include <QtCore/qeasingcurve.h>
-#include <QtCore/qabstractanimation.h>
-#include <QtCore/qvector.h>
-#include <QtCore/qvariant.h>
-#include <QtCore/qpair.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-#ifndef QT_NO_ANIMATION
-
-class QVariantAnimationPrivate;
-class Q_CORE_EXPORT QVariantAnimation : public QAbstractAnimation
-{
- Q_OBJECT
- Q_PROPERTY(QVariant startValue READ startValue WRITE setStartValue)
- Q_PROPERTY(QVariant endValue READ endValue WRITE setEndValue)
- Q_PROPERTY(QVariant currentValue READ currentValue NOTIFY currentValueChanged)
- Q_PROPERTY(int duration READ duration WRITE setDuration)
- Q_PROPERTY(QEasingCurve easingCurve READ easingCurve WRITE setEasingCurve)
-
-public:
- typedef QPair<qreal, QVariant> KeyValue;
- typedef QVector<KeyValue> KeyValues;
-
- QVariantAnimation(QObject *parent = 0);
- ~QVariantAnimation();
-
- QVariant startValue() const;
- void setStartValue(const QVariant &value);
-
- QVariant endValue() const;
- void setEndValue(const QVariant &value);
-
- QVariant keyValueAt(qreal step) const;
- void setKeyValueAt(qreal step, const QVariant &value);
-
- KeyValues keyValues() const;
- void setKeyValues(const KeyValues &values);
-
- QVariant currentValue() const;
-
- int duration() const;
- void setDuration(int msecs);
-
- QEasingCurve easingCurve() const;
- void setEasingCurve(const QEasingCurve &easing);
-
- typedef QVariant (*Interpolator)(const void *from, const void *to, qreal progress);
-
-Q_SIGNALS:
- void valueChanged(const QVariant &value);
-
-protected:
- QVariantAnimation(QVariantAnimationPrivate &dd, QObject *parent = 0);
- bool event(QEvent *event);
-
- void updateCurrentTime(int msecs);
- void updateState(QAbstractAnimation::State oldState, QAbstractAnimation::State newState);
-
- virtual void updateCurrentValue(const QVariant &value) = 0;
- virtual QVariant interpolated(const QVariant &from, const QVariant &to, qreal progress) const;
-
-private:
- template <typename T> friend void qRegisterAnimationInterpolator(QVariant (*func)(const T &, const T &, qreal));
- static void registerInterpolator(Interpolator func, int interpolationType);
-
- Q_DISABLE_COPY(QVariantAnimation)
- Q_DECLARE_PRIVATE(QVariantAnimation)
-};
-
-template <typename T>
-static void qRegisterAnimationInterpolator(QVariant (*func)(const T &from, const T &to, qreal progress)) {
- QVariantAnimation::registerInterpolator(reinterpret_cast<QVariantAnimation::Interpolator>(func), qMetaTypeId<T>());
-}
-
-#endif //QT_NO_ANIMATION
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif //QANIMATION_H
diff --git a/src/corelib/animation/qvariantanimation_p.h b/src/corelib/animation/qvariantanimation_p.h
deleted file mode 100644
index 0d296db..0000000
--- a/src/corelib/animation/qvariantanimation_p.h
+++ /dev/null
@@ -1,130 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QANIMATION_P_H
-#define QANIMATION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists for the convenience
-// of QIODevice. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qvariantanimation.h"
-#include <QtCore/qeasingcurve.h>
-#include <QtCore/qmetaobject.h>
-#include <QtCore/qvector.h>
-
-#include "qabstractanimation_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QVariantAnimationPrivate : public QAbstractAnimationPrivate
-{
- Q_DECLARE_PUBLIC(QVariantAnimation)
-public:
-
- QVariantAnimationPrivate() : duration(250), hasStartValue(false)
- {
- }
-
- void init()
- {
- //we keep the mask so that we emit valueChanged only when needed (for performance reasons)
- changedSignalMask = (1 << q_func()->metaObject()->indexOfSignal("valueChanged(QVariant)"));
- currentInterval.start.first = currentInterval.end.first = 2; //will force the initial refresh
- interpolator = 0;
- }
-
- static QVariantAnimationPrivate *get(QVariantAnimation *q)
- {
- return q->d_func();
- }
-
- void setDefaultStartValue(const QVariant &value);
-
- int duration;
- QEasingCurve easing;
-
- QVariantAnimation::KeyValues keyValues;
- QVariant currentValue;
- QVariant defaultStartValue;
- bool hasStartValue;
-
- //this is used to keep track of the KeyValue interval in which we currently are
- struct
- {
- QVariantAnimation::KeyValue start, end;
- } currentInterval;
-
- mutable QVariantAnimation::Interpolator interpolator;
-
- quint32 changedSignalMask;
-
- void setCurrentValueForProgress(const qreal progress);
- void recalculateCurrentInterval(bool force=false);
- void setValueAt(qreal, const QVariant &);
- QVariant valueAt(qreal step) const;
- void convertValues(int t);
-
- static QVariantAnimation::Interpolator getInterpolator(int interpolationType);
-};
-
-//this should make the interpolation faster
-template<typename T> inline T _q_interpolate(const T &f, const T &t, qreal progress)
-{
- return T(f + (t - f) * progress);
-}
-
-template<typename T > inline QVariant _q_interpolateVariant(const T &from, const T &to, qreal progress)
-{
- return _q_interpolate(from, to, progress);
-}
-
-
-QT_END_NAMESPACE
-
-#endif //QANIMATION_P_H
diff --git a/src/corelib/corelib.pro b/src/corelib/corelib.pro
index db51d43..f99d57f 100644
--- a/src/corelib/corelib.pro
+++ b/src/corelib/corelib.pro
@@ -5,7 +5,6 @@ DEFINES += QT_BUILD_CORE_LIB QT_NO_USING_NAMESPACE
win32-msvc*|win32-icc:QMAKE_LFLAGS += /BASE:0x67000000
include(../qbase.pri)
-include(animation/animation.pri)
include(arch/arch.pri)
include(concurrent/concurrent.pri)
include(global/global.pri)
@@ -15,7 +14,6 @@ include(io/io.pri)
include(plugin/plugin.pri)
include(kernel/kernel.pri)
include(codecs/codecs.pri)
-include(statemachine/statemachine.pri)
include(xml/xml.pri)
mac|darwin:LIBS += -framework ApplicationServices
diff --git a/src/corelib/kernel/kernel.pri b/src/corelib/kernel/kernel.pri
index ecef555..68649a6 100644
--- a/src/corelib/kernel/kernel.pri
+++ b/src/corelib/kernel/kernel.pri
@@ -12,7 +12,7 @@ HEADERS += \
kernel/qcoreevent.h \
kernel/qmetaobject.h \
kernel/qmetatype.h \
- kernel/qmimedata.h \
+ kernel/qmimedata.h \
kernel/qobject.h \
kernel/qobjectdefs.h \
kernel/qsignalmapper.h \
@@ -27,8 +27,8 @@ HEADERS += \
kernel/qvariant_p.h \
kernel/qmetaobject_p.h \
kernel/qobject_p.h \
- kernel/qcoreglobaldata_p.h \
- kernel/qsharedmemory.h \
+ kernel/qcoreglobaldata_p.h \
+ kernel/qsharedmemory.h \
kernel/qsharedmemory_p.h \
kernel/qsystemsemaphore.h \
kernel/qsystemsemaphore_p.h \
@@ -43,7 +43,7 @@ SOURCES += \
kernel/qcoreevent.cpp \
kernel/qmetaobject.cpp \
kernel/qmetatype.cpp \
- kernel/qmimedata.cpp \
+ kernel/qmimedata.cpp \
kernel/qobject.cpp \
kernel/qobjectcleanuphandler.cpp \
kernel/qsignalmapper.cpp \
diff --git a/src/corelib/kernel/qcoreevent.cpp b/src/corelib/kernel/qcoreevent.cpp
index d6b0174..11a2d3c 100644
--- a/src/corelib/kernel/qcoreevent.cpp
+++ b/src/corelib/kernel/qcoreevent.cpp
@@ -264,8 +264,6 @@ QT_BEGIN_NAMESPACE
\omitvalue NetworkReplyUpdated
\omitvalue FutureCallOut
\omitvalue CocoaRequestModal
- \omitvalue Wrapped
- \omitvalue Signal
*/
/*!
diff --git a/src/corelib/kernel/qcoreevent.h b/src/corelib/kernel/qcoreevent.h
index 18188a8..fa472e6 100644
--- a/src/corelib/kernel/qcoreevent.h
+++ b/src/corelib/kernel/qcoreevent.h
@@ -44,7 +44,6 @@
#include <QtCore/qnamespace.h>
#include <QtCore/qbytearray.h>
-#include <QtCore/qobjectdefs.h>
QT_BEGIN_HEADER
@@ -55,9 +54,7 @@ QT_MODULE(Core)
class QEventPrivate;
class Q_CORE_EXPORT QEvent // event base class
{
- Q_GADGET
QDOC_PROPERTY(bool accepted READ isAccepted WRITE setAccepted)
- Q_ENUMS(Type)
public:
enum Type {
/*
@@ -269,10 +266,7 @@ public:
CocoaRequestModal = 190, // Internal for requesting an application modal Cocoa Window
MacGLClearDrawable = 191, // Internal Cocoa, the window has changed, so we must clear
- Signal = 192,
- Wrapped = 193,
-
- // 512 reserved for Qt Jambi's MetaCall event
+ // 512 reserved for Qt Jambi's MetaCall event
// 513 reserved for Qt Jambi's DeleteOnMainThread event
User = 1000, // first user event id
diff --git a/src/corelib/statemachine/qabstractstate.cpp b/src/corelib/statemachine/qabstractstate.cpp
deleted file mode 100644
index 942722f..0000000
--- a/src/corelib/statemachine/qabstractstate.cpp
+++ /dev/null
@@ -1,202 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qabstractstate.h"
-#include "qabstractstate_p.h"
-#include "qstate.h"
-#include "qstate_p.h"
-#include "qstatemachine.h"
-#include "qstatemachine_p.h"
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QAbstractState
-
- \brief The QAbstractState class is the base class of states of a QStateMachine.
-
- \since 4.6
- \ingroup statemachine
-
- The QAbstractState class is the abstract base class of states that are part
- of a QStateMachine. It defines the interface that all state objects have in
- common. QAbstractState is part of \l{The State Machine Framework}.
-
- The entered() signal is emitted when the state has been entered. The
- exited() signal is emitted when the state has been exited.
-
- The parentState() function returns the state's parent state. The machine()
- function returns the state machine that the state is part of.
-
- \section1 Subclassing
-
- The onEntry() function is called when the state is entered; reimplement this
- function to perform custom processing when the state is entered.
-
- The onExit() function is called when the state is exited; reimplement this
- function to perform custom processing when the state is exited.
-*/
-
-QAbstractStatePrivate::QAbstractStatePrivate()
-{
-}
-
-QAbstractStatePrivate *QAbstractStatePrivate::get(QAbstractState *q)
-{
- return q->d_func();
-}
-
-QStateMachine *QAbstractStatePrivate::machine() const
-{
- Q_Q(const QAbstractState);
- QObject *par = q->parent();
- while (par != 0) {
- if (QStateMachine *mach = qobject_cast<QStateMachine*>(par))
- return mach;
- par = par->parent();
- }
- return 0;
-}
-
-void QAbstractStatePrivate::callOnEntry(QEvent *e)
-{
- Q_Q(QAbstractState);
- q->onEntry(e);
-}
-
-void QAbstractStatePrivate::callOnExit(QEvent *e)
-{
- Q_Q(QAbstractState);
- q->onExit(e);
-}
-
-void QAbstractStatePrivate::emitEntered()
-{
- Q_Q(QAbstractState);
- emit q->entered();
-}
-
-void QAbstractStatePrivate::emitExited()
-{
- Q_Q(QAbstractState);
- emit q->exited();
-}
-
-/*!
- Constructs a new state with the given \a parent state.
-*/
-QAbstractState::QAbstractState(QState *parent)
- : QObject(*new QAbstractStatePrivate, parent)
-{
-}
-
-/*!
- \internal
-*/
-QAbstractState::QAbstractState(QAbstractStatePrivate &dd, QState *parent)
- : QObject(dd, parent)
-{
-}
-
-/*!
- Destroys this state.
-*/
-QAbstractState::~QAbstractState()
-{
-}
-
-/*!
- Returns this state's parent state, or 0 if the state has no parent state.
-*/
-QState *QAbstractState::parentState() const
-{
- return qobject_cast<QState*>(parent());
-}
-
-/*!
- Returns the state machine that this state is part of, or 0 if the state is
- not part of a state machine.
-*/
-QStateMachine *QAbstractState::machine() const
-{
- Q_D(const QAbstractState);
- return d->machine();
-}
-
-/*!
- \fn QAbstractState::onExit(QEvent *event)
-
- This function is called when the state is exited. The given \a event is what
- caused the state to be exited. Reimplement this function to perform custom
- processing when the state is exited.
-*/
-
-/*!
- \fn QAbstractState::onEntry(QEvent *event)
-
- This function is called when the state is entered. The given \a event is
- what caused the state to be entered. Reimplement this function to perform
- custom processing when the state is entered.
-*/
-
-/*!
- \fn QAbstractState::entered()
-
- This signal is emitted when the state has been entered (after onEntry() has
- been called).
-*/
-
-/*!
- \fn QAbstractState::exited()
-
- This signal is emitted when the state has been exited (after onExit() has
- been called).
-*/
-
-/*!
- \reimp
-*/
-bool QAbstractState::event(QEvent *e)
-{
- return QObject::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qabstractstate.h b/src/corelib/statemachine/qabstractstate.h
deleted file mode 100644
index d0ebb52..0000000
--- a/src/corelib/statemachine/qabstractstate.h
+++ /dev/null
@@ -1,90 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTSTATE_H
-#define QABSTRACTSTATE_H
-
-#include <QtCore/qobject.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QState;
-class QStateMachine;
-
-class QAbstractStatePrivate;
-class Q_CORE_EXPORT QAbstractState : public QObject
-{
- Q_OBJECT
-public:
- ~QAbstractState();
-
- QState *parentState() const;
- QStateMachine *machine() const;
-
-Q_SIGNALS:
- void entered();
- void exited();
-
-protected:
- QAbstractState(QState *parent = 0);
-
- virtual void onEntry(QEvent *event) = 0;
- virtual void onExit(QEvent *event) = 0;
-
- bool event(QEvent *e);
-
-protected:
- QAbstractState(QAbstractStatePrivate &dd, QState *parent);
-
-private:
- Q_DISABLE_COPY(QAbstractState)
- Q_DECLARE_PRIVATE(QAbstractState)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qabstractstate_p.h b/src/corelib/statemachine/qabstractstate_p.h
deleted file mode 100644
index 2aad47e..0000000
--- a/src/corelib/statemachine/qabstractstate_p.h
+++ /dev/null
@@ -1,84 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTSTATE_P_H
-#define QABSTRACTSTATE_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <private/qobject_p.h>
-
-QT_BEGIN_NAMESPACE
-
-class QStateMachine;
-
-class QAbstractState;
-class Q_CORE_EXPORT QAbstractStatePrivate
- : public QObjectPrivate
-{
- Q_DECLARE_PUBLIC(QAbstractState)
-
-public:
- QAbstractStatePrivate();
-
- static QAbstractStatePrivate *get(QAbstractState *q);
-
- QStateMachine *machine() const;
-
- void callOnEntry(QEvent *e);
- void callOnExit(QEvent *e);
-
- void emitEntered();
- void emitExited();
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qabstracttransition.cpp b/src/corelib/statemachine/qabstracttransition.cpp
deleted file mode 100644
index dfcafeb..0000000
--- a/src/corelib/statemachine/qabstracttransition.cpp
+++ /dev/null
@@ -1,342 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qabstracttransition.h"
-#include "qabstracttransition_p.h"
-#include "qabstractstate.h"
-#include "qstate.h"
-#include "qstatemachine.h"
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QAbstractTransition
-
- \brief The QAbstractTransition class is the base class of transitions between QAbstractState objects.
-
- \since 4.6
- \ingroup statemachine
-
- The QAbstractTransition class is the abstract base class of transitions
- between states (QAbstractState objects) of a
- QStateMachine. QAbstractTransition is part of \l{The State Machine
- Framework}.
-
- The sourceState() function returns the source of the transition. The
- targetStates() function returns the targets of the transition. The machine()
- function returns the state machine that the transition is part of.
-
- Transitions can cause animations to be played. Use the addAnimation()
- function to add an animation to the transition.
-
- \section1 Subclassing
-
- The eventTest() function is called by the state machine to determine whether
- an event should trigger the transition. In your reimplementation you
- typically check the event type and cast the event object to the proper type,
- and check that one or more properties of the event meet your criteria.
-
- The onTransition() function is called when the transition is triggered;
- reimplement this function to perform custom processing for the transition.
-*/
-
-/*!
- \property QAbstractTransition::sourceState
-
- \brief the source state (parent) of this transition
-*/
-
-/*!
- \property QAbstractTransition::targetState
-
- \brief the target state of this transition
-*/
-
-/*!
- \property QAbstractTransition::targetStates
-
- \brief the target states of this transition
-
- If multiple states are specified, all must be descendants of the same
- parallel group state.
-*/
-
-QAbstractTransitionPrivate::QAbstractTransitionPrivate()
-{
-}
-
-QAbstractTransitionPrivate *QAbstractTransitionPrivate::get(QAbstractTransition *q)
-{
- return q->d_func();
-}
-
-QStateMachine *QAbstractTransitionPrivate::machine() const
-{
- Q_Q(const QAbstractTransition);
- QObject *par = q->parent();
- while (par != 0) {
- if (QStateMachine *mach = qobject_cast<QStateMachine*>(par))
- return mach;
- par = par->parent();
- }
- return 0;
-}
-
-bool QAbstractTransitionPrivate::callEventTest(QEvent *e)
-{
- Q_Q(QAbstractTransition);
- return q->eventTest(e);
-}
-
-void QAbstractTransitionPrivate::callOnTransition(QEvent *e)
-{
- Q_Q(QAbstractTransition);
- q->onTransition(e);
-}
-
-QState *QAbstractTransitionPrivate::sourceState() const
-{
- Q_Q(const QAbstractTransition);
- return qobject_cast<QState*>(q->parent());
-}
-
-/*!
- Constructs a new QAbstractTransition object with the given \a sourceState.
-*/
-QAbstractTransition::QAbstractTransition(QState *sourceState)
- : QObject(*new QAbstractTransitionPrivate, sourceState)
-{
-}
-
-/*!
- Constructs a new QAbstractTransition object with the given \a targets and \a
- sourceState.
-*/
-QAbstractTransition::QAbstractTransition(const QList<QAbstractState*> &targets,
- QState *sourceState)
- : QObject(*new QAbstractTransitionPrivate, sourceState)
-{
- setTargetStates(targets);
-}
-
-/*!
- \internal
-*/
-QAbstractTransition::QAbstractTransition(QAbstractTransitionPrivate &dd,
- QState *parent)
- : QObject(dd, parent)
-{
-}
-
-/*!
- \internal
-*/
-QAbstractTransition::QAbstractTransition(QAbstractTransitionPrivate &dd,
- const QList<QAbstractState*> &targets,
- QState *parent)
- : QObject(dd, parent)
-{
- setTargetStates(targets);
-}
-
-/*!
- Destroys this transition.
-*/
-QAbstractTransition::~QAbstractTransition()
-{
-}
-
-/*!
- Returns the source state of this transition, or 0 if this transition has no
- source state.
-*/
-QState *QAbstractTransition::sourceState() const
-{
- Q_D(const QAbstractTransition);
- return d->sourceState();
-}
-
-/*!
- Returns the target state of this transition, or 0 if the transition has no
- target.
-*/
-QAbstractState *QAbstractTransition::targetState() const
-{
- Q_D(const QAbstractTransition);
- if (d->targetStates.isEmpty())
- return 0;
- return d->targetStates.first();
-}
-
-/*!
- Sets the \a target state of this transition.
-*/
-void QAbstractTransition::setTargetState(QAbstractState* target)
-{
- Q_D(QAbstractTransition);
- if (!target)
- d->targetStates.clear();
- else
- setTargetStates(QList<QAbstractState*>() << target);
-}
-
-/*!
- Returns the target states of this transition, or an empty list if this
- transition has no target states.
-*/
-QList<QAbstractState*> QAbstractTransition::targetStates() const
-{
- Q_D(const QAbstractTransition);
- QList<QAbstractState*> result;
- for (int i = 0; i < d->targetStates.size(); ++i) {
- QAbstractState *target = d->targetStates.at(i);
- if (target)
- result.append(target);
- }
- return result;
-}
-
-/*!
- Sets the target states of this transition to be the given \a targets.
-*/
-void QAbstractTransition::setTargetStates(const QList<QAbstractState*> &targets)
-{
- Q_D(QAbstractTransition);
-
- for (int i=0; i<targets.size(); ++i) {
- QAbstractState *target = targets.at(i);
- if (!target) {
- qWarning("QAbstractTransition::setTargetStates: target state(s) cannot be null");
- return;
- }
- if (target->machine() != 0 && target->machine()->rootState() == target) {
- qWarning("QAbstractTransition::setTargetStates: root state cannot be target of transition");
- return;
- }
- }
-
- d->targetStates.clear();
- for (int i = 0; i < targets.size(); ++i)
- d->targetStates.append(targets.at(i));
-}
-
-/*!
- Returns the state machine that this transition is part of, or 0 if the
- transition is not part of a state machine.
-*/
-QStateMachine *QAbstractTransition::machine() const
-{
- Q_D(const QAbstractTransition);
- return d->machine();
-}
-
-#ifndef QT_NO_ANIMATION
-
-/*!
- Adds the given \a animation to this transition.
- The transition does not take ownership of the animation.
-
- \sa removeAnimation(), animations()
-*/
-void QAbstractTransition::addAnimation(QAbstractAnimation *animation)
-{
- Q_D(QAbstractTransition);
- if (!animation) {
- qWarning("QAbstractTransition::addAnimation: cannot add null animation");
- return;
- }
- d->animations.append(animation);
-}
-
-/*!
- Removes the given \a animation from this transition.
-
- \sa addAnimation()
-*/
-void QAbstractTransition::removeAnimation(QAbstractAnimation *animation)
-{
- Q_D(QAbstractTransition);
- if (!animation) {
- qWarning("QAbstractTransition::removeAnimation: cannot remove null animation");
- return;
- }
- d->animations.removeOne(animation);
-}
-
-/*!
- Returns the list of animations associated with this transition, or an empty
- list if it has no animations.
-
- \sa addAnimation()
-*/
-QList<QAbstractAnimation*> QAbstractTransition::animations() const
-{
- Q_D(const QAbstractTransition);
- return d->animations;
-}
-
-#endif
-
-/*!
- \fn QAbstractTransition::eventTest(QEvent *event)
-
- This function is called to determine whether the given \a event should cause
- this transition to trigger. Reimplement this function and return true if the
- event should trigger the transition, otherwise return false.
-*/
-
-/*!
- \fn QAbstractTransition::onTransition(QEvent *event)
-
- This function is called when the transition is triggered. The given \a event
- is what caused the transition to trigger. Reimplement this function to
- perform custom processing when the transition is triggered.
-*/
-
-/*!
- \reimp
-*/
-bool QAbstractTransition::event(QEvent *e)
-{
- return QObject::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qabstracttransition.h b/src/corelib/statemachine/qabstracttransition.h
deleted file mode 100644
index c63d55a..0000000
--- a/src/corelib/statemachine/qabstracttransition.h
+++ /dev/null
@@ -1,111 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTTRANSITION_H
-#define QABSTRACTTRANSITION_H
-
-#include <QtCore/qobject.h>
-
-#include <QtCore/qlist.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QEvent;
-class QAbstractState;
-class QState;
-class QStateMachine;
-
-#ifndef QT_NO_ANIMATION
-class QAbstractAnimation;
-#endif
-
-class QAbstractTransitionPrivate;
-class Q_CORE_EXPORT QAbstractTransition : public QObject
-{
- Q_OBJECT
- Q_PROPERTY(QState* sourceState READ sourceState)
- Q_PROPERTY(QAbstractState* targetState READ targetState WRITE setTargetState)
- Q_PROPERTY(QList<QAbstractState*> targetStates READ targetStates WRITE setTargetStates)
-public:
- QAbstractTransition(QState *sourceState = 0);
- QAbstractTransition(const QList<QAbstractState*> &targets, QState *sourceState = 0);
- virtual ~QAbstractTransition();
-
- QState *sourceState() const;
- QAbstractState *targetState() const;
- void setTargetState(QAbstractState* target);
- QList<QAbstractState*> targetStates() const;
- void setTargetStates(const QList<QAbstractState*> &targets);
-
- QStateMachine *machine() const;
-
-#ifndef QT_NO_ANIMATION
- void addAnimation(QAbstractAnimation *animation);
- void removeAnimation(QAbstractAnimation *animation);
- QList<QAbstractAnimation*> animations() const;
-#endif
-
-protected:
- virtual bool eventTest(QEvent *event) = 0;
-
- virtual void onTransition(QEvent *event) = 0;
-
- bool event(QEvent *e);
-
-protected:
- QAbstractTransition(QAbstractTransitionPrivate &dd, QState *parent);
- QAbstractTransition(QAbstractTransitionPrivate &dd,
- const QList<QAbstractState*> &targets, QState *parent);
-
-private:
- Q_DISABLE_COPY(QAbstractTransition)
- Q_DECLARE_PRIVATE(QAbstractTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qabstracttransition_p.h b/src/corelib/statemachine/qabstracttransition_p.h
deleted file mode 100644
index f067984..0000000
--- a/src/corelib/statemachine/qabstracttransition_p.h
+++ /dev/null
@@ -1,91 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QABSTRACTTRANSITION_P_H
-#define QABSTRACTTRANSITION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <private/qobject_p.h>
-
-#include <QtCore/qlist.h>
-#include <QtCore/qpointer.h>
-
-QT_BEGIN_NAMESPACE
-
-class QAbstractState;
-class QState;
-class QStateMachine;
-
-class QAbstractTransition;
-class Q_CORE_EXPORT QAbstractTransitionPrivate
- : public QObjectPrivate
-{
- Q_DECLARE_PUBLIC(QAbstractTransition)
-public:
- QAbstractTransitionPrivate();
-
- static QAbstractTransitionPrivate *get(QAbstractTransition *q);
-
- bool callEventTest(QEvent *e);
- void callOnTransition(QEvent *e);
- QState *sourceState() const;
- QStateMachine *machine() const;
-
- QList<QPointer<QAbstractState> > targetStates;
-
-#ifndef QT_NO_ANIMATION
- QList<QAbstractAnimation*> animations;
-#endif
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qeventtransition.cpp b/src/corelib/statemachine/qeventtransition.cpp
deleted file mode 100644
index 74eb577..0000000
--- a/src/corelib/statemachine/qeventtransition.cpp
+++ /dev/null
@@ -1,282 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qeventtransition.h"
-#include "qeventtransition_p.h"
-#include "qwrappedevent.h"
-#include "qstate.h"
-#include "qstate_p.h"
-#include "qstatemachine.h"
-#include "qstatemachine_p.h"
-#include <qdebug.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QEventTransition
-
- \brief The QEventTransition class provides a QObject-specific transition for Qt events.
-
- \since 4.6
- \ingroup statemachine
-
- A QEventTransition object binds an event to a particular QObject.
- QEventTransition is part of \l{The State Machine Framework}.
-
- Example:
-
- \code
- QPushButton *button = ...;
- QState *s1 = ...;
- QState *s2 = ...;
- // If in s1 and the button receives an Enter event, transition to s2
- QEventTransition *enterTransition = new QEventTransition(button, QEvent::Enter);
- enterTransition->setTargetState(s2);
- s1->addTransition(enterTransition);
- // If in s2 and the button receives an Exit event, transition back to s1
- QEventTransition *leaveTransition = new QEventTransition(button, QEvent::Leave);
- leaveTransition->setTargetState(s1);
- s2->addTransition(leaveTransition);
- \endcode
-
- \section1 Subclassing
-
- When reimplementing the eventTest() function, you should first call the base
- implementation to verify that the event is a QWrappedEvent for the proper
- object and event type. You may then cast the event to a QWrappedEvent and
- get the original event by calling QWrappedEvent::event(), and perform
- additional checks on that object.
-
- \sa QState::addTransition()
-*/
-
-/*!
- \property QEventTransition::eventObject
-
- \brief the event source that this event transition is associated with
-*/
-
-/*!
- \property QEventTransition::eventType
-
- \brief the type of event that this event transition is associated with
-*/
-QEventTransitionPrivate::QEventTransitionPrivate()
-{
- object = 0;
- eventType = QEvent::None;
- registered = false;
-}
-
-QEventTransitionPrivate *QEventTransitionPrivate::get(QEventTransition *q)
-{
- return q->d_func();
-}
-
-void QEventTransitionPrivate::invalidate()
-{
- Q_Q(QEventTransition);
- if (registered) {
- QState *source = sourceState();
- QStatePrivate *source_d = QStatePrivate::get(source);
- QStateMachinePrivate *mach = QStateMachinePrivate::get(source_d->machine());
- if (mach) {
- mach->unregisterEventTransition(q);
- if (mach->configuration.contains(source))
- mach->registerEventTransition(q);
- }
- }
-}
-
-/*!
- Constructs a new QEventTransition object with the given \a sourceState.
-*/
-QEventTransition::QEventTransition(QState *sourceState)
- : QAbstractTransition(*new QEventTransitionPrivate, sourceState)
-{
-}
-
-/*!
- Constructs a new QEventTransition object associated with events of the given
- \a type for the given \a object, and with the given \a sourceState.
-*/
-QEventTransition::QEventTransition(QObject *object, QEvent::Type type,
- QState *sourceState)
- : QAbstractTransition(*new QEventTransitionPrivate, sourceState)
-{
- Q_D(QEventTransition);
- d->registered = false;
- d->object = object;
- d->eventType = type;
-}
-
-/*!
- Constructs a new QEventTransition object associated with events of the given
- \a type for the given \a object. The transition has the given \a targets and
- \a sourceState.
-*/
-QEventTransition::QEventTransition(QObject *object, QEvent::Type type,
- const QList<QAbstractState*> &targets,
- QState *sourceState)
- : QAbstractTransition(*new QEventTransitionPrivate, targets, sourceState)
-{
- Q_D(QEventTransition);
- d->registered = false;
- d->object = object;
- d->eventType = type;
-}
-
-/*!
- \internal
-*/
-QEventTransition::QEventTransition(QEventTransitionPrivate &dd, QState *parent)
- : QAbstractTransition(dd, parent)
-{
-}
-
-/*!
- \internal
-*/
-QEventTransition::QEventTransition(QEventTransitionPrivate &dd, QObject *object,
- QEvent::Type type, QState *parent)
- : QAbstractTransition(dd, parent)
-{
- Q_D(QEventTransition);
- d->registered = false;
- d->object = object;
- d->eventType = type;
-}
-
-/*!
- \internal
-*/
-QEventTransition::QEventTransition(QEventTransitionPrivate &dd, QObject *object,
- QEvent::Type type, const QList<QAbstractState*> &targets,
- QState *parent)
- : QAbstractTransition(dd, targets, parent)
-{
- Q_D(QEventTransition);
- d->registered = false;
- d->object = object;
- d->eventType = type;
-}
-
-/*!
- Destroys this QObject event transition.
-*/
-QEventTransition::~QEventTransition()
-{
-}
-
-/*!
- Returns the event type that this event transition is associated with.
-*/
-QEvent::Type QEventTransition::eventType() const
-{
- Q_D(const QEventTransition);
- return d->eventType;
-}
-
-/*!
- Sets the event \a type that this event transition is associated with.
-*/
-void QEventTransition::setEventType(QEvent::Type type)
-{
- Q_D(QEventTransition);
- if (d->eventType == type)
- return;
- d->eventType = type;
- d->invalidate();
-}
-
-/*!
- Returns the event source associated with this event transition.
-*/
-QObject *QEventTransition::eventObject() const
-{
- Q_D(const QEventTransition);
- return d->object;
-}
-
-/*!
- Sets the event source associated with this event transition to be the given
- \a object.
-*/
-void QEventTransition::setEventObject(QObject *object)
-{
- Q_D(QEventTransition);
- if (d->object == object)
- return;
- d->object = object;
- d->invalidate();
-}
-
-/*!
- \reimp
-*/
-bool QEventTransition::eventTest(QEvent *event)
-{
- Q_D(const QEventTransition);
- if (event->type() == QEvent::Wrapped) {
- QWrappedEvent *we = static_cast<QWrappedEvent*>(event);
- return (we->object() == d->object)
- && (we->event()->type() == d->eventType);
- }
- return false;
-}
-
-/*!
- \reimp
-*/
-void QEventTransition::onTransition(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-bool QEventTransition::event(QEvent *e)
-{
- return QAbstractTransition::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qeventtransition.h b/src/corelib/statemachine/qeventtransition.h
deleted file mode 100644
index 3530bdd..0000000
--- a/src/corelib/statemachine/qeventtransition.h
+++ /dev/null
@@ -1,96 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QEVENTTRANSITION_H
-#define QEVENTTRANSITION_H
-
-#include <QtCore/qabstracttransition.h>
-#include <QtCore/qcoreevent.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QEventTransitionPrivate;
-class Q_CORE_EXPORT QEventTransition : public QAbstractTransition
-{
- Q_OBJECT
- Q_PROPERTY(QObject* eventObject READ eventObject WRITE setEventObject)
- Q_PROPERTY(QEvent::Type eventType READ eventType WRITE setEventType)
-public:
- QEventTransition(QState *sourceState = 0);
- QEventTransition(QObject *object, QEvent::Type type, QState *sourceState = 0);
- QEventTransition(QObject *object, QEvent::Type type,
- const QList<QAbstractState*> &targets, QState *sourceState = 0);
- ~QEventTransition();
-
- QObject *eventObject() const;
- void setEventObject(QObject *object);
-
- QEvent::Type eventType() const;
- void setEventType(QEvent::Type type);
-
-protected:
- bool eventTest(QEvent *event);
- void onTransition(QEvent *event);
-
- bool event(QEvent *e);
-
-protected:
- QEventTransition(QEventTransitionPrivate &dd, QState *parent);
- QEventTransition(QEventTransitionPrivate &dd, QObject *object,
- QEvent::Type type, QState *parent);
- QEventTransition(QEventTransitionPrivate &dd, QObject *object,
- QEvent::Type type, const QList<QAbstractState*> &targets,
- QState *parent);
-
-private:
- Q_DISABLE_COPY(QEventTransition)
- Q_DECLARE_PRIVATE(QEventTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qeventtransition_p.h b/src/corelib/statemachine/qeventtransition_p.h
deleted file mode 100644
index fca8c0d..0000000
--- a/src/corelib/statemachine/qeventtransition_p.h
+++ /dev/null
@@ -1,78 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QEVENTTRANSITION_P_H
-#define QEVENTTRANSITION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qabstracttransition_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QEventTransition;
-class Q_CORE_EXPORT QEventTransitionPrivate : public QAbstractTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QEventTransition)
-public:
- QEventTransitionPrivate();
-
- static QEventTransitionPrivate *get(QEventTransition *q);
-
- void invalidate();
-
- bool registered;
- QObject *object;
- QEvent::Type eventType;
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qfinalstate.cpp b/src/corelib/statemachine/qfinalstate.cpp
deleted file mode 100644
index 0980336..0000000
--- a/src/corelib/statemachine/qfinalstate.cpp
+++ /dev/null
@@ -1,134 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qfinalstate.h"
-#include "qabstractstate_p.h"
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QFinalState
-
- \brief The QFinalState class provides a final state.
-
- \since 4.6
- \ingroup statemachine
-
- A final state is used to communicate that (part of) a QStateMachine has
- finished its work. When a final top-level state is entered, the state
- machine's \l{QStateMachine::finished()}{finished}() signal is emitted. In
- general, when a final substate (a child of a QState) is entered, the parent
- state's \l{QState::finished()}{finished}() signal is emitted. QFinalState
- is part of \l{The State Machine Framework}.
-
- To use a final state, you create a QFinalState object and add a transition
- to it from another state. Example:
-
- \code
- QPushButton button;
-
- QStateMachine machine;
- QState *s1 = new QState();
- QFinalState *s2 = new QFinalState();
- s1->addTransition(&button, SIGNAL(clicked()), s2);
- machine.addState(s1);
- machine.addState(s2);
-
- QObject::connect(&machine, SIGNAL(finished()), QApplication::instance(), SLOT(quit()));
- machine.setInitialState(s1);
- machine.start();
- \endcode
-
- \sa QStateMachine::finished(), QState::finished()
-*/
-
-class QFinalStatePrivate : public QAbstractStatePrivate
-{
- Q_DECLARE_PUBLIC(QFinalState)
-
-public:
- QFinalStatePrivate();
-};
-
-QFinalStatePrivate::QFinalStatePrivate()
-{
-}
-
-/*!
- Constructs a new QFinalState object with the given \a parent state.
-*/
-QFinalState::QFinalState(QState *parent)
- : QAbstractState(*new QFinalStatePrivate, parent)
-{
-}
-
-/*!
- Destroys this final state.
-*/
-QFinalState::~QFinalState()
-{
-}
-
-/*!
- \reimp
-*/
-void QFinalState::onEntry(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-void QFinalState::onExit(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-bool QFinalState::event(QEvent *e)
-{
- return QAbstractState::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qfinalstate.h b/src/corelib/statemachine/qfinalstate.h
deleted file mode 100644
index fa68394..0000000
--- a/src/corelib/statemachine/qfinalstate.h
+++ /dev/null
@@ -1,76 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QFINALSTATE_H
-#define QFINALSTATE_H
-
-#include <QtCore/qabstractstate.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QFinalStatePrivate;
-class Q_CORE_EXPORT QFinalState : public QAbstractState
-{
- Q_OBJECT
-public:
- QFinalState(QState *parent = 0);
- ~QFinalState();
-
-protected:
- void onEntry(QEvent *event);
- void onExit(QEvent *event);
-
- bool event(QEvent *e);
-
-private:
- Q_DISABLE_COPY(QFinalState)
- Q_DECLARE_PRIVATE(QFinalState)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qhistorystate.cpp b/src/corelib/statemachine/qhistorystate.cpp
deleted file mode 100644
index 517faa8..0000000
--- a/src/corelib/statemachine/qhistorystate.cpp
+++ /dev/null
@@ -1,223 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qhistorystate.h"
-#include "qhistorystate_p.h"
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QHistoryState
-
- \brief The QHistoryState class provides a means of returning to a previously active substate.
-
- \since 4.6
- \ingroup statemachine
-
- A history state is a pseudo-state that represents the child state that the
- parent state was in the last time the parent state was exited. A transition
- with a history state as its target is in fact a transition to one of the
- other child states of the parent state. QHistoryState is part of \l{The
- State Machine Framework}.
-
- Use the setDefaultState() function to set the state that should be entered
- if the parent state has never been entered. Example:
-
- \code
- QStateMachine machine;
-
- QState *s1 = new QState();
- QState *s11 = new QState(s1);
- QState *s12 = new QState(s1);
-
- QHistoryState *s1h = new QHistoryState(s1);
- s1h->setDefaultState(s11);
-
- machine.addState(s1);
-
- QState *s2 = new QState();
- machine.addState(s2);
-
- QPushButton *button = new QPushButton();
- // Clicking the button will cause the state machine to enter the child state
- // that s1 was in the last time s1 was exited, or the history state's default
- // state if s1 has never been entered.
- s1->addTransition(button, SIGNAL(clicked()), s1h);
- \endcode
-
- By default a history state is shallow, meaning that it won't remember nested
- states. This can be configured through the historyType property.
-*/
-
-/*!
- \property QHistoryState::defaultState
-
- \brief the default state of this history state
-*/
-
-/*!
- \property QHistoryState::historyType
-
- \brief the type of history that this history state records
-
- The default value of this property is QHistoryState::ShallowHistory.
-*/
-
-/*!
- \enum QHistoryState::HistoryType
-
- This enum specifies the type of history that a QHistoryState records.
-
- \value ShallowHistory Only the immediate child states of the parent state
- are recorded. In this case a transition with the history state as its
- target will end up in the immediate child state that the parent was in the
- last time it was exited. This is the default.
-
- \value DeepHistory Nested states are recorded. In this case a transition
- with the history state as its target will end up in the most deeply nested
- descendant state the parent was in the last time it was exited.
-*/
-
-QHistoryStatePrivate::QHistoryStatePrivate()
- : defaultState(0)
-{
-}
-
-QHistoryStatePrivate *QHistoryStatePrivate::get(QHistoryState *q)
-{
- return q->d_func();
-}
-
-/*!
- Constructs a new shallow history state with the given \a parent state.
-*/
-QHistoryState::QHistoryState(QState *parent)
- : QAbstractState(*new QHistoryStatePrivate, parent)
-{
- Q_D(QHistoryState);
- d->historyType = ShallowHistory;
-}
-/*!
- Constructs a new history state of the given \a type, with the given \a
- parent state.
-*/
-QHistoryState::QHistoryState(HistoryType type, QState *parent)
- : QAbstractState(*new QHistoryStatePrivate, parent)
-{
- Q_D(QHistoryState);
- d->historyType = type;
-}
-
-/*!
- Destroys this history state.
-*/
-QHistoryState::~QHistoryState()
-{
-}
-
-/*!
- Returns this history state's default state. The default state indicates the
- state to transition to if the parent state has never been entered before.
-*/
-QAbstractState *QHistoryState::defaultState() const
-{
- Q_D(const QHistoryState);
- return d->defaultState;
-}
-
-/*!
- Sets this history state's default state to be the given \a state.
- \a state must be a sibling of this history state.
-*/
-void QHistoryState::setDefaultState(QAbstractState *state)
-{
- Q_D(QHistoryState);
- if (state && state->parentState() != parentState()) {
- qWarning("QHistoryState::setDefaultState: state %p does not belong "
- "to this history state's group (%p)", state, parentState());
- return;
- }
- d->defaultState = state;
-}
-
-/*!
- Returns the type of history that this history state records.
-*/
-QHistoryState::HistoryType QHistoryState::historyType() const
-{
- Q_D(const QHistoryState);
- return d->historyType;
-}
-
-/*!
- Sets the \a type of history that this history state records.
-*/
-void QHistoryState::setHistoryType(HistoryType type)
-{
- Q_D(QHistoryState);
- d->historyType = type;
-}
-
-/*!
- \reimp
-*/
-void QHistoryState::onEntry(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-void QHistoryState::onExit(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-bool QHistoryState::event(QEvent *e)
-{
- return QAbstractState::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qhistorystate.h b/src/corelib/statemachine/qhistorystate.h
deleted file mode 100644
index a0682bd..0000000
--- a/src/corelib/statemachine/qhistorystate.h
+++ /dev/null
@@ -1,91 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QHISTORYSTATE_H
-#define QHISTORYSTATE_H
-
-#include <QtCore/qabstractstate.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QHistoryStatePrivate;
-class Q_CORE_EXPORT QHistoryState : public QAbstractState
-{
- Q_OBJECT
- Q_PROPERTY(QAbstractState* defaultState READ defaultState WRITE setDefaultState)
- Q_PROPERTY(HistoryType historyType READ historyType WRITE setHistoryType)
- Q_ENUMS(HistoryType)
-public:
- enum HistoryType {
- ShallowHistory,
- DeepHistory
- };
-
- QHistoryState(QState *parent = 0);
- QHistoryState(HistoryType type, QState *parent = 0);
- ~QHistoryState();
-
- QAbstractState *defaultState() const;
- void setDefaultState(QAbstractState *state);
-
- HistoryType historyType() const;
- void setHistoryType(HistoryType type);
-
-protected:
- void onEntry(QEvent *event);
- void onExit(QEvent *event);
-
- bool event(QEvent *e);
-
-private:
- Q_DISABLE_COPY(QHistoryState)
- Q_DECLARE_PRIVATE(QHistoryState)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qhistorystate_p.h b/src/corelib/statemachine/qhistorystate_p.h
deleted file mode 100644
index 5aaa64c..0000000
--- a/src/corelib/statemachine/qhistorystate_p.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QHISTORYSTATE_P_H
-#define QHISTORYSTATE_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qabstractstate_p.h"
-
-#include <QtCore/qlist.h>
-
-QT_BEGIN_NAMESPACE
-
-class QHistoryState;
-class QHistoryStatePrivate : public QAbstractStatePrivate
-{
- Q_DECLARE_PUBLIC(QHistoryState)
-
-public:
- QHistoryStatePrivate();
-
- static QHistoryStatePrivate *get(QHistoryState *q);
-
- QAbstractState *defaultState;
- QHistoryState::HistoryType historyType;
- QList<QAbstractState*> configuration;
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qsignalevent.h b/src/corelib/statemachine/qsignalevent.h
deleted file mode 100644
index 8221f68..0000000
--- a/src/corelib/statemachine/qsignalevent.h
+++ /dev/null
@@ -1,77 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSIGNALEVENT_H
-#define QSIGNALEVENT_H
-
-#include <QtCore/qcoreevent.h>
-
-#include <QtCore/qlist.h>
-#include <QtCore/qvariant.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class Q_CORE_EXPORT QSignalEvent : public QEvent
-{
-public:
- QSignalEvent(const QObject *sender, int signalIndex,
- const QList<QVariant> &arguments);
- ~QSignalEvent();
-
- inline const QObject *sender() const { return m_sender; }
- inline int signalIndex() const { return m_signalIndex; }
- inline QList<QVariant> arguments() const { return m_arguments; }
-
-private:
- const QObject *m_sender;
- int m_signalIndex;
- QList<QVariant> m_arguments;
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qsignaleventgenerator_p.h b/src/corelib/statemachine/qsignaleventgenerator_p.h
deleted file mode 100644
index cf0ea1e..0000000
--- a/src/corelib/statemachine/qsignaleventgenerator_p.h
+++ /dev/null
@@ -1,78 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSIGNALEVENTGENERATOR_P_H
-#define QSIGNALEVENTGENERATOR_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <QtCore/qobject.h>
-
-QT_BEGIN_NAMESPACE
-
-class QStateMachine;
-
-class QSignalEventGenerator : public QObject
-{
-public:
- QSignalEventGenerator(QStateMachine *parent);
-
- static const QMetaObject staticMetaObject;
- virtual const QMetaObject *metaObject() const;
- virtual void *qt_metacast(const char *);
- virtual int qt_metacall(QMetaObject::Call, int, void **argv);
-
-private:
- Q_DISABLE_COPY(QSignalEventGenerator)
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qsignaltransition.cpp b/src/corelib/statemachine/qsignaltransition.cpp
deleted file mode 100644
index 4caa917..0000000
--- a/src/corelib/statemachine/qsignaltransition.cpp
+++ /dev/null
@@ -1,257 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qsignaltransition.h"
-#include "qsignaltransition_p.h"
-#include "qsignalevent.h"
-#include "qstate.h"
-#include "qstate_p.h"
-#include "qstatemachine.h"
-#include "qstatemachine_p.h"
-#include <qdebug.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QSignalTransition
-
- \brief The QSignalTransition class provides a transition based on a Qt signal.
-
- \since 4.6
- \ingroup statemachine
-
- Typically you would use the overload of QState::addTransition() that takes a
- sender and signal as arguments, rather than creating QSignalTransition
- objects directly. QSignalTransition is part of \l{The State Machine
- Framework}.
-
- You can subclass QSignalTransition and reimplement eventTest() to make a
- signal transition conditional; the event object passed to eventTest() will
- be a QSignalEvent object. Example:
-
- \code
- class CheckedTransition : public QSignalTransition
- {
- public:
- CheckedTransition(QCheckBox *check)
- : QSignalTransition(check, SIGNAL(stateChanged(int))) {}
- protected:
- bool eventTest(QEvent *e) const {
- if (!QSignalTransition::eventTest(e))
- return false;
- QSignalEvent *se = static_cast<QSignalEvent*>(e);
- return (se->arguments().at(0).toInt() == Qt::Checked);
- }
- };
-
- ...
-
- QCheckBox *check = new QCheckBox();
- check->setTristate(true);
-
- QState *s1 = new QState();
- QState *s2 = new QState();
- CheckedTransition *t1 = new CheckedTransition(check);
- t1->setTargetState(s2);
- s1->addTransition(t1);
- \endcode
-*/
-
-/*!
- \property QSignalTransition::senderObject
-
- \brief the sender object that this signal transition is associated with
-*/
-
-/*!
- \property QSignalTransition::signal
-
- \brief the signal that this signal transition is associated with
-*/
-
-QSignalTransitionPrivate::QSignalTransitionPrivate()
-{
- sender = 0;
- signalIndex = -1;
-}
-
-QSignalTransitionPrivate *QSignalTransitionPrivate::get(QSignalTransition *q)
-{
- return q->d_func();
-}
-
-void QSignalTransitionPrivate::invalidate()
-{
- Q_Q(QSignalTransition);
- if (signalIndex != -1) {
- QState *source = sourceState();
- QStatePrivate *source_d = QStatePrivate::get(source);
- QStateMachinePrivate *mach = QStateMachinePrivate::get(source_d->machine());
- if (mach) {
- mach->unregisterSignalTransition(q);
- if (mach->configuration.contains(source))
- mach->registerSignalTransition(q);
- }
- }
-}
-
-/*!
- Constructs a new signal transition with the given \a sourceState.
-*/
-QSignalTransition::QSignalTransition(QState *sourceState)
- : QAbstractTransition(*new QSignalTransitionPrivate, sourceState)
-{
-}
-
-/*!
- Constructs a new signal transition associated with the given \a signal of
- the given \a sender, and with the given \a sourceState.
-*/
-QSignalTransition::QSignalTransition(QObject *sender, const char *signal,
- QState *sourceState)
- : QAbstractTransition(*new QSignalTransitionPrivate, sourceState)
-{
- Q_D(QSignalTransition);
- d->sender = sender;
- d->signal = signal;
-}
-
-/*!
- Constructs a new signal transition associated with the given \a signal of
- the given \a sender. The transition has the given \a targets and \a
- sourceState.
-*/
-QSignalTransition::QSignalTransition(QObject *sender, const char *signal,
- const QList<QAbstractState*> &targets,
- QState *sourceState)
- : QAbstractTransition(*new QSignalTransitionPrivate, targets, sourceState)
-{
- Q_D(QSignalTransition);
- d->sender = sender;
- d->signal = signal;
-}
-
-/*!
- Destroys this signal transition.
-*/
-QSignalTransition::~QSignalTransition()
-{
-}
-
-/*!
- Returns the sender object associated with this signal transition.
-*/
-QObject *QSignalTransition::senderObject() const
-{
- Q_D(const QSignalTransition);
- return d->sender;
-}
-
-/*!
- Sets the \a sender object associated with this signal transition.
-*/
-void QSignalTransition::setSenderObject(QObject *sender)
-{
- Q_D(QSignalTransition);
- if (sender == d->sender)
- return;
- d->sender = sender;
- d->invalidate();
-}
-
-/*!
- Returns the signal associated with this signal transition.
-*/
-QByteArray QSignalTransition::signal() const
-{
- Q_D(const QSignalTransition);
- return d->signal;
-}
-
-/*!
- Sets the \a signal associated with this signal transition.
-*/
-void QSignalTransition::setSignal(const QByteArray &signal)
-{
- Q_D(QSignalTransition);
- if (signal == d->signal)
- return;
- d->signal = signal;
- d->invalidate();
-}
-
-/*!
- \reimp
-
- The \a event is a QSignalEvent object. The default implementation returns
- true if the event's sender and signal index match this transition, and
- returns false otherwise.
-*/
-bool QSignalTransition::eventTest(QEvent *event)
-{
- Q_D(const QSignalTransition);
- if (event->type() == QEvent::Signal) {
- if (d->signalIndex == -1)
- return false;
- QSignalEvent *se = static_cast<QSignalEvent*>(event);
- return (se->sender() == d->sender)
- && (se->signalIndex() == d->signalIndex);
- }
- return false;
-}
-
-/*!
- \reimp
-*/
-void QSignalTransition::onTransition(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-bool QSignalTransition::event(QEvent *e)
-{
- return QAbstractTransition::event(e);
-}
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qsignaltransition.h b/src/corelib/statemachine/qsignaltransition.h
deleted file mode 100644
index b485785..0000000
--- a/src/corelib/statemachine/qsignaltransition.h
+++ /dev/null
@@ -1,89 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSIGNALTRANSITION_H
-#define QSIGNALTRANSITION_H
-
-#include <QtCore/qabstracttransition.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QSignalTransitionPrivate;
-class Q_CORE_EXPORT QSignalTransition : public QAbstractTransition
-{
- Q_OBJECT
- Q_PROPERTY(QObject* senderObject READ senderObject WRITE setSenderObject)
- Q_PROPERTY(QByteArray signal READ signal WRITE setSignal)
-public:
- QSignalTransition(QState *sourceState = 0);
- QSignalTransition(QObject *sender, const char *signal,
- QState *sourceState = 0);
- QSignalTransition(QObject *sender, const char *signal,
- const QList<QAbstractState*> &targets,
- QState *sourceState = 0);
- ~QSignalTransition();
-
- QObject *senderObject() const;
- void setSenderObject(QObject *sender);
-
- QByteArray signal() const;
- void setSignal(const QByteArray &signal);
-
-protected:
- bool eventTest(QEvent *event);
- void onTransition(QEvent *event);
-
- bool event(QEvent *e);
-
-private:
- Q_DISABLE_COPY(QSignalTransition)
- Q_DECLARE_PRIVATE(QSignalTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qsignaltransition_p.h b/src/corelib/statemachine/qsignaltransition_p.h
deleted file mode 100644
index a23e58c..0000000
--- a/src/corelib/statemachine/qsignaltransition_p.h
+++ /dev/null
@@ -1,78 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSIGNALTRANSITION_P_H
-#define QSIGNALTRANSITION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qabstracttransition_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QSignalTransition;
-class QSignalTransitionPrivate : public QAbstractTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QSignalTransition)
-public:
- QSignalTransitionPrivate();
-
- static QSignalTransitionPrivate *get(QSignalTransition *q);
-
- void invalidate();
-
- QObject *sender;
- QByteArray signal;
- int signalIndex;
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qstate.cpp b/src/corelib/statemachine/qstate.cpp
deleted file mode 100644
index e42e463..0000000
--- a/src/corelib/statemachine/qstate.cpp
+++ /dev/null
@@ -1,497 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qstate.h"
-#include "qstate_p.h"
-#include "qhistorystate.h"
-#include "qhistorystate_p.h"
-#include "qabstracttransition.h"
-#include "qabstracttransition_p.h"
-#include "qsignaltransition.h"
-#include "qstatemachine.h"
-#include "qstatemachine_p.h"
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QState
-
- \brief The QState class provides a general-purpose state for QStateMachine.
-
- \since 4.6
- \ingroup statemachine
-
- QState objects can have child states, and can have transitions to other
- states. QState is part of \l{The State Machine Framework}.
-
- The addTransition() function adds a transition. The removeTransition()
- function removes a transition.
-
- The assignProperty() function is used for defining property assignments that
- should be performed when a state is entered.
-
- Top-level states must be passed QStateMachine::rootState() as their parent
- state, or added to a state machine using QStateMachine::addState().
-
- \section1 States with Child States
-
- The childMode property determines how child states are treated. For
- non-parallel state groups, the setInitialState() function must be called to
- set the initial state. The child states are mutually exclusive states, and
- the state machine needs to know which child state to enter when the parent
- state is the target of a transition.
-
- The state emits the QState::finished() signal when a final child state
- (QFinalState) is entered.
-
- The setErrorState() sets the state's error state. The error state is the
- state that the state machine will transition to if an error is detected when
- attempting to enter the state (e.g. because no initial state has been set).
-
-*/
-
-/*!
- \property QState::initialState
-
- \brief the initial state of this state (one of its child states)
-*/
-
-/*!
- \property QState::errorState
-
- \brief the error state of this state
-*/
-
-/*!
- \property QState::childMode
-
- \brief the child mode of this state
-
- The default value of this property is QState::ExclusiveStates.
-*/
-
-/*!
- \enum QState::ChildMode
-
- This enum specifies how a state's child states are treated.
-
- \value ExclusiveStates The child states are mutually exclusive and an
- initial state must be set by calling QState::setInitialState().
-
- \value ParallelStates The child states are parallel. When the parent state
- is entered, all its child states are entered in parallel.
-*/
-
-QStatePrivate::QStatePrivate()
- : errorState(0), initialState(0), childMode(QState::ExclusiveStates)
-{
-}
-
-QStatePrivate::~QStatePrivate()
-{
-}
-
-QStatePrivate *QStatePrivate::get(QState *q)
-{
- if (!q)
- return 0;
- return q->d_func();
-}
-
-const QStatePrivate *QStatePrivate::get(const QState *q)
-{
- if (!q)
- return 0;
- return q->d_func();
-}
-
-void QStatePrivate::emitFinished()
-{
- Q_Q(QState);
- emit q->finished();
-}
-
-void QStatePrivate::emitPolished()
-{
- Q_Q(QState);
- emit q->polished();
-}
-
-/*!
- Constructs a new state with the given \a parent state.
-*/
-QState::QState(QState *parent)
- : QAbstractState(*new QStatePrivate, parent)
-{
-}
-
-/*!
- Constructs a new state with the given \a childMode and the given \a parent
- state.
-*/
-QState::QState(ChildMode childMode, QState *parent)
- : QAbstractState(*new QStatePrivate, parent)
-{
- Q_D(QState);
- d->childMode = childMode;
-}
-
-/*!
- \internal
-*/
-QState::QState(QStatePrivate &dd, QState *parent)
- : QAbstractState(dd, parent)
-{
-}
-
-/*!
- Destroys this state.
-*/
-QState::~QState()
-{
-}
-
-QList<QAbstractState*> QStatePrivate::childStates() const
-{
- QList<QAbstractState*> result;
- QList<QObject*>::const_iterator it;
- for (it = children.constBegin(); it != children.constEnd(); ++it) {
- QAbstractState *s = qobject_cast<QAbstractState*>(*it);
- if (!s || qobject_cast<QHistoryState*>(s))
- continue;
- result.append(s);
- }
- return result;
-}
-
-QList<QHistoryState*> QStatePrivate::historyStates() const
-{
- QList<QHistoryState*> result;
- QList<QObject*>::const_iterator it;
- for (it = children.constBegin(); it != children.constEnd(); ++it) {
- QHistoryState *h = qobject_cast<QHistoryState*>(*it);
- if (h)
- result.append(h);
- }
- return result;
-}
-
-QList<QAbstractTransition*> QStatePrivate::transitions() const
-{
- QList<QAbstractTransition*> result;
- QList<QObject*>::const_iterator it;
- for (it = children.constBegin(); it != children.constEnd(); ++it) {
- QAbstractTransition *t = qobject_cast<QAbstractTransition*>(*it);
- if (t)
- result.append(t);
- }
- return result;
-}
-
-/*!
- Instructs this state to set the property with the given \a name of the given
- \a object to the given \a value when the state is entered.
-
- \sa polished()
-*/
-void QState::assignProperty(QObject *object, const char *name,
- const QVariant &value)
-{
- Q_D(QState);
- if (!object) {
- qWarning("QState::assignProperty: cannot assign property '%s' of null object", name);
- return;
- }
- for (int i = 0; i < d->propertyAssignments.size(); ++i) {
- QPropertyAssignment &assn = d->propertyAssignments[i];
- if ((assn.object == object) && (assn.propertyName == name)) {
- assn.value = value;
- return;
- }
- }
- d->propertyAssignments.append(QPropertyAssignment(object, name, value));
-}
-
-/*!
- Returns this state group's error state.
-
- \sa QStateMachine::errorState(), QStateMachine::setErrorState()
-*/
-QAbstractState *QState::errorState() const
-{
- Q_D(const QState);
- return d->errorState;
-}
-
-/*!
- Sets this state's error state to be the given \a state. If the error state
- is not set, or if it is set to 0, the state will inherit its parent's error
- state recursively.
-
- \sa QStateMachine::setErrorState(), QStateMachine::errorState()
-*/
-void QState::setErrorState(QAbstractState *state)
-{
- Q_D(QState);
- if (state != 0 && state->machine() != machine()) {
- qWarning("QState::setErrorState: error state cannot belong "
- "to a different state machine");
- return;
- }
- if (state != 0 && state->machine() != 0 && state->machine()->rootState() == state) {
- qWarning("QStateMachine::setErrorState: root state cannot be error state");
- return;
- }
-
- d->errorState = state;
-}
-
-/*!
- Adds the given \a transition. The transition has this state as the source.
- This state takes ownership of the transition. If the transition is successfully
- added, the function will return the \a transition pointer. Otherwise it will return null.
-*/
-QAbstractTransition *QState::addTransition(QAbstractTransition *transition)
-{
- Q_D(QState);
- if (!transition) {
- qWarning("QState::addTransition: cannot add null transition");
- return 0;
- }
-
- // machine() will always be non-null for root state
- if (machine() != 0 && machine()->rootState() == this) {
- qWarning("QState::addTransition: cannot add transition from root state");
- return 0;
- }
-
- const QList<QPointer<QAbstractState> > &targets = QAbstractTransitionPrivate::get(transition)->targetStates;
- for (int i = 0; i < targets.size(); ++i) {
- QAbstractState *t = targets.at(i);
- if (!t) {
- qWarning("QState::addTransition: cannot add transition to null state");
- return 0;
- }
- if ((QAbstractStatePrivate::get(t)->machine() != d->machine())
- && QAbstractStatePrivate::get(t)->machine() && d->machine()) {
- qWarning("QState::addTransition: cannot add transition "
- "to a state in a different state machine");
- return 0;
- }
- }
- transition->setParent(this);
- if (machine() != 0 && machine()->configuration().contains(this))
- QStateMachinePrivate::get(machine())->registerTransitions(this);
- return transition;
-}
-
-/*!
- Adds a transition associated with the given \a signal of the given \a sender
- object, and returns the new QSignalTransition object. The transition has
- this state as the source, and the given \a target as the target state.
-*/
-QSignalTransition *QState::addTransition(QObject *sender, const char *signal,
- QAbstractState *target)
-{
- if (!sender) {
- qWarning("QState::addTransition: sender cannot be null");
- return 0;
- }
- if (!signal) {
- qWarning("QState::addTransition: signal cannot be null");
- return 0;
- }
- if (!target) {
- qWarning("QState::addTransition: cannot add transition to null state");
- return 0;
- }
- if (*signal && sender->metaObject()->indexOfSignal(signal+1) == -1) {
- qWarning("QState::addTransition: no such signal %s::%s",
- sender->metaObject()->className(), signal+1);
- return 0;
- }
- QSignalTransition *trans = new QSignalTransition(sender, signal, QList<QAbstractState*>() << target);
- addTransition(trans);
- return trans;
-}
-
-namespace {
-
-// ### Make public?
-class UnconditionalTransition : public QAbstractTransition
-{
-public:
- UnconditionalTransition(QAbstractState *target)
- : QAbstractTransition(QList<QAbstractState*>() << target) {}
-protected:
- void onTransition(QEvent *) {}
- bool eventTest(QEvent *) { return true; }
-};
-
-} // namespace
-
-/*!
- Adds an unconditional transition from this state to the given \a target
- state, and returns then new transition object.
-*/
-QAbstractTransition *QState::addTransition(QAbstractState *target)
-{
- if (!target) {
- qWarning("QState::addTransition: cannot add transition to null state");
- return 0;
- }
- UnconditionalTransition *trans = new UnconditionalTransition(target);
- return addTransition(trans);
-}
-
-/*!
- Removes the given \a transition from this state. The state releases
- ownership of the transition.
-
- \sa addTransition()
-*/
-void QState::removeTransition(QAbstractTransition *transition)
-{
- Q_D(QState);
- if (!transition) {
- qWarning("QState::removeTransition: cannot remove null transition");
- return;
- }
- if (transition->sourceState() != this) {
- qWarning("QState::removeTransition: transition %p's source state (%p)"
- " is different from this state (%p)",
- transition, transition->sourceState(), this);
- return;
- }
- QStateMachinePrivate *mach = QStateMachinePrivate::get(d->machine());
- if (mach)
- mach->unregisterTransition(transition);
- transition->setParent(0);
-}
-
-/*!
- \reimp
-*/
-void QState::onEntry(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \reimp
-*/
-void QState::onExit(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- Returns this state's initial state, or 0 if the state has no initial state.
-*/
-QAbstractState *QState::initialState() const
-{
- Q_D(const QState);
- return d->initialState;
-}
-
-/*!
- Sets this state's initial state to be the given \a state.
- \a state has to be a child of this state.
-*/
-void QState::setInitialState(QAbstractState *state)
-{
- Q_D(QState);
- if (d->childMode == QState::ParallelStates) {
- qWarning("QState::setInitialState: ignoring attempt to set initial state "
- "of parallel state group %p", this);
- return;
- }
- if (state && (state->parentState() != this)) {
- qWarning("QState::setInitialState: state %p is not a child of this state (%p)",
- state, this);
- return;
- }
- d->initialState = state;
-}
-
-/*!
- Returns the child mode of this state.
-*/
-QState::ChildMode QState::childMode() const
-{
- Q_D(const QState);
- return d->childMode;
-}
-
-/*!
- Sets the child \a mode of this state.
-*/
-void QState::setChildMode(ChildMode mode)
-{
- Q_D(QState);
- d->childMode = mode;
-}
-
-/*!
- \reimp
-*/
-bool QState::event(QEvent *e)
-{
- return QAbstractState::event(e);
-}
-
-/*!
- \fn QState::finished()
-
- This signal is emitted when a final child state of this state is entered.
-
- \sa QFinalState
-*/
-
-/*!
- \fn QState::polished()
-
- This signal is emitted when all properties have been assigned their final value.
-
- \sa QState::assignProperty(), QAbstractTransition::addAnimation()
-*/
-
-QT_END_NAMESPACE
diff --git a/src/corelib/statemachine/qstate.h b/src/corelib/statemachine/qstate.h
deleted file mode 100644
index 6729c69..0000000
--- a/src/corelib/statemachine/qstate.h
+++ /dev/null
@@ -1,113 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSTATE_H
-#define QSTATE_H
-
-#include <QtCore/qabstractstate.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QAbstractTransition;
-class QSignalTransition;
-
-class QStatePrivate;
-class Q_CORE_EXPORT QState : public QAbstractState
-{
- Q_OBJECT
- Q_PROPERTY(QAbstractState* initialState READ initialState WRITE setInitialState)
- Q_PROPERTY(QAbstractState* errorState READ errorState WRITE setErrorState)
- Q_PROPERTY(ChildMode childMode READ childMode WRITE setChildMode)
- Q_ENUMS(ChildMode)
-public:
- enum ChildMode {
- ExclusiveStates,
- ParallelStates
- };
-
- QState(QState *parent = 0);
- QState(ChildMode childMode, QState *parent = 0);
- ~QState();
-
- QAbstractState *errorState() const;
- void setErrorState(QAbstractState *state);
-
- QAbstractTransition *addTransition(QAbstractTransition *transition);
- QSignalTransition *addTransition(QObject *sender, const char *signal, QAbstractState *target);
- QAbstractTransition *addTransition(QAbstractState *target);
- void removeTransition(QAbstractTransition *transition);
-
- QAbstractState *initialState() const;
- void setInitialState(QAbstractState *state);
-
- ChildMode childMode() const;
- void setChildMode(ChildMode mode);
-
- void assignProperty(QObject *object, const char *name,
- const QVariant &value);
-
-Q_SIGNALS:
- void finished();
- void polished();
-
-protected:
- void onEntry(QEvent *event);
- void onExit(QEvent *event);
-
- bool event(QEvent *e);
-
-protected:
- QState(QStatePrivate &dd, QState *parent);
-
-private:
- Q_DISABLE_COPY(QState)
- Q_DECLARE_PRIVATE(QState)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qstate_p.h b/src/corelib/statemachine/qstate_p.h
deleted file mode 100644
index 1f913b4..0000000
--- a/src/corelib/statemachine/qstate_p.h
+++ /dev/null
@@ -1,108 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSTATE_P_H
-#define QSTATE_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include "qabstractstate_p.h"
-
-#include <QtCore/qlist.h>
-#include <QtCore/qbytearray.h>
-#include <QtCore/qvariant.h>
-
-QT_BEGIN_NAMESPACE
-
-struct QPropertyAssignment
-{
- QPropertyAssignment()
- : object(0) {}
- QPropertyAssignment(QObject *o, const QByteArray &n,
- const QVariant &v, bool es = true)
- : object(o), propertyName(n), value(v), explicitlySet(es)
- {}
- QObject *object;
- QByteArray propertyName;
- QVariant value;
- bool explicitlySet;
-};
-
-class QAbstractTransition;
-class QHistoryState;
-
-class QState;
-class Q_CORE_EXPORT QStatePrivate : public QAbstractStatePrivate
-{
- Q_DECLARE_PUBLIC(QState)
-public:
- QStatePrivate();
- ~QStatePrivate();
-
- static QStatePrivate *get(QState *q);
- static const QStatePrivate *get(const QState *q);
-
- QList<QAbstractState*> childStates() const;
- QList<QHistoryState*> historyStates() const;
- QList<QAbstractTransition*> transitions() const;
-
- void emitFinished();
- void emitPolished();
-
- QAbstractState *errorState;
- QAbstractState *initialState;
- QState::ChildMode childMode;
-
- QList<QPropertyAssignment> propertyAssignments;
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qstatemachine.cpp b/src/corelib/statemachine/qstatemachine.cpp
deleted file mode 100644
index 744515b..0000000
--- a/src/corelib/statemachine/qstatemachine.cpp
+++ /dev/null
@@ -1,2216 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qstatemachine.h"
-#include "qstate.h"
-#include "qstate_p.h"
-#include "qstatemachine_p.h"
-#include "qabstracttransition.h"
-#include "qabstracttransition_p.h"
-#include "qsignaltransition.h"
-#include "qsignaltransition_p.h"
-#include "qsignalevent.h"
-#include "qsignaleventgenerator_p.h"
-#include "qabstractstate.h"
-#include "qabstractstate_p.h"
-#include "qfinalstate.h"
-#include "qhistorystate.h"
-#include "qhistorystate_p.h"
-#include "private/qobject_p.h"
-#include "private/qthread_p.h"
-
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
-#include "qeventtransition.h"
-#include "qeventtransition_p.h"
-#include "qwrappedevent.h"
-#endif
-
-#ifndef QT_NO_ANIMATION
-#include "qpropertyanimation.h"
-#include "qanimationgroup.h"
-#include <private/qvariantanimation_p.h>
-#endif
-
-#include <QtCore/qmetaobject.h>
-#include <qdebug.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QStateMachine
- \reentrant
-
- \brief The QStateMachine class provides a hierarchical finite state machine.
-
- \since 4.6
- \ingroup statemachine
-
- QStateMachine is based on the concepts and notation of
- \l{Statecharts: A visual formalism for complex
- systems}{Statecharts}. QStateMachine is part of \l{The State
- Machine Framework}.
-
- A state machine manages a set of states (classes that inherit from
- QAbstractState) and transitions (descendants of
- QAbstractTransition) between those states; these states and
- transitions define a state graph. Once a state graph has been
- built, the state machine can execute it. \l{QStateMachine}'s
- execution algorithm is based on the \l{State Chart XML: State
- Machine Notation for Control Abstraction}{State Chart XML (SCXML)}
- algorithm. The framework's \l{The State Machine
- Framework}{overview} gives several state graphs and the code to
- build them.
-
- The rootState() is the parent of all top-level states in the
- machine; it is used, for instance, when the state graph is
- deleted. It is created by the machine.
-
- Use the addState() function to add a state to the state machine.
- All top-level states are added to the root state. States are
- removed with the removeState() function. Removing states while the
- machine is running is discouraged.
-
- Before the machine can be started, the \l{initialState}{initial
- state} must be set. The initial state is the state that the
- machine enters when started. You can then start() the state
- machine. The started() signal is emitted when the initial state is
- entered.
-
- The machine is event driven and keeps its own event loop. Events
- are posted to the machine through postEvent(). Note that this
- means that it executes asynchronously, and that it will not
- progress without a running event loop. You will normally not have
- to post events to the machine directly as Qt's transitions, e.g.,
- QEventTransition and its subclasses, handle this. But for custom
- transitions triggered by events, postEvent() is useful.
-
- The state machine processes events and takes transitions until a
- top-level final state is entered; the state machine then emits the
- finished() signal. You can also stop() the state machine
- explicitly. The stopped() signal is emitted in this case.
-
- The following snippet shows a state machine that will finish when a button
- is clicked:
-
- \code
- QPushButton button;
-
- QStateMachine machine;
- QState *s1 = new QState();
- s1->assignProperty(&button, "text", "Click me");
-
- QFinalState *s2 = new QFinalState();
- s1->addTransition(&button, SIGNAL(clicked()), s2);
-
- machine.addState(s1);
- machine.addState(s2);
- machine.setInitialState(s1);
- machine.start();
- \endcode
-
- This code example uses QState, which inherits QAbstractState. The
- QState class provides a state that you can use to set properties
- and invoke methods on \l{QObject}s when the state is entered or
- exited. It also contains convenience functions for adding
- transitions, e.g., \l{QSignalTransition}s as in this example. See
- the QState class description for further details.
-
- If an error is encountered, the machine will enter the
- \l{errorState}{error state}, which is a special state created by
- the machine. The types of errors possible are described by the
- \l{QStateMachine::}{Error} enum. After the error state is entered,
- the type of the error can be retrieved with error(). The execution
- of the state graph will not stop when the error state is entered.
- So it is possible to handle the error, for instance, by connecting
- to the \l{QAbstractState::}{entered()} signal of the error state.
- It is also possible to set a custom error state with
- setErrorState().
-
- \omit This stuff will be moved elsewhere
-This is
- typically used in conjunction with \l{Signals and Slots}{signals}; the
- signals determine the flow of the state graph, whereas the states' property
- assignments and method invocations are the actions.
-
- The postEvent() function posts an event to the state machine. This is useful
- when you are using custom events to trigger transitions.
- \endomit
-
- \sa QAbstractState, QAbstractTransition, QState, {The State Machine Framework}
-*/
-
-/*!
- \property QStateMachine::rootState
-
- \brief the root state of this state machine
-*/
-
-/*!
- \property QStateMachine::initialState
-
- \brief the initial state of this state machine
-
- The initial state must be one of the rootState()'s child states.
-*/
-
-/*!
- \property QStateMachine::errorState
-
- \brief the error state of this state machine
-*/
-
-/*!
- \property QStateMachine::errorString
-
- \brief the error string of this state machine
-*/
-
-/*!
- \property QStateMachine::globalRestorePolicy
-
- \brief the restore policy for states of this state machine.
-
- The default value of this property is
- QStateMachine::DoNotRestoreProperties.
-*/
-
-#ifndef QT_NO_ANIMATION
-/*!
- \property QStateMachine::animationsEnabled
-
- \brief whether animations are enabled
-
- The default value of this property is true.
-
- \sa QAbstractTransition::addAnimation()
-*/
-#endif
-
-// #define QSTATEMACHINE_DEBUG
-
-QStateMachinePrivate::QStateMachinePrivate()
-{
- state = NotRunning;
- processing = false;
- processingScheduled = false;
- stop = false;
- error = QStateMachine::NoError;
- globalRestorePolicy = QStateMachine::DoNotRestoreProperties;
- rootState = 0;
- initialErrorStateForRoot = 0;
- signalEventGenerator = 0;
-#ifndef QT_NO_ANIMATION
- animationsEnabled = true;
-#endif
-}
-
-QStateMachinePrivate::~QStateMachinePrivate()
-{
- qDeleteAll(internalEventQueue);
- qDeleteAll(externalEventQueue);
-}
-
-QStateMachinePrivate *QStateMachinePrivate::get(QStateMachine *q)
-{
- if (q)
- return q->d_func();
- return 0;
-}
-
-static QEvent *cloneEvent(QEvent *e)
-{
- switch (e->type()) {
- case QEvent::None:
- return new QEvent(*e);
- case QEvent::Timer:
- return new QTimerEvent(*static_cast<QTimerEvent*>(e));
- default:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- }
- return 0;
-}
-
-const QStateMachinePrivate::Handler qt_kernel_statemachine_handler = {
- cloneEvent
-};
-
-const QStateMachinePrivate::Handler *QStateMachinePrivate::handler = &qt_kernel_statemachine_handler;
-
-Q_CORE_EXPORT const QStateMachinePrivate::Handler *qcoreStateMachineHandler()
-{
- return &qt_kernel_statemachine_handler;
-}
-
-static int indexOfDescendant(QState *s, QAbstractState *desc)
-{
- QList<QAbstractState*> childStates = QStatePrivate::get(s)->childStates();
- for (int i = 0; i < childStates.size(); ++i) {
- QAbstractState *c = childStates.at(i);
- if ((c == desc) || QStateMachinePrivate::isDescendantOf(desc, c)) {
- return i;
- }
- }
- return -1;
-}
-
-bool QStateMachinePrivate::stateEntryLessThan(QAbstractState *s1, QAbstractState *s2)
-{
- if (s1->parent() == s2->parent()) {
- return s1->children().indexOf(s1)
- < s2->children().indexOf(s2);
- } else if (isDescendantOf(s1, s2)) {
- return false;
- } else if (isDescendantOf(s2, s1)) {
- return true;
- } else {
- QState *lca = findLCA(QList<QAbstractState*>() << s1 << s2);
- Q_ASSERT(lca != 0);
- return (indexOfDescendant(lca, s1) < indexOfDescendant(lca, s2));
- }
-}
-
-bool QStateMachinePrivate::stateExitLessThan(QAbstractState *s1, QAbstractState *s2)
-{
- if (s1->parent() == s2->parent()) {
- return s1->children().indexOf(s1)
- < s2->children().indexOf(s2);
- } else if (isDescendantOf(s1, s2)) {
- return true;
- } else if (isDescendantOf(s2, s1)) {
- return false;
- } else {
- QState *lca = findLCA(QList<QAbstractState*>() << s1 << s2);
- Q_ASSERT(lca != 0);
- return (indexOfDescendant(lca, s1) < indexOfDescendant(lca, s2));
- }
-}
-
-QState *QStateMachinePrivate::findLCA(const QList<QAbstractState*> &states)
-{
- if (states.isEmpty())
- return 0;
- QList<QState*> ancestors = properAncestors(states.at(0), 0);
- for (int i = 0; i < ancestors.size(); ++i) {
- QState *anc = ancestors.at(i);
- bool ok = true;
- for (int j = states.size() - 1; (j > 0) && ok; --j) {
- const QAbstractState *s = states.at(j);
- if (!isDescendantOf(s, anc))
- ok = false;
- }
- if (ok)
- return anc;
- }
- return 0;
-}
-
-bool QStateMachinePrivate::isPreempted(const QAbstractState *s, const QSet<QAbstractTransition*> &transitions) const
-{
- QSet<QAbstractTransition*>::const_iterator it;
- for (it = transitions.constBegin(); it != transitions.constEnd(); ++it) {
- QAbstractTransition *t = *it;
- QList<QAbstractState*> lst = t->targetStates();
- if (!lst.isEmpty()) {
- lst.prepend(t->sourceState());
- QAbstractState *lca = findLCA(lst);
- if (isDescendantOf(s, lca)) {
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ":" << transitions << "preempts selection of a transition from"
- << s << "because" << s << "is a descendant of" << lca;
-#endif
- return true;
- }
- }
- }
- return false;
-}
-
-QSet<QAbstractTransition*> QStateMachinePrivate::selectTransitions(QEvent *event) const
-{
- Q_Q(const QStateMachine);
- QSet<QAbstractTransition*> enabledTransitions;
- QSet<QAbstractState*>::const_iterator it;
- const_cast<QStateMachine*>(q)->beginSelectTransitions(event);
- for (it = configuration.constBegin(); it != configuration.constEnd(); ++it) {
- QAbstractState *state = *it;
- if (!isAtomic(state))
- continue;
- if (isPreempted(state, enabledTransitions))
- continue;
- QList<QState*> lst = properAncestors(state, 0);
- if (QState *grp = qobject_cast<QState*>(state))
- lst.prepend(grp);
- bool found = false;
- for (int j = 0; (j < lst.size()) && !found; ++j) {
- QState *s = lst.at(j);
- QList<QAbstractTransition*> transitions = QStatePrivate::get(s)->transitions();
- for (int k = 0; k < transitions.size(); ++k) {
- QAbstractTransition *t = transitions.at(k);
- if (QAbstractTransitionPrivate::get(t)->callEventTest(event)) {
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": selecting transition" << t;
-#endif
- enabledTransitions.insert(t);
- found = true;
- break;
- }
- }
- }
- }
- const_cast<QStateMachine*>(q)->endSelectTransitions(event);
- return enabledTransitions;
-}
-
-void QStateMachinePrivate::microstep(QEvent *event, const QList<QAbstractTransition*> &enabledTransitions)
-{
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": begin microstep( enabledTransitions:" << enabledTransitions << ")";
- qDebug() << q_func() << ": configuration before exiting states:" << configuration;
-#endif
- QList<QAbstractState*> exitedStates = exitStates(event, enabledTransitions);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": configuration after exiting states:" << configuration;
-#endif
- executeTransitionContent(event, enabledTransitions);
- QList<QAbstractState*> enteredStates = enterStates(event, enabledTransitions);
- applyProperties(enabledTransitions, exitedStates, enteredStates);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": configuration after entering states:" << configuration;
- qDebug() << q_func() << ": end microstep";
-#endif
-}
-
-QList<QAbstractState*> QStateMachinePrivate::exitStates(QEvent *event, const QList<QAbstractTransition*> &enabledTransitions)
-{
-// qDebug() << "exitStates(" << enabledTransitions << ")";
- QSet<QAbstractState*> statesToExit;
-// QSet<QAbstractState*> statesToSnapshot;
- for (int i = 0; i < enabledTransitions.size(); ++i) {
- QAbstractTransition *t = enabledTransitions.at(i);
- QList<QAbstractState*> lst = t->targetStates();
- if (lst.isEmpty())
- continue;
- lst.prepend(t->sourceState());
- QAbstractState *lca = findLCA(lst);
- if (lca == 0) {
- setError(QStateMachine::NoCommonAncestorForTransitionError, t->sourceState());
- lst = pendingErrorStates.toList();
- lst.prepend(t->sourceState());
-
- lca = findLCA(lst);
- Q_ASSERT(lca != 0);
- }
-
- {
- QSet<QAbstractState*>::const_iterator it;
- for (it = configuration.constBegin(); it != configuration.constEnd(); ++it) {
- QAbstractState *s = *it;
- if (isDescendantOf(s, lca))
- statesToExit.insert(s);
- }
- }
- }
- QList<QAbstractState*> statesToExit_sorted = statesToExit.toList();
- qSort(statesToExit_sorted.begin(), statesToExit_sorted.end(), stateExitLessThan);
- for (int i = 0; i < statesToExit_sorted.size(); ++i) {
- QAbstractState *s = statesToExit_sorted.at(i);
- if (QState *grp = qobject_cast<QState*>(s)) {
- QList<QHistoryState*> hlst = QStatePrivate::get(grp)->historyStates();
- for (int j = 0; j < hlst.size(); ++j) {
- QHistoryState *h = hlst.at(j);
- QHistoryStatePrivate::get(h)->configuration.clear();
- QSet<QAbstractState*>::const_iterator it;
- for (it = configuration.constBegin(); it != configuration.constEnd(); ++it) {
- QAbstractState *s0 = *it;
- if (QHistoryStatePrivate::get(h)->historyType == QHistoryState::DeepHistory) {
- if (isAtomic(s0) && isDescendantOf(s0, s))
- QHistoryStatePrivate::get(h)->configuration.append(s0);
- } else if (s0->parentState() == s) {
- QHistoryStatePrivate::get(h)->configuration.append(s0);
- }
- }
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": recorded" << ((QHistoryStatePrivate::get(h)->historyType == QHistoryState::DeepHistory) ? "deep" : "shallow")
- << "history for" << s << "in" << h << ":" << QHistoryStatePrivate::get(h)->configuration;
-#endif
- }
- }
- }
- for (int i = 0; i < statesToExit_sorted.size(); ++i) {
- QAbstractState *s = statesToExit_sorted.at(i);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": exiting" << s;
-#endif
- QAbstractStatePrivate::get(s)->callOnExit(event);
- configuration.remove(s);
- QAbstractStatePrivate::get(s)->emitExited();
- }
- return statesToExit_sorted;
-}
-
-void QStateMachinePrivate::executeTransitionContent(QEvent *event, const QList<QAbstractTransition*> &enabledTransitions)
-{
- for (int i = 0; i < enabledTransitions.size(); ++i) {
- QAbstractTransition *t = enabledTransitions.at(i);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": triggering" << t;
-#endif
- QAbstractTransitionPrivate::get(t)->callOnTransition(event);
- }
-}
-
-QList<QAbstractState*> QStateMachinePrivate::enterStates(QEvent *event, const QList<QAbstractTransition*> &enabledTransitions)
-{
-#ifdef QSTATEMACHINE_DEBUG
- Q_Q(QStateMachine);
-#endif
-// qDebug() << "enterStates(" << enabledTransitions << ")";
- QSet<QAbstractState*> statesToEnter;
- QSet<QAbstractState*> statesForDefaultEntry;
-
- if (pendingErrorStates.isEmpty()) {
- for (int i = 0; i < enabledTransitions.size(); ++i) {
- QAbstractTransition *t = enabledTransitions.at(i);
- QList<QAbstractState*> lst = t->targetStates();
- if (lst.isEmpty())
- continue;
- lst.prepend(t->sourceState());
- QState *lca = findLCA(lst);
- for (int j = 1; j < lst.size(); ++j) {
- QAbstractState *s = lst.at(j);
- addStatesToEnter(s, lca, statesToEnter, statesForDefaultEntry);
- if (isParallel(lca)) {
- QList<QAbstractState*> lcac = QStatePrivate::get(lca)->childStates();
- foreach (QAbstractState* child,lcac) {
- if (!statesToEnter.contains(child))
- addStatesToEnter(child,lca,statesToEnter,statesForDefaultEntry);
- }
- }
- }
- }
- }
-
- // Did an error occur while selecting transitions? Then we enter the error state.
- if (!pendingErrorStates.isEmpty()) {
- statesToEnter.clear();
- statesToEnter = pendingErrorStates;
- statesForDefaultEntry = pendingErrorStatesForDefaultEntry;
- pendingErrorStates.clear();
- pendingErrorStatesForDefaultEntry.clear();
- }
-
- QList<QAbstractState*> statesToEnter_sorted = statesToEnter.toList();
- qSort(statesToEnter_sorted.begin(), statesToEnter_sorted.end(), stateEntryLessThan);
-
- for (int i = 0; i < statesToEnter_sorted.size(); ++i) {
- QAbstractState *s = statesToEnter_sorted.at(i);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": entering" << s;
-#endif
- configuration.insert(s);
- registerTransitions(s);
- QAbstractStatePrivate::get(s)->callOnEntry(event);
- QAbstractStatePrivate::get(s)->emitEntered();
- if (statesForDefaultEntry.contains(s)) {
- // ### executeContent(s.initial.transition.children())
- }
- if (isFinal(s)) {
- QState *parent = s->parentState();
- if (parent) {
- QState *grandparent = parent->parentState();
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": emitting finished signal for" << parent;
-#endif
- QStatePrivate::get(parent)->emitFinished();
- if (grandparent && isParallel(grandparent)) {
- bool allChildStatesFinal = true;
- QList<QAbstractState*> childStates = QStatePrivate::get(grandparent)->childStates();
- for (int j = 0; j < childStates.size(); ++j) {
- QAbstractState *cs = childStates.at(j);
- if (!isInFinalState(cs)) {
- allChildStatesFinal = false;
- break;
- }
- }
- if (allChildStatesFinal) {
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": emitting finished signal for" << grandparent;
-#endif
- QStatePrivate::get(grandparent)->emitFinished();
- }
- }
- }
- }
- }
- {
- QSet<QAbstractState*>::const_iterator it;
- for (it = configuration.constBegin(); it != configuration.constEnd(); ++it) {
- if (isFinal(*it) && (*it)->parentState() == rootState) {
- processing = false;
- stopProcessingReason = Finished;
- break;
- }
- }
- }
-// qDebug() << "configuration:" << configuration.toList();
- return statesToEnter_sorted;
-}
-
-void QStateMachinePrivate::addStatesToEnter(QAbstractState *s, QState *root,
- QSet<QAbstractState*> &statesToEnter,
- QSet<QAbstractState*> &statesForDefaultEntry)
-{
- if (QHistoryState *h = qobject_cast<QHistoryState*>(s)) {
- QList<QAbstractState*> hconf = QHistoryStatePrivate::get(h)->configuration;
- if (!hconf.isEmpty()) {
- for (int k = 0; k < hconf.size(); ++k) {
- QAbstractState *s0 = hconf.at(k);
- addStatesToEnter(s0, root, statesToEnter, statesForDefaultEntry);
- }
- #ifdef QSTATEMACHINE_DEBUG
- qDebug() <<q_func() << ": restoring"
- << ((QHistoryStatePrivate::get(h)->historyType == QHistoryState::DeepHistory) ? "deep" : "shallow")
- << "history from" << s << ":" << hconf;
- #endif
- } else {
- QList<QAbstractState*> hlst;
- if (QHistoryStatePrivate::get(h)->defaultState)
- hlst.append(QHistoryStatePrivate::get(h)->defaultState);
-
- if (hlst.isEmpty()) {
- setError(QStateMachine::NoDefaultStateInHistoryStateError, h);
- } else {
- for (int k = 0; k < hlst.size(); ++k) {
- QAbstractState *s0 = hlst.at(k);
- addStatesToEnter(s0, root, statesToEnter, statesForDefaultEntry);
- }
- #ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": initial history targets for" << s << ":" << hlst;
- #endif
- }
- }
- } else {
- statesToEnter.insert(s);
- if (isParallel(s)) {
- QState *grp = qobject_cast<QState*>(s);
- QList<QAbstractState*> lst = QStatePrivate::get(grp)->childStates();
- for (int i = 0; i < lst.size(); ++i) {
- QAbstractState *child = lst.at(i);
- addStatesToEnter(child, grp, statesToEnter, statesForDefaultEntry);
- }
- } else if (isCompound(s)) {
- statesForDefaultEntry.insert(s);
- QState *grp = qobject_cast<QState*>(s);
- QAbstractState *initial = grp->initialState();
- if (initial != 0) {
- addStatesToEnter(initial, grp, statesToEnter, statesForDefaultEntry);
- } else {
- setError(QStateMachine::NoInitialStateError, grp);
- return;
- }
- }
- QList<QState*> ancs = properAncestors(s, root);
- for (int i = 0; i < ancs.size(); ++i) {
- QState *anc = ancs.at(i);
- if (!anc->parentState())
- continue;
- statesToEnter.insert(anc);
- if (isParallel(anc)) {
- QList<QAbstractState*> lst = QStatePrivate::get(anc)->childStates();
- for (int j = 0; j < lst.size(); ++j) {
- QAbstractState *child = lst.at(j);
- bool hasDescendantInList = false;
- QSet<QAbstractState*>::const_iterator it;
- for (it = statesToEnter.constBegin(); it != statesToEnter.constEnd(); ++it) {
- if (isDescendantOf(*it, child)) {
- hasDescendantInList = true;
- break;
- }
- }
- if (!hasDescendantInList)
- addStatesToEnter(child, anc, statesToEnter, statesForDefaultEntry);
- }
- }
- }
- }
-}
-
-void QStateMachinePrivate::applyProperties(const QList<QAbstractTransition*> &transitionList,
- const QList<QAbstractState*> &exitedStates,
- const QList<QAbstractState*> &enteredStates)
-{
- Q_Q(QStateMachine);
-#ifdef QT_NO_ANIMATION
- Q_UNUSED(transitionList);
-#endif
- // Process the property assignments of the entered states.
- QHash<QAbstractState*, QList<QPropertyAssignment> > propertyAssignmentsForState;
- QHash<RestorableId, QVariant> pendingRestorables = registeredRestorables;
- for (int i = 0; i < enteredStates.size(); ++i) {
- QState *s = qobject_cast<QState*>(enteredStates.at(i));
- if (!s)
- continue;
-
- QList<QPropertyAssignment> assignments = QStatePrivate::get(s)->propertyAssignments;
- for (int j = 0; j < assignments.size(); ++j) {
- const QPropertyAssignment &assn = assignments.at(j);
- if (globalRestorePolicy == QStateMachine::RestoreProperties) {
- registerRestorable(assn.object, assn.propertyName);
- }
- pendingRestorables.remove(RestorableId(assn.object, assn.propertyName));
- propertyAssignmentsForState[s].append(assn);
- }
-
- // Remove pending restorables for all parent states to avoid restoring properties
- // before the state that assigned them is exited. If state does not explicitly
- // assign a property which is assigned by the parent, it inherits the parent's assignment.
- QState *parentState = s;
- while ((parentState = parentState->parentState()) != 0) {
- assignments = QStatePrivate::get(parentState)->propertyAssignments;
- for (int j=0; j<assignments.size(); ++j) {
- const QPropertyAssignment &assn = assignments.at(j);
- int c = pendingRestorables.remove(RestorableId(assn.object, assn.propertyName));
- if (c > 0)
- propertyAssignmentsForState[s].append(assn);
- }
- }
- }
- if (!pendingRestorables.isEmpty()) {
- QAbstractState *s;
- if (!enteredStates.isEmpty())
- s = enteredStates.last(); // ### handle if parallel
- else
- s = 0;
- propertyAssignmentsForState[s] << restorablesToPropertyList(pendingRestorables);
- }
-
-#ifndef QT_NO_ANIMATION
- // Gracefully terminate playing animations for states that are exited.
- for (int i = 0; i < exitedStates.size(); ++i) {
- QAbstractState *s = exitedStates.at(i);
- QList<QAbstractAnimation*> animations = animationsForState.take(s);
- for (int j = 0; j < animations.size(); ++j) {
- QAbstractAnimation *anim = animations.at(j);
- QObject::disconnect(anim, SIGNAL(finished()), q, SLOT(_q_animationFinished()));
- stateForAnimation.remove(anim);
-
- // Stop the (top-level) animation.
- // ### Stopping nested animation has weird behavior.
- QAbstractAnimation *topLevelAnim = anim;
- while (QAnimationGroup *group = topLevelAnim->group())
- topLevelAnim = group;
- topLevelAnim->stop();
-
- if (resetAnimationEndValues.contains(anim)) {
- qobject_cast<QVariantAnimation*>(anim)->setEndValue(QVariant()); // ### generalize
- resetAnimationEndValues.remove(anim);
- }
- QPropertyAssignment assn = propertyForAnimation.take(anim);
- Q_ASSERT(assn.object != 0);
- // If there is no property assignment that sets this property,
- // set the property to its target value.
- bool found = false;
- QHash<QAbstractState*, QList<QPropertyAssignment> >::const_iterator it;
- for (it = propertyAssignmentsForState.constBegin(); it != propertyAssignmentsForState.constEnd(); ++it) {
- const QList<QPropertyAssignment> &assignments = it.value();
- for (int k = 0; k < assignments.size(); ++k) {
- if ((assignments.at(k).object == assn.object)
- && (assignments.at(k).propertyName == assn.propertyName)) {
- found = true;
- break;
- }
- }
- }
- if (!found) {
- assn.object->setProperty(assn.propertyName, assn.value);
- }
- }
- }
-
- // Find the animations to use for the state change.
- QList<QAbstractAnimation*> selectedAnimations;
- if (animationsEnabled) {
- for (int i = 0; i < transitionList.size(); ++i) {
- QAbstractTransition *transition = transitionList.at(i);
-
- selectedAnimations << transition->animations();
- selectedAnimations << defaultAnimationsForSource.values(transition->sourceState());
-
- QList<QAbstractState *> targetStates = transition->targetStates();
- for (int j=0; j<targetStates.size(); ++j)
- selectedAnimations << defaultAnimationsForTarget.values(targetStates.at(j));
- }
- selectedAnimations << defaultAnimations;
- }
-
- // Initialize animations from property assignments.
- for (int i = 0; i < selectedAnimations.size(); ++i) {
- QAbstractAnimation *anim = selectedAnimations.at(i);
- QHash<QAbstractState*, QList<QPropertyAssignment> >::iterator it;
- for (it = propertyAssignmentsForState.begin(); it != propertyAssignmentsForState.end(); ) {
- QList<QPropertyAssignment>::iterator it2;
- QAbstractState *s = it.key();
- QList<QPropertyAssignment> &assignments = it.value();
- for (it2 = assignments.begin(); it2 != assignments.end(); ) {
- QPair<QList<QAbstractAnimation*>, QList<QAbstractAnimation*> > ret;
- ret = initializeAnimation(anim, *it2);
- QList<QAbstractAnimation*> handlers = ret.first;
- if (!handlers.isEmpty()) {
- for (int j = 0; j < handlers.size(); ++j) {
- QAbstractAnimation *a = handlers.at(j);
- propertyForAnimation.insert(a, *it2);
- stateForAnimation.insert(a, s);
- animationsForState[s].append(a);
- // ### connect to just the top-level animation?
- QObject::disconnect(a, SIGNAL(finished()), q, SLOT(_q_animationFinished()));
- QObject::connect(a, SIGNAL(finished()), q, SLOT(_q_animationFinished()));
- }
- it2 = assignments.erase(it2);
- } else {
- ++it2;
- }
- for (int j = 0; j < ret.second.size(); ++j)
- resetAnimationEndValues.insert(ret.second.at(j));
- }
- if (assignments.isEmpty())
- it = propertyAssignmentsForState.erase(it);
- else
- ++it;
- }
- // We require that at least one animation is valid.
- // ### generalize
- QList<QVariantAnimation*> variantAnims = qFindChildren<QVariantAnimation*>(anim);
- if (QVariantAnimation *va = qobject_cast<QVariantAnimation*>(anim))
- variantAnims.append(va);
-
- bool hasValidEndValue = false;
- for (int j = 0; j < variantAnims.size(); ++j) {
- if (variantAnims.at(j)->endValue().isValid()) {
- hasValidEndValue = true;
- break;
- }
- }
-
- if (hasValidEndValue) {
- anim->start();
- }
- }
-#endif // !QT_NO_ANIMATION
-
- // Immediately set the properties that are not animated.
- {
- QHash<QAbstractState*, QList<QPropertyAssignment> >::const_iterator it;
- for (it = propertyAssignmentsForState.constBegin(); it != propertyAssignmentsForState.constEnd(); ++it) {
- const QList<QPropertyAssignment> &assignments = it.value();
- for (int i = 0; i < assignments.size(); ++i) {
- const QPropertyAssignment &assn = assignments.at(i);
- assn.object->setProperty(assn.propertyName, assn.value);
- }
- }
- }
-
- // Emit polished signal for entered states that have no animated properties.
- for (int i = 0; i < enteredStates.size(); ++i) {
- QState *s = qobject_cast<QState*>(enteredStates.at(i));
- if (s && !animationsForState.contains(s))
- QStatePrivate::get(s)->emitPolished();
- }
-}
-
-bool QStateMachinePrivate::isFinal(const QAbstractState *s)
-{
- return qobject_cast<const QFinalState*>(s) != 0;
-}
-
-bool QStateMachinePrivate::isParallel(const QAbstractState *s)
-{
- const QState *ss = qobject_cast<const QState*>(s);
- return ss && (QStatePrivate::get(ss)->childMode == QState::ParallelStates);
-}
-
-bool QStateMachinePrivate::isCompound(const QAbstractState *s)
-{
- const QState *group = qobject_cast<const QState*>(s);
- if (!group)
- return false;
- return (!isParallel(group) && !QStatePrivate::get(group)->childStates().isEmpty())
- || (qobject_cast<QStateMachine*>(group->parent()) != 0);
-}
-
-bool QStateMachinePrivate::isAtomic(const QAbstractState *s)
-{
- const QState *ss = qobject_cast<const QState*>(s);
- return (ss && QStatePrivate::get(ss)->childStates().isEmpty())
- || isFinal(s);
-}
-
-
-bool QStateMachinePrivate::isDescendantOf(const QAbstractState *state, const QAbstractState *other)
-{
- Q_ASSERT(state != 0);
- for (QAbstractState *s = state->parentState(); s != 0; s = s->parentState()) {
- if (s == other)
- return true;
- }
- return false;
-}
-
-QList<QState*> QStateMachinePrivate::properAncestors(const QAbstractState *state, const QState *upperBound)
-{
- Q_ASSERT(state != 0);
- QList<QState*> result;
- for (QState *s = state->parentState(); s && s != upperBound; s = s->parentState()) {
- result.append(s);
- }
- return result;
-}
-
-bool QStateMachinePrivate::isInFinalState(QAbstractState* s) const
-{
- if (isCompound(s)) {
- QState *grp = qobject_cast<QState*>(s);
- QList<QAbstractState*> lst = QStatePrivate::get(grp)->childStates();
- for (int i = 0; i < lst.size(); ++i) {
- QAbstractState *cs = lst.at(i);
- if (isFinal(cs) && configuration.contains(cs))
- return true;
- }
- return false;
- } else if (isParallel(s)) {
- QState *grp = qobject_cast<QState*>(s);
- QList<QAbstractState*> lst = QStatePrivate::get(grp)->childStates();
- for (int i = 0; i < lst.size(); ++i) {
- QAbstractState *cs = lst.at(i);
- if (!isInFinalState(cs))
- return false;
- }
- return true;
- }
- else
- return false;
-}
-
-void QStateMachinePrivate::registerRestorable(QObject *object, const QByteArray &propertyName)
-{
- RestorableId id(object, propertyName);
- if (!registeredRestorables.contains(id))
- registeredRestorables.insert(id, object->property(propertyName));
-}
-
-QList<QPropertyAssignment> QStateMachinePrivate::restorablesToPropertyList(const QHash<RestorableId, QVariant> &restorables) const
-{
- QList<QPropertyAssignment> result;
- QHash<RestorableId, QVariant>::const_iterator it;
- for (it = restorables.constBegin(); it != restorables.constEnd(); ++it) {
-// qDebug() << "restorable:" << it.key().first << it.key().second << it.value();
- result.append(QPropertyAssignment(it.key().first, it.key().second, it.value(), /*explicitlySet=*/false));
- }
- return result;
-}
-
-/*!
- \internal
- Returns true if the variable with the given \a id has been registered for restoration.
-*/
-bool QStateMachinePrivate::hasRestorable(QObject *object, const QByteArray &propertyName) const
-{
- return registeredRestorables.contains(RestorableId(object, propertyName));
-}
-
-QVariant QStateMachinePrivate::restorableValue(QObject *object, const QByteArray &propertyName) const
-{
- return registeredRestorables.value(RestorableId(object, propertyName), QVariant());
-}
-
-
-/*!
- \internal
- Unregisters the variable identified by \a id
-*/
-void QStateMachinePrivate::unregisterRestorable(QObject *object, const QByteArray &propertyName)
-{
-// qDebug() << "unregisterRestorable(" << object << propertyName << ")";
- RestorableId id(object, propertyName);
- registeredRestorables.remove(id);
-}
-
-QAbstractState *QStateMachinePrivate::findErrorState(QAbstractState *context)
-{
- // If the user sets the root state's error state to 0, we return the initial error state
- if (context == 0)
- return initialErrorStateForRoot;
-
- // Find error state recursively in parent hierarchy if not set explicitly for context state
- QAbstractState *errorState = 0;
-
- QState *s = qobject_cast<QState*>(context);
- if (s)
- errorState = s->errorState();
-
- if (!errorState)
- errorState = findErrorState(context->parentState());
-
- return errorState;
-}
-
-void QStateMachinePrivate::setError(QStateMachine::Error errorCode, QAbstractState *currentContext)
-{
- error = errorCode;
-
- switch (errorCode) {
- case QStateMachine::NoInitialStateError:
- Q_ASSERT(currentContext != 0);
-
- errorString = QStateMachine::tr("Missing initial state in compound state '%1'")
- .arg(currentContext->objectName());
-
- break;
- case QStateMachine::NoDefaultStateInHistoryStateError:
- Q_ASSERT(currentContext != 0);
-
- errorString = QStateMachine::tr("Missing default state in history state '%1'")
- .arg(currentContext->objectName());
- break;
-
- case QStateMachine::NoCommonAncestorForTransitionError:
- Q_ASSERT(currentContext != 0);
-
- errorString = QStateMachine::tr("No common ancestor for targets and source of transition from state '%1'")
- .arg(currentContext->objectName());
- break;
- default:
- errorString = QStateMachine::tr("Unknown error");
- };
-
- pendingErrorStates.clear();
- pendingErrorStatesForDefaultEntry.clear();
-
- QAbstractState *currentErrorState = findErrorState(currentContext);
-
- // Avoid infinite loop if the error state itself has an error
- if (currentContext == currentErrorState) {
- Q_ASSERT(currentContext != initialErrorStateForRoot); // RootErrorState is broken
- currentErrorState = initialErrorStateForRoot;
- }
-
- Q_ASSERT(currentErrorState != 0);
- Q_ASSERT(currentErrorState != rootState);
-
- QState *lca = findLCA(QList<QAbstractState*>() << currentErrorState << currentContext);
- addStatesToEnter(currentErrorState, lca, pendingErrorStates, pendingErrorStatesForDefaultEntry);
-}
-
-#ifndef QT_NO_ANIMATION
-
-QPair<QList<QAbstractAnimation*>, QList<QAbstractAnimation*> >
-QStateMachinePrivate::initializeAnimation(QAbstractAnimation *abstractAnimation,
- const QPropertyAssignment &prop)
-{
- QList<QAbstractAnimation*> handledAnimations;
- QList<QAbstractAnimation*> localResetEndValues;
- QAnimationGroup *group = qobject_cast<QAnimationGroup*>(abstractAnimation);
- if (group) {
- for (int i = 0; i < group->animationCount(); ++i) {
- QAbstractAnimation *animationChild = group->animationAt(i);
- QPair<QList<QAbstractAnimation*>, QList<QAbstractAnimation*> > ret;
- ret = initializeAnimation(animationChild, prop);
- handledAnimations << ret.first;
- localResetEndValues << ret.second;
- }
- } else {
- QPropertyAnimation *animation = qobject_cast<QPropertyAnimation *>(abstractAnimation);
- if (animation != 0
- && prop.object == animation->targetObject()
- && prop.propertyName == animation->propertyName()) {
-
- // Only change end value if it is undefined
- if (!animation->endValue().isValid()) {
- animation->setEndValue(prop.value);
- localResetEndValues.append(animation);
- }
- handledAnimations.append(animation);
- }
- }
- return qMakePair(handledAnimations, localResetEndValues);
-}
-
-void QStateMachinePrivate::_q_animationFinished()
-{
- Q_Q(QStateMachine);
- QAbstractAnimation *anim = qobject_cast<QAbstractAnimation*>(q->sender());
- Q_ASSERT(anim != 0);
- QObject::disconnect(anim, SIGNAL(finished()), q, SLOT(_q_animationFinished()));
- if (resetAnimationEndValues.contains(anim)) {
- qobject_cast<QVariantAnimation*>(anim)->setEndValue(QVariant()); // ### generalize
- resetAnimationEndValues.remove(anim);
- }
-
- // Set the final property value.
- QPropertyAssignment assn = propertyForAnimation.take(anim);
- Q_ASSERT(assn.object != 0);
- assn.object->setProperty(assn.propertyName, assn.value);
- if (!assn.explicitlySet)
- unregisterRestorable(assn.object, assn.propertyName);
-
- QAbstractState *state = stateForAnimation.take(anim);
- Q_ASSERT(state != 0);
- QHash<QAbstractState*, QList<QAbstractAnimation*> >::iterator it;
- it = animationsForState.find(state);
- Q_ASSERT(it != animationsForState.end());
- QList<QAbstractAnimation*> &animations = it.value();
- animations.removeOne(anim);
- if (animations.isEmpty()) {
- animationsForState.erase(it);
- QStatePrivate::get(qobject_cast<QState*>(state))->emitPolished();
- }
-}
-
-#endif // !QT_NO_ANIMATION
-
-namespace {
-
-class StartState : public QState
-{
-public:
- StartState(QState *parent)
- : QState(parent) {}
-protected:
- void onEntry(QEvent *) {}
- void onExit(QEvent *) {}
-};
-
-class InitialTransition : public QAbstractTransition
-{
-public:
- InitialTransition(QAbstractState *target)
- : QAbstractTransition(QList<QAbstractState*>() << target) {}
-protected:
- virtual bool eventTest(QEvent *) { return true; }
- virtual void onTransition(QEvent *) {}
-};
-
-} // namespace
-
-void QStateMachinePrivate::_q_start()
-{
- Q_Q(QStateMachine);
- Q_ASSERT(state == Starting);
- if (!rootState) {
- state = NotRunning;
- return;
- }
- QAbstractState *initial = rootState->initialState();
- if (initial == 0)
- setError(QStateMachine::NoInitialStateError, rootState);
-
- configuration.clear();
- qDeleteAll(internalEventQueue);
- internalEventQueue.clear();
- qDeleteAll(externalEventQueue);
- externalEventQueue.clear();
-
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": starting";
-#endif
- state = Running;
- processingScheduled = true; // we call _q_process() below
- emit q->started();
-
- StartState *start = new StartState(rootState);
- QAbstractTransition *initialTransition = new InitialTransition(initial);
- start->addTransition(initialTransition);
- QList<QAbstractTransition*> transitions;
- transitions.append(initialTransition);
- QEvent nullEvent(QEvent::None);
- executeTransitionContent(&nullEvent, transitions);
- enterStates(&nullEvent, transitions);
- applyProperties(transitions, QList<QAbstractState*>() << start,
- QList<QAbstractState*>() << initial);
- delete start;
-
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": initial configuration:" << configuration;
-#endif
- _q_process();
-}
-
-void QStateMachinePrivate::_q_process()
-{
- Q_Q(QStateMachine);
- Q_ASSERT(state == Running);
- Q_ASSERT(!processing);
- processing = true;
- processingScheduled = false;
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": starting the event processing loop";
-#endif
- while (processing) {
- if (stop) {
- stop = false;
- processing = false;
- stopProcessingReason = Stopped;
- break;
- }
- QSet<QAbstractTransition*> enabledTransitions;
- QEvent *e = new QEvent(QEvent::None);
- enabledTransitions = selectTransitions(e);
- if (enabledTransitions.isEmpty()) {
- delete e;
- e = 0;
- }
- if (enabledTransitions.isEmpty() && !internalEventQueue.isEmpty()) {
- e = internalEventQueue.takeFirst();
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": dequeued internal event" << e << "of type" << e->type();
-#endif
- enabledTransitions = selectTransitions(e);
- if (enabledTransitions.isEmpty()) {
- delete e;
- e = 0;
- }
- }
- if (enabledTransitions.isEmpty()) {
- if (externalEventQueue.isEmpty()) {
- if (internalEventQueue.isEmpty()) {
- processing = false;
- stopProcessingReason = EventQueueEmpty;
- }
- } else {
- e = externalEventQueue.takeFirst();
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": dequeued external event" << e << "of type" << e->type();
-#endif
- enabledTransitions = selectTransitions(e);
- if (enabledTransitions.isEmpty()) {
- delete e;
- e = 0;
- }
- }
- }
- if (!enabledTransitions.isEmpty()) {
- q->beginMicrostep(e);
- microstep(e, enabledTransitions.toList());
- q->endMicrostep(e);
- }
-#ifdef QSTATEMACHINE_DEBUG
- else {
- qDebug() << q << ": no transitions enabled";
- }
-#endif
- delete e;
- }
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": finished the event processing loop";
-#endif
- switch (stopProcessingReason) {
- case EventQueueEmpty:
- break;
- case Finished:
- state = NotRunning;
- unregisterAllTransitions();
- emit q->finished();
- break;
- case Stopped:
- state = NotRunning;
- unregisterAllTransitions();
- emit q->stopped();
- break;
- }
-}
-
-void QStateMachinePrivate::scheduleProcess()
-{
- if ((state != Running) || processing || processingScheduled)
- return;
- processingScheduled = true;
- QMetaObject::invokeMethod(q_func(), "_q_process", Qt::QueuedConnection);
-}
-
-void QStateMachinePrivate::registerTransitions(QAbstractState *state)
-{
- QState *group = qobject_cast<QState*>(state);
- if (!group)
- return;
- QList<QAbstractTransition*> transitions = QStatePrivate::get(group)->transitions();
- for (int i = 0; i < transitions.size(); ++i) {
- QAbstractTransition *t = transitions.at(i);
- if (QSignalTransition *st = qobject_cast<QSignalTransition*>(t)) {
- registerSignalTransition(st);
- }
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
- else if (QEventTransition *oet = qobject_cast<QEventTransition*>(t)) {
- registerEventTransition(oet);
- }
-#endif
- }
-}
-
-void QStateMachinePrivate::unregisterTransition(QAbstractTransition *transition)
-{
- if (QSignalTransition *st = qobject_cast<QSignalTransition*>(transition)) {
- unregisterSignalTransition(st);
- }
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
- else if (QEventTransition *oet = qobject_cast<QEventTransition*>(transition)) {
- unregisterEventTransition(oet);
- }
-#endif
-}
-
-static int senderSignalIndex(const QObject *sender)
-{
- QObjectPrivate *d = QObjectPrivate::get(const_cast<QObject*>(sender));
- QMutexLocker(&d->threadData->mutex);
- if (!d->currentSender)
- return -1;
-
- // Return -1 if d->currentSender isn't in d->senders
- bool found = false;
- for (int i = 0; !found && i < d->senders.count(); ++i)
- found = (d->senders.at(i)->sender == d->currentSender->sender);
- if (!found)
- return -1;
- return d->currentSender->signal;
-}
-
-void QStateMachinePrivate::registerSignalTransition(QSignalTransition *transition)
-{
- Q_Q(QStateMachine);
- if (QSignalTransitionPrivate::get(transition)->signalIndex != -1)
- return; // already registered
- QObject *sender = QSignalTransitionPrivate::get(transition)->sender;
- if (!sender)
- return;
- QByteArray signal = QSignalTransitionPrivate::get(transition)->signal;
- if (signal.startsWith('0'+QSIGNAL_CODE))
- signal.remove(0, 1);
- int signalIndex = sender->metaObject()->indexOfSignal(signal);
- if (signalIndex == -1) {
- qWarning("QSignalTransition: no such signal: %s::%s",
- sender->metaObject()->className(), signal.constData());
- return;
- }
- QVector<int> &connectedSignalIndexes = connections[sender];
- if (connectedSignalIndexes.size() <= signalIndex)
- connectedSignalIndexes.resize(signalIndex+1);
- if (connectedSignalIndexes.at(signalIndex) == 0) {
- if (!signalEventGenerator)
- signalEventGenerator = new QSignalEventGenerator(q);
- bool ok = QMetaObject::connect(sender, signalIndex, signalEventGenerator,
- signalEventGenerator->metaObject()->methodOffset());
- if (!ok) {
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": FAILED to add signal transition from" << transition->sourceState()
- << ": ( sender =" << sender << ", signal =" << (signal.mid(1))
- << ", targets =" << transition->targetStates() << ")";
-#endif
- return;
- }
- }
- ++connectedSignalIndexes[signalIndex];
- QSignalTransitionPrivate::get(transition)->signalIndex = signalIndex;
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": added signal transition from" << transition->sourceState()
- << ": ( sender =" << sender << ", signal =" << (signal.mid(1))
- << ", targets =" << transition->targetStates() << ")";
-#endif
-}
-
-void QStateMachinePrivate::unregisterSignalTransition(QSignalTransition *transition)
-{
- int signalIndex = QSignalTransitionPrivate::get(transition)->signalIndex;
- if (signalIndex == -1)
- return; // not registered
- QSignalTransitionPrivate::get(transition)->signalIndex = -1;
- const QObject *sender = QSignalTransitionPrivate::get(transition)->sender;
- QVector<int> &connectedSignalIndexes = connections[sender];
- Q_ASSERT(connectedSignalIndexes.size() > signalIndex);
- Q_ASSERT(connectedSignalIndexes.at(signalIndex) != 0);
- if (--connectedSignalIndexes[signalIndex] == 0) {
- Q_ASSERT(signalEventGenerator != 0);
- QMetaObject::disconnect(sender, signalIndex, signalEventGenerator,
- signalEventGenerator->metaObject()->methodOffset());
- int sum = 0;
- for (int i = 0; i < connectedSignalIndexes.size(); ++i)
- sum += connectedSignalIndexes.at(i);
- if (sum == 0)
- connections.remove(sender);
- }
-}
-
-void QStateMachinePrivate::unregisterAllTransitions()
-{
- {
- QList<QSignalTransition*> transitions = qFindChildren<QSignalTransition*>(rootState);
- for (int i = 0; i < transitions.size(); ++i)
- unregisterSignalTransition(transitions.at(i));
- }
- {
- QList<QEventTransition*> transitions = qFindChildren<QEventTransition*>(rootState);
- for (int i = 0; i < transitions.size(); ++i)
- unregisterEventTransition(transitions.at(i));
- }
-}
-
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
-void QStateMachinePrivate::registerEventTransition(QEventTransition *transition)
-{
- Q_Q(QStateMachine);
- if (QEventTransitionPrivate::get(transition)->registered)
- return;
- if (transition->eventType() >= QEvent::User) {
- qWarning("QObject event transitions are not supported for custom types");
- return;
- }
- QObject *object = QEventTransitionPrivate::get(transition)->object;
- if (!object)
- return;
- QObjectPrivate *od = QObjectPrivate::get(object);
- if (!od->eventFilters.contains(q))
- object->installEventFilter(q);
- ++qobjectEvents[object][transition->eventType()];
- QEventTransitionPrivate::get(transition)->registered = true;
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q << ": added event transition from" << transition->sourceState()
- << ": ( object =" << object << ", event =" << transition->eventType()
- << ", targets =" << transition->targetStates() << ")";
-#endif
-}
-
-void QStateMachinePrivate::unregisterEventTransition(QEventTransition *transition)
-{
- Q_Q(QStateMachine);
- if (!QEventTransitionPrivate::get(transition)->registered)
- return;
- QObject *object = QEventTransitionPrivate::get(transition)->object;
- QHash<QEvent::Type, int> &events = qobjectEvents[object];
- Q_ASSERT(events.value(transition->eventType()) > 0);
- if (--events[transition->eventType()] == 0) {
- events.remove(transition->eventType());
- int sum = 0;
- QHash<QEvent::Type, int>::const_iterator it;
- for (it = events.constBegin(); it != events.constEnd(); ++it)
- sum += it.value();
- if (sum == 0) {
- qobjectEvents.remove(object);
- object->removeEventFilter(q);
- }
- }
- QEventTransitionPrivate::get(transition)->registered = false;
-}
-#endif
-
-void QStateMachinePrivate::handleTransitionSignal(const QObject *sender, int signalIndex,
- void **argv)
-{
- const QVector<int> &connectedSignalIndexes = connections[sender];
- Q_ASSERT(connectedSignalIndexes.at(signalIndex) != 0);
- const QMetaObject *meta = sender->metaObject();
- QMetaMethod method = meta->method(signalIndex);
- QList<QByteArray> parameterTypes = method.parameterTypes();
- int argc = parameterTypes.count();
- QList<QVariant> vargs;
- for (int i = 0; i < argc; ++i) {
- int type = QMetaType::type(parameterTypes.at(i));
- vargs.append(QVariant(type, argv[i+1]));
- }
-
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << q_func() << ": sending signal event ( sender =" << sender
- << ", signal =" << sender->metaObject()->method(signalIndex).signature() << ")";
-#endif
- internalEventQueue.append(new QSignalEvent(sender, signalIndex, vargs));
- scheduleProcess();
-}
-
-/*!
- Constructs a new state machine with the given \a parent.
-*/
-QStateMachine::QStateMachine(QObject *parent)
- : QObject(*new QStateMachinePrivate, parent)
-{
-}
-
-/*!
- \internal
-*/
-QStateMachine::QStateMachine(QStateMachinePrivate &dd, QObject *parent)
- : QObject(dd, parent)
-{
-}
-
-/*!
- Destroys this state machine.
-*/
-QStateMachine::~QStateMachine()
-{
-}
-
-namespace {
-
-class RootErrorState : public QAbstractState
-{
-public:
- RootErrorState(QState *parent)
- : QAbstractState(parent)
- {
- setObjectName(QString::fromLatin1("DefaultErrorState"));
- }
-
- void onEntry(QEvent *)
- {
- QAbstractStatePrivate *d = QAbstractStatePrivate::get(this);
- QStateMachine *machine = d->machine();
-
- qWarning("Unrecoverable error detected in running state machine: %s",
- qPrintable(machine->errorString()));
- }
-
- void onExit(QEvent *) {}
-};
-
-class RootState : public QState
-{
-public:
- RootState(QState *parent)
- : QState(parent)
- {
- }
-
- void onEntry(QEvent *) {}
- void onExit(QEvent *) {}
-};
-
-} // namespace
-
-/*!
- Returns this state machine's root state.
-*/
-QState *QStateMachine::rootState() const
-{
- Q_D(const QStateMachine);
- if (!d->rootState) {
- const_cast<QStateMachinePrivate*>(d)->rootState = new RootState(0);
- const_cast<QStateMachinePrivate*>(d)->initialErrorStateForRoot = new RootErrorState(d->rootState);
- d->rootState->setParent(const_cast<QStateMachine*>(this));
- d->rootState->setErrorState(d->initialErrorStateForRoot);
- }
- return d->rootState;
-}
-
-/*!
- Returns the error state of the state machine's root state.
-
- \sa QState::errorState()
-*/
-QAbstractState *QStateMachine::errorState() const
-{
- return rootState()->errorState();
-}
-
-/*!
- Sets the error state of this state machine's root state to be \a state. When a running state
- machine encounters an error which puts it in an undefined state, it will enter an error state
- based on the context of the error that occurred. It will enter this state regardless of what
- is currently in the event queue.
-
- If the erroneous state has an error state set, this will be entered by the machine. If no error
- state has been set, the state machine will search the parent hierarchy recursively for an
- error state. The error state of the root state can thus be seen as a global error state that
- applies for the states for which a more specific error state has not been set.
-
- Before entering the error state, the state machine will set the error code returned by error() and
- error message returned by errorString().
-
- The default error state will print a warning to the console containing the information returned by
- errorString(). By setting a new error state on either the state machine itself, or on specific
- states, you can fine tune error handling in the state machine.
-
- If the root state's error state is set to 0, or if the error state selected by the machine itself
- contains an error, the default error state will be used.
-
- \sa QState::setErrorState(), rootState()
-*/
-void QStateMachine::setErrorState(QAbstractState *state)
-{
- rootState()->setErrorState(state);
-}
-
-/*! \enum QStateMachine::Error
-
- This enum type defines errors that can occur in the state machine at run time. When the state
- machine encounters an unrecoverable error at run time, it will set the error code returned
- by error(), the error message returned by errorString(), and enter an error state based on
- the context of the error.
-
- \value NoError No error has occurred.
- \value NoInitialStateError The machine has entered a QState with children which does not have an
- initial state set. The context of this error is the state which is missing an initial
- state.
- \value NoDefaultStateInHistoryStateError The machine has entered a QHistoryState which does not have
- a default state set. The context of this error is the QHistoryState which is missing a
- default state.
- \value NoCommonAncestorForTransitionError The machine has selected a transition whose source
- and targets are not part of the same tree of states, and thus are not part of the same
- state machine. Commonly, this could mean that one of the states has not been given
- any parent or added to any machine. The context of this error is the source state of
- the transition.
-
- \sa setErrorState()
-*/
-
-/*!
- \enum QStateMachine::RestorePolicy
-
- This enum specifies the restore policy type. The restore policy
- takes effect when the machine enters a state which sets one or more
- properties. If the restore policy is set to RestoreProperties,
- the state machine will save the original value of the property before the
- new value is set.
-
- Later, when the machine either enters a state which does not set
- a value for the given property, the property will automatically be restored
- to its initial value.
-
- Only one initial value will be saved for any given property. If a value for a property has
- already been saved by the state machine, it will not be overwritten until the property has been
- successfully restored.
-
- \value DoNotRestoreProperties The state machine should not save the initial values of properties
- and restore them later.
- \value RestoreProperties The state machine should save the initial values of properties
- and restore them later.
-
- \sa QStateMachine::globalRestorePolicy QState::assignProperty()
-*/
-
-
-/*!
- Returns the error code of the last error that occurred in the state machine.
-*/
-QStateMachine::Error QStateMachine::error() const
-{
- Q_D(const QStateMachine);
- return d->error;
-}
-
-/*!
- Returns the error string of the last error that occurred in the state machine.
-*/
-QString QStateMachine::errorString() const
-{
- Q_D(const QStateMachine);
- return d->errorString;
-}
-
-/*!
- Clears the error string and error code of the state machine.
-*/
-void QStateMachine::clearError()
-{
- Q_D(QStateMachine);
- d->errorString.clear();
- d->error = NoError;
-}
-
-/*!
- Returns the restore policy of the state machine.
-
- \sa setGlobalRestorePolicy()
-*/
-QStateMachine::RestorePolicy QStateMachine::globalRestorePolicy() const
-{
- Q_D(const QStateMachine);
- return d->globalRestorePolicy;
-}
-
-/*!
- Sets the restore policy of the state machine to \a restorePolicy. The default
- restore policy is QAbstractState::DoNotRestoreProperties.
-
- \sa globalRestorePolicy()
-*/
-void QStateMachine::setGlobalRestorePolicy(QStateMachine::RestorePolicy restorePolicy)
-{
- Q_D(QStateMachine);
- d->globalRestorePolicy = restorePolicy;
-}
-
-/*!
- Returns this state machine's initial state, or 0 if no initial state has
- been set.
-*/
-QAbstractState *QStateMachine::initialState() const
-{
- Q_D(const QStateMachine);
- if (!d->rootState)
- return 0;
- return d->rootState->initialState();
-}
-
-/*!
- Sets this state machine's initial \a state.
-*/
-void QStateMachine::setInitialState(QAbstractState *state)
-{
- Q_D(QStateMachine);
- if (!d->rootState) {
- if (!state)
- return;
- rootState()->setInitialState(state);
- }
- d->rootState->setInitialState(state);
-}
-
-/*!
- Adds the given \a state to this state machine. The state becomes a top-level
- state (i.e. a child of the rootState()).
-
- If the state is already in a different machine, it will first be removed
- from its old machine, and then added to this machine.
-
- \sa removeState(), rootState(), setInitialState()
-*/
-void QStateMachine::addState(QAbstractState *state)
-{
- if (!state) {
- qWarning("QStateMachine::addState: cannot add null state");
- return;
- }
- if (QAbstractStatePrivate::get(state)->machine() == this) {
- qWarning("QStateMachine::addState: state has already been added to this machine");
- return;
- }
- state->setParent(rootState());
-}
-
-/*!
- Removes the given \a state from this state machine. The state machine
- releases ownership of the state.
-
- \sa addState()
-*/
-void QStateMachine::removeState(QAbstractState *state)
-{
- if (!state) {
- qWarning("QStateMachine::removeState: cannot remove null state");
- return;
- }
- if (QAbstractStatePrivate::get(state)->machine() != this) {
- qWarning("QStateMachine::removeState: state %p's machine (%p)"
- " is different from this machine (%p)",
- state, QAbstractStatePrivate::get(state)->machine(), this);
- return;
- }
- state->setParent(0);
-}
-
-/*!
- Returns whether this state machine is running.
-
- start(), stop()
-*/
-bool QStateMachine::isRunning() const
-{
- Q_D(const QStateMachine);
- return (d->state == QStateMachinePrivate::Running);
-}
-
-/*!
- Starts this state machine. The machine will reset its configuration and
- transition to the initial state. When a final top-level state (QFinalState)
- is entered, the machine will emit the finished() signal.
-
- \sa started(), finished(), stop(), initialState()
-*/
-void QStateMachine::start()
-{
- Q_D(QStateMachine);
-
- if (rootState()->initialState() == 0) {
- qWarning("QStateMachine::start: No initial state set for machine. Refusing to start.");
- return;
- }
-
- switch (d->state) {
- case QStateMachinePrivate::NotRunning:
- d->state = QStateMachinePrivate::Starting;
- QMetaObject::invokeMethod(this, "_q_start", Qt::QueuedConnection);
- break;
- case QStateMachinePrivate::Starting:
- break;
- case QStateMachinePrivate::Running:
- qWarning("QStateMachine::start(): already running");
- break;
- }
-}
-
-/*!
- Stops this state machine. The state machine will stop processing events and
- then emit the stopped() signal.
-
- \sa stopped(), start()
-*/
-void QStateMachine::stop()
-{
- Q_D(QStateMachine);
- switch (d->state) {
- case QStateMachinePrivate::NotRunning:
- break;
- case QStateMachinePrivate::Starting:
- // the machine will exit as soon as it enters the event processing loop
- d->stop = true;
- break;
- case QStateMachinePrivate::Running:
- d->stop = true;
- d->scheduleProcess();
- break;
- }
-}
-
-/*!
- Posts the given \a event for processing by this state machine, with a delay
- of \a delay milliseconds.
-
- This function returns immediately. The event is added to the state machine's
- event queue. Events are processed in the order posted. The state machine
- takes ownership of the event and deletes it once it has been processed.
-
- You can only post events when the state machine is running.
-*/
-void QStateMachine::postEvent(QEvent *event, int delay)
-{
- Q_D(QStateMachine);
- if (d->state != QStateMachinePrivate::Running) {
- qWarning("QStateMachine::postEvent: cannot post event when the state machine is not running");
- return;
- }
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << this << ": posting external event" << event << "with delay" << delay;
-#endif
- if (delay) {
- int tid = startTimer(delay);
- d->delayedEvents[tid] = event;
- } else {
- d->externalEventQueue.append(event);
- d->scheduleProcess();
- }
-}
-
-/*!
- \internal
-
- Posts the given internal \a event for processing by this state machine.
-*/
-void QStateMachine::postInternalEvent(QEvent *event)
-{
- Q_D(QStateMachine);
-#ifdef QSTATEMACHINE_DEBUG
- qDebug() << this << ": posting internal event" << event;
-#endif
- d->internalEventQueue.append(event);
- d->scheduleProcess();
-}
-
-/*!
- \internal
-
- Returns the maximal consistent set of states (including parallel and final
- states) that this state machine is currently in. If a state \c s is in the
- configuration, it is always the case that the parent of \c s is also in
- c. Note, however, that the rootState() is not an explicit member of the
- configuration.
-*/
-QSet<QAbstractState*> QStateMachine::configuration() const
-{
- Q_D(const QStateMachine);
- return d->configuration;
-}
-
-/*!
- \fn QStateMachine::started()
-
- This signal is emitted when the state machine has entered its initial state
- (QStateMachine::initialState).
-
- \sa QStateMachine::finished(), QStateMachine::start()
-*/
-
-/*!
- \fn QStateMachine::finished()
-
- This signal is emitted when the state machine has reached a top-level final
- state (QFinalState).
-
- \sa QStateMachine::started()
-*/
-
-/*!
- \fn QStateMachine::stopped()
-
- This signal is emitted when the state machine has stopped.
-
- \sa QStateMachine::stop(), QStateMachine::finished()
-*/
-
-/*!
- \reimp
-*/
-bool QStateMachine::event(QEvent *e)
-{
- Q_D(QStateMachine);
- if (e->type() == QEvent::Timer) {
- QTimerEvent *te = static_cast<QTimerEvent*>(e);
- int tid = te->timerId();
- if (d->delayedEvents.contains(tid)) {
- killTimer(tid);
- QEvent *ee = d->delayedEvents.take(tid);
- d->externalEventQueue.append(ee);
- d->scheduleProcess();
- return true;
- }
- } else if (e->type() == QEvent::ChildAdded) {
- QChildEvent *ce = static_cast<QChildEvent*>(e);
- if (QAbstractState *state = qobject_cast<QAbstractState*>(ce->child())) {
- if (state != rootState()) {
- state->setParent(rootState());
- return true;
- }
- }
- }
- return QObject::event(e);
-}
-
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
-/*!
- \reimp
-*/
-bool QStateMachine::eventFilter(QObject *watched, QEvent *event)
-{
- Q_D(QStateMachine);
- Q_ASSERT(d->qobjectEvents.contains(watched));
- if (d->qobjectEvents[watched].contains(event->type()))
- postEvent(new QWrappedEvent(watched, d->handler->cloneEvent(event)));
- return false;
-}
-#endif
-
-/*!
- \internal
-
- This function is called when the state machine is about to select
- transitions based on the given \a event.
-
- The default implementation does nothing.
-*/
-void QStateMachine::beginSelectTransitions(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \internal
-
- This function is called when the state machine has finished selecting
- transitions based on the given \a event.
-
- The default implementation does nothing.
-*/
-void QStateMachine::endSelectTransitions(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \internal
-
- This function is called when the state machine is about to do a microstep.
-
- The default implementation does nothing.
-*/
-void QStateMachine::beginMicrostep(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-/*!
- \internal
-
- This function is called when the state machine has finished doing a
- microstep.
-
- The default implementation does nothing.
-*/
-void QStateMachine::endMicrostep(QEvent *event)
-{
- Q_UNUSED(event);
-}
-
-#ifndef QT_NO_ANIMATION
-
-/*!
- Returns whether animations are enabled for this state machine.
-*/
-bool QStateMachine::animationsEnabled() const
-{
- Q_D(const QStateMachine);
- return d->animationsEnabled;
-}
-
-/*!
- Sets whether animations are \a enabled for this state machine.
-*/
-void QStateMachine::setAnimationsEnabled(bool enabled)
-{
- Q_D(QStateMachine);
- d->animationsEnabled = enabled;
-}
-
-/*!
- Adds a default \a animation to be considered for any transition.
-*/
-void QStateMachine::addDefaultAnimation(QAbstractAnimation *animation)
-{
- Q_D(QStateMachine);
- d->defaultAnimations.append(animation);
-}
-
-/*!
- Returns the list of default animations that will be considered for any transition.
-*/
-QList<QAbstractAnimation*> QStateMachine::defaultAnimations() const
-{
- Q_D(const QStateMachine);
- return d->defaultAnimations;
-}
-
-/*!
- Removes \a animation from the list of default animations.
-*/
-void QStateMachine::removeDefaultAnimation(QAbstractAnimation *animation)
-{
- Q_D(QStateMachine);
- d->defaultAnimations.removeAll(animation);
-}
-
-#endif // QT_NO_ANIMATION
-
-
-static const uint qt_meta_data_QSignalEventGenerator[] = {
-
- // content:
- 2, // revision
- 0, // classname
- 0, 0, // classinfo
- 1, 12, // methods
- 0, 0, // properties
- 0, 0, // enums/sets
- 0, 0, // constructors
-
- // slots: signature, parameters, type, tag, flags
- 23, 22, 22, 22, 0x0a,
-
- 0 // eod
-};
-
-static const char qt_meta_stringdata_QSignalEventGenerator[] = {
- "QSignalEventGenerator\0\0execute()\0"
-};
-
-const QMetaObject QSignalEventGenerator::staticMetaObject = {
- { &QObject::staticMetaObject, qt_meta_stringdata_QSignalEventGenerator,
- qt_meta_data_QSignalEventGenerator, 0 }
-};
-
-const QMetaObject *QSignalEventGenerator::metaObject() const
-{
- return &staticMetaObject;
-}
-
-void *QSignalEventGenerator::qt_metacast(const char *_clname)
-{
- if (!_clname) return 0;
- if (!strcmp(_clname, qt_meta_stringdata_QSignalEventGenerator))
- return static_cast<void*>(const_cast< QSignalEventGenerator*>(this));
- return QObject::qt_metacast(_clname);
-}
-
-int QSignalEventGenerator::qt_metacall(QMetaObject::Call _c, int _id, void **_a)
-{
- _id = QObject::qt_metacall(_c, _id, _a);
- if (_id < 0)
- return _id;
- if (_c == QMetaObject::InvokeMetaMethod) {
- switch (_id) {
- case 0: {
-// ### in Qt 4.6 we can use QObject::senderSignalIndex()
- int signalIndex = senderSignalIndex(this);
- Q_ASSERT(signalIndex != -1);
- QStateMachine *machine = qobject_cast<QStateMachine*>(parent());
- QStateMachinePrivate::get(machine)->handleTransitionSignal(sender(), signalIndex, _a);
- break;
- }
- default: ;
- }
- _id -= 1;
- }
- return _id;
-}
-
-QSignalEventGenerator::QSignalEventGenerator(QStateMachine *parent)
- : QObject(parent)
-{
-}
-
-/*!
- \class QSignalEvent
-
- \brief The QSignalEvent class represents a Qt signal event.
-
- \since 4.6
- \ingroup statemachine
-
- A signal event is generated by a QStateMachine in response to a Qt
- signal. The QSignalTransition class provides a transition associated with a
- signal event. QSignalEvent is part of \l{The State Machine Framework}.
-
- The sender() function returns the object that generated the signal. The
- signalIndex() function returns the index of the signal. The arguments()
- function returns the arguments of the signal.
-
- \sa QSignalTransition
-*/
-
-/*!
- \internal
-
- Constructs a new QSignalEvent object with the given \a sender, \a
- signalIndex and \a arguments.
-*/
-QSignalEvent::QSignalEvent(const QObject *sender, int signalIndex,
- const QList<QVariant> &arguments)
- : QEvent(QEvent::Signal), m_sender(sender),
- m_signalIndex(signalIndex), m_arguments(arguments)
-{
-}
-
-/*!
- Destroys this QSignalEvent.
-*/
-QSignalEvent::~QSignalEvent()
-{
-}
-
-/*!
- \fn QSignalEvent::sender() const
-
- Returns the object that emitted the signal.
-
- \sa QObject::sender()
-*/
-
-/*!
- \fn QSignalEvent::signalIndex() const
-
- Returns the index of the signal.
-
- \sa QMetaObject::indexOfSignal(), QMetaObject::method()
-*/
-
-/*!
- \fn QSignalEvent::arguments() const
-
- Returns the arguments of the signal.
-*/
-
-
-/*!
- \class QWrappedEvent
-
- \brief The QWrappedEvent class holds a clone of an event associated with a QObject.
-
- \since 4.6
- \ingroup statemachine
-
- A wrapped event is generated by a QStateMachine in response to a Qt
- event. The QEventTransition class provides a transition associated with a
- such an event. QWrappedEvent is part of \l{The State Machine Framework}.
-
- The object() function returns the object that generated the event. The
- event() function returns a clone of the original event.
-
- \sa QEventTransition
-*/
-
-/*!
- \internal
-
- Constructs a new QWrappedEvent object with the given \a object
- and \a event.
-*/
-QWrappedEvent::QWrappedEvent(QObject *object, QEvent *event)
- : QEvent(QEvent::Wrapped), m_object(object), m_event(event)
-{
-}
-
-/*!
- Destroys this QWrappedEvent.
-*/
-QWrappedEvent::~QWrappedEvent()
-{
-}
-
-/*!
- \fn QWrappedEvent::object() const
-
- Returns the object that the event is associated with.
-*/
-
-/*!
- \fn QWrappedEvent::event() const
-
- Returns a clone of the original event.
-*/
-
-QT_END_NAMESPACE
-
-#include "moc_qstatemachine.cpp"
diff --git a/src/corelib/statemachine/qstatemachine.h b/src/corelib/statemachine/qstatemachine.h
deleted file mode 100644
index 2a98a9a..0000000
--- a/src/corelib/statemachine/qstatemachine.h
+++ /dev/null
@@ -1,166 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSTATEMACHINE_H
-#define QSTATEMACHINE_H
-
-#include <QtCore/qabstractstate.h>
-
-#include <QtCore/qlist.h>
-#include <QtCore/qobject.h>
-#include <QtCore/qset.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QEvent;
-class QAbstractState;
-class QState;
-
-class QStateMachinePrivate;
-class QAbstractAnimation;
-class QAbstractState;
-class Q_CORE_EXPORT QStateMachine : public QObject
-{
- Q_OBJECT
- Q_PROPERTY(QState* rootState READ rootState)
- Q_PROPERTY(QAbstractState* initialState READ initialState WRITE setInitialState)
- Q_PROPERTY(QAbstractState* errorState READ errorState WRITE setErrorState)
- Q_PROPERTY(QString errorString READ errorString)
- Q_PROPERTY(RestorePolicy globalRestorePolicy READ globalRestorePolicy WRITE setGlobalRestorePolicy)
- Q_ENUMS(RestorePolicy)
-#ifndef QT_NO_ANIMATION
- Q_PROPERTY(bool animationsEnabled READ animationsEnabled WRITE setAnimationsEnabled)
-#endif
-public:
- enum RestorePolicy {
- DoNotRestoreProperties,
- RestoreProperties
- };
-
- enum Error {
- NoError,
- NoInitialStateError,
- NoDefaultStateInHistoryStateError,
- NoCommonAncestorForTransitionError
- };
-
- QStateMachine(QObject *parent = 0);
- ~QStateMachine();
-
- void addState(QAbstractState *state);
- void removeState(QAbstractState *state);
-
- QState *rootState() const;
-
- QAbstractState *initialState() const;
- void setInitialState(QAbstractState *state);
-
- QAbstractState *errorState() const;
- void setErrorState(QAbstractState *state);
-
- Error error() const;
- QString errorString() const;
- void clearError();
-
- bool isRunning() const;
-
-#ifndef QT_NO_ANIMATION
- bool animationsEnabled() const;
- void setAnimationsEnabled(bool enabled);
-
- void addDefaultAnimation(QAbstractAnimation *animation);
- QList<QAbstractAnimation *> defaultAnimations() const;
- void removeDefaultAnimation(QAbstractAnimation *animation);
-#endif // QT_NO_ANIMATION
-
- QStateMachine::RestorePolicy globalRestorePolicy() const;
- void setGlobalRestorePolicy(QStateMachine::RestorePolicy restorePolicy);
-
- void postEvent(QEvent *event, int delay = 0);
-
- QSet<QAbstractState*> configuration() const;
-
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
- bool eventFilter(QObject *watched, QEvent *event);
-#endif
-
-public Q_SLOTS:
- void start();
- void stop();
-
-Q_SIGNALS:
- void started();
- void stopped();
- void finished();
-
-protected:
- void postInternalEvent(QEvent *event);
-
- virtual void beginSelectTransitions(QEvent *event);
- virtual void endSelectTransitions(QEvent *event);
-
- virtual void beginMicrostep(QEvent *event);
- virtual void endMicrostep(QEvent *event);
-
- bool event(QEvent *e);
-
-protected:
- QStateMachine(QStateMachinePrivate &dd, QObject *parent);
-
-private:
- Q_DISABLE_COPY(QStateMachine)
- Q_DECLARE_PRIVATE(QStateMachine)
- Q_PRIVATE_SLOT(d_func(), void _q_start())
- Q_PRIVATE_SLOT(d_func(), void _q_process())
-#ifndef QT_NO_ANIMATION
- Q_PRIVATE_SLOT(d_func(), void _q_animationFinished())
-#endif
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/qstatemachine_p.h b/src/corelib/statemachine/qstatemachine_p.h
deleted file mode 100644
index dfa5575..0000000
--- a/src/corelib/statemachine/qstatemachine_p.h
+++ /dev/null
@@ -1,217 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QSTATEMACHINE_P_H
-#define QSTATEMACHINE_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <private/qobject_p.h>
-#include <QtCore/qcoreevent.h>
-#include <QtCore/qhash.h>
-#include <QtCore/qlist.h>
-#include <QtCore/qpair.h>
-#include <QtCore/qset.h>
-#include <QtCore/qvector.h>
-
-#include "qstate.h"
-#include "qstate_p.h"
-
-QT_BEGIN_NAMESPACE
-
-class QEvent;
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
-class QEventTransition;
-#endif
-class QSignalEventGenerator;
-class QSignalTransition;
-class QAbstractState;
-class QAbstractTransition;
-class QState;
-
-#ifndef QT_NO_ANIMATION
-class QAbstractAnimation;
-#endif
-
-class QStateMachine;
-class Q_CORE_EXPORT QStateMachinePrivate
- : public QObjectPrivate
-{
- Q_DECLARE_PUBLIC(QStateMachine)
-public:
- enum State {
- NotRunning,
- Starting,
- Running
- };
- enum StopProcessingReason {
- EventQueueEmpty,
- Finished,
- Stopped
- };
-
- QStateMachinePrivate();
- ~QStateMachinePrivate();
-
- static QStateMachinePrivate *get(QStateMachine *q);
-
- static QState *findLCA(const QList<QAbstractState*> &states);
-
- static bool stateEntryLessThan(QAbstractState *s1, QAbstractState *s2);
- static bool stateExitLessThan(QAbstractState *s1, QAbstractState *s2);
-
- QAbstractState *findErrorState(QAbstractState *context);
- void setError(QStateMachine::Error error, QAbstractState *currentContext);
-
- // private slots
- void _q_start();
- void _q_process();
-#ifndef QT_NO_ANIMATION
- void _q_animationFinished();
-#endif
-
- void microstep(QEvent *event, const QList<QAbstractTransition*> &transitionList);
- bool isPreempted(const QAbstractState *s, const QSet<QAbstractTransition*> &transitions) const;
- QSet<QAbstractTransition*> selectTransitions(QEvent *event) const;
- QList<QAbstractState*> exitStates(QEvent *event, const QList<QAbstractTransition*> &transitionList);
- void executeTransitionContent(QEvent *event, const QList<QAbstractTransition*> &transitionList);
- QList<QAbstractState*> enterStates(QEvent *event, const QList<QAbstractTransition*> &enabledTransitions);
- void addStatesToEnter(QAbstractState *s, QState *root,
- QSet<QAbstractState*> &statesToEnter,
- QSet<QAbstractState*> &statesForDefaultEntry);
-
- void applyProperties(const QList<QAbstractTransition*> &transitionList,
- const QList<QAbstractState*> &exitedStates,
- const QList<QAbstractState*> &enteredStates);
-
- bool isInFinalState(QAbstractState *s) const;
- static bool isFinal(const QAbstractState *s);
- static bool isParallel(const QAbstractState *s);
- static bool isCompound(const QAbstractState *s);
- static bool isAtomic(const QAbstractState *s);
- static bool isDescendantOf(const QAbstractState *s, const QAbstractState *other);
- static QList<QState*> properAncestors(const QAbstractState *s, const QState *upperBound);
-
- void registerTransitions(QAbstractState *state);
- void registerSignalTransition(QSignalTransition *transition);
- void unregisterSignalTransition(QSignalTransition *transition);
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
- void registerEventTransition(QEventTransition *transition);
- void unregisterEventTransition(QEventTransition *transition);
-#endif
- void unregisterTransition(QAbstractTransition *transition);
- void unregisterAllTransitions();
- void handleTransitionSignal(const QObject *sender, int signalIndex,
- void **args);
- void scheduleProcess();
-
- typedef QPair<QObject *, QByteArray> RestorableId;
- QHash<RestorableId, QVariant> registeredRestorables;
- void registerRestorable(QObject *object, const QByteArray &propertyName);
- void unregisterRestorable(QObject *object, const QByteArray &propertyName);
- bool hasRestorable(QObject *object, const QByteArray &propertyName) const;
- QVariant restorableValue(QObject *object, const QByteArray &propertyName) const;
- QList<QPropertyAssignment> restorablesToPropertyList(const QHash<RestorableId, QVariant> &restorables) const;
-
- State state;
- bool processing;
- bool processingScheduled;
- bool stop;
- StopProcessingReason stopProcessingReason;
- QState *rootState;
- QSet<QAbstractState*> configuration;
- QList<QEvent*> internalEventQueue;
- QList<QEvent*> externalEventQueue;
-
- QStateMachine::Error error;
- QStateMachine::RestorePolicy globalRestorePolicy;
-
- QString errorString;
- QSet<QAbstractState *> pendingErrorStates;
- QSet<QAbstractState *> pendingErrorStatesForDefaultEntry;
- QAbstractState *initialErrorStateForRoot;
-
-#ifndef QT_NO_ANIMATION
- bool animationsEnabled;
-
- QPair<QList<QAbstractAnimation*>, QList<QAbstractAnimation*> >
- initializeAnimation(QAbstractAnimation *abstractAnimation,
- const QPropertyAssignment &prop);
-
- QHash<QAbstractState*, QList<QAbstractAnimation*> > animationsForState;
- QHash<QAbstractAnimation*, QPropertyAssignment> propertyForAnimation;
- QHash<QAbstractAnimation*, QAbstractState*> stateForAnimation;
- QSet<QAbstractAnimation*> resetAnimationEndValues;
-
- QList<QAbstractAnimation *> defaultAnimations;
- QMultiHash<QAbstractState *, QAbstractAnimation *> defaultAnimationsForSource;
- QMultiHash<QAbstractState *, QAbstractAnimation *> defaultAnimationsForTarget;
-
-#endif // QT_NO_ANIMATION
-
- QSignalEventGenerator *signalEventGenerator;
-
- QHash<const QObject*, QVector<int> > connections;
-#ifndef QT_NO_STATEMACHINE_EVENTFILTER
- QHash<QObject*, QHash<QEvent::Type, int> > qobjectEvents;
-#endif
- QHash<int, QEvent*> delayedEvents;
-
- typedef QEvent* (*f_cloneEvent)(QEvent*);
- struct Handler {
- f_cloneEvent cloneEvent;
- };
-
- static const Handler *handler;
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/corelib/statemachine/qwrappedevent.h b/src/corelib/statemachine/qwrappedevent.h
deleted file mode 100644
index b01c608..0000000
--- a/src/corelib/statemachine/qwrappedevent.h
+++ /dev/null
@@ -1,76 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QWRAPPEDEVENT_H
-#define QWRAPPEDEVENT_H
-
-#include <QtCore/qcoreevent.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QObject;
-
-class Q_CORE_EXPORT QWrappedEvent : public QEvent
-{
-public:
- QWrappedEvent(QObject *object, QEvent *event);
- ~QWrappedEvent();
-
- inline QObject *object() const { return m_object; }
- inline QEvent *event() const { return m_event; }
-
-private:
- QObject *m_object;
- QEvent *m_event;
-
-private:
- Q_DISABLE_COPY(QWrappedEvent)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/statemachine/statemachine.pri b/src/corelib/statemachine/statemachine.pri
deleted file mode 100644
index 5b19bc1..0000000
--- a/src/corelib/statemachine/statemachine.pri
+++ /dev/null
@@ -1,30 +0,0 @@
-HEADERS += $$PWD/qstatemachine.h \
- $$PWD/qstatemachine_p.h \
- $$PWD/qsignaleventgenerator_p.h \
- $$PWD/qabstractstate.h \
- $$PWD/qabstractstate_p.h \
- $$PWD/qstate.h \
- $$PWD/qstate_p.h \
- $$PWD/qfinalstate.h \
- $$PWD/qhistorystate.h \
- $$PWD/qhistorystate_p.h \
- $$PWD/qabstracttransition.h \
- $$PWD/qabstracttransition_p.h \
- $$PWD/qsignalevent.h \
- $$PWD/qsignaltransition.h \
- $$PWD/qsignaltransition_p.h
-
-SOURCES += $$PWD/qstatemachine.cpp \
- $$PWD/qabstractstate.cpp \
- $$PWD/qstate.cpp \
- $$PWD/qfinalstate.cpp \
- $$PWD/qhistorystate.cpp \
- $$PWD/qabstracttransition.cpp \
- $$PWD/qsignaltransition.cpp
-
-!contains(DEFINES, QT_NO_STATEMACHINE_EVENTFILTER) {
-HEADERS += $$PWD/qwrappedevent.h \
- $$PWD/qeventtransition.h \
- $$PWD/qeventtransition_p.h
-SOURCES += $$PWD/qeventtransition.cpp
-}
diff --git a/src/corelib/tools/qeasingcurve.cpp b/src/corelib/tools/qeasingcurve.cpp
deleted file mode 100644
index 2b027fc..0000000
--- a/src/corelib/tools/qeasingcurve.cpp
+++ /dev/null
@@ -1,846 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-/*
-
-| *property* | *Used for type* |
-| period | QEasingCurve::{In,Out,InOut,OutIn}Elastic |
-| amplitude | QEasingCurve::{In,Out,InOut,OutIn}Bounce, QEasingCurve::{In,Out,InOut,OutIn}Elastic |
-| overshoot | QEasingCurve::{In,Out,InOut,OutIn}Back |
-
-*/
-
-
-
-
-/*!
- \class QEasingCurve
- \since 4.6
- \ingroup animation
- \brief The QEasingCurve class provides easing curves for controlling animation.
-
- Easing curves describe a function that controls how the speed of the interpolation
- between 0 and 1 should be. Easing curves allow transitions from
- one value to another to appear more natural than a simple constant speed would allow.
- The QEasingCurve class is usually used in conjunction with the QAnimation class,
- but can be used on its own.
-
- To calculate the speed of the interpolation, the easing curve provides the function
- valueForProgress(), where the \a progress argument specifies the progress of the
- interpolation: 0 is the start value of the interpolation, 1 is the end value of the
- interpolation. The returned value is the effective progress of the interpolation.
- If the returned value is the same as the input value for all input values the easing
- curve is a linear curve. This is the default behaviour.
-
- For example,
- \code
- QEasingCurve easing(QEasingCurve::InOutQuad);
-
- for(qreal t = 0.0; t < 1.0; t+=0.1)
- qWarning() << "Effective progress" << t << " is
- << easing.valueForProgress(t);
- \endcode
- will print the effective progress of the interpolation between 0 and 1.
-
- When using a QAnimation, the easing curve will be used to control the
- progress of the interpolation between startValue and endValue:
- \code
- QAnimation animation;
- animation.setStartValue(0);
- animation.setEndValue(1000);
- animation.setDuration(1000);
- animation.setEasingCurve(QEasingCurve::InOutQuad);
- \endcode
- */
-
-/*!
- \enum QEasingCurve::Type
-
- The type of easing curve.
-
- \value Linear \inlineimage qeasingcurve-linear.png
- \br
- Easing equation function for a simple linear tweening,
- with no easing.
- \value InQuad \inlineimage qeasingcurve-inquad.png
- \br
- Easing equation function for a quadratic (t^2) easing
- in: accelerating from zero velocity.
- \value OutQuad \inlineimage qeasingcurve-outquad.png
- \br
- Easing equation function for a quadratic (t^2) easing
- out: decelerating to zero velocity.
- \value InOutQuad \inlineimage qeasingcurve-inoutquad.png
- \br
- Easing equation function for a quadratic (t^2) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInQuad \inlineimage qeasingcurve-outinquad.png
- \br
- Easing equation function for a quadratic (t^2) easing
- out/in: deceleration until halfway, then acceleration.
- \value InCubic \inlineimage qeasingcurve-incubic.png
- \br
- Easing equation function for a cubic (t^3) easing
- in: accelerating from zero velocity.
- \value OutCubic \inlineimage qeasingcurve-outcubic.png
- \br
- Easing equation function for a cubic (t^3) easing
- out: decelerating from zero velocity.
- \value InOutCubic \inlineimage qeasingcurve-inoutcubic.png
- \br
- Easing equation function for a cubic (t^3) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInCubic \inlineimage qeasingcurve-outincubic.png
- \br
- Easing equation function for a cubic (t^3) easing
- out/in: deceleration until halfway, then acceleration.
- \value InQuart \inlineimage qeasingcurve-inquart.png
- \br
- Easing equation function for a quartic (t^4) easing
- in: accelerating from zero velocity.
- \value OutQuart \inlineimage qeasingcurve-outquart.png
- \br
- Easing equation function for a quartic (t^4) easing
- out: decelerating from zero velocity.
- \value InOutQuart \inlineimage qeasingcurve-inoutquart.png
- \br
- Easing equation function for a quartic (t^4) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInQuart \inlineimage qeasingcurve-outinquart.png
- \br
- Easing equation function for a quartic (t^4) easing
- out/in: deceleration until halfway, then acceleration.
- \value InQuint \inlineimage qeasingcurve-inquint.png
- \br
- Easing equation function for a quintic (t^5) easing
- in: accelerating from zero velocity.
- \value OutQuint \inlineimage qeasingcurve-outquint.png
- \br
- Easing equation function for a quintic (t^5) easing
- out: decelerating from zero velocity.
- \value InOutQuint \inlineimage qeasingcurve-inoutquint.png
- \br
- Easing equation function for a quintic (t^5) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInQuint \inlineimage qeasingcurve-outinquint.png
- \br
- Easing equation function for a quintic (t^5) easing
- out/in: deceleration until halfway, then acceleration.
- \value InSine \inlineimage qeasingcurve-insine.png
- \br
- Easing equation function for a sinusoidal (sin(t)) easing
- in: accelerating from zero velocity.
- \value OutSine \inlineimage qeasingcurve-outsine.png
- \br
- Easing equation function for a sinusoidal (sin(t)) easing
- out: decelerating from zero velocity.
- \value InOutSine \inlineimage qeasingcurve-inoutsine.png
- \br
- Easing equation function for a sinusoidal (sin(t)) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInSine \inlineimage qeasingcurve-outinsine.png
- \br
- Easing equation function for a sinusoidal (sin(t)) easing
- out/in: deceleration until halfway, then acceleration.
- \value InExpo \inlineimage qeasingcurve-inexpo.png
- \br
- Easing equation function for an exponential (2^t) easing
- in: accelerating from zero velocity.
- \value OutExpo \inlineimage qeasingcurve-outexpo.png
- \br
- Easing equation function for an exponential (2^t) easing
- out: decelerating from zero velocity.
- \value InOutExpo \inlineimage qeasingcurve-inoutexpo.png
- \br
- Easing equation function for an exponential (2^t) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInExpo \inlineimage qeasingcurve-outinexpo.png
- \br
- Easing equation function for an exponential (2^t) easing
- out/in: deceleration until halfway, then acceleration.
- \value InCirc \inlineimage qeasingcurve-incirc.png
- \br
- Easing equation function for a circular (sqrt(1-t^2)) easing
- in: accelerating from zero velocity.
- \value OutCirc \inlineimage qeasingcurve-outcirc.png
- \br
- Easing equation function for a circular (sqrt(1-t^2)) easing
- out: decelerating from zero velocity.
- \value InOutCirc \inlineimage qeasingcurve-inoutcirc.png
- \br
- Easing equation function for a circular (sqrt(1-t^2)) easing
- in/out: acceleration until halfway, then deceleration.
- \value OutInCirc \inlineimage qeasingcurve-outincirc.png
- \br
- Easing equation function for a circular (sqrt(1-t^2)) easing
- out/in: deceleration until halfway, then acceleration.
- \value InElastic \inlineimage qeasingcurve-inelastic.png
- \br
- Easing equation function for an elastic
- (exponentially decaying sine wave) easing in:
- accelerating from zero velocity. The peak amplitude
- can be set with the \e amplitude parameter, and the
- period of decay by the \e period parameter.
- \value OutElastic \inlineimage qeasingcurve-outelastic.png
- \br
- Easing equation function for an elastic
- (exponentially decaying sine wave) easing out:
- decelerating from zero velocity. The peak amplitude
- can be set with the \e amplitude parameter, and the
- period of decay by the \e period parameter.
- \value InOutElastic \inlineimage qeasingcurve-inoutelastic.png
- \br
- Easing equation function for an elastic
- (exponentially decaying sine wave) easing in/out:
- acceleration until halfway, then deceleration.
- \value OutInElastic \inlineimage qeasingcurve-outinelastic.png
- \br
- Easing equation function for an elastic
- (exponentially decaying sine wave) easing out/in:
- deceleration until halfway, then acceleration.
- \value InBack \inlineimage qeasingcurve-inback.png
- \br
- Easing equation function for a back (overshooting
- cubic easing: (s+1)*t^3 - s*t^2) easing in:
- accelerating from zero velocity.
- \value OutBack \inlineimage qeasingcurve-outback.png
- \br
- Easing equation function for a back (overshooting
- cubic easing: (s+1)*t^3 - s*t^2) easing out:
- decelerating from zero velocity.
- \value InOutBack \inlineimage qeasingcurve-inoutback.png
- \br
- Easing equation function for a back (overshooting
- cubic easing: (s+1)*t^3 - s*t^2) easing in/out:
- acceleration until halfway, then deceleration.
- \value OutInBack \inlineimage qeasingcurve-outinback.png
- \br
- Easing equation function for a back (overshooting
- cubic easing: (s+1)*t^3 - s*t^2) easing out/in:
- deceleration until halfway, then acceleration.
- \value InBounce \inlineimage qeasingcurve-inbounce.png
- \br
- Easing equation function for a bounce (exponentially
- decaying parabolic bounce) easing in: accelerating
- from zero velocity.
- \value OutBounce \inlineimage qeasingcurve-outbounce.png
- \br
- Easing equation function for a bounce (exponentially
- decaying parabolic bounce) easing out: decelerating
- from zero velocity.
- \value InOutBounce \inlineimage qeasingcurve-inoutbounce.png
- \br
- Easing equation function for a bounce (exponentially
- decaying parabolic bounce) easing in/out:
- acceleration until halfway, then deceleration.
- \value OutInBounce \inlineimage qeasingcurve-outinbounce.png
- \br
- Easing equation function for a bounce (exponentially
- decaying parabolic bounce) easing out/in:
- deceleration until halfway, then acceleration.
- \omitvalue InCurve
- \omitvalue OutCurve
- \omitvalue SineCurve
- \omitvalue CosineCurve
- \value Custom This is returned if the user have specified a custom curve type with setCustomType(). Note that you cannot call setType() with this value, but type() can return it.
- \omitvalue NCurveTypes
-*/
-
-/*!
- \typedef QEasingCurve::EasingFunction
-
- This is a typedef for a pointer to a function with the following
- signature:
-
- \snippet doc/src/snippets/code/src_corelib_tools_qeasingcurve.cpp 0
-*/
-
-#include "qeasingcurve.h"
-
-#ifndef QT_NO_DEBUG_STREAM
-#include <QtCore/qdebug.h>
-#include <QtCore/QString>
-#endif
-
-QT_BEGIN_NAMESPACE
-
-static bool isConfigFunction(QEasingCurve::Type type)
-{
- return type >= QEasingCurve::InElastic
- && type <= QEasingCurve::OutInBounce;
-}
-
-class QEasingCurveFunction
-{
-public:
- enum Type { In, Out, InOut, OutIn };
-
- QEasingCurveFunction(QEasingCurveFunction::Type type = In, qreal period = 0.3, qreal amplitude = 1.0,
- qreal overshoot = 1.70158f)
- : _t(type), _p(period), _a(amplitude), _o(overshoot)
- { }
- virtual ~QEasingCurveFunction() {}
- virtual qreal value(qreal t);
- virtual QEasingCurveFunction *copy() const;
- bool operator==(const QEasingCurveFunction& other);
-
- Type _t;
- qreal _p;
- qreal _a;
- qreal _o;
-};
-
-qreal QEasingCurveFunction::value(qreal t)
-{
- return t;
-}
-
-QEasingCurveFunction *QEasingCurveFunction::copy() const
-{
- return new QEasingCurveFunction(_t, _p, _a, _o);
-}
-
-bool QEasingCurveFunction::operator==(const QEasingCurveFunction& other)
-{
- return _t == other._t &&
- _p == other._p &&
- _a == other._a &&
- _o == other._o;
-}
-
-QT_BEGIN_INCLUDE_NAMESPACE
-#include "../../3rdparty/easing/easing.cpp"
-QT_END_INCLUDE_NAMESPACE
-
-class QEasingCurvePrivate
-{
-public:
- QEasingCurvePrivate()
- : type(QEasingCurve::Linear),
- config(0),
- func(&easeNone)
- { }
- ~QEasingCurvePrivate() { delete config; }
- void setType_helper(QEasingCurve::Type);
-
- QEasingCurve::Type type;
- QEasingCurveFunction *config;
- QEasingCurve::EasingFunction func;
-};
-
-struct ElasticEase : public QEasingCurveFunction
-{
- ElasticEase(Type type)
- : QEasingCurveFunction(type, qreal(0.3), qreal(1.0))
- { }
-
- QEasingCurveFunction *copy() const
- {
- ElasticEase *rv = new ElasticEase(_t);
- rv->_p = _p;
- rv->_a = _a;
- return rv;
- }
-
- qreal value(qreal t)
- {
- qreal p = (_p < 0) ? 0.3f : _p;
- qreal a = (_a < 0) ? 1.0f : _a;
- switch(_t) {
- case In:
- return easeInElastic(t, a, p);
- case Out:
- return easeOutElastic(t, a, p);
- case InOut:
- return easeInOutElastic(t, a, p);
- case OutIn:
- return easeOutInElastic(t, a, p);
- default:
- return t;
- }
- }
-};
-
-struct BounceEase : public QEasingCurveFunction
-{
- BounceEase(Type type)
- : QEasingCurveFunction(type, 0.3f, 1.0f)
- { }
-
- QEasingCurveFunction *copy() const
- {
- BounceEase *rv = new BounceEase(_t);
- rv->_a = _a;
- return rv;
- }
-
- qreal value(qreal t)
- {
- qreal a = (_a < 0) ? 1.0f : _a;
- switch(_t) {
- case In:
- return easeInBounce(t, a);
- case Out:
- return easeOutBounce(t, a);
- case InOut:
- return easeInOutBounce(t, a);
- case OutIn:
- return easeOutInBounce(t, a);
- default:
- return t;
- }
- }
-};
-
-struct BackEase : public QEasingCurveFunction
-{
- BackEase(Type type)
- : QEasingCurveFunction(type, 0.3f, 1.0f, 1.70158f)
- { }
-
- QEasingCurveFunction *copy() const
- {
- BackEase *rv = new BackEase(_t);
- rv->_o = _o;
- return rv;
- }
-
- qreal value(qreal t)
- {
- qreal o = (_o < 0) ? 1.70158f : _o;
- switch(_t) {
- case In:
- return easeInBack(t, o);
- case Out:
- return easeOutBack(t, o);
- case InOut:
- return easeInOutBack(t, o);
- case OutIn:
- return easeOutInBack(t, o);
- default:
- return t;
- }
- }
-};
-
-static QEasingCurve::EasingFunction curveToFunc(QEasingCurve::Type curve)
-{
- switch(curve) {
- case QEasingCurve::Linear:
- return &easeNone;
- case QEasingCurve::InQuad:
- return &easeInQuad;
- case QEasingCurve::OutQuad:
- return &easeOutQuad;
- case QEasingCurve::InOutQuad:
- return &easeInOutQuad;
- case QEasingCurve::OutInQuad:
- return &easeOutInQuad;
- case QEasingCurve::InCubic:
- return &easeInCubic;
- case QEasingCurve::OutCubic:
- return &easeOutCubic;
- case QEasingCurve::InOutCubic:
- return &easeInOutCubic;
- case QEasingCurve::OutInCubic:
- return &easeOutInCubic;
- case QEasingCurve::InQuart:
- return &easeInQuart;
- case QEasingCurve::OutQuart:
- return &easeOutQuart;
- case QEasingCurve::InOutQuart:
- return &easeInOutQuart;
- case QEasingCurve::OutInQuart:
- return &easeOutInQuart;
- case QEasingCurve::InQuint:
- return &easeInQuint;
- case QEasingCurve::OutQuint:
- return &easeOutQuint;
- case QEasingCurve::InOutQuint:
- return &easeInOutQuint;
- case QEasingCurve::OutInQuint:
- return &easeOutInQuint;
- case QEasingCurve::InSine:
- return &easeInSine;
- case QEasingCurve::OutSine:
- return &easeOutSine;
- case QEasingCurve::InOutSine:
- return &easeInOutSine;
- case QEasingCurve::OutInSine:
- return &easeOutInSine;
- case QEasingCurve::InExpo:
- return &easeInExpo;
- case QEasingCurve::OutExpo:
- return &easeOutExpo;
- case QEasingCurve::InOutExpo:
- return &easeInOutExpo;
- case QEasingCurve::OutInExpo:
- return &easeOutInExpo;
- case QEasingCurve::InCirc:
- return &easeInCirc;
- case QEasingCurve::OutCirc:
- return &easeOutCirc;
- case QEasingCurve::InOutCirc:
- return &easeInOutCirc;
- case QEasingCurve::OutInCirc:
- return &easeOutInCirc;
- // Internal for, compatibility with QTimeLine only ??
- case QEasingCurve::InCurve:
- return &easeInCurve;
- case QEasingCurve::OutCurve:
- return &easeOutCurve;
- case QEasingCurve::SineCurve:
- return &easeSineCurve;
- case QEasingCurve::CosineCurve:
- return &easeCosineCurve;
- default:
- return 0;
- };
-}
-
-static QEasingCurveFunction *curveToFunctionObject(QEasingCurve::Type type)
-{
- QEasingCurveFunction *curveFunc = 0;
- switch(type) {
- case QEasingCurve::InElastic:
- curveFunc = new ElasticEase(ElasticEase::In);
- break;
- case QEasingCurve::OutElastic:
- curveFunc = new ElasticEase(ElasticEase::Out);
- break;
- case QEasingCurve::InOutElastic:
- curveFunc = new ElasticEase(ElasticEase::InOut);
- break;
- case QEasingCurve::OutInElastic:
- curveFunc = new ElasticEase(ElasticEase::OutIn);
- break;
- case QEasingCurve::OutBounce:
- curveFunc = new BounceEase(BounceEase::Out);
- break;
- case QEasingCurve::InBounce:
- curveFunc = new BounceEase(BounceEase::In);
- break;
- case QEasingCurve::OutInBounce:
- curveFunc = new BounceEase(BounceEase::OutIn);
- break;
- case QEasingCurve::InOutBounce:
- curveFunc = new BounceEase(BounceEase::InOut);
- break;
- case QEasingCurve::InBack:
- curveFunc = new BackEase(BackEase::In);
- break;
- case QEasingCurve::OutBack:
- curveFunc = new BackEase(BackEase::Out);
- break;
- case QEasingCurve::InOutBack:
- curveFunc = new BackEase(BackEase::InOut);
- break;
- case QEasingCurve::OutInBack:
- curveFunc = new BackEase(BackEase::OutIn);
- break;
- default:
- curveFunc = new QEasingCurveFunction(QEasingCurveFunction::In, 0.3f, 1.0f, 1.70158f); // ###
- }
-
- return curveFunc;
-}
-
-/*!
- Constructs an easing curve of the given \a type.
- */
-QEasingCurve::QEasingCurve(Type type)
- : d_ptr(new QEasingCurvePrivate)
-{
- setType(type);
-}
-
-/*!
- Construct a copy of \a other.
- */
-QEasingCurve::QEasingCurve(const QEasingCurve &other)
-: d_ptr(new QEasingCurvePrivate)
-{
- // ### non-atomic, requires malloc on shallow copy
- *d_ptr = *other.d_ptr;
- if(other.d_ptr->config)
- d_ptr->config = other.d_ptr->config->copy();
-}
-
-/*!
- Destructor.
- */
-
-QEasingCurve::~QEasingCurve()
-{
- delete d_ptr;
-}
-
-/*!
- Copy \a other.
- */
-QEasingCurve &QEasingCurve::operator=(const QEasingCurve &other)
-{
- // ### non-atomic, requires malloc on shallow copy
- if (d_ptr->config) {
- delete d_ptr->config;
- d_ptr->config = 0;
- }
-
- *d_ptr = *other.d_ptr;
- if(other.d_ptr->config)
- d_ptr->config = other.d_ptr->config->copy();
-
- return *this;
-}
-
-/*!
- Compare this easing curve with \a other and returns true if they are
- equal. It will also compare the properties of a curve.
- */
-bool QEasingCurve::operator==(const QEasingCurve &other) const
-{
- bool res = d_ptr->func == other.d_ptr->func
- && d_ptr->type == other.d_ptr->type;
- if (res && d_ptr->config && other.d_ptr->config) {
- // catch the config content
- res = d_ptr->config->operator==(*(other.d_ptr->config));
- }
- return res;
-}
-
-/*!
- \fn bool QEasingCurve::operator!=(const QEasingCurve &other) const
- Compare this easing curve with \a other and returns true if they are not equal.
- It will also compare the properties of a curve.
-
- \sa operator==()
-*/
-
-/*!
- Returns the amplitude. This is not applicable for all curve types.
- It is only applicable for bounce and elastic curves (curves of type()
- QEasingCurve::InBounce, QEasingCurve::OutBounce, QEasingCurve::InOutBounce,
- QEasingCurve::OutInBounce, QEasingCurve::InElastic, QEasingCurve::OutElastic,
- QEasingCurve::InOutElastic or QEasingCurve::OutInElastic).
- */
-qreal QEasingCurve::amplitude() const
-{
- return d_ptr->config ? d_ptr->config->_a : 1.0;
-}
-
-/*!
- Sets the amplitude to \a amplitude.
-
- This will set the amplitude of the bounce or the amplitude of the
- elastic "spring" effect. The higher the number, the higher the amplitude.
- \sa amplitude()
-*/
-void QEasingCurve::setAmplitude(qreal amplitude)
-{
- if (!d_ptr->config)
- d_ptr->config = curveToFunctionObject(d_ptr->type);
- d_ptr->config->_a = amplitude;
-}
-
-/*!
- Returns the period. This is not applicable for all curve types.
- It is only applicable if type() is QEasingCurve::InElastic, QEasingCurve::OutElastic,
- QEasingCurve::InOutElastic or QEasingCurve::OutInElastic.
- */
-qreal QEasingCurve::period() const
-{
- return d_ptr->config ? d_ptr->config->_p : 0.3;
-}
-
-/*!
- Sets the period to \a period.
- Setting a small period value will give a high frequency of the curve. A
- large period will give it a small frequency.
-
- \sa period()
-*/
-void QEasingCurve::setPeriod(qreal period)
-{
- if (!d_ptr->config)
- d_ptr->config = curveToFunctionObject(d_ptr->type);
- d_ptr->config->_p = period;
-}
-
-/*!
- Returns the overshoot. This is not applicable for all curve types.
- It is only applicable if type() is QEasingCurve::InBack, QEasingCurve::OutBack,
- QEasingCurve::InOutBack or QEasingCurve::OutInBack.
- */
-qreal QEasingCurve::overshoot() const
-{
- return d_ptr->config ? d_ptr->config->_o : 1.70158f;
-}
-
-/*!
- Sets the overshoot to \a overshoot.
-
- 0 produces no overshoot, and the default value of 1.70158 produces an overshoot of 10 percent.
-
- \sa overshoot()
-*/
-void QEasingCurve::setOvershoot(qreal overshoot)
-{
- if (!d_ptr->config)
- d_ptr->config = curveToFunctionObject(d_ptr->type);
- d_ptr->config->_o = overshoot;
-}
-
-/*!
- Returns the type of the easing curve.
-*/
-QEasingCurve::Type QEasingCurve::type() const
-{
- return d_ptr->type;
-}
-
-void QEasingCurvePrivate::setType_helper(QEasingCurve::Type newType)
-{
- qreal amp = -1.0;
- qreal period = -1.0;
- qreal overshoot = -1.0;
-
- if (config) {
- amp = config->_a;
- period = config->_p;
- overshoot = config->_o;
- delete config;
- config = 0;
- }
-
- if (isConfigFunction(newType) || (amp != -1.0) || (period != -1.0) || (overshoot != -1.0)) {
- config = curveToFunctionObject(newType);
- if (amp != -1.0)
- config->_a = amp;
- if (period != -1.0)
- config->_p = period;
- if (overshoot != -1.0)
- config->_o = overshoot;
- func = 0;
- } else if (newType != QEasingCurve::Custom) {
- func = curveToFunc(newType);
- }
- Q_ASSERT((func == 0) == (config != 0));
- type = newType;
-}
-
-/*!
- Sets the type of the easing curve to \a type.
-*/
-void QEasingCurve::setType(Type type)
-{
- if (d_ptr->type == type)
- return;
- if (type < Linear || type >= NCurveTypes - 1) {
- qWarning("QEasingCurve: Invalid curve type %d", type);
- return;
- }
-
- d_ptr->setType_helper(type);
-}
-
-/*!
- Sets a custom easing curve that is defined by the user in the function \a func.
- The signature of the function is qreal myEasingFunction(qreal progress),
- where \e progress and the return value is considered to be normalized between 0 and 1.
- (In some cases the return value can be outside that range)
- After calling this function type() will return QEasingCurve::Custom.
- \a func cannot be zero.
-
- \sa customType()
- \sa valueForProgress()
-*/
-void QEasingCurve::setCustomType(EasingFunction func)
-{
- if (!func) {
- qWarning("Function pointer must not be null");
- return;
- }
- d_ptr->func = func;
- d_ptr->setType_helper(Custom);
-}
-
-/*!
- Returns the function pointer to the custom easing curve.
- If type() does not return QEasingCurve::Custom, this function
- will return 0.
-*/
-QEasingCurve::EasingFunction QEasingCurve::customType() const
-{
- return d_ptr->type == Custom ? d_ptr->func : 0;
-}
-
-/*!
- Return the effective progress for the easing curve at \a progress.
- While \a progress must be between 0 and 1, the returned effective progress
- can be outside those bounds. For instance, QEasingCurve::InBack will
- return negative values in the beginning of the function.
- */
-qreal QEasingCurve::valueForProgress(qreal progress) const
-{
- progress = qBound<qreal>(0, progress, 1);
- if (d_ptr->func)
- return d_ptr->func(progress);
- else if (d_ptr->config)
- return d_ptr->config->value(progress);
- else
- return progress;
-}
-
-#ifndef QT_NO_DEBUG_STREAM
-QDebug operator<<(QDebug debug, const QEasingCurve &item)
-{
- debug << "type:" << item.d_ptr->type
- << "func:" << item.d_ptr->func;
- if (item.d_ptr->config) {
- debug << QString::fromAscii("period:%1").arg(item.d_ptr->config->_p, 0, 'f', 20)
- << QString::fromAscii("amp:%1").arg(item.d_ptr->config->_a, 0, 'f', 20)
- << QString::fromAscii("overshoot:%1").arg(item.d_ptr->config->_o, 0, 'f', 20);
- }
- return debug;
-}
-#endif
-
-QT_END_NAMESPACE
diff --git a/src/corelib/tools/qeasingcurve.h b/src/corelib/tools/qeasingcurve.h
deleted file mode 100644
index a240bc0..0000000
--- a/src/corelib/tools/qeasingcurve.h
+++ /dev/null
@@ -1,114 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtCore module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QEASINGCURVE_H
-#define QEASINGCURVE_H
-
-#include <QtCore/qglobal.h>
-#include <QtCore/qobjectdefs.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QEasingCurvePrivate;
-class Q_CORE_EXPORT QEasingCurve
-{
- Q_GADGET
- Q_ENUMS(Type)
-public:
- enum Type {
- Linear,
- InQuad, OutQuad, InOutQuad, OutInQuad,
- InCubic, OutCubic, InOutCubic, OutInCubic,
- InQuart, OutQuart, InOutQuart, OutInQuart,
- InQuint, OutQuint, InOutQuint, OutInQuint,
- InSine, OutSine, InOutSine, OutInSine,
- InExpo, OutExpo, InOutExpo, OutInExpo,
- InCirc, OutCirc, InOutCirc, OutInCirc,
- InElastic, OutElastic, InOutElastic, OutInElastic,
- InBack, OutBack, InOutBack, OutInBack,
- InBounce, OutBounce, InOutBounce, OutInBounce,
- InCurve, OutCurve, SineCurve, CosineCurve,
- Custom, NCurveTypes
- };
-
- QEasingCurve(Type type = Linear);
- QEasingCurve(const QEasingCurve &other);
- ~QEasingCurve();
-
- QEasingCurve &operator=(const QEasingCurve &other);
- bool operator==(const QEasingCurve &other) const;
- inline bool operator!=(const QEasingCurve &other) const
- { return !(this->operator==(other)); }
-
- qreal amplitude() const;
- void setAmplitude(qreal amplitude);
-
- qreal period() const;
- void setPeriod(qreal period);
-
- qreal overshoot() const;
- void setOvershoot(qreal overshoot);
-
- Type type() const;
- void setType(Type type);
- typedef qreal (*EasingFunction)(qreal progress);
- void setCustomType(EasingFunction func);
- EasingFunction customType() const;
-
- qreal valueForProgress(qreal progress) const;
-private:
- QEasingCurvePrivate *d_ptr;
- friend Q_CORE_EXPORT QDebug operator<<(QDebug debug, const QEasingCurve &item);
-};
-
-#ifndef QT_NO_DEBUG_STREAM
-Q_CORE_EXPORT QDebug operator<<(QDebug debug, const QEasingCurve &item);
-#endif
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/corelib/tools/qtimeline.cpp b/src/corelib/tools/qtimeline.cpp
index ee4f73c..3a03558 100644
--- a/src/corelib/tools/qtimeline.cpp
+++ b/src/corelib/tools/qtimeline.cpp
@@ -48,6 +48,20 @@
QT_BEGIN_NAMESPACE
+static const qreal pi = qreal(3.14159265359);
+static const qreal halfPi = pi / qreal(2.0);
+
+
+static inline qreal qt_sinProgress(qreal value)
+{
+ return qSin((value * pi) - halfPi) / 2 + qreal(0.5);
+}
+
+static inline qreal qt_smoothBeginEndMixFactor(qreal value)
+{
+ return qMin(qMax(1 - value * 2 + qreal(0.3), qreal(0.0)), qreal(1.0));
+}
+
class QTimeLinePrivate : public QObjectPrivate
{
Q_DECLARE_PUBLIC(QTimeLine)
@@ -56,7 +70,7 @@ public:
: startTime(0), duration(1000), startFrame(0), endFrame(0),
updateInterval(1000 / 25),
totalLoopCount(1), currentLoopCount(0), currentTime(0), timerId(0),
- direction(QTimeLine::Forward), easingCurve(QEasingCurve::InOutSine),
+ direction(QTimeLine::Forward), curveShape(QTimeLine::EaseInOutCurve),
state(QTimeLine::NotRunning)
{ }
@@ -74,7 +88,7 @@ public:
QTime timer;
QTimeLine::Direction direction;
- QEasingCurve easingCurve;
+ QTimeLine::CurveShape curveShape;
QTimeLine::State state;
inline void setState(QTimeLine::State newState)
{
@@ -509,68 +523,12 @@ void QTimeLine::setUpdateInterval(int interval)
QTimeLine::CurveShape QTimeLine::curveShape() const
{
Q_D(const QTimeLine);
- switch (d->easingCurve.type()) {
- default:
- case QEasingCurve::InOutSine:
- return EaseInOutCurve;
- case QEasingCurve::InCurve:
- return EaseInCurve;
- case QEasingCurve::OutCurve:
- return EaseOutCurve;
- case QEasingCurve::Linear:
- return LinearCurve;
- case QEasingCurve::SineCurve:
- return SineCurve;
- case QEasingCurve::CosineCurve:
- return CosineCurve;
- }
- return EaseInOutCurve;
+ return d->curveShape;
}
-
void QTimeLine::setCurveShape(CurveShape shape)
{
- switch (shape) {
- default:
- case EaseInOutCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::InOutSine));
- break;
- case EaseInCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::InCurve));
- break;
- case EaseOutCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::OutCurve));
- break;
- case LinearCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::Linear));
- break;
- case SineCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::SineCurve));
- break;
- case CosineCurve:
- setEasingCurve(QEasingCurve(QEasingCurve::CosineCurve));
- break;
- }
-}
-
-/*!
- \property QTimeLine::easingCurve
-
- Specifies the easing curve that the timeline will use.
- If both easing curve and curveShape are set, the last set property will
- override the previous one. (If valueForTime() is reimplemented it will
- override both)
-*/
-
-QEasingCurve QTimeLine::easingCurve() const
-{
- Q_D(const QTimeLine);
- return d->easingCurve;
-}
-
-void QTimeLine::setEasingCurve(const QEasingCurve& curve)
-{
Q_D(QTimeLine);
- d->easingCurve = curve;
+ d->curveShape = shape;
}
/*!
@@ -650,8 +608,42 @@ qreal QTimeLine::valueForTime(int msec) const
Q_D(const QTimeLine);
msec = qMin(qMax(msec, 0), d->duration);
+ // Simple linear interpolation
qreal value = msec / qreal(d->duration);
- return d->easingCurve.valueForProgress(value);
+
+ switch (d->curveShape) {
+ case EaseInOutCurve:
+ value = qt_sinProgress(value);
+ break;
+ // SmoothBegin blends Smooth and Linear Interpolation.
+ // Progress 0 - 0.3 : Smooth only
+ // Progress 0.3 - ~ 0.5 : Mix of Smooth and Linear
+ // Progress ~ 0.5 - 1 : Linear only
+ case EaseInCurve: {
+ const qreal sinProgress = qt_sinProgress(value);
+ const qreal linearProgress = value;
+ const qreal mix = qt_smoothBeginEndMixFactor(value);
+ value = sinProgress * mix + linearProgress * (1 - mix);
+ break;
+ }
+ case EaseOutCurve: {
+ const qreal sinProgress = qt_sinProgress(value);
+ const qreal linearProgress = value;
+ const qreal mix = qt_smoothBeginEndMixFactor(1 - value);
+ value = sinProgress * mix + linearProgress * (1 - mix);
+ break;
+ }
+ case SineCurve:
+ value = (qSin(((msec * pi * 2) / d->duration) - pi/2) + 1) / 2;
+ break;
+ case CosineCurve:
+ value = (qCos(((msec * pi * 2) / d->duration) - pi/2) + 1) / 2;
+ break;
+ default:
+ break;
+ }
+
+ return value;
}
/*!
diff --git a/src/corelib/tools/qtimeline.h b/src/corelib/tools/qtimeline.h
index 48c9232..18c3980 100644
--- a/src/corelib/tools/qtimeline.h
+++ b/src/corelib/tools/qtimeline.h
@@ -42,7 +42,6 @@
#ifndef QTIMELINE_H
#define QTIMELINE_H
-#include <QtCore/qeasingcurve.h>
#include <QtCore/qobject.h>
QT_BEGIN_HEADER
@@ -61,7 +60,6 @@ class Q_CORE_EXPORT QTimeLine : public QObject
Q_PROPERTY(Direction direction READ direction WRITE setDirection)
Q_PROPERTY(int loopCount READ loopCount WRITE setLoopCount)
Q_PROPERTY(CurveShape curveShape READ curveShape WRITE setCurveShape)
- Q_PROPERTY(QEasingCurve easingCurve READ easingCurve WRITE setEasingCurve)
public:
enum State {
NotRunning,
@@ -107,9 +105,6 @@ public:
CurveShape curveShape() const;
void setCurveShape(CurveShape shape);
- QEasingCurve easingCurve() const;
- void setEasingCurve(const QEasingCurve &curve);
-
int currentTime() const;
int currentFrame() const;
qreal currentValue() const;
diff --git a/src/corelib/tools/tools.pri b/src/corelib/tools/tools.pri
index 90287cb..a6fdac7 100644
--- a/src/corelib/tools/tools.pri
+++ b/src/corelib/tools/tools.pri
@@ -11,7 +11,6 @@ HEADERS += \
tools/qcryptographichash.h \
tools/qdatetime.h \
tools/qdatetime_p.h \
- tools/qeasingcurve.h \
tools/qhash.h \
tools/qline.h \
tools/qlinkedlist.h \
@@ -47,7 +46,6 @@ SOURCES += \
tools/qbytearraymatcher.cpp \
tools/qcryptographichash.cpp \
tools/qdatetime.cpp \
- tools/qeasingcurve.cpp \
tools/qhash.cpp \
tools/qline.cpp \
tools/qlinkedlist.cpp \
diff --git a/src/gui/animation/animation.pri b/src/gui/animation/animation.pri
deleted file mode 100644
index 27763ca..0000000
--- a/src/gui/animation/animation.pri
+++ /dev/null
@@ -1,3 +0,0 @@
-# Qt gui animation module
-
-SOURCES += animation/qguivariantanimation.cpp
diff --git a/src/gui/animation/qguivariantanimation.cpp b/src/gui/animation/qguivariantanimation.cpp
deleted file mode 100644
index 37ca6a1..0000000
--- a/src/gui/animation/qguivariantanimation.cpp
+++ /dev/null
@@ -1,75 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QT_NO_ANIMATION
-
-#include <QtCore/qvariantanimation.h>
-#include <private/qvariantanimation_p.h>
-
-#include <QtGui/qcolor.h>
-
-QT_BEGIN_NAMESPACE
-
-template<> Q_INLINE_TEMPLATE QColor _q_interpolate(const QColor &f,const QColor &t, qreal progress)
-{
- return QColor(_q_interpolate(f.red(), t.red(), progress),
- _q_interpolate(f.green(), t.green(), progress),
- _q_interpolate(f.blue(), t.blue(), progress),
- _q_interpolate(f.alpha(), t.alpha(), progress));
-}
-
-static int qRegisterGuiGetInterpolator()
-{
- qRegisterAnimationInterpolator<QColor>(_q_interpolateVariant<QColor>);
- return 1;
-}
-Q_CONSTRUCTOR_FUNCTION(qRegisterGuiGetInterpolator)
-
-static int qUnregisterGuiGetInterpolator()
-{
- qRegisterAnimationInterpolator<QColor>(0);
- return 1;
-}
-Q_DESTRUCTOR_FUNCTION(qUnregisterGuiGetInterpolator)
-
-QT_END_NAMESPACE
-
-#endif //QT_NO_ANIMATION
diff --git a/src/gui/graphicsview/qgraphicsitem_p.h b/src/gui/graphicsview/qgraphicsitem_p.h
index 62e0411..b2569c1 100644
--- a/src/gui/graphicsview/qgraphicsitem_p.h
+++ b/src/gui/graphicsview/qgraphicsitem_p.h
@@ -95,15 +95,6 @@ class Q_AUTOTEST_EXPORT QGraphicsItemPrivate
{
Q_DECLARE_PUBLIC(QGraphicsItem)
public:
- struct TransformData
- {
- TransformData() : rotationX(0),rotationY(0),rotationZ(0),scaleX(1),scaleY(1), dirty(true) {}
- QTransform baseTransform;
- QTransform transform;
- QPointF transformCenter;
- qreal rotationX,rotationY,rotationZ,scaleX,scaleY;
- bool dirty;
- };
enum Extra {
ExtraTransform,
ExtraToolTip,
@@ -248,7 +239,7 @@ public:
}
}
}
-
+
struct ExtraStruct {
ExtraStruct(Extra type, QVariant value)
: type(type), value(value)
@@ -260,7 +251,6 @@ public:
bool operator<(Extra extra) const
{ return type < extra; }
};
-
QList<ExtraStruct> extras;
QGraphicsItemCache *maybeExtraItemCache() const;
diff --git a/src/gui/graphicsview/qgraphicsproxywidget.cpp b/src/gui/graphicsview/qgraphicsproxywidget.cpp
index a5b11ff..01b7593 100644
--- a/src/gui/graphicsview/qgraphicsproxywidget.cpp
+++ b/src/gui/graphicsview/qgraphicsproxywidget.cpp
@@ -976,7 +976,6 @@ void QGraphicsProxyWidget::contextMenuEvent(QGraphicsSceneContextMenuEvent *even
}
#endif // QT_NO_CONTEXTMENU
-#ifndef QT_NO_DRAGANDDROP
/*!
\reimp
*/
@@ -1097,7 +1096,6 @@ void QGraphicsProxyWidget::dropEvent(QGraphicsSceneDragDropEvent *event)
}
#endif
}
-#endif
/*!
\reimp
diff --git a/src/gui/graphicsview/qgraphicsproxywidget.h b/src/gui/graphicsview/qgraphicsproxywidget.h
index ab8c9da..b2c3c8f 100644
--- a/src/gui/graphicsview/qgraphicsproxywidget.h
+++ b/src/gui/graphicsview/qgraphicsproxywidget.h
@@ -90,12 +90,10 @@ protected:
void contextMenuEvent(QGraphicsSceneContextMenuEvent *event);
#endif
-#ifndef QT_NO_DRAGANDDROP
void dragEnterEvent(QGraphicsSceneDragDropEvent *event);
void dragLeaveEvent(QGraphicsSceneDragDropEvent *event);
void dragMoveEvent(QGraphicsSceneDragDropEvent *event);
void dropEvent(QGraphicsSceneDragDropEvent *event);
-#endif
void hoverEnterEvent(QGraphicsSceneHoverEvent *event);
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event);
diff --git a/src/gui/gui.pro b/src/gui/gui.pro
index 329fb01..1aa6558 100644
--- a/src/gui/gui.pro
+++ b/src/gui/gui.pro
@@ -19,7 +19,6 @@ win32:include(kernel/win.pri)
embedded:include(embedded/embedded.pri)
#modules
-include(animation/animation.pri)
include(kernel/kernel.pri)
include(image/image.pri)
include(painting/painting.pri)
@@ -32,7 +31,6 @@ include(itemviews/itemviews.pri)
include(inputmethod/inputmethod.pri)
include(graphicsview/graphicsview.pri)
include(util/util.pri)
-include(statemachine/statemachine.pri)
include(math3d/math3d.pri)
embedded: QT += network
diff --git a/src/gui/kernel/qapplication.cpp b/src/gui/kernel/qapplication.cpp
index a9424db..824d6f1 100644
--- a/src/gui/kernel/qapplication.cpp
+++ b/src/gui/kernel/qapplication.cpp
@@ -838,9 +838,6 @@ void QApplicationPrivate::initialize()
// trigger registering of QVariant's GUI types
extern int qRegisterGuiVariant();
qRegisterGuiVariant();
- // trigger registering of QStateMachine's GUI types
- extern int qRegisterGuiStateMachine();
- qRegisterGuiStateMachine();
is_app_running = true; // no longer starting up
@@ -1062,9 +1059,6 @@ QApplication::~QApplication()
QApplicationPrivate::fade_tooltip = false;
QApplicationPrivate::widgetCount = false;
- // trigger unregistering of QStateMachine's GUI types
- extern int qUnregisterGuiStateMachine();
- qUnregisterGuiStateMachine();
// trigger unregistering of QVariant's GUI types
extern int qUnregisterGuiVariant();
qUnregisterGuiVariant();
diff --git a/src/gui/painting/qdrawhelper.cpp b/src/gui/painting/qdrawhelper.cpp
index bbe1a76..fdd0c21 100644
--- a/src/gui/painting/qdrawhelper.cpp
+++ b/src/gui/painting/qdrawhelper.cpp
@@ -6930,7 +6930,7 @@ static void qt_alphamapblit_quint16(QRasterBuffer *rasterBuffer,
}
void qt_build_pow_tables() {
- qreal smoothing = qreal(1.7);
+ qreal smoothing = 1.7;
#ifdef Q_WS_MAC
// decided by testing a few things on an iMac, should probably get this from the
@@ -6952,15 +6952,15 @@ void qt_build_pow_tables() {
}
#else
for (int i=0; i<256; ++i) {
- qt_pow_rgb_gamma[i] = uchar(qRound(pow(i / qreal(255.0), smoothing) * 255));
- qt_pow_rgb_invgamma[i] = uchar(qRound(pow(i / qreal(255.), 1 / smoothing) * 255));
+ qt_pow_rgb_gamma[i] = uchar(qRound(pow(i / 255.0, smoothing) * 255));
+ qt_pow_rgb_invgamma[i] = uchar(qRound(pow(i / 255.0, 1 / smoothing) * 255));
}
#endif
#if defined(Q_OS_WIN) && !defined(Q_OS_WINCE)
const qreal gray_gamma = 2.31;
for (int i=0; i<256; ++i)
- qt_pow_gamma[i] = uint(qRound(pow(i / qreal(255.), gray_gamma) * 2047));
+ qt_pow_gamma[i] = uint(qRound(pow(i / 255.0, gray_gamma) * 2047));
for (int i=0; i<2048; ++i)
qt_pow_invgamma[i] = uchar(qRound(pow(i / 2047.0, 1 / gray_gamma) * 255));
#endif
diff --git a/src/gui/statemachine/qbasickeyeventtransition.cpp b/src/gui/statemachine/qbasickeyeventtransition.cpp
deleted file mode 100644
index f7f1eb6..0000000
--- a/src/gui/statemachine/qbasickeyeventtransition.cpp
+++ /dev/null
@@ -1,203 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qbasickeyeventtransition_p.h"
-#include <QtGui/qevent.h>
-#include <qdebug.h>
-#include <private/qabstracttransition_p.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \internal
- \class QBasicKeyEventTransition
- \since 4.6
- \ingroup statemachine
-
- \brief The QBasicKeyEventTransition class provides a transition for Qt key events.
-*/
-
-class QBasicKeyEventTransitionPrivate : public QAbstractTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QBasicKeyEventTransition)
-public:
- QBasicKeyEventTransitionPrivate();
-
- static QBasicKeyEventTransitionPrivate *get(QBasicKeyEventTransition *q);
-
- QEvent::Type eventType;
- int key;
- Qt::KeyboardModifiers modifiersMask;
-};
-
-QBasicKeyEventTransitionPrivate::QBasicKeyEventTransitionPrivate()
-{
- eventType = QEvent::None;
- key = 0;
- modifiersMask = Qt::NoModifier;
-}
-
-QBasicKeyEventTransitionPrivate *QBasicKeyEventTransitionPrivate::get(QBasicKeyEventTransition *q)
-{
- return q->d_func();
-}
-
-/*!
- Constructs a new key event transition with the given \a sourceState.
-*/
-QBasicKeyEventTransition::QBasicKeyEventTransition(QState *sourceState)
- : QAbstractTransition(*new QBasicKeyEventTransitionPrivate, sourceState)
-{
-}
-
-/*!
- Constructs a new event transition for events of the given \a type for the
- given \a key, with the given \a sourceState.
-*/
-QBasicKeyEventTransition::QBasicKeyEventTransition(QEvent::Type type, int key,
- QState *sourceState)
- : QAbstractTransition(*new QBasicKeyEventTransitionPrivate, sourceState)
-{
- Q_D(QBasicKeyEventTransition);
- d->eventType = type;
- d->key = key;
-}
-
-/*!
- Constructs a new event transition for events of the given \a type for the
- given \a key, with the given \a modifiersMask and \a sourceState.
-*/
-QBasicKeyEventTransition::QBasicKeyEventTransition(QEvent::Type type, int key,
- Qt::KeyboardModifiers modifiersMask,
- QState *sourceState)
- : QAbstractTransition(*new QBasicKeyEventTransitionPrivate, sourceState)
-{
- Q_D(QBasicKeyEventTransition);
- d->eventType = type;
- d->key = key;
- d->modifiersMask = modifiersMask;
-}
-
-/*!
- Destroys this event transition.
-*/
-QBasicKeyEventTransition::~QBasicKeyEventTransition()
-{
-}
-
-/*!
- Returns the event type that this key event transition is associated with.
-*/
-QEvent::Type QBasicKeyEventTransition::eventType() const
-{
- Q_D(const QBasicKeyEventTransition);
- return d->eventType;
-}
-
-/*!
- Sets the event \a type that this key event transition is associated with.
-*/
-void QBasicKeyEventTransition::setEventType(QEvent::Type type)
-{
- Q_D(QBasicKeyEventTransition);
- d->eventType = type;
-}
-
-/*!
- Returns the key that this key event transition checks for.
-*/
-int QBasicKeyEventTransition::key() const
-{
- Q_D(const QBasicKeyEventTransition);
- return d->key;
-}
-
-/*!
- Sets the key that this key event transition will check for.
-*/
-void QBasicKeyEventTransition::setKey(int key)
-{
- Q_D(QBasicKeyEventTransition);
- d->key = key;
-}
-
-/*!
- Returns the keyboard modifiers mask that this key event transition checks
- for.
-*/
-Qt::KeyboardModifiers QBasicKeyEventTransition::modifiersMask() const
-{
- Q_D(const QBasicKeyEventTransition);
- return d->modifiersMask;
-}
-
-/*!
- Sets the keyboard modifiers mask that this key event transition will check
- for.
-*/
-void QBasicKeyEventTransition::setModifiersMask(Qt::KeyboardModifiers modifiersMask)
-{
- Q_D(QBasicKeyEventTransition);
- d->modifiersMask = modifiersMask;
-}
-
-/*!
- \reimp
-*/
-bool QBasicKeyEventTransition::eventTest(QEvent *event)
-{
- Q_D(const QBasicKeyEventTransition);
- if (event->type() == d->eventType) {
- QKeyEvent *ke = static_cast<QKeyEvent*>(event);
- return (ke->key() == d->key)
- && ((ke->modifiers() & d->modifiersMask) == d->modifiersMask);
- }
- return false;
-}
-
-/*!
- \reimp
-*/
-void QBasicKeyEventTransition::onTransition(QEvent *)
-{
-}
-
-QT_END_NAMESPACE
diff --git a/src/gui/statemachine/qbasickeyeventtransition_p.h b/src/gui/statemachine/qbasickeyeventtransition_p.h
deleted file mode 100644
index 39fa6ad..0000000
--- a/src/gui/statemachine/qbasickeyeventtransition_p.h
+++ /dev/null
@@ -1,93 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QBASICKEYEVENTTRANSITION_P_H
-#define QBASICKEYEVENTTRANSITION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <QtCore/qabstracttransition.h>
-#include <QtGui/qevent.h>
-
-QT_BEGIN_NAMESPACE
-
-class QBasicKeyEventTransitionPrivate;
-class Q_AUTOTEST_EXPORT QBasicKeyEventTransition : public QAbstractTransition
-{
- Q_OBJECT
-public:
- QBasicKeyEventTransition(QState *sourceState = 0);
- QBasicKeyEventTransition(QEvent::Type type, int key, QState *sourceState = 0);
- QBasicKeyEventTransition(QEvent::Type type, int key,
- Qt::KeyboardModifiers modifiersMask,
- QState *sourceState = 0);
- ~QBasicKeyEventTransition();
-
- QEvent::Type eventType() const;
- void setEventType(QEvent::Type type);
-
- int key() const;
- void setKey(int key);
-
- Qt::KeyboardModifiers modifiersMask() const;
- void setModifiersMask(Qt::KeyboardModifiers modifiers);
-
-protected:
- bool eventTest(QEvent *event);
- void onTransition(QEvent *);
-
-private:
- Q_DISABLE_COPY(QBasicKeyEventTransition)
- Q_DECLARE_PRIVATE(QBasicKeyEventTransition)
-};
-
-QT_END_NAMESPACE
-
-#endif
diff --git a/src/gui/statemachine/qbasicmouseeventtransition.cpp b/src/gui/statemachine/qbasicmouseeventtransition.cpp
deleted file mode 100644
index 20dd792..0000000
--- a/src/gui/statemachine/qbasicmouseeventtransition.cpp
+++ /dev/null
@@ -1,208 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qbasicmouseeventtransition_p.h"
-#include <QtGui/qevent.h>
-#include <QtGui/qpainterpath.h>
-#include <qdebug.h>
-#include <private/qabstracttransition_p.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \internal
- \class QBasicMouseEventTransition
- \since 4.6
- \ingroup statemachine
-
- \brief The QBasicMouseEventTransition class provides a transition for Qt mouse events.
-*/
-
-class QBasicMouseEventTransitionPrivate : public QAbstractTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QBasicMouseEventTransition)
-public:
- QBasicMouseEventTransitionPrivate();
-
- static QBasicMouseEventTransitionPrivate *get(QBasicMouseEventTransition *q);
-
- QEvent::Type eventType;
- Qt::MouseButton button;
- Qt::KeyboardModifiers modifiersMask;
- QPainterPath path;
-};
-
-QBasicMouseEventTransitionPrivate::QBasicMouseEventTransitionPrivate()
-{
- eventType = QEvent::None;
- button = Qt::NoButton;
-}
-
-QBasicMouseEventTransitionPrivate *QBasicMouseEventTransitionPrivate::get(QBasicMouseEventTransition *q)
-{
- return q->d_func();
-}
-
-/*!
- Constructs a new mouse event transition with the given \a sourceState.
-*/
-QBasicMouseEventTransition::QBasicMouseEventTransition(QState *sourceState)
- : QAbstractTransition(*new QBasicMouseEventTransitionPrivate, sourceState)
-{
-}
-
-/*!
- Constructs a new mouse event transition for events of the given \a type.
-*/
-QBasicMouseEventTransition::QBasicMouseEventTransition(QEvent::Type type,
- Qt::MouseButton button,
- QState *sourceState)
- : QAbstractTransition(*new QBasicMouseEventTransitionPrivate, sourceState)
-{
- Q_D(QBasicMouseEventTransition);
- d->eventType = type;
- d->button = button;
-}
-
-/*!
- Destroys this mouse event transition.
-*/
-QBasicMouseEventTransition::~QBasicMouseEventTransition()
-{
-}
-
-/*!
- Returns the event type that this mouse event transition is associated with.
-*/
-QEvent::Type QBasicMouseEventTransition::eventType() const
-{
- Q_D(const QBasicMouseEventTransition);
- return d->eventType;
-}
-
-/*!
- Sets the event \a type that this mouse event transition is associated with.
-*/
-void QBasicMouseEventTransition::setEventType(QEvent::Type type)
-{
- Q_D(QBasicMouseEventTransition);
- d->eventType = type;
-}
-
-/*!
- Returns the button that this mouse event transition checks for.
-*/
-Qt::MouseButton QBasicMouseEventTransition::button() const
-{
- Q_D(const QBasicMouseEventTransition);
- return d->button;
-}
-
-/*!
- Sets the button that this mouse event transition will check for.
-*/
-void QBasicMouseEventTransition::setButton(Qt::MouseButton button)
-{
- Q_D(QBasicMouseEventTransition);
- d->button = button;
-}
-
-/*!
- Returns the keyboard modifiers mask that this mouse event transition checks
- for.
-*/
-Qt::KeyboardModifiers QBasicMouseEventTransition::modifiersMask() const
-{
- Q_D(const QBasicMouseEventTransition);
- return d->modifiersMask;
-}
-
-/*!
- Sets the keyboard modifiers mask that this mouse event transition will check
- for.
-*/
-void QBasicMouseEventTransition::setModifiersMask(Qt::KeyboardModifiers modifiersMask)
-{
- Q_D(QBasicMouseEventTransition);
- d->modifiersMask = modifiersMask;
-}
-
-/*!
- Returns the path for this mouse event transition.
-*/
-QPainterPath QBasicMouseEventTransition::path() const
-{
- Q_D(const QBasicMouseEventTransition);
- return d->path;
-}
-
-/*!
- Sets the path for this mouse event transition.
-*/
-void QBasicMouseEventTransition::setPath(const QPainterPath &path)
-{
- Q_D(QBasicMouseEventTransition);
- d->path = path;
-}
-
-/*!
- \reimp
-*/
-bool QBasicMouseEventTransition::eventTest(QEvent *event)
-{
- Q_D(const QBasicMouseEventTransition);
- if (event->type() == d->eventType) {
- QMouseEvent *me = static_cast<QMouseEvent*>(event);
- return (me->button() == d->button)
- && ((me->modifiers() & d->modifiersMask) == d->modifiersMask)
- && (d->path.isEmpty() || d->path.contains(me->pos()));
- }
- return false;
-}
-
-/*!
- \reimp
-*/
-void QBasicMouseEventTransition::onTransition(QEvent *)
-{
-}
-
-QT_END_NAMESPACE
diff --git a/src/gui/statemachine/qbasicmouseeventtransition_p.h b/src/gui/statemachine/qbasicmouseeventtransition_p.h
deleted file mode 100644
index 6c0afe4..0000000
--- a/src/gui/statemachine/qbasicmouseeventtransition_p.h
+++ /dev/null
@@ -1,98 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QBASICMOUSEEVENTTRANSITION_P_H
-#define QBASICMOUSEEVENTTRANSITION_P_H
-
-//
-// W A R N I N G
-// -------------
-//
-// This file is not part of the Qt API. It exists purely as an
-// implementation detail. This header file may change from version to
-// version without notice, or even be removed.
-//
-// We mean it.
-//
-
-#include <QtCore/qabstracttransition.h>
-#include <QtGui/qevent.h>
-
-QT_BEGIN_NAMESPACE
-
-class QPainterPath;
-
-class QBasicMouseEventTransitionPrivate;
-class Q_AUTOTEST_EXPORT QBasicMouseEventTransition : public QAbstractTransition
-{
- Q_OBJECT
-public:
- QBasicMouseEventTransition(QState *sourceState = 0);
- QBasicMouseEventTransition(QEvent::Type type, Qt::MouseButton button,
- QState *sourceState = 0);
- ~QBasicMouseEventTransition();
-
- QEvent::Type eventType() const;
- void setEventType(QEvent::Type type);
-
- Qt::MouseButton button() const;
- void setButton(Qt::MouseButton button);
-
- Qt::KeyboardModifiers modifiersMask() const;
- void setModifiersMask(Qt::KeyboardModifiers modifiers);
-
- QPainterPath path() const;
- void setPath(const QPainterPath &path);
-
-protected:
- bool eventTest(QEvent *event);
- void onTransition(QEvent *);
-
-private:
- Q_DISABLE_COPY(QBasicMouseEventTransition)
- Q_DECLARE_PRIVATE(QBasicMouseEventTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/gui/statemachine/qguistatemachine.cpp b/src/gui/statemachine/qguistatemachine.cpp
deleted file mode 100644
index 612e43e..0000000
--- a/src/gui/statemachine/qguistatemachine.cpp
+++ /dev/null
@@ -1,559 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtCore/qstatemachine.h>
-#include <private/qstatemachine_p.h>
-#include <QtGui/qevent.h>
-#include <QtGui/qgraphicssceneevent.h>
-
-QT_BEGIN_NAMESPACE
-
-Q_CORE_EXPORT const QStateMachinePrivate::Handler *qcoreStateMachineHandler();
-
-static QEvent *cloneEvent(QEvent *e)
-{
- switch (e->type()) {
- case QEvent::MouseButtonPress:
- case QEvent::MouseButtonRelease:
- case QEvent::MouseButtonDblClick:
- case QEvent::MouseMove:
- return new QMouseEvent(*static_cast<QMouseEvent*>(e));
- case QEvent::KeyPress:
- case QEvent::KeyRelease:
- return new QKeyEvent(*static_cast<QKeyEvent*>(e));
- case QEvent::FocusIn:
- case QEvent::FocusOut:
- return new QFocusEvent(*static_cast<QFocusEvent*>(e));
- case QEvent::Enter:
- return new QEvent(*e);
- case QEvent::Leave:
- return new QEvent(*e);
- break;
- case QEvent::Paint:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Move:
- return new QMoveEvent(*static_cast<QMoveEvent*>(e));
- case QEvent::Resize:
- return new QResizeEvent(*static_cast<QResizeEvent*>(e));
- case QEvent::Create:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Destroy:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Show:
- return new QShowEvent(*static_cast<QShowEvent*>(e));
- case QEvent::Hide:
- return new QHideEvent(*static_cast<QHideEvent*>(e));
- case QEvent::Close:
- return new QCloseEvent(*static_cast<QCloseEvent*>(e));
- case QEvent::Quit:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ParentChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ParentAboutToChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ThreadChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::WindowActivate:
- case QEvent::WindowDeactivate:
- return new QEvent(*e);
-
- case QEvent::ShowToParent:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::HideToParent:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Wheel:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WindowTitleChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WindowIconChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ApplicationWindowIconChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ApplicationFontChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ApplicationLayoutDirectionChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ApplicationPaletteChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::PaletteChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Clipboard:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Speech:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::MetaCall:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::SockAct:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WinEventAct:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::DeferredDelete:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::DragEnter:
- return new QDragEnterEvent(*static_cast<QDragEnterEvent*>(e));
- case QEvent::DragMove:
- return new QDragMoveEvent(*static_cast<QDragMoveEvent*>(e));
- case QEvent::DragLeave:
- return new QDragLeaveEvent(*static_cast<QDragLeaveEvent*>(e));
- case QEvent::Drop:
- return new QDropEvent(*static_cast<QDragMoveEvent*>(e));
- case QEvent::DragResponse:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ChildAdded:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ChildPolished:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-#ifdef QT3_SUPPORT
- case QEvent::ChildInsertedRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ChildInserted:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LayoutHint:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-#endif
- case QEvent::ChildRemoved:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ShowWindowRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::PolishRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Polish:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LayoutRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::UpdateRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::UpdateLater:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::EmbeddingControl:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ActivateControl:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::DeactivateControl:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ContextMenu:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::InputMethod:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::AccessibilityPrepare:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::TabletMove:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LocaleChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LanguageChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LayoutDirectionChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::Style:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::TabletPress:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::TabletRelease:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::OkRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::HelpRequest:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::IconDrag:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::FontChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::EnabledChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ActivationChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::StyleChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::IconTextChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ModifiedChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::MouseTrackingChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::WindowBlocked:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WindowUnblocked:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WindowStateChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ToolTip:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::WhatsThis:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::StatusTip:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ActionChanged:
- case QEvent::ActionAdded:
- case QEvent::ActionRemoved:
- return new QActionEvent(*static_cast<QActionEvent*>(e));
-
- case QEvent::FileOpen:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::Shortcut:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ShortcutOverride:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
-#ifdef QT3_SUPPORT
- case QEvent::Accel:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::AccelAvailable:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-#endif
-
- case QEvent::WhatsThisClicked:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ToolBarChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ApplicationActivate:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ApplicationDeactivate:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::QueryWhatsThis:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::EnterWhatsThisMode:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LeaveWhatsThisMode:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ZOrderChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::HoverEnter:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::HoverLeave:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::HoverMove:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::AccessibilityHelp:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::AccessibilityDescription:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
-#ifdef QT_KEYPAD_NAVIGATION
- case QEvent::EnterEditFocus:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::LeaveEditFocus:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-#endif
- case QEvent::AcceptDropsChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::MenubarUpdated:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ZeroTimerEvent:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::GraphicsSceneMouseMove:
- case QEvent::GraphicsSceneMousePress:
- case QEvent::GraphicsSceneMouseRelease:
- case QEvent::GraphicsSceneMouseDoubleClick: {
- QGraphicsSceneMouseEvent *me = static_cast<QGraphicsSceneMouseEvent*>(e);
- QGraphicsSceneMouseEvent *me2 = new QGraphicsSceneMouseEvent(me->type());
- me2->setWidget(me->widget());
- me2->setPos(me->pos());
- me2->setScenePos(me->scenePos());
- me2->setScreenPos(me->screenPos());
-// ### for all buttons
- me2->setButtonDownPos(Qt::LeftButton, me->buttonDownPos(Qt::LeftButton));
- me2->setButtonDownPos(Qt::RightButton, me->buttonDownPos(Qt::RightButton));
- me2->setButtonDownScreenPos(Qt::LeftButton, me->buttonDownScreenPos(Qt::LeftButton));
- me2->setButtonDownScreenPos(Qt::RightButton, me->buttonDownScreenPos(Qt::RightButton));
- me2->setLastPos(me->lastPos());
- me2->setLastScenePos(me->lastScenePos());
- me2->setLastScreenPos(me->lastScreenPos());
- me2->setButtons(me->buttons());
- me2->setButton(me->button());
- me2->setModifiers(me->modifiers());
- return me2;
- }
-
- case QEvent::GraphicsSceneContextMenu: {
- QGraphicsSceneContextMenuEvent *me = static_cast<QGraphicsSceneContextMenuEvent*>(e);
- QGraphicsSceneContextMenuEvent *me2 = new QGraphicsSceneContextMenuEvent(me->type());
- me2->setWidget(me->widget());
- me2->setPos(me->pos());
- me2->setScenePos(me->scenePos());
- me2->setScreenPos(me->screenPos());
- me2->setModifiers(me->modifiers());
- me2->setReason(me->reason());
- return me2;
- }
-
- case QEvent::GraphicsSceneHoverEnter:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneHoverMove:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneHoverLeave:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneHelp:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneDragEnter:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneDragMove:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneDragLeave:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneDrop:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneWheel:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::KeyboardLayoutChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::DynamicPropertyChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::TabletEnterProximity:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::TabletLeaveProximity:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::NonClientAreaMouseMove:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::NonClientAreaMouseButtonPress:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::NonClientAreaMouseButtonRelease:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::NonClientAreaMouseButtonDblClick:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::MacSizeChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::ContentsRectChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::MacGLWindowChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::FutureCallOut:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::GraphicsSceneResize:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::GraphicsSceneMove: {
- QGraphicsSceneMoveEvent *me = static_cast<QGraphicsSceneMoveEvent*>(e);
- QGraphicsSceneMoveEvent *me2 = new QGraphicsSceneMoveEvent();
- me2->setWidget(me->widget());
- me2->setNewPos(me->newPos());
- me2->setOldPos(me->oldPos());
- return me2;
- }
-
- case QEvent::CursorChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- case QEvent::ToolTipChange:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::NetworkReplyUpdated:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-
- case QEvent::GrabMouse:
- case QEvent::UngrabMouse:
- case QEvent::GrabKeyboard:
- case QEvent::UngrabKeyboard:
- return new QEvent(*e);
-
-#ifdef QT_MAC_USE_COCOA
- case QEvent::CocoaRequestModal:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
-#endif
- case QEvent::User:
- case QEvent::MaxUser:
- Q_ASSERT_X(false, "cloneEvent()", "not implemented");
- break;
- default:
- ;
- }
- return qcoreStateMachineHandler()->cloneEvent(e);
-}
-
-const QStateMachinePrivate::Handler qt_gui_statemachine_handler = {
- cloneEvent
-};
-
-static const QStateMachinePrivate::Handler *qt_guistatemachine_last_handler = 0;
-int qRegisterGuiStateMachine()
-{
- qt_guistatemachine_last_handler = QStateMachinePrivate::handler;
- QStateMachinePrivate::handler = &qt_gui_statemachine_handler;
- return 1;
-}
-Q_CONSTRUCTOR_FUNCTION(qRegisterGuiStateMachine)
-
-int qUnregisterGuiStateMachine()
-{
- QStateMachinePrivate::handler = qt_guistatemachine_last_handler;
- return 1;
-}
-Q_DESTRUCTOR_FUNCTION(qUnregisterGuiStateMachine)
-
-QT_END_NAMESPACE
diff --git a/src/gui/statemachine/qkeyeventtransition.cpp b/src/gui/statemachine/qkeyeventtransition.cpp
deleted file mode 100644
index f803711..0000000
--- a/src/gui/statemachine/qkeyeventtransition.cpp
+++ /dev/null
@@ -1,186 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qkeyeventtransition.h"
-#include "qbasickeyeventtransition_p.h"
-#include <QtCore/qwrappedevent.h>
-#include <private/qeventtransition_p.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QKeyEventTransition
-
- \brief The QKeyEventTransition class provides a transition for key events.
-
- \since 4.6
- \ingroup statemachine
-
- QKeyEventTransition is part of \l{The State Machine Framework}.
-
- \sa QState::addTransition()
-*/
-
-/*!
- \property QKeyEventTransition::key
-
- \brief the key that this key event transition is associated with
-*/
-
-/*!
- \property QKeyEventTransition::modifiersMask
-
- \brief the keyboard modifiers mask that this key event transition checks for
-*/
-
-class QKeyEventTransitionPrivate : public QEventTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QKeyEventTransition)
-public:
- QKeyEventTransitionPrivate() {}
-
- QBasicKeyEventTransition *transition;
-};
-
-/*!
- Constructs a new key event transition with the given \a sourceState.
-*/
-QKeyEventTransition::QKeyEventTransition(QState *sourceState)
- : QEventTransition(*new QKeyEventTransitionPrivate, sourceState)
-{
- Q_D(QKeyEventTransition);
- d->transition = new QBasicKeyEventTransition();
-}
-
-/*!
- Constructs a new key event transition for events of the given \a type for
- the given \a object, with the given \a key and \a sourceState.
-*/
-QKeyEventTransition::QKeyEventTransition(QObject *object, QEvent::Type type,
- int key, QState *sourceState)
- : QEventTransition(*new QKeyEventTransitionPrivate, object, type, sourceState)
-{
- Q_D(QKeyEventTransition);
- d->transition = new QBasicKeyEventTransition(type, key);
-}
-
-/*!
- Constructs a new key event transition for events of the given \a type for
- the given \a object, with the given \a key, \a targets and \a sourceState.
-*/
-QKeyEventTransition::QKeyEventTransition(QObject *object, QEvent::Type type,
- int key, const QList<QAbstractState*> &targets,
- QState *sourceState)
- : QEventTransition(*new QKeyEventTransitionPrivate, object, type, targets, sourceState)
-{
- Q_D(QKeyEventTransition);
- d->transition = new QBasicKeyEventTransition(type, key);
-}
-
-/*!
- Destroys this key event transition.
-*/
-QKeyEventTransition::~QKeyEventTransition()
-{
- Q_D(QKeyEventTransition);
- delete d->transition;
-}
-
-/*!
- Returns the key that this key event transition checks for.
-*/
-int QKeyEventTransition::key() const
-{
- Q_D(const QKeyEventTransition);
- return d->transition->key();
-}
-
-/*!
- Sets the key that this key event transition will check for.
-*/
-void QKeyEventTransition::setKey(int key)
-{
- Q_D(QKeyEventTransition);
- d->transition->setKey(key);
-}
-
-/*!
- Returns the keyboard modifiers mask that this key event transition checks
- for.
-*/
-Qt::KeyboardModifiers QKeyEventTransition::modifiersMask() const
-{
- Q_D(const QKeyEventTransition);
- return d->transition->modifiersMask();
-}
-
-/*!
- Sets the keyboard \a modifiers mask that this key event transition will
- check for.
-*/
-void QKeyEventTransition::setModifiersMask(Qt::KeyboardModifiers modifiersMask)
-{
- Q_D(QKeyEventTransition);
- d->transition->setModifiersMask(modifiersMask);
-}
-
-/*!
- \reimp
-*/
-bool QKeyEventTransition::eventTest(QEvent *event)
-{
- Q_D(const QKeyEventTransition);
- if (!QEventTransition::eventTest(event))
- return false;
- QWrappedEvent *we = static_cast<QWrappedEvent*>(event);
- d->transition->setEventType(we->event()->type());
- return QAbstractTransitionPrivate::get(d->transition)->callEventTest(we->event());
-}
-
-/*!
- \reimp
-*/
-void QKeyEventTransition::onTransition(QEvent *event)
-{
- QEventTransition::onTransition(event);
-}
-
-QT_END_NAMESPACE
diff --git a/src/gui/statemachine/qkeyeventtransition.h b/src/gui/statemachine/qkeyeventtransition.h
deleted file mode 100644
index 3c8295f..0000000
--- a/src/gui/statemachine/qkeyeventtransition.h
+++ /dev/null
@@ -1,87 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QKEYEVENTTRANSITION_H
-#define QKEYEVENTTRANSITION_H
-
-#include <QtCore/qeventtransition.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QKeyEventTransitionPrivate;
-class Q_GUI_EXPORT QKeyEventTransition : public QEventTransition
-{
- Q_OBJECT
- Q_PROPERTY(int key READ key WRITE setKey)
- Q_PROPERTY(Qt::KeyboardModifiers modifiersMask READ modifiersMask WRITE setModifiersMask)
-public:
- QKeyEventTransition(QState *sourceState = 0);
- QKeyEventTransition(QObject *object, QEvent::Type type, int key,
- QState *sourceState = 0);
- QKeyEventTransition(QObject *object, QEvent::Type type, int key,
- const QList<QAbstractState*> &targets,
- QState *sourceState = 0);
- ~QKeyEventTransition();
-
- int key() const;
- void setKey(int key);
-
- Qt::KeyboardModifiers modifiersMask() const;
- void setModifiersMask(Qt::KeyboardModifiers modifiers);
-
-protected:
- void onTransition(QEvent *event);
- bool eventTest(QEvent *event);
-
-private:
- Q_DISABLE_COPY(QKeyEventTransition)
- Q_DECLARE_PRIVATE(QKeyEventTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/gui/statemachine/qmouseeventtransition.cpp b/src/gui/statemachine/qmouseeventtransition.cpp
deleted file mode 100644
index e4e18eb..0000000
--- a/src/gui/statemachine/qmouseeventtransition.cpp
+++ /dev/null
@@ -1,216 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "qmouseeventtransition.h"
-#include "qbasicmouseeventtransition_p.h"
-#include <QtCore/qwrappedevent.h>
-#include <QtGui/qpainterpath.h>
-#include <private/qeventtransition_p.h>
-
-QT_BEGIN_NAMESPACE
-
-/*!
- \class QMouseEventTransition
-
- \brief The QMouseEventTransition class provides a transition for mouse events.
-
- \since 4.6
- \ingroup statemachine
-
- QMouseEventTransition is part of \l{The State Machine Framework}.
-
- \sa QState::addTransition()
-*/
-
-/*!
- \property QMouseEventTransition::button
-
- \brief the button that this mouse event transition is associated with
-*/
-
-/*!
- \property QMouseEventTransition::modifiersMask
-
- \brief the keyboard modifiers mask that this mouse event transition checks for
-*/
-
-class QMouseEventTransitionPrivate : public QEventTransitionPrivate
-{
- Q_DECLARE_PUBLIC(QMouseEventTransition)
-public:
- QMouseEventTransitionPrivate();
-
- QBasicMouseEventTransition *transition;
-};
-
-QMouseEventTransitionPrivate::QMouseEventTransitionPrivate()
-{
-}
-
-/*!
- Constructs a new mouse event transition with the given \a sourceState.
-*/
-QMouseEventTransition::QMouseEventTransition(QState *sourceState)
- : QEventTransition(*new QMouseEventTransitionPrivate, sourceState)
-{
- Q_D(QMouseEventTransition);
- d->transition = new QBasicMouseEventTransition();
-}
-
-/*!
- Constructs a new mouse event transition for events of the given \a type for
- the given \a object, with the given \a button and \a sourceState.
-*/
-QMouseEventTransition::QMouseEventTransition(QObject *object, QEvent::Type type,
- Qt::MouseButton button,
- QState *sourceState)
- : QEventTransition(*new QMouseEventTransitionPrivate, object, type, sourceState)
-{
- Q_D(QMouseEventTransition);
- d->transition = new QBasicMouseEventTransition(type, button);
-}
-
-/*!
- Constructs a new mouse event transition for events of the given \a type for
- the given \a object, with the given \a button, \a targets and \a
- sourceState.
-*/
-QMouseEventTransition::QMouseEventTransition(QObject *object, QEvent::Type type,
- Qt::MouseButton button,
- const QList<QAbstractState*> &targets,
- QState *sourceState)
- : QEventTransition(*new QMouseEventTransitionPrivate, object, type, targets, sourceState)
-{
- Q_D(QMouseEventTransition);
- d->transition = new QBasicMouseEventTransition(type, button);
-}
-
-/*!
- Destroys this mouse event transition.
-*/
-QMouseEventTransition::~QMouseEventTransition()
-{
- Q_D(QMouseEventTransition);
- delete d->transition;
-}
-
-/*!
- Returns the button that this mouse event transition checks for.
-*/
-Qt::MouseButton QMouseEventTransition::button() const
-{
- Q_D(const QMouseEventTransition);
- return d->transition->button();
-}
-
-/*!
- Sets the \a button that this mouse event transition will check for.
-*/
-void QMouseEventTransition::setButton(Qt::MouseButton button)
-{
- Q_D(QMouseEventTransition);
- d->transition->setButton(button);
-}
-
-/*!
- Returns the keyboard modifiers mask that this mouse event transition checks
- for.
-*/
-Qt::KeyboardModifiers QMouseEventTransition::modifiersMask() const
-{
- Q_D(const QMouseEventTransition);
- return d->transition->modifiersMask();
-}
-
-/*!
- Sets the keyboard \a modifiers mask that this mouse event transition will
- check for.
-*/
-void QMouseEventTransition::setModifiersMask(Qt::KeyboardModifiers modifiersMask)
-{
- Q_D(QMouseEventTransition);
- d->transition->setModifiersMask(modifiersMask);
-}
-
-/*!
- Returns the path for this mouse event transition.
-*/
-QPainterPath QMouseEventTransition::path() const
-{
- Q_D(const QMouseEventTransition);
- return d->transition->path();
-}
-
-/*!
- Sets the \a path for this mouse event transition.
- If a valid path has been set, the transition will only trigger if the mouse
- event position (QMouseEvent::pos()) is inside the path.
-
- \sa QPainterPath::contains()
-*/
-void QMouseEventTransition::setPath(const QPainterPath &path)
-{
- Q_D(QMouseEventTransition);
- d->transition->setPath(path);
-}
-
-/*!
- \reimp
-*/
-bool QMouseEventTransition::eventTest(QEvent *event)
-{
- Q_D(const QMouseEventTransition);
- if (!QEventTransition::eventTest(event))
- return false;
- QWrappedEvent *we = static_cast<QWrappedEvent*>(event);
- d->transition->setEventType(we->event()->type());
- return QAbstractTransitionPrivate::get(d->transition)->callEventTest(we->event());
-}
-
-/*!
- \reimp
-*/
-void QMouseEventTransition::onTransition(QEvent *event)
-{
- QEventTransition::onTransition(event);
-}
-
-QT_END_NAMESPACE
diff --git a/src/gui/statemachine/qmouseeventtransition.h b/src/gui/statemachine/qmouseeventtransition.h
deleted file mode 100644
index 3f5f3ac..0000000
--- a/src/gui/statemachine/qmouseeventtransition.h
+++ /dev/null
@@ -1,92 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
-** Contact: Qt Software Information (qt-info@nokia.com)
-**
-** This file is part of the QtGui module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the either Technology Preview License Agreement or the
-** Beta Release License Agreement.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain
-** additional rights. These rights are described in the Nokia Qt LGPL
-** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
-** package.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3.0 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU General Public License version 3.0 requirements will be
-** met: http://www.gnu.org/copyleft/gpl.html.
-**
-** If you are unsure which license is appropriate for your use, please
-** contact the sales department at qt-sales@nokia.com.
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef QMOUSEEVENTTRANSITION_H
-#define QMOUSEEVENTTRANSITION_H
-
-#include <QtCore/qeventtransition.h>
-
-QT_BEGIN_HEADER
-
-QT_BEGIN_NAMESPACE
-
-QT_MODULE(Core)
-
-class QMouseEventTransitionPrivate;
-class QPainterPath;
-class Q_GUI_EXPORT QMouseEventTransition : public QEventTransition
-{
- Q_OBJECT
- Q_PROPERTY(Qt::MouseButton button READ button WRITE setButton)
- Q_PROPERTY(Qt::KeyboardModifiers modifiersMask READ modifiersMask WRITE setModifiersMask)
-public:
- QMouseEventTransition(QState *sourceState = 0);
- QMouseEventTransition(QObject *object, QEvent::Type type,
- Qt::MouseButton button, QState *sourceState = 0);
- QMouseEventTransition(QObject *object, QEvent::Type type,
- Qt::MouseButton button,
- const QList<QAbstractState*> &targets,
- QState *sourceState = 0);
- ~QMouseEventTransition();
-
- Qt::MouseButton button() const;
- void setButton(Qt::MouseButton button);
-
- Qt::KeyboardModifiers modifiersMask() const;
- void setModifiersMask(Qt::KeyboardModifiers modifiers);
-
- QPainterPath path() const;
- void setPath(const QPainterPath &path);
-
-protected:
- void onTransition(QEvent *event);
- bool eventTest(QEvent *event);
-
-private:
- Q_DISABLE_COPY(QMouseEventTransition)
- Q_DECLARE_PRIVATE(QMouseEventTransition)
-};
-
-QT_END_NAMESPACE
-
-QT_END_HEADER
-
-#endif
diff --git a/src/gui/statemachine/statemachine.pri b/src/gui/statemachine/statemachine.pri
deleted file mode 100644
index 2eb1e05..0000000
--- a/src/gui/statemachine/statemachine.pri
+++ /dev/null
@@ -1,13 +0,0 @@
-SOURCES += $$PWD/qguistatemachine.cpp
-!contains(DEFINES, QT_NO_STATEMACHINE_EVENTFILTER) {
- HEADERS += \
- $$PWD/qkeyeventtransition.h \
- $$PWD/qmouseeventtransition.h \
- $$PWD/qbasickeyeventtransition_p.h \
- $$PWD/qbasicmouseeventtransition_p.h
- SOURCES += \
- $$PWD/qkeyeventtransition.cpp \
- $$PWD/qmouseeventtransition.cpp \
- $$PWD/qbasickeyeventtransition.cpp \
- $$PWD/qbasicmouseeventtransition.cpp
-}