aboutsummaryrefslogtreecommitdiffstats
path: root/src/qml/qml/qqmlcompiler.cpp
diff options
context:
space:
mode:
authorMichael Brasser <michael.brasser@nokia.com>2012-05-21 09:27:43 +1000
committerQt by Nokia <qt-info@nokia.com>2012-08-24 00:55:55 +0200
commit0853343c33e394f35c31c161b019b2aed17f9256 (patch)
tree3f792f58979ae75f8e75a0c0ef6e7f89265b1c16 /src/qml/qml/qqmlcompiler.cpp
parent9ee6bb0e14d968647350683eafbe80eed7a27058 (diff)
Avoid dynamic lookup of signal handler arguments
Rewrite signal handlers to include the parameters in the rewrite. Also check whether parameters are actually used when possible, and if not don't provide them to the expression. Change-Id: I7d65c05f4639979dd61035cf7478119ef7647c25 Reviewed-by: Matthew Vogt <matthew.vogt@nokia.com> Reviewed-by: Kent Hansen <kent.hansen@nokia.com>
Diffstat (limited to 'src/qml/qml/qqmlcompiler.cpp')
-rw-r--r--src/qml/qml/qqmlcompiler.cpp20
1 files changed, 19 insertions, 1 deletions
diff --git a/src/qml/qml/qqmlcompiler.cpp b/src/qml/qml/qqmlcompiler.cpp
index ec1d19dd4e..ee8b30aab7 100644
--- a/src/qml/qml/qqmlcompiler.cpp
+++ b/src/qml/qml/qqmlcompiler.cpp
@@ -1323,8 +1323,17 @@ void QQmlCompiler::genObjectBody(QQmlScript::Object *obj)
Instruction::StoreSignal store;
store.signalIndex = prop->index;
- const QString &rewrite = rewriteSignalHandler(v->value, prop->name().toString());
+
+ const QList<QByteArray> &parameterNameList = obj->metatype->signalParameterNames(prop->index);
+ QQmlRewrite::RewriteSignalHandler rewriter;
+ int count = 0;
+ const QString &rewrite = rewriter(v->value.asAST(), v->value.asScript(),
+ prop->name().toString(),
+ obj->metatype->signalParameterStringForJS(prop->index, &count),
+ parameterNameList);
store.value = output->indexForByteArray(rewrite.toUtf8());
+ store.parameterCount =
+ (rewriter.parameterAccess() == QQmlRewrite::RewriteSignalHandler::ParametersUnaccessed) ? 0 : count;
store.context = v->signalExpressionContextStack;
store.line = v->location.start.line;
store.column = v->location.start.column;
@@ -1694,6 +1703,15 @@ bool QQmlCompiler::buildSignal(QQmlScript::Property *prop, QQmlScript::Object *o
if (script.isEmpty())
COMPILE_EXCEPTION(prop, tr("Empty signal assignment"));
+ //all handlers should be on the original, rather than cloned signals in order
+ //to ensure all parameters are available (see qqmlboundsignal constructor for more details)
+ prop->index = obj->metatype->originalClone(prop->index);
+
+ QString errorString;
+ obj->metatype->signalParameterStringForJS(prop->index, 0, &errorString);
+ if (!errorString.isEmpty())
+ COMPILE_EXCEPTION(prop, errorString);
+
prop->values.first()->signalExpressionContextStack = ctxt.stack;
}
}