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
b9716b84
Commit
b9716b84
authored
Jan 19, 2016
by
Ian Hickson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reimplement Inherited.notifyDescendants to use a registration list
...instead of a deep walk.
parent
0911e5d3
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
15 deletions
+57
-15
binding.dart
packages/flutter/lib/src/widgets/binding.dart
+14
-2
framework.dart
packages/flutter/lib/src/widgets/framework.dart
+43
-13
No files found.
packages/flutter/lib/src/widgets/binding.dart
View file @
b9716b84
...
...
@@ -105,6 +105,18 @@ class WidgetFlutterBinding extends BindingBase with Scheduler, Gesturer, Rendere
_dirtyElements
.
add
(
element
);
}
static
int
_elementSort
(
BuildableElement
a
,
BuildableElement
b
)
{
if
(
a
.
depth
<
b
.
depth
)
return
-
1
;
if
(
b
.
depth
<
a
.
depth
)
return
1
;
if
(
b
.
dirty
&&
!
a
.
dirty
)
return
-
1
;
if
(
a
.
dirty
&&
!
b
.
dirty
)
return
1
;
return
0
;
}
/// Builds all the elements that were marked as dirty using schedule(), in depth order.
/// If elements are marked as dirty while this runs, they must be deeper than the algorithm
/// has yet reached.
...
...
@@ -114,14 +126,14 @@ class WidgetFlutterBinding extends BindingBase with Scheduler, Gesturer, Rendere
return
;
Timeline
.
startSync
(
'Build'
);
BuildableElement
.
lockState
(()
{
_dirtyElements
.
sort
(
(
BuildableElement
a
,
BuildableElement
b
)
=>
a
.
depth
-
b
.
depth
);
_dirtyElements
.
sort
(
_elementSort
);
int
dirtyCount
=
_dirtyElements
.
length
;
int
index
=
0
;
while
(
index
<
dirtyCount
)
{
_dirtyElements
[
index
].
rebuild
();
index
+=
1
;
if
(
dirtyCount
<
_dirtyElements
.
length
)
{
_dirtyElements
.
sort
(
(
BuildableElement
a
,
BuildableElement
b
)
=>
a
.
depth
-
b
.
depth
);
_dirtyElements
.
sort
(
_elementSort
);
dirtyCount
=
_dirtyElements
.
length
;
}
}
...
...
packages/flutter/lib/src/widgets/framework.dart
View file @
b9716b84
...
...
@@ -554,6 +554,7 @@ class _InactiveElements {
element
.
deactivate
();
assert
(
element
.
_debugLifecycleState
==
_ElementLifecycle
.
inactive
);
element
.
visitChildren
(
_deactivate
);
assert
(()
{
element
.
debugDeactivated
();
return
true
;
});
}
void
add
(
Element
element
)
{
...
...
@@ -851,10 +852,20 @@ abstract class Element<T extends Widget> implements BuildContext {
assert
(
widget
!=
null
);
assert
(
depth
!=
null
);
assert
(
_active
);
if
(
_dependencies
!=
null
)
{
for
(
InheritedElement
dependency
in
_dependencies
)
dependency
.
_dependants
.
remove
(
this
);
_dependencies
.
clear
();
}
_active
=
false
;
assert
(()
{
_debugLifecycleState
=
_ElementLifecycle
.
inactive
;
return
true
;
});
}
/// Called after children have been deactivated.
void
debugDeactivated
()
{
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
inactive
);
}
void
reactivate
()
{
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
inactive
);
assert
(
widget
!=
null
);
...
...
@@ -879,12 +890,20 @@ abstract class Element<T extends Widget> implements BuildContext {
RenderObject
findRenderObject
()
=>
renderObject
;
Set
<
Type
>
_dependencies
;
Set
<
InheritedElement
>
_dependencies
;
InheritedWidget
inheritFromWidgetOfExactType
(
Type
targetType
)
{
if
(
_dependencies
==
null
)
_dependencies
=
new
Set
<
Type
>();
_dependencies
.
add
(
targetType
);
return
ancestorWidgetOfExactType
(
targetType
);
Element
ancestor
=
_parent
;
while
(
ancestor
!=
null
&&
ancestor
.
widget
.
runtimeType
!=
targetType
)
ancestor
=
ancestor
.
_parent
;
if
(
ancestor
!=
null
)
{
assert
(
ancestor
is
InheritedElement
);
_dependencies
??=
new
Set
<
InheritedElement
>();
_dependencies
.
add
(
ancestor
);
InheritedElement
typedAncestor
=
ancestor
;
typedAncestor
.
_dependants
.
add
(
this
);
return
ancestor
.
widget
;
}
return
null
;
}
Widget
ancestorWidgetOfExactType
(
Type
targetType
)
{
...
...
@@ -1359,19 +1378,30 @@ class ParentDataElement extends _ProxyElement<ParentDataWidget> {
class
InheritedElement
extends
_ProxyElement
<
InheritedWidget
>
{
InheritedElement
(
InheritedWidget
widget
)
:
super
(
widget
);
Set
<
Element
>
_dependants
=
new
Set
<
Element
>();
void
debugDeactivated
()
{
assert
(()
{
assert
(
_dependants
.
isEmpty
);
return
true
;
});
super
.
debugDeactivated
();
}
void
notifyDescendants
(
InheritedWidget
oldWidget
)
{
if
(!
widget
.
updateShouldNotify
(
oldWidget
))
return
;
final
Type
ourRuntimeType
=
widget
.
runtimeType
;
void
notifyChildren
(
Element
child
)
{
if
(
child
.
_dependencies
!=
null
&&
child
.
_dependencies
.
contains
(
ourRuntimeType
))
{
child
.
dependenciesChanged
(
ourRuntimeType
);
}
if
(
child
.
runtimeType
!=
ourRuntimeType
)
child
.
visitChildren
(
notifyChildren
);
for
(
Element
dependant
in
_dependants
)
{
dependant
.
dependenciesChanged
(
ourRuntimeType
);
assert
(()
{
// check that it really is our descendant
Element
ancestor
=
dependant
.
_parent
;
while
(
ancestor
!=
this
&&
ancestor
!=
null
)
ancestor
=
ancestor
.
_parent
;
return
ancestor
==
this
;
});
}
visitChildren
(
notifyChildren
);
}
}
...
...
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