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
Patch (15.46 KB, patch)
2012-02-14 05:29 PST, Andrey Kosyakov
no flags
Patch (14.71 KB, patch)
2012-02-14 05:41 PST, Andrey Kosyakov
pfeldman: review+
Andrey Kosyakov
Comment 1 2012-02-14 05:02:11 PST
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
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
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
Note You need to log in before you can comment on or make changes to this bug.