Unverified Commit 2ea9edc1 authored by Kate Lovett's avatar Kate Lovett Committed by GitHub

Update KeepAlive.debugTypicalAncestorWidgetClass (#133498)

parent b4953c37
...@@ -1577,8 +1577,7 @@ class _ActionButtonParentDataWidget ...@@ -1577,8 +1577,7 @@ class _ActionButtonParentDataWidget
} }
@override @override
Type get debugTypicalAncestorWidgetClass => Type get debugTypicalAncestorWidgetClass => _CupertinoDialogActionsRenderWidget;
_CupertinoDialogActionsRenderWidget;
} }
// ParentData applied to individual action buttons that report whether or not // ParentData applied to individual action buttons that report whether or not
......
...@@ -1592,15 +1592,19 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget { ...@@ -1592,15 +1592,19 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget {
return renderObject.parentData is T; return renderObject.parentData is T;
} }
/// The [RenderObjectWidget] that is typically used to set up the [ParentData] /// Describes the [RenderObjectWidget] that is typically used to set up the
/// that [applyParentData] will write to. /// [ParentData] that [applyParentData] will write to.
/// ///
/// This is only used in error messages to tell users what widget typically /// This is only used in error messages to tell users what widget typically
/// wraps this [ParentDataWidget]. /// wraps this [ParentDataWidget] through
/// [debugTypicalAncestorWidgetDescription].
/// ///
/// ## Implementations /// ## Implementations
/// ///
/// The returned type should be a subclass of `RenderObjectWidget`. /// The returned Type should describe a subclass of `RenderObjectWidget`. If
/// more than one Type is supported, use
/// [debugTypicalAncestorWidgetDescription], which typically inserts this
/// value but can be overridden to describe more than one Type.
/// ///
/// ```dart /// ```dart
/// @override /// @override
...@@ -1612,6 +1616,16 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget { ...@@ -1612,6 +1616,16 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget {
/// type is specialized), or specifying the upper bound (e.g. `Foo<Object?>`). /// type is specialized), or specifying the upper bound (e.g. `Foo<Object?>`).
Type get debugTypicalAncestorWidgetClass; Type get debugTypicalAncestorWidgetClass;
/// Describes the [RenderObjectWidget] that is typically used to set up the
/// [ParentData] that [applyParentData] will write to.
///
/// This is only used in error messages to tell users what widget typically
/// wraps this [ParentDataWidget].
///
/// Returns [debugTypicalAncestorWidgetClass] by default as a String. This can
/// be overridden to describe more than one Type of valid parent.
String get debugTypicalAncestorWidgetDescription => '$debugTypicalAncestorWidgetClass';
Iterable<DiagnosticsNode> _debugDescribeIncorrectParentDataType({ Iterable<DiagnosticsNode> _debugDescribeIncorrectParentDataType({
required ParentData? parentData, required ParentData? parentData,
RenderObjectWidget? parentDataCreator, RenderObjectWidget? parentDataCreator,
...@@ -1632,7 +1646,7 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget { ...@@ -1632,7 +1646,7 @@ abstract class ParentDataWidget<T extends ParentData> extends ProxyWidget {
), ),
ErrorHint( ErrorHint(
'Usually, this means that the $runtimeType widget has the wrong ancestor RenderObjectWidget. ' 'Usually, this means that the $runtimeType widget has the wrong ancestor RenderObjectWidget. '
'Typically, $runtimeType widgets are placed directly inside $debugTypicalAncestorWidgetClass widgets.', 'Typically, $runtimeType widgets are placed directly inside $debugTypicalAncestorWidgetDescription widgets.',
), ),
if (parentDataCreator != null) if (parentDataCreator != null)
ErrorHint( ErrorHint(
...@@ -6300,7 +6314,7 @@ abstract class RenderObjectElement extends Element { ...@@ -6300,7 +6314,7 @@ abstract class RenderObjectElement extends Element {
ErrorSummary('Incorrect use of ParentDataWidget.'), ErrorSummary('Incorrect use of ParentDataWidget.'),
ErrorDescription('The following ParentDataWidgets are providing parent data to the same RenderObject:'), ErrorDescription('The following ParentDataWidgets are providing parent data to the same RenderObject:'),
for (final ParentDataElement<ParentData> ancestor in badAncestors) for (final ParentDataElement<ParentData> ancestor in badAncestors)
ErrorDescription('- ${ancestor.widget} (typically placed directly inside a ${(ancestor.widget as ParentDataWidget<ParentData>).debugTypicalAncestorWidgetClass} widget)'), ErrorDescription('- ${ancestor.widget} (typically placed directly inside a ${(ancestor.widget as ParentDataWidget<ParentData>).debugTypicalAncestorWidgetDescription} widget)'),
ErrorDescription('However, a RenderObject can only receive parent data from at most one ParentDataWidget.'), ErrorDescription('However, a RenderObject can only receive parent data from at most one ParentDataWidget.'),
ErrorHint('Usually, this indicates that at least one of the offending ParentDataWidgets listed above is not placed directly inside a compatible ancestor widget.'), ErrorHint('Usually, this indicates that at least one of the offending ParentDataWidgets listed above is not placed directly inside a compatible ancestor widget.'),
ErrorDescription('The ownership chain for the RenderObject that received the parent data was:\n ${debugGetCreatorChain(10)}'), ErrorDescription('The ownership chain for the RenderObject that received the parent data was:\n ${debugGetCreatorChain(10)}'),
......
...@@ -1311,8 +1311,8 @@ class _SliverOffstageElement extends SingleChildRenderObjectElement { ...@@ -1311,8 +1311,8 @@ class _SliverOffstageElement extends SingleChildRenderObjectElement {
/// Mark a child as needing to stay alive even when it's in a lazy list that /// Mark a child as needing to stay alive even when it's in a lazy list that
/// would otherwise remove it. /// would otherwise remove it.
/// ///
/// This widget is for use in [SliverWithKeepAliveWidget]s, such as /// This widget is for use in a [RenderAbstractViewport]s, such as
/// [SliverGrid] or [SliverList]. /// [Viewport] or [TwoDimensionalViewport].
/// ///
/// This widget is rarely used directly. The [SliverChildBuilderDelegate] and /// This widget is rarely used directly. The [SliverChildBuilderDelegate] and
/// [SliverChildListDelegate] delegates, used with [SliverList] and /// [SliverChildListDelegate] delegates, used with [SliverList] and
...@@ -1322,6 +1322,9 @@ class _SliverOffstageElement extends SingleChildRenderObjectElement { ...@@ -1322,6 +1322,9 @@ class _SliverOffstageElement extends SingleChildRenderObjectElement {
/// each child, causing [KeepAlive] widgets to be automatically added and /// each child, causing [KeepAlive] widgets to be automatically added and
/// configured in response to [KeepAliveNotification]s. /// configured in response to [KeepAliveNotification]s.
/// ///
/// The same `addAutomaticKeepAlives` feature is supported by the
/// [TwoDimensionalChildBuilderDelegate] and [TwoDimensionalChildListDelegate].
///
/// Therefore, to keep a widget alive, it is more common to use those /// Therefore, to keep a widget alive, it is more common to use those
/// notifications than to directly deal with [KeepAlive] widgets. /// notifications than to directly deal with [KeepAlive] widgets.
/// ///
...@@ -1365,7 +1368,10 @@ class KeepAlive extends ParentDataWidget<KeepAliveParentDataMixin> { ...@@ -1365,7 +1368,10 @@ class KeepAlive extends ParentDataWidget<KeepAliveParentDataMixin> {
bool debugCanApplyOutOfTurn() => keepAlive; bool debugCanApplyOutOfTurn() => keepAlive;
@override @override
Type get debugTypicalAncestorWidgetClass => SliverWithKeepAliveWidget; Type get debugTypicalAncestorWidgetClass => throw FlutterError('Multiple Types are supported, use debugTypicalAncestorWidgetDescription.');
@override
String get debugTypicalAncestorWidgetDescription => 'SliverWithKeepAliveWidget or TwoDimensionalViewport';
@override @override
void debugFillProperties(DiagnosticPropertiesBuilder properties) { void debugFillProperties(DiagnosticPropertiesBuilder properties) {
......
...@@ -47,6 +47,14 @@ List<Widget> generateList(Widget child) { ...@@ -47,6 +47,14 @@ List<Widget> generateList(Widget child) {
} }
void main() { void main() {
test('KeepAlive debugTypicalAncestorWidgetClass', () {
final KeepAlive keepAlive = KeepAlive(keepAlive: false, child: Container());
expect(
keepAlive.debugTypicalAncestorWidgetDescription,
'SliverWithKeepAliveWidget or TwoDimensionalViewport',
);
});
testWidgetsWithLeakTracking('KeepAlive with ListView with itemExtent', (WidgetTester tester) async { testWidgetsWithLeakTracking('KeepAlive with ListView with itemExtent', (WidgetTester tester) async {
await tester.pumpWidget( await tester.pumpWidget(
Directionality( Directionality(
......
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