Commit 66316433 authored by Ian Hickson's avatar Ian Hickson

Merge pull request #2984 from Hixie/table

More table fixes
parents 992fc76e bdfeaaa4
...@@ -491,7 +491,7 @@ class RenderTable extends RenderBox { ...@@ -491,7 +491,7 @@ class RenderTable extends RenderBox {
assert(_rows == 0); assert(_rows == 0);
return; return;
} }
for (RenderBox oldChild in cells) { for (RenderBox oldChild in _children) {
if (oldChild != null) if (oldChild != null)
dropChild(oldChild); dropChild(oldChild);
} }
...@@ -503,8 +503,8 @@ class RenderTable extends RenderBox { ...@@ -503,8 +503,8 @@ class RenderTable extends RenderBox {
assert(cells != null); assert(cells != null);
assert(cells.length % columns == 0); assert(cells.length % columns == 0);
// remove cells that are moving away // remove cells that are moving away
for (int y = 0; y < _columns; y += 1) { for (int y = 0; y < _rows; y += 1) {
for (int x = 0; x < _rows; x += 1) { for (int x = 0; x < _columns; x += 1) {
int xyOld = x + y * _columns; int xyOld = x + y * _columns;
int xyNew = x + y * columns; int xyNew = x + y * columns;
if (_children[xyOld] != null && (x >= columns || xyNew >= cells.length || _children[xyOld] != cells[xyNew])) if (_children[xyOld] != null && (x >= columns || xyNew >= cells.length || _children[xyOld] != cells[xyNew]))
...@@ -567,6 +567,8 @@ class RenderTable extends RenderBox { ...@@ -567,6 +567,8 @@ class RenderTable extends RenderBox {
assert(_children.length == rows * columns); assert(_children.length == rows * columns);
final int xy = x + y * columns; final int xy = x + y * columns;
RenderBox oldChild = _children[xy]; RenderBox oldChild = _children[xy];
if (oldChild == value)
return;
if (oldChild != null) if (oldChild != null)
dropChild(oldChild); dropChild(oldChild);
_children[xy] = value; _children[xy] = value;
...@@ -759,6 +761,7 @@ class RenderTable extends RenderBox { ...@@ -759,6 +761,7 @@ class RenderTable extends RenderBox {
RenderBox child = _children[xy]; RenderBox child = _children[xy];
if (child != null) { if (child != null) {
TableCellParentData childParentData = child.parentData; TableCellParentData childParentData = child.parentData;
assert(childParentData != null);
childParentData.x = x; childParentData.x = x;
childParentData.y = y; childParentData.y = y;
switch (childParentData.verticalAlignment ?? defaultVerticalAlignment) { switch (childParentData.verticalAlignment ?? defaultVerticalAlignment) {
......
...@@ -71,4 +71,24 @@ void main() { ...@@ -71,4 +71,24 @@ void main() {
table.rows = 4; table.rows = 4;
expect(child.attached, isFalse); expect(child.attached, isFalse);
}); });
test('Table test: replacing cells', () {
RenderTable table;
RenderBox child1 = new RenderPositionedBox();
RenderBox child2 = new RenderPositionedBox();
RenderBox child3 = new RenderPositionedBox();
table = new RenderTable();
table.setFlatChildren(3, <RenderBox>[child1, new RenderPositionedBox(), child2,
new RenderPositionedBox(), child3, new RenderPositionedBox()]);
expect(table.rows, equals(2));
layout(table);
table.setFlatChildren(3, <RenderBox>[new RenderPositionedBox(), child1, new RenderPositionedBox(),
child2, new RenderPositionedBox(), child3]);
layout(table);
table.setFlatChildren(3, <RenderBox>[new RenderPositionedBox(), child1, new RenderPositionedBox(),
child2, new RenderPositionedBox(), child3]);
layout(table);
expect(table.columns, equals(3));
expect(table.rows, equals(2));
});
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment