Commit 501b948e authored by Adam Barth's avatar Adam Barth

Remove bogus intrinsic size assert

This patch tweaks the definition of max intrinsic size to give implementations
more wiggle room to compute there intrinsic sizes more efficiently.
Specifically, implementations can now ignore the incomming constraint in the
cross axis if they prefer.

This patch removes an assert that is no longer valid w.r.t. the new definition
of intrinsic sizing.

Fixes #2099
parent 0e675be6
...@@ -151,11 +151,6 @@ class RenderBlock extends RenderBlockBase { ...@@ -151,11 +151,6 @@ class RenderBlock extends RenderBlockBase {
double childExtent = isVertical ? double childExtent = isVertical ?
child.getMinIntrinsicHeight(innerConstraints) : child.getMinIntrinsicHeight(innerConstraints) :
child.getMinIntrinsicWidth(innerConstraints); child.getMinIntrinsicWidth(innerConstraints);
assert(() {
if (isVertical)
return childExtent == child.getMaxIntrinsicHeight(innerConstraints);
return childExtent == child.getMaxIntrinsicWidth(innerConstraints);
});
extent += childExtent; extent += childExtent;
final BlockParentData childParentData = child.parentData; final BlockParentData childParentData = child.parentData;
child = childParentData.nextSibling; child = childParentData.nextSibling;
......
...@@ -419,7 +419,7 @@ abstract class RenderBox extends RenderObject { ...@@ -419,7 +419,7 @@ abstract class RenderBox extends RenderObject {
} }
/// Returns the smallest width beyond which increasing the width never /// Returns the smallest width beyond which increasing the width never
/// decreases the height. /// decreases the preferred height.
/// ///
/// Override in subclasses that implement [performLayout]. /// Override in subclasses that implement [performLayout].
double getMaxIntrinsicWidth(BoxConstraints constraints) { double getMaxIntrinsicWidth(BoxConstraints constraints) {
...@@ -437,7 +437,7 @@ abstract class RenderBox extends RenderObject { ...@@ -437,7 +437,7 @@ abstract class RenderBox extends RenderObject {
} }
/// Returns the smallest height beyond which increasing the height never /// Returns the smallest height beyond which increasing the height never
/// decreases the width. /// decreases the preferred width.
/// ///
/// If the layout algorithm used is width-in-height-out, i.e. the height /// If the layout algorithm used is width-in-height-out, i.e. the height
/// depends on the width and not vice versa, then this will return the same /// depends on the width and not vice versa, then this will return the same
......
...@@ -166,7 +166,7 @@ abstract class GridDelegate { ...@@ -166,7 +166,7 @@ abstract class GridDelegate {
} }
/// Returns the smallest width beyond which increasing the width never /// Returns the smallest width beyond which increasing the width never
/// decreases the height. /// decreases the preferred height.
double getMaxIntrinsicWidth(BoxConstraints constraints, int childCount) { double getMaxIntrinsicWidth(BoxConstraints constraints, int childCount) {
return constraints.constrainWidth(_getGridSize(constraints, childCount).width); return constraints.constrainWidth(_getGridSize(constraints, childCount).width);
} }
...@@ -178,7 +178,7 @@ abstract class GridDelegate { ...@@ -178,7 +178,7 @@ abstract class GridDelegate {
} }
/// Returns the smallest height beyond which increasing the height never /// Returns the smallest height beyond which increasing the height never
/// decreases the width. /// decreases the preferred width.
double getMaxIntrinsicHeight(BoxConstraints constraints, int childCount) { double getMaxIntrinsicHeight(BoxConstraints constraints, int childCount) {
return constraints.constrainHeight(_getGridSize(constraints, childCount).height); return constraints.constrainHeight(_getGridSize(constraints, childCount).height);
} }
......
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