Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
6d4221cb
Commit
6d4221cb
authored
Oct 28, 2015
by
Ian Hickson
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1851 from Hixie/MixedViewport-bug
Fix crash when removing a card in card_collection
parents
58013dc8
a8a32a97
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
77 additions
and
17 deletions
+77
-17
card_collection.dart
examples/widgets/card_collection.dart
+1
-1
homogeneous_viewport.dart
packages/flutter/lib/src/widgets/homogeneous_viewport.dart
+1
-1
mixed_viewport.dart
packages/flutter/lib/src/widgets/mixed_viewport.dart
+18
-6
scrollable_list_with_inherited_test.dart
...unit/test/widget/scrollable_list_with_inherited_test.dart
+47
-0
test_widgets.dart
packages/unit/test/widget/test_widgets.dart
+10
-9
No files found.
examples/widgets/card_collection.dart
View file @
6d4221cb
...
@@ -301,7 +301,7 @@ class CardCollectionState extends State<CardCollection> {
...
@@ -301,7 +301,7 @@ class CardCollectionState extends State<CardCollection> {
)
)
:
new
DefaultTextStyle
(
:
new
DefaultTextStyle
(
style:
DefaultTextStyle
.
of
(
context
).
merge
(
cardLabelStyle
).
merge
(
_textStyle
).
copyWith
(
style:
DefaultTextStyle
.
of
(
context
).
merge
(
cardLabelStyle
).
merge
(
_textStyle
).
copyWith
(
fontSize:
_varyFontSizes
?
5.0
+
_cardModels
.
length
.
toDouble
()
:
null
fontSize:
_varyFontSizes
?
_cardModels
.
length
.
toDouble
()
:
null
),
),
child:
new
Column
(<
Widget
>[
child:
new
Column
(<
Widget
>[
new
Text
(
cardModel
.
label
)
new
Text
(
cardModel
.
label
)
...
...
packages/flutter/lib/src/widgets/homogeneous_viewport.dart
View file @
6d4221cb
...
@@ -140,7 +140,7 @@ class _HomogeneousViewportElement extends RenderObjectElement<HomogeneousViewpor
...
@@ -140,7 +140,7 @@ class _HomogeneousViewportElement extends RenderObjectElement<HomogeneousViewpor
renderObject
.
minExtent
=
getTotalExtent
(
null
);
renderObject
.
minExtent
=
getTotalExtent
(
null
);
renderObject
.
startOffset
=
offset
;
renderObject
.
startOffset
=
offset
;
renderObject
.
overlayPainter
=
widget
.
overlayPainter
;
renderObject
.
overlayPainter
=
widget
.
overlayPainter
;
});
}
,
building:
true
);
}
}
void
_updateChildren
()
{
void
_updateChildren
()
{
...
...
packages/flutter/lib/src/widgets/mixed_viewport.dart
View file @
6d4221cb
...
@@ -17,7 +17,7 @@ enum _ChangeDescription { none, scrolled, resized }
...
@@ -17,7 +17,7 @@ enum _ChangeDescription { none, scrolled, resized }
class
MixedViewport
extends
RenderObjectWidget
{
class
MixedViewport
extends
RenderObjectWidget
{
MixedViewport
({
MixedViewport
({
Key
key
,
Key
key
,
this
.
startOffset
,
this
.
startOffset
:
0.0
,
this
.
direction
:
ScrollDirection
.
vertical
,
this
.
direction
:
ScrollDirection
.
vertical
,
this
.
builder
,
this
.
builder
,
this
.
token
,
this
.
token
,
...
@@ -28,9 +28,9 @@ class MixedViewport extends RenderObjectWidget {
...
@@ -28,9 +28,9 @@ class MixedViewport extends RenderObjectWidget {
final
double
startOffset
;
final
double
startOffset
;
final
ScrollDirection
direction
;
final
ScrollDirection
direction
;
final
IndexedBuilder
builder
;
final
IndexedBuilder
builder
;
final
Object
token
;
final
Object
token
;
// change this if the list changed (i.e. there are added, removed, or resorted items)
final
ExtentsUpdateCallback
onExtentsUpdate
;
final
ExtentsUpdateCallback
onExtentsUpdate
;
final
InvalidatorAvailableCallback
onInvalidatorAvailable
;
final
InvalidatorAvailableCallback
onInvalidatorAvailable
;
// call the callback this gives to invalidate sizes
_MixedViewportElement
createElement
()
=>
new
_MixedViewportElement
(
this
);
_MixedViewportElement
createElement
()
=>
new
_MixedViewportElement
(
this
);
...
@@ -171,7 +171,16 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
...
@@ -171,7 +171,16 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
if
(
changes
!=
_ChangeDescription
.
none
||
!
isValid
)
{
if
(
changes
!=
_ChangeDescription
.
none
||
!
isValid
)
{
renderObject
.
markNeedsLayout
();
renderObject
.
markNeedsLayout
();
}
else
{
}
else
{
reinvokeBuilders
();
// We have to reinvoke our builders because they might return new data.
// Consider a stateful component that owns us. The builder it gives us
// includes some of the state from that component. The component calls
// setState() on itself. It rebuilds. Part of that involves rebuilding
// us, but now what? If we don't reinvoke the builders. then they will
// not be rebuilt, and so the new state won't be used.
// Note that if the builders are to change so much that the _sizes_ of
// the children would change, then the parent must change the 'token'.
if
(!
renderObject
.
needsLayout
)
reinvokeBuilders
();
}
}
}
}
...
@@ -207,7 +216,7 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
...
@@ -207,7 +216,7 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
}
}
BuildableElement
.
lockState
(()
{
BuildableElement
.
lockState
(()
{
_doLayout
(
constraints
);
_doLayout
(
constraints
);
});
}
,
building:
true
);
if
(
widget
.
onExtentsUpdate
!=
null
)
{
if
(
widget
.
onExtentsUpdate
!=
null
)
{
final
double
newExtents
=
_didReachLastChild
?
_childOffsets
.
last
:
null
;
final
double
newExtents
=
_didReachLastChild
?
_childOffsets
.
last
:
null
;
if
(
newExtents
!=
_lastReportedExtents
)
{
if
(
newExtents
!=
_lastReportedExtents
)
{
...
@@ -239,7 +248,10 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
...
@@ -239,7 +248,10 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
if
(
widget
.
builder
==
null
)
if
(
widget
.
builder
==
null
)
return
null
;
return
null
;
final
Widget
newWidget
=
widget
.
builder
(
this
,
index
);
final
Widget
newWidget
=
widget
.
builder
(
this
,
index
);
assert
(
newWidget
==
null
||
newWidget
.
key
!=
null
);
// every widget in a list must have a list-unique key
assert
(()
{
'Every widget in a list must have a list-unique key.'
;
return
newWidget
==
null
||
newWidget
.
key
!=
null
;
});
return
newWidget
;
return
newWidget
;
}
}
...
...
packages/unit/test/widget/scrollable_list_with_inherited_test.dart
0 → 100644
View file @
6d4221cb
import
'package:flutter/widgets.dart'
;
import
'package:test/test.dart'
;
import
'widget_tester.dart'
;
List
<
int
>
items
=
<
int
>[
0
,
1
,
2
,
3
,
4
,
5
];
Widget
buildCard
(
BuildContext
context
,
int
index
)
{
if
(
index
>=
items
.
length
)
return
null
;
return
new
Container
(
key:
new
ValueKey
<
int
>(
items
[
index
]),
height:
100.0
,
child:
new
DefaultTextStyle
(
style:
new
TextStyle
(
fontSize:
2.0
+
items
.
length
.
toDouble
()),
child:
new
Text
(
'
${items[index]}
'
)
)
);
}
InvalidatorCallback
invalidator
;
Widget
buildFrame
(
)
{
return
new
ScrollableMixedWidgetList
(
builder:
buildCard
,
token:
items
.
length
,
onInvalidatorAvailable:
(
InvalidatorCallback
callback
)
{
invalidator
=
callback
;
}
);
}
void
main
(
)
{
test
(
'MixedViewport is a build function (smoketest)'
,
()
{
testWidgets
((
WidgetTester
tester
)
{
tester
.
pumpWidget
(
buildFrame
());
expect
(
tester
.
findText
(
'0'
),
isNotNull
);
expect
(
tester
.
findText
(
'1'
),
isNotNull
);
expect
(
tester
.
findText
(
'2'
),
isNotNull
);
expect
(
tester
.
findText
(
'3'
),
isNotNull
);
items
.
removeAt
(
2
);
tester
.
pumpWidget
(
buildFrame
());
expect
(
tester
.
findText
(
'0'
),
isNotNull
);
expect
(
tester
.
findText
(
'1'
),
isNotNull
);
expect
(
tester
.
findText
(
'2'
),
isNull
);
expect
(
tester
.
findText
(
'3'
),
isNotNull
);
});
});
}
packages/unit/test/widget/test_widgets.dart
View file @
6d4221cb
...
@@ -15,6 +15,16 @@ final BoxDecoration kBoxDecorationC = new BoxDecoration(
...
@@ -15,6 +15,16 @@ final BoxDecoration kBoxDecorationC = new BoxDecoration(
backgroundColor:
const
Color
(
0xFF0000FF
)
backgroundColor:
const
Color
(
0xFF0000FF
)
);
);
class
TestBuildCounter
extends
StatelessComponent
{
static
int
buildCount
=
0
;
Widget
build
(
BuildContext
context
)
{
++
buildCount
;
return
new
DecoratedBox
(
decoration:
kBoxDecorationA
);
}
}
class
FlipComponent
extends
StatefulComponent
{
class
FlipComponent
extends
StatefulComponent
{
FlipComponent
({
Key
key
,
this
.
left
,
this
.
right
})
:
super
(
key:
key
);
FlipComponent
({
Key
key
,
this
.
left
,
this
.
right
})
:
super
(
key:
key
);
...
@@ -38,15 +48,6 @@ class FlipComponentState extends State<FlipComponent> {
...
@@ -38,15 +48,6 @@ class FlipComponentState extends State<FlipComponent> {
}
}
}
}
class
TestBuildCounter
extends
StatelessComponent
{
static
int
buildCount
=
0
;
Widget
build
(
BuildContext
context
)
{
++
buildCount
;
return
new
DecoratedBox
(
decoration:
kBoxDecorationA
);
}
}
void
flipStatefulComponent
(
WidgetTester
tester
)
{
void
flipStatefulComponent
(
WidgetTester
tester
)
{
StatefulComponentElement
stateElement
=
StatefulComponentElement
stateElement
=
tester
.
findElement
((
Element
element
)
=>
element
is
StatefulComponentElement
);
tester
.
findElement
((
Element
element
)
=>
element
is
StatefulComponentElement
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment