WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
148010
Web Inspector: NavigationBar.updateLayoutSoon should use requestAnimationFrame
https://bugs.webkit.org/show_bug.cgi?id=148010
Summary
Web Inspector: NavigationBar.updateLayoutSoon should use requestAnimationFrame
Matt Baker
Reported
2015-08-13 18:36:07 PDT
* SUMMARY NavigationBar.updateLayoutSoon should use requestAnimationFrame. Currently it just uses a simple setTimeout(..., 0).
Attachments
[Patch] Proposed Fix
(2.65 KB, patch)
2015-08-14 18:16 PDT
,
Matt Baker
no flags
Details
Formatted Diff
Diff
[Patch] Proposed Fix
(2.39 KB, patch)
2015-08-14 19:54 PDT
,
Matt Baker
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Radar WebKit Bug Importer
Comment 1
2015-08-13 18:36:19 PDT
<
rdar://problem/22281006
>
Matt Baker
Comment 2
2015-08-14 18:16:36 PDT
Created
attachment 259062
[details]
[Patch] Proposed Fix
Devin Rousso
Comment 3
2015-08-14 18:54:20 PDT
Comment on
attachment 259062
[details]
[Patch] Proposed Fix View in context:
https://bugs.webkit.org/attachment.cgi?id=259062&action=review
> Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:59 > + this._updateLayoutIdentifier = 0;
To me, _updateLayoutIdentifier is a bit ambiguous as to what it represents. _updateLayoutTimeout was clear that it represented a timeout, so maybe use something like _updateLayoutAnimationFrameIdentifier?
Matt Baker
Comment 4
2015-08-14 19:35:46 PDT
(In reply to
comment #3
)
> Comment on
attachment 259062
[details]
> [Patch] Proposed Fix > > View in context: >
https://bugs.webkit.org/attachment.cgi?id=259062&action=review
> > > Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:59 > > + this._updateLayoutIdentifier = 0; > > To me, _updateLayoutIdentifier is a bit ambiguous as to what it represents. > _updateLayoutTimeout was clear that it represented a timeout, so maybe use > something like _updateLayoutAnimationFrameIdentifier?
It's consistent with our other request id variable names. However, we should create an abstraction to encapsulate the boilerplate layout code in Inspector view classes. This would would also address the ambiguity issue.
Blaze Burg
Comment 5
2015-08-14 19:36:05 PDT
Comment on
attachment 259062
[details]
[Patch] Proposed Fix View in context:
https://bugs.webkit.org/attachment.cgi?id=259062&action=review
r=me
>> Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:59 >> + this._updateLayoutIdentifier = 0; > > To me, _updateLayoutIdentifier is a bit ambiguous as to what it represents. _updateLayoutTimeout was clear that it represented a timeout, so maybe use something like _updateLayoutAnimationFrameIdentifier?
The existing name, or _scheduledUpdateIdentifier, would be consistent with existing code.
> Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:60 > + this._needsLayout = false;
Not necessary.
> Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:148 > + this._updateLayoutIdentifier = 0;
I would assign back to undefined, since the intention is less ambiguous.
Matt Baker
Comment 6
2015-08-14 19:44:40 PDT
(In reply to
comment #5
)
> Comment on
attachment 259062
[details]
> [Patch] Proposed Fix > > View in context: >
https://bugs.webkit.org/attachment.cgi?id=259062&action=review
> > r=me > > >> Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:59 > >> + this._updateLayoutIdentifier = 0; > > > > To me, _updateLayoutIdentifier is a bit ambiguous as to what it represents. _updateLayoutTimeout was clear that it represented a timeout, so maybe use something like _updateLayoutAnimationFrameIdentifier? > > The existing name, or _scheduledUpdateIdentifier, would be consistent with > existing code. > > > Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:60 > > + this._needsLayout = false; > > Not necessary. > > > Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:148 > > + this._updateLayoutIdentifier = 0; > > I would assign back to undefined, since the intention is less ambiguous.
Zero seems more appropriate, since requestAnimationFrame returns a non-zero value. It looks like we use undefined more than zero currently, and delete this._*Identifier the majority of the time. I'm fine with either, although I prefer zero.
Matt Baker
Comment 7
2015-08-14 19:54:44 PDT
Created
attachment 259075
[details]
[Patch] Proposed Fix
WebKit Commit Bot
Comment 8
2015-08-14 20:47:29 PDT
Comment on
attachment 259075
[details]
[Patch] Proposed Fix Clearing flags on attachment: 259075 Committed
r188506
: <
http://trac.webkit.org/changeset/188506
>
WebKit Commit Bot
Comment 9
2015-08-14 20:47:34 PDT
All reviewed patches have been landed. Closing bug.
Blaze Burg
Comment 10
2015-08-14 21:35:04 PDT
(In reply to
comment #6
) >
> > > Source/WebInspectorUI/UserInterface/Views/NavigationBar.js:148 > > > + this._updateLayoutIdentifier = 0; > > > > I would assign back to undefined, since the intention is less ambiguous. > > Zero seems more appropriate, since requestAnimationFrame returns a non-zero > value. It looks like we use undefined more than zero currently, and delete > this._*Identifier the majority of the time. I'm fine with either, although I > prefer zero.
What I meant was that `= undefined` is a generic replacement for delete, whereas `= 0` only makes sense in some context. So if I read the former, I need to think less about what is being done.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug