From 7f33f64d25fd3b01301f5998118f5cdf63cbb7a2 Mon Sep 17 00:00:00 2001 From: konsoletyper Date: Mon, 9 Mar 2015 22:20:59 +0300 Subject: [PATCH] Store postponed actions in a queue --- .../resources/org/teavm/javascript/runtime.js | 41 +++++++++---------- 1 file changed, 20 insertions(+), 21 deletions(-) diff --git a/teavm-core/src/main/resources/org/teavm/javascript/runtime.js b/teavm-core/src/main/resources/org/teavm/javascript/runtime.js index d13941d6d..88d9ddef4 100644 --- a/teavm-core/src/main/resources/org/teavm/javascript/runtime.js +++ b/teavm-core/src/main/resources/org/teavm/javascript/runtime.js @@ -460,10 +460,10 @@ function $rt_rootInvocationAdapter(f) { }); f.apply(this, args); var thread = $rt_getThread(); - while (thread.postponed) { - var postponed = thread.postponed; - thread.postponed = null; - postponed(); + if (thread.hasOwnProperty("postponed")) { + while (thread.postponed.length > 0) { + thread.postponed.shift()(); + } } } } @@ -491,23 +491,22 @@ function $rt_s(index) { } var $rt_continueCounter = 0; function $rt_continue(f) { - if ($rt_continueCounter++ == 5) { - $rt_continueCounter = 0; - return function() { - var self = this; - var args = arguments; - var thread = $rt_getThread(); - var oldPostponed = thread.postponed; - thread.postponed = function() { - if (oldPostponed) { - oldPostponed(); - } - f.apply(self, args); - }; - }; - } else { - return f; - } + if ($rt_continueCounter++ == 5) { + $rt_continueCounter = 0; + return function() { + var self = this; + var args = arguments; + var thread = $rt_getThread(); + if (!thread.hasOwnProperty("postponed")) { + thread.postponed = []; + } + thread.postponed.push(function() { + f.apply(self, args); + }); + }; + } else { + return f; + } } function $rt_guardAsync(f, continuation) { return function() {