Improve handling of bounds caching.

Cloning was done in the wrong place.
This commit is contained in:
Jürg Lehni 2013-02-24 14:56:51 -08:00
parent 0a81787c7e
commit afac35fabf

View file

@ -634,8 +634,12 @@ var Item = this.Item = Base.extend(Callback, {
// If we're returning 'bounds', create a LinkedRectangle that uses // If we're returning 'bounds', create a LinkedRectangle that uses
// the setBounds() setter to update the Item whenever the bounds are // the setBounds() setter to update the Item whenever the bounds are
// changed: // changed:
return name == 'bounds' ? LinkedRectangle.create(this, 'setBounds', return name == 'getBounds'
bounds.x, bounds.y, bounds.width, bounds.height) : bounds; ? LinkedRectangle.create(this, 'setBounds',
bounds.x, bounds.y, bounds.width, bounds.height)
// Return a clone of the cahce, so modifications won't
// affect it.
: bounds.clone();
}; };
}, },
/** @lends Item# */{ /** @lends Item# */{
@ -691,9 +695,7 @@ var Item = this.Item = Base.extend(Callback, {
if (cache) { if (cache) {
if (!this._bounds) if (!this._bounds)
this._bounds = {}; this._bounds = {};
// Put a separate instance into the cache, so modifications of the this._bounds[cache] = bounds;
// returned one won't affect it.
this._bounds[cache] = bounds.clone();
} }
return bounds; return bounds;
}, },