From 8a4d849a0152c76bd9107a1b38a641cf8c0ff226 Mon Sep 17 00:00:00 2001 From: Aaron Kennedy Date: Thu, 27 Oct 2011 13:34:16 +0100 Subject: [PATCH] [V8] Introduce a QML compilation mode In QML mode, there is a second global object - known as the QML global object. During property resolution, if a property is not present on the JS global object, it is resolved on the QML global object. This global object behavior is only enabled if a script is being compiled in QML mode. The object to use as the QML global object is passed as a parameter to the Script::Run() method. Any function closures etc. created during the run will retain a reference to this object, so different objects can be passed in different script runs. Change-Id: Ib6b4ed363b7e8089d38a9cdcfb0d3b314dc333ca Reviewed-by: Simon Hausmann --- src/3rdparty/v8/include/v8.h | 19 ++++-- src/3rdparty/v8/src/api.cc | 47 +++++++++++--- src/3rdparty/v8/src/arm/code-stubs-arm.cc | 8 +++ src/3rdparty/v8/src/arm/full-codegen-arm.cc | 28 +++++---- src/3rdparty/v8/src/arm/lithium-arm.cc | 4 +- src/3rdparty/v8/src/arm/lithium-arm.h | 12 +++- src/3rdparty/v8/src/arm/lithium-codegen-arm.cc | 9 +-- src/3rdparty/v8/src/arm/macro-assembler-arm.h | 5 ++ src/3rdparty/v8/src/ast-inl.h | 5 ++ src/3rdparty/v8/src/ast.cc | 5 ++ src/3rdparty/v8/src/ast.h | 1 + src/3rdparty/v8/src/bootstrapper.cc | 2 + src/3rdparty/v8/src/code-stubs.h | 4 +- src/3rdparty/v8/src/compiler.cc | 15 ++++- src/3rdparty/v8/src/compiler.h | 16 ++++- src/3rdparty/v8/src/contexts.cc | 35 +++++++++++ src/3rdparty/v8/src/contexts.h | 4 ++ src/3rdparty/v8/src/execution.cc | 31 ++++++++-- src/3rdparty/v8/src/execution.h | 8 +++ src/3rdparty/v8/src/full-codegen.cc | 3 +- src/3rdparty/v8/src/full-codegen.h | 1 + src/3rdparty/v8/src/heap.cc | 4 ++ src/3rdparty/v8/src/hydrogen-instructions.cc | 5 ++ src/3rdparty/v8/src/hydrogen-instructions.h | 21 ++++++- src/3rdparty/v8/src/hydrogen.cc | 4 ++ src/3rdparty/v8/src/ia32/code-stubs-ia32.cc | 9 +++ src/3rdparty/v8/src/ia32/full-codegen-ia32.cc | 28 +++++---- src/3rdparty/v8/src/ia32/lithium-codegen-ia32.cc | 9 +-- src/3rdparty/v8/src/ia32/lithium-ia32.cc | 4 +- src/3rdparty/v8/src/ia32/lithium-ia32.h | 12 +++- src/3rdparty/v8/src/ia32/macro-assembler-ia32.h | 3 + src/3rdparty/v8/src/mips/code-stubs-mips.cc | 9 +++ src/3rdparty/v8/src/mips/full-codegen-mips.cc | 29 +++++---- src/3rdparty/v8/src/mips/macro-assembler-mips.h | 5 ++ src/3rdparty/v8/src/objects-inl.h | 2 + src/3rdparty/v8/src/objects.h | 7 +++ src/3rdparty/v8/src/parser.cc | 28 +++++++-- src/3rdparty/v8/src/parser.h | 4 +- src/3rdparty/v8/src/prettyprinter.cc | 3 + src/3rdparty/v8/src/runtime.cc | 78 ++++++++++++++++-------- src/3rdparty/v8/src/runtime.h | 6 +- src/3rdparty/v8/src/scopeinfo.cc | 28 +++++++-- src/3rdparty/v8/src/scopeinfo.h | 1 + src/3rdparty/v8/src/scopes.cc | 63 +++++++++++++++++++ src/3rdparty/v8/src/scopes.h | 8 +++ src/3rdparty/v8/src/variables.cc | 3 +- src/3rdparty/v8/src/variables.h | 5 ++ src/3rdparty/v8/src/x64/code-stubs-x64.cc | 8 +++ src/3rdparty/v8/src/x64/full-codegen-x64.cc | 27 ++++---- src/3rdparty/v8/src/x64/lithium-codegen-x64.cc | 9 +-- src/3rdparty/v8/src/x64/lithium-x64.cc | 4 +- src/3rdparty/v8/src/x64/lithium-x64.h | 12 ++++ src/3rdparty/v8/src/x64/macro-assembler-x64.h | 5 ++ 53 files changed, 566 insertions(+), 139 deletions(-) diff --git a/src/3rdparty/v8/include/v8.h b/src/3rdparty/v8/include/v8.h index 3ef4dd6..193e2fe 100644 --- a/src/3rdparty/v8/include/v8.h +++ b/src/3rdparty/v8/include/v8.h @@ -587,6 +587,11 @@ class ScriptOrigin { */ class V8EXPORT Script { public: + enum CompileFlags { + Default = 0x00, + QmlMode = 0x01 + }; + /** * Compiles the specified script (context-independent). * @@ -605,7 +610,8 @@ class V8EXPORT Script { static Local