summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/script/api/qscriptcontext.cpp47
1 files changed, 38 insertions, 9 deletions
diff --git a/src/script/api/qscriptcontext.cpp b/src/script/api/qscriptcontext.cpp
index e820596..15e4efe 100644
--- a/src/script/api/qscriptcontext.cpp
+++ b/src/script/api/qscriptcontext.cpp
@@ -47,6 +47,7 @@
#include "qscriptcontextinfo.h"
#include "qscriptengine.h"
#include "qscriptengine_p.h"
+#include "../bridge/qscriptactivationobject_p.h"
#include "Arguments.h"
#include "CodeBlock.h"
@@ -432,14 +433,34 @@ void QScriptContext::setReturnValue(const QScriptValue &result)
QScriptValue QScriptContext::activationObject() const
{
Q_D(const QScriptContext);
- JSC::CodeBlock *codeBlock = d->frame->codeBlock();
- if (!codeBlock) {
- qWarning("QScriptContext::activationObject() not implemented for native functions");
- return QScriptValue();
- }
// ### this is still a bit shaky
- JSC::FunctionBodyNode *body = static_cast<JSC::FunctionBodyNode*>(codeBlock->ownerNode());
- return d->engine->scriptValueFromJSCValue(new (&d->frame->globalData())JSC::JSActivation(d->frame, body));
+ // if properties of the activation are accessed after this context is
+ // popped, we CRASH.
+ // Ideally we should be able to store the activation object in the callframe
+ // and JSC would clean it up for us.
+ JSC::JSObject *result = 0;
+ // look in scope chain
+ {
+ JSC::ScopeChainNode *node = d->frame->scopeChain();
+ JSC::ScopeChainIterator it(node);
+ for (it = node->begin(); it != node->end(); ++it) {
+ if ((*it)->isVariableObject()) {
+ result = *it;
+ break;
+ }
+ }
+ }
+ if (!result) {
+ JSC::CodeBlock *codeBlock = d->frame->codeBlock();
+ if (!codeBlock) {
+ // native function
+ result = new (d->frame)QScript::QScriptActivationObject(d->frame);
+ } else {
+ JSC::FunctionBodyNode *body = static_cast<JSC::FunctionBodyNode*>(codeBlock->ownerNode());
+ result = new (d->frame)JSC::JSActivation(d->frame, body);
+ }
+ }
+ return d->engine->scriptValueFromJSCValue(result);
}
/*!
@@ -450,8 +471,16 @@ QScriptValue QScriptContext::activationObject() const
*/
void QScriptContext::setActivationObject(const QScriptValue &activation)
{
- Q_ASSERT_X(false, Q_FUNC_INFO, "not implemented");
- Q_UNUSED(activation);
+ Q_D(QScriptContext);
+ if (!activation.isObject())
+ return;
+ JSC::JSObject *object = JSC::asObject(d->engine->scriptValueToJSCValue(activation));
+ if (!object->isVariableObject()) {
+ qWarning("QScriptContext::setActivationObject(): not an activation object");
+ return;
+ }
+// ### look for variableObject in d->frame->scopeChain, replace by object
+ qWarning("QScriptContext::setActivationObject() not implemented");
}
/*!