// 'BuildContext' argument which you can pass to Theme.of() and other
// 'BuildContext' argument which you can pass to Theme.of() and other
// InheritedWidget APIs which eventually trigger a rebuild.)
// InheritedWidget APIs which eventually trigger a rebuild.)
assert((){
assert((){
thrownewWidgetError('$runtimeType failed to implement reinvokeBuilders(), but got marked dirty.');
thrownewWidgetError(
'$runtimeType failed to implement reinvokeBuilders(), but got marked dirty.\n'
'If a RenderObjectElement subclass supports being marked dirty, then the '
'reinvokeBuilders() method must be implemented.\n'
'If a RenderObjectElement uses a builder callback, it must support being '
'marked dirty, because builder callbacks can register the object as having '
'an Inherited dependency.'
);
});
});
}
}
...
@@ -1812,7 +1838,11 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -1812,7 +1838,11 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
continue;// when these nodes are reordered, we just reassign the data
continue;// when these nodes are reordered, we just reassign the data
if(!idSet.add(child.key)){
if(!idSet.add(child.key)){
thrownewWidgetError('If multiple keyed nodes exist as children of another node, they must have unique keys. $widget has multiple children with key "${child.key}".');
thrownewWidgetError(
'Duplicate keys found.\n'
'If multiple keyed nodes exist as children of another node, they must have unique keys.\n'
'$widget has multiple children with key "${child.key}".'
);
}
}
}
}
returnfalse;
returnfalse;
...
@@ -1841,16 +1871,10 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -1841,16 +1871,10 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
thrownewWidgetError('Having both a pan gesture recognizer and a scale gesture recognizer is redundant; scale is a superset of pan. Just use the scale gesture recognizer.');
thrownewWidgetError(
'Incorrect GestureDetector arguments.\n'
'Having both a pan gesture recognizer and a scale gesture recognizer is redundant; scale is a superset of pan. Just use the scale gesture recognizer.'
);
}
Stringrecognizer=havePan?'pan':'scale';
Stringrecognizer=havePan?'pan':'scale';
if(haveVerticalDrag&&haveHorizontalDrag)
if(haveVerticalDrag&&haveHorizontalDrag){
thrownewWidgetError('Simultaneously having a vertical drag gesture recognizer, a horizontal drag gesture recognizer, and a $recognizer gesture recognizer will result in the $recognizer gesture recognizer being ignored, since the other two will catch all drags.');
thrownewWidgetError(
'Incorrect GestureDetector arguments.\n'
'Simultaneously having a vertical drag gesture recognizer, a horizontal drag gesture recognizer, and a $recognizer gesture recognizer '
'will result in the $recognizer gesture recognizer being ignored, since the other two will catch all drags.'
);
}
}
}
returntrue;
returntrue;
});
});
...
@@ -279,8 +288,15 @@ class RawGestureDetectorState extends State<RawGestureDetector> {
...
@@ -279,8 +288,15 @@ class RawGestureDetectorState extends State<RawGestureDetector> {
thrownewWidgetError('openTransaction called with a context that does not include a Navigator. The context passed to the Navigator.openTransaction() method must be that of a widget that is a descendant of a Navigator widget.');
thrownewWidgetError(
'openTransaction called with a context that does not include a Navigator.\n'
'The context passed to the Navigator.openTransaction() method must be that of a widget that is a descendant of a Navigator widget.'