mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Fix an issue in _clearBoundsCache where circular recursion could happen in certain circumstances.
This commit is contained in:
parent
f39b7603de
commit
a1c1fc8ed8
1 changed files with 11 additions and 9 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue