From 96b886ae8d6fa64f3635db73f0cc78adc5ec0de8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Tue, 9 Apr 2013 22:38:23 -0700 Subject: [PATCH] Avoid endless recursion when changing view from onFrame handler. Closes #184. --- src/ui/View.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/ui/View.js b/src/ui/View.js index 2ada1cc8..80ee4b61 100644 --- a/src/ui/View.js +++ b/src/ui/View.js @@ -183,6 +183,7 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{ var now = Date.now() / 1000, delta = this._before ? now - this._before : 0; this._before = now; + this._handlingFrame = true; // Use Base.merge to convert into a Base object, for #toString() this.fire('frame', Base.merge({ // Time elapsed since last redraw in seconds: @@ -194,6 +195,7 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{ // Update framerate stats if (this._stats) this._stats.update(); + this._handlingFrame = false; // Automatically draw view on each frame. this.draw(true); }, @@ -234,6 +236,8 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{ _redraw: function() { this._redrawNeeded = true; + if (this._handlingFrame) + return; if (this._animate) { // If we're animating, call _handleFrame staight away, but without // requesting another animation frame.