summaryrefslogtreecommitdiffstats
path: root/src/script/api/qscriptengine.cpp
diff options
context:
space:
mode:
authorA-Team <ateam@pad.test.qt.nokia.com>2010-10-01 22:00:17 (GMT)
committerA-Team <ateam@pad.test.qt.nokia.com>2010-10-01 22:00:17 (GMT)
commit9d0317c91dbbe660af2ed2aa8ea47446049467d2 (patch)
treeb10925754df0608beb5de941b5c1ea4da1f3bd55 /src/script/api/qscriptengine.cpp
parent628c9625c4bf6d0e189f9e8da5268eb7629e7597 (diff)
parent33b76a659b2f44fa7038e375bbfb4cfd449ae617 (diff)
downloadQt-9d0317c91dbbe660af2ed2aa8ea47446049467d2.zip
Qt-9d0317c91dbbe660af2ed2aa8ea47446049467d2.tar.gz
Qt-9d0317c91dbbe660af2ed2aa8ea47446049467d2.tar.bz2
Merge branch '4.7-upstream' into 4.7-doc
Diffstat (limited to 'src/script/api/qscriptengine.cpp')
-rw-r--r--src/script/api/qscriptengine.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/script/api/qscriptengine.cpp b/src/script/api/qscriptengine.cpp
index 07aced4..128e9c3 100644
--- a/src/script/api/qscriptengine.cpp
+++ b/src/script/api/qscriptengine.cpp
@@ -46,6 +46,7 @@
#include "Error.h"
#include "Interpreter.h"
+#include "ExceptionHelpers.h"
#include "PrototypeFunction.h"
#include "InitializeThreading.h"
#include "ObjectPrototype.h"
@@ -4116,9 +4117,11 @@ bool QScriptEngine::isEvaluating() const
void QScriptEngine::abortEvaluation(const QScriptValue &result)
{
Q_D(QScriptEngine);
-
- d->timeoutChecker()->setShouldAbort(true);
+ if (!isEvaluating())
+ return;
d->abortResult = result;
+ d->timeoutChecker()->setShouldAbort(true);
+ JSC::throwError(d->currentFrame, JSC::createInterruptedExecutionException(&d->currentFrame->globalData()).toObject(d->currentFrame));
}
#ifndef QT_NO_QOBJECT