WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
78599
Web Inspector: [refactoring] extract TimelineOverviewWindow from TimelineOverviewPanel
https://bugs.webkit.org/show_bug.cgi?id=78599
Summary
Web Inspector: [refactoring] extract TimelineOverviewWindow from TimelineOver...
Andrey Kosyakov
Reported
2012-02-14 04:55:02 PST
This patch separates the logic of window selection in timeline overview panel from the rest of the overview pane.
Attachments
Patch
(15.45 KB, patch)
2012-02-14 05:02 PST
,
Andrey Kosyakov
no flags
Details
Formatted Diff
Diff
Patch
(15.46 KB, patch)
2012-02-14 05:29 PST
,
Andrey Kosyakov
no flags
Details
Formatted Diff
Diff
Patch
(14.71 KB, patch)
2012-02-14 05:41 PST
,
Andrey Kosyakov
pfeldman
: review+
Details
Formatted Diff
Diff
Show Obsolete
(2)
View All
Add attachment
proposed patch, testcase, etc.
Andrey Kosyakov
Comment 1
2012-02-14 05:02:11 PST
Created
attachment 126960
[details]
Patch
WebKit Review Bot
Comment 2
2012-02-14 05:06:28 PST
Attachment 126960
[details]
did not pass style-queue: Failed to run "['Tools/Scripts/update-webkit']" exit_code: 9 Updating OpenSource First, rewinding head to replay your work on top of it... Applying: [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets Using index info to reconstruct a base tree... <stdin>:1578: trailing whitespace. <stdin>:1647: trailing whitespace. <stdin>:1657: trailing whitespace. <stdin>:1672: trailing whitespace. return 0; <stdin>:1674: trailing whitespace. warning: squelched 7 whitespace errors warning: 12 lines add whitespace errors. Falling back to patching base and 3-way merge... warning: too many files (created: 168776 deleted: 3), skipping inexact rename detection Auto-merging LayoutTests/ChangeLog CONFLICT (content): Merge conflict in LayoutTests/ChangeLog Auto-merging Source/WebCore/ChangeLog CONFLICT (content): Merge conflict in Source/WebCore/ChangeLog Auto-merging Source/WebKit2/ChangeLog CONFLICT (content): Merge conflict in Source/WebKit2/ChangeLog Auto-merging Tools/ChangeLog CONFLICT (content): Merge conflict in Tools/ChangeLog Failed to merge in the changes. Patch failed at 0001 [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets When you have resolved this problem run "git rebase --continue". If you would prefer to skip this patch, instead run "git rebase --skip". To restore the original branch and stop rebasing run "git rebase --abort". rebase refs/remotes/origin/master: command returned error: 1 Died at Tools/Scripts/update-webkit line 164. If any of these errors are false positives, please file a bug against check-webkit-style.
Pavel Feldman
Comment 3
2012-02-14 05:16:34 PST
Comment on
attachment 126960
[details]
Patch Could you describe the responsibilities of each? What is TimelineOverviewPane and TimelineOverviewWindow now?
Andrey Kosyakov
Comment 4
2012-02-14 05:23:25 PST
(In reply to
comment #3
)
> (From update of
attachment 126960
[details]
) > Could you describe the responsibilities of each? What is TimelineOverviewPane and TimelineOverviewWindow now?
TimelineOverviewPane is a high-level class that holds together overview grid and heap graph. Overview window is essentially a control that manages window selection within an element passed as parent -- i.e. drag-n-drop resizing, scrolling etc.
Andrey Kosyakov
Comment 5
2012-02-14 05:29:29 PST
Created
attachment 126964
[details]
Patch
Pavel Feldman
Comment 6
2012-02-14 05:32:07 PST
Comment on
attachment 126964
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=126960&action=review
> Source/WebCore/inspector/front-end/TimelineOverviewPane.js:196 > + this._parent = parentElement;
this._parentElement
> Source/WebCore/inspector/front-end/TimelineOverviewPane.js:237 > + scrollWindow: function(event)
Could you leave it in place for the sake of better diff?
> Source/WebCore/inspector/front-end/TimelineOverviewPane.js:261 > + if (node.hasStyleClass("resources-dividers-label-bar")) {
why did this change?
WebKit Review Bot
Comment 7
2012-02-14 05:32:10 PST
Attachment 126964
[details]
did not pass style-queue: Failed to run "['Tools/Scripts/update-webkit']" exit_code: 9 Updating OpenSource First, rewinding head to replay your work on top of it... Applying: [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets Using index info to reconstruct a base tree... <stdin>:1578: trailing whitespace. <stdin>:1647: trailing whitespace. <stdin>:1657: trailing whitespace. <stdin>:1672: trailing whitespace. return 0; <stdin>:1674: trailing whitespace. warning: squelched 7 whitespace errors warning: 12 lines add whitespace errors. Falling back to patching base and 3-way merge... warning: too many files (created: 168776 deleted: 3), skipping inexact rename detection Auto-merging LayoutTests/ChangeLog CONFLICT (content): Merge conflict in LayoutTests/ChangeLog Auto-merging Source/WebCore/ChangeLog CONFLICT (content): Merge conflict in Source/WebCore/ChangeLog Auto-merging Source/WebKit2/ChangeLog CONFLICT (content): Merge conflict in Source/WebKit2/ChangeLog Auto-merging Tools/ChangeLog CONFLICT (content): Merge conflict in Tools/ChangeLog Failed to merge in the changes. Patch failed at 0001 [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets When you have resolved this problem run "git rebase --continue". If you would prefer to skip this patch, instead run "git rebase --skip". To restore the original branch and stop rebasing run "git rebase --abort". rebase refs/remotes/origin/master: command returned error: 1 Died at Tools/Scripts/update-webkit line 164. If any of these errors are false positives, please file a bug against check-webkit-style.
Andrey Kosyakov
Comment 8
2012-02-14 05:41:05 PST
Created
attachment 126965
[details]
Patch
WebKit Review Bot
Comment 9
2012-02-14 05:43:33 PST
Attachment 126965
[details]
did not pass style-queue: Failed to run "['Tools/Scripts/update-webkit']" exit_code: 9 Updating OpenSource First, rewinding head to replay your work on top of it... Applying: [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets Using index info to reconstruct a base tree... <stdin>:1578: trailing whitespace. <stdin>:1647: trailing whitespace. <stdin>:1657: trailing whitespace. <stdin>:1672: trailing whitespace. return 0; <stdin>:1674: trailing whitespace. warning: squelched 7 whitespace errors warning: 12 lines add whitespace errors. Falling back to patching base and 3-way merge... warning: too many files (created: 168776 deleted: 3), skipping inexact rename detection Auto-merging LayoutTests/ChangeLog CONFLICT (content): Merge conflict in LayoutTests/ChangeLog Auto-merging Source/WebCore/ChangeLog CONFLICT (content): Merge conflict in Source/WebCore/ChangeLog Auto-merging Source/WebKit2/ChangeLog CONFLICT (content): Merge conflict in Source/WebKit2/ChangeLog Auto-merging Tools/ChangeLog CONFLICT (content): Merge conflict in Tools/ChangeLog Failed to merge in the changes. Patch failed at 0001 [Mac][Win][WK2] Switch to RFC 6455 protocol for WebSockets When you have resolved this problem run "git rebase --continue". If you would prefer to skip this patch, instead run "git rebase --skip". To restore the original branch and stop rebasing run "git rebase --abort". rebase refs/remotes/origin/master: command returned error: 1 Died at Tools/Scripts/update-webkit line 164. If any of these errors are false positives, please file a bug against check-webkit-style.
Pavel Feldman
Comment 10
2012-02-14 05:44:29 PST
Comment on
attachment 126965
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=126965&action=review
> Source/WebCore/inspector/front-end/TimelineOverviewPane.js:255 > + if (node.hasStyleClass("resources-dividers-label-bar")) {
Why did this change?
> Source/WebCore/inspector/front-end/TimelineOverviewPane.js:-264 > - if (this._overviewGrid.itemsGraphsElement.offsetWidth - window.end > WebInspector.TimelineOverviewPane.MinSelectableSize)
This also might have side effects due to margins?
Andrey Kosyakov
Comment 11
2012-02-14 05:45:35 PST
(In reply to
comment #6
)
> > Source/WebCore/inspector/front-end/TimelineOverviewPane.js:196 > > + this._parent = parentElement; > this._parentElement
done
> > > Source/WebCore/inspector/front-end/TimelineOverviewPane.js:237 > > + scrollWindow: function(event) > Could you leave it in place for the sake of better diff?
done (as long as another class qualifies as "in place" :-))
> > > Source/WebCore/inspector/front-end/TimelineOverviewPane.js:261 > > + if (node.hasStyleClass("resources-dividers-label-bar")) { > > why did this change?
We used to peak into private field of a class defined in another file. We could as well use the style here, considering it's not 'private'.
Andrey Kosyakov
Comment 12
2012-02-14 05:48:52 PST
(In reply to
comment #10
)
> > Source/WebCore/inspector/front-end/TimelineOverviewPane.js:-264 > > - if (this._overviewGrid.itemsGraphsElement.offsetWidth - window.end > WebInspector.TimelineOverviewPane.MinSelectableSize) > > This also might have side effects due to margins?
The values are actually identical in our case. We do use clientWidth for the width of the parent container in quite a few places within the rest of overview window, do you see why it should be different in this particular case?
Pavel Feldman
Comment 13
2012-02-14 05:51:13 PST
> We used to peak into private field of a class defined in another file. We could as well use the style here, considering it's not 'private'.
Style class is as private as any other private field, so we are only masking the issue. Is there a way to fix it properly?
> The values are actually identical in our case. We do use clientWidth for the width of the parent container in quite a few places within the rest of overview window, do you see why it should be different in this particular case?
As you say, we decided to do differently in this case and I wonder if that might be for a reason.
Andrey Kosyakov
Comment 14
2012-02-14 06:05:32 PST
(In reply to
comment #13
)
> > We used to peak into private field of a class defined in another file. We could as well use the style here, considering it's not 'private'. > > Style class is as private as any other private field, so we are only masking the issue. Is there a way to fix it properly?
I do not see a true fix for this yet, as least a cheap one. We do this because we'd like to handle dragging on timeline label bar differently from that on the graph area (moving window vs. re-creating it). The label bar is in TimelineGrid, which is not related to overview pane. We can probably use a designated style to mark it, perhaps add it in the TimelineOverviewPane (this will still require making the element public).
> > The values are actually identical in our case. We do use clientWidth for the width of the parent container in quite a few places within the rest of overview window, do you see why it should be different in this particular case? > > As you say, we decided to do differently in this case and I wonder if that might be for a reason.
A few days that I spent with the timeline code seriously undermine my ability to presume that all the decisions there were made consciously and in the good will ;) So I rather assured there's no practical difference between these values.
Andrey Kosyakov
Comment 15
2012-02-14 06:25:31 PST
Committed
r107709
: <
http://trac.webkit.org/changeset/107709
>
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