Fix issue with Item#removeChildren(from, to) removing too many items.

This commit is contained in:
Jürg Lehni 2011-12-26 02:39:54 +01:00
parent 7af06502bc
commit c552925426

View file

@ -1265,6 +1265,7 @@ function(name) {
this.setSelected(false); this.setSelected(false);
if (this._name) if (this._name)
this._removeFromNamed(); this._removeFromNamed();
if (this._index != null)
Base.splice(this._parent._children, null, this._index, 1); Base.splice(this._parent._children, null, this._index, 1);
// Notify parent of changed hierarchy // Notify parent of changed hierarchy
if (notify) if (notify)
@ -1307,7 +1308,10 @@ function(name) {
return null; return null;
from = from || 0; from = from || 0;
to = Base.pick(to, this._children.length); to = Base.pick(to, this._children.length);
var removed = this._children.splice(from, to - from); // Use Base.splice(), wich adjusts #_index for the items above, and
// deletes it for the removed items. Calling #_remove() afterwards is
// fine, since it only calls Base.splice() if #_index is set.
var removed = Base.splice(this._children, null, from, to - from);
for (var i = removed.length - 1; i >= 0; i--) for (var i = removed.length - 1; i >= 0; i--)
removed[i]._remove(true, false); removed[i]._remove(true, false);
if (removed.length > 0) if (removed.length > 0)