Fix an issue in _clearBoundsCache where circular recursion could happen in certain circumstances.

This commit is contained in:
Jürg Lehni 2014-05-15 21:24:09 +02:00
parent f39b7603de
commit a1c1fc8ed8

View file

@ -945,7 +945,7 @@ var Item = Base.extend(Callback, /** @lends Item# */{
var _matrix = internalGetter ? null : this._matrix.orNullIfIdentity(), var _matrix = internalGetter ? null : this._matrix.orNullIfIdentity(),
cache = (!matrix || matrix.equals(_matrix)) && getter; cache = (!matrix || matrix.equals(_matrix)) && getter;
// Set up a boundsCache structure that keeps track of items that keep // Set up a boundsCache structure that keeps track of items that keep
// cached bounds that depend on this item. We store this in our parent, // cached bounds that depend on this item. We store this in the parent,
// for multiple reasons: // for multiple reasons:
// The parent receives CHILDREN change notifications for when its // The parent receives CHILDREN change notifications for when its
// children are added or removed and can thus clear the cache, and we // children are added or removed and can thus clear the cache, and we
@ -1011,15 +1011,17 @@ var Item = Base.extend(Callback, /** @lends Item# */{
if (item._boundsCache) { if (item._boundsCache) {
for (var i = 0, list = item._boundsCache.list, l = list.length; for (var i = 0, list = item._boundsCache.list, l = list.length;
i < l; i++) { i < l; i++) {
var child = list[i]; var other = list[i];
if (child !== item) { if (other && other !== item) {
child._bounds = child._position = undefined; other._bounds = other._position = undefined;
// We need to recursively call _clearBoundsCache, // We need to recursively call _clearBoundsCache, as
// because when the cache for this child's children is // when the cache for the other item's children is not
// not valid anymore, that propagates up the DOM tree. // valid anymore, that propagates up the DOM tree.
if (child._boundsCache) if (other._boundsCache)
Item._clearBoundsCache(child); Item._clearBoundsCache(other);
} }
// Erase entry now, to prevent circular recursion.
list[i] = null;
} }
// Clear the item itself, as well as its bounds cache. // Clear the item itself, as well as its bounds cache.
item._bounds = item._position = item._boundsCache = undefined; item._bounds = item._position = item._boundsCache = undefined;