aboutsummaryrefslogtreecommitdiffstats
path: root/src/qml/compiler/qv4codegen_p.h
diff options
context:
space:
mode:
authorLars Knoll <lars.knoll@digia.com>2013-10-21 17:07:45 +0200
committerThe Qt Project <gerrit-noreply@qt-project.org>2013-10-29 10:38:48 +0100
commit34bf0139c75de861c948391737af3c8c2a42703c (patch)
tree3eeeb615078c27b30e15a77adcda7d6537baef17 /src/qml/compiler/qv4codegen_p.h
parent5229a8b259286c9ea61036fd6b4bd0039104a206 (diff)
Rework IR code generation for try/catch/finally
Simplify the generated code. Add a special block to catch exceptions thrown inside a catch() statement. store the exception on the stack when entering finally and rethrow it at the end. This ensure correct behavior for break/continue/return statements inside finally. Don't check for exceptions after calling push_catch_scope and pop_scope in the JIT'ed code. This can lead to infinite loops when throwing inside an exception handler. Change-Id: I67e9325794e2fd25b0773b21e02fbaadb43faab0 Change-Id: Ic1ea9c0c43eec1d49177dc1ab4552a1da04e96fe Reviewed-by: Simon Hausmann <simon.hausmann@digia.com>
Diffstat (limited to 'src/qml/compiler/qv4codegen_p.h')
-rw-r--r--src/qml/compiler/qv4codegen_p.h7
1 files changed, 3 insertions, 4 deletions
diff --git a/src/qml/compiler/qv4codegen_p.h b/src/qml/compiler/qv4codegen_p.h
index 652f395a88..b0d1962bca 100644
--- a/src/qml/compiler/qv4codegen_p.h
+++ b/src/qml/compiler/qv4codegen_p.h
@@ -238,12 +238,11 @@ protected:
ScopeAndFinally *parent;
AST::Finally *finally;
- V4IR::ExprList *finishTryArgs;
ScopeType type;
- ScopeAndFinally(ScopeAndFinally *parent, ScopeType t = WithScope) : parent(parent), finally(0), finishTryArgs(0), type(t) {}
- ScopeAndFinally(ScopeAndFinally *parent, AST::Finally *finally, V4IR::ExprList *finishTryArgs)
- : parent(parent), finally(finally), finishTryArgs(finishTryArgs), type(TryScope)
+ ScopeAndFinally(ScopeAndFinally *parent, ScopeType t = WithScope) : parent(parent), finally(0), type(t) {}
+ ScopeAndFinally(ScopeAndFinally *parent, AST::Finally *finally)
+ : parent(parent), finally(finally), type(TryScope)
{}
};