summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/script/bridge/bridge.pri6
-rw-r--r--src/script/bridge/qscriptactivationobject_p.h91
-rw-r--r--src/script/bridge/qscriptfunction.cpp40
3 files changed, 100 insertions, 37 deletions
diff --git a/src/script/bridge/bridge.pri b/src/script/bridge/bridge.pri
index cf8395a..f2883e7 100644
--- a/src/script/bridge/bridge.pri
+++ b/src/script/bridge/bridge.pri
@@ -3,11 +3,13 @@ SOURCES += \
$$PWD/qscriptobject.cpp \
$$PWD/qscriptclassobject.cpp \
$$PWD/qscriptvariant.cpp \
- $$PWD/qscriptqobject.cpp
+ $$PWD/qscriptqobject.cpp \
+ $$PWD/qscriptactivationobject.cpp
HEADERS += \
$$PWD/qscriptfunction_p.h \
$$PWD/qscriptobject_p.h \
$$PWD/qscriptclassobject_p.h \
$$PWD/qscriptvariant_p.h \
- $$PWD/qscriptqobject_p.h
+ $$PWD/qscriptqobject_p.h \
+ $$PWD/qscriptactivationobject_p.h
diff --git a/src/script/bridge/qscriptactivationobject_p.h b/src/script/bridge/qscriptactivationobject_p.h
new file mode 100644
index 0000000..633cbf6
--- /dev/null
+++ b/src/script/bridge/qscriptactivationobject_p.h
@@ -0,0 +1,91 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the QtScript 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 http://www.qtsoftware.com/contact.
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#ifndef QSCRIPTACTIVATIONOBJECT_P_H
+#define QSCRIPTACTIVATIONOBJECT_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/qobjectdefs.h>
+
+#ifndef QT_NO_SCRIPT
+
+#include "JSVariableObject.h"
+
+QT_BEGIN_NAMESPACE
+
+class QScriptClass;
+
+namespace QScript
+{
+
+class QScriptActivationObject : public JSC::JSVariableObject {
+public:
+ QScriptActivationObject(JSC::ExecState *callFrame);
+ virtual ~QScriptActivationObject();
+ virtual bool isDynamicScope() const { return true; }
+ virtual void putWithAttributes(JSC::ExecState *exec, const JSC::Identifier &propertyName, JSC::JSValue value, unsigned attributes);
+private:
+ struct QScriptActivationObjectData : public JSVariableObjectData {
+ QScriptActivationObjectData(JSC::Register* registers)
+ : JSVariableObjectData(&symbolTable, registers)
+ { }
+ JSC::SymbolTable symbolTable;
+ };
+};
+
+
+} // namespace QScript
+
+QT_END_NAMESPACE
+
+#endif // QT_NO_SCRIPT
+
+#endif
diff --git a/src/script/bridge/qscriptfunction.cpp b/src/script/bridge/qscriptfunction.cpp
index 777bd3b..309315c 100644
--- a/src/script/bridge/qscriptfunction.cpp
+++ b/src/script/bridge/qscriptfunction.cpp
@@ -46,11 +46,11 @@
#include "private/qscriptengine_p.h"
#include "qscriptcontext.h"
#include "private/qscriptcontext_p.h"
+#include "qscriptactivationobject_p.h"
#include "JSGlobalObject.h"
-QT_BEGIN_NAMESPACE
namespace JSC
{
ASSERT_CLASS_FITS_IN_CELL(QScript::FunctionWrapper);
@@ -61,36 +61,6 @@ namespace QScript
{
-class QScriptActivation : public JSC::JSVariableObject {
-public:
- QScriptActivation(JSC::ExecState *callFrame)
- : JSC::JSVariableObject(callFrame->globalData().activationStructure, new QScriptActivationData(callFrame->registers()))
- {}
- virtual ~QScriptActivation() { delete d; }
- virtual bool isDynamicScope() const {return true; }
-// virtual bool isActivationObject() const { return true; }
-
- virtual void putWithAttributes(JSC::ExecState *exec, const JSC::Identifier &propertyName, JSC::JSValue value, unsigned attributes)
- {
- if (symbolTablePutWithAttributes(propertyName, value, attributes))
- return;
-
- JSC::PutPropertySlot slot;
- JSObject::putWithAttributes(exec, propertyName, value, attributes, true, slot);
- }
-
-
-private:
- struct QScriptActivationData : public JSVariableObjectData {
- QScriptActivationData(JSC::Register* registers)
- : JSVariableObjectData(&symbolTable, registers)
- { }
- JSC::SymbolTable symbolTable;
- };
-};
-
-
-
FunctionWrapper::FunctionWrapper(QScriptEngine *engine, int length, const JSC::Identifier &name,
QScriptEngine::FunctionSignature function)
: JSC::PrototypeFunction(QScriptEnginePrivate::get(engine)->globalExec(),
@@ -121,7 +91,7 @@ JSC::JSValue FunctionWrapper::proxyCall(JSC::ExecState *exec, JSC::JSObject *cal
QScriptContext *ctx = eng_p->contextForFrame(exec);
//We might have nested eval inside our function so we should create another scope
- JSC::JSObject* scope = new (exec) QScriptActivation(exec);
+ JSC::JSObject* scope = new (exec) QScriptActivationObject(exec);
exec->setScopeChain(exec->scopeChain()->copy()->push(scope));
QScriptValue result = self->data->function(ctx, self->data->engine);
@@ -147,7 +117,7 @@ JSC::JSObject* FunctionWrapper::proxyConstruct(JSC::ExecState *exec, JSC::JSObje
eng_p->currentFrame = exec;
//We might have nested eval inside our function so we should create another scope
- JSC::JSObject* scope = new (exec) QScriptActivation(exec);
+ JSC::JSObject* scope = new (exec) QScriptActivationObject(exec);
exec->setScopeChain(exec->scopeChain()->copy()->push(scope));
QScriptValue defaultObject = ctx->thisObject();
@@ -194,7 +164,7 @@ JSC::JSValue FunctionWithArgWrapper::proxyCall(JSC::ExecState *exec, JSC::JSObje
eng_p->currentFrame = exec;
//We might have nested eval inside our function so we should create another scope
- JSC::JSObject* scope = new (exec) QScriptActivation(exec);
+ JSC::JSObject* scope = new (exec) QScriptActivationObject(exec);
exec->setScopeChain(exec->scopeChain()->copy()->push(scope));
QScriptValue result = self->data->function(ctx, self->data->engine, self->data->arg);
@@ -218,7 +188,7 @@ JSC::JSObject* FunctionWithArgWrapper::proxyConstruct(JSC::ExecState *exec, JSC:
eng_p->currentFrame = exec;
//We might have nested eval inside our function so we should create another scope
- JSC::JSObject* scope = new (exec) QScriptActivation(exec);
+ JSC::JSObject* scope = new (exec) QScriptActivationObject(exec);
exec->setScopeChain(exec->scopeChain()->copy()->push(scope));
QScriptValue defaultObject = ctx->thisObject();