RESOLVED FIXED 113364
Selection code spends a lot of time in InlineTextBox::localSelectionRect
https://bugs.webkit.org/show_bug.cgi?id=113364
Summary Selection code spends a lot of time in InlineTextBox::localSelectionRect
Ryosuke Niwa
Reported 2013-03-26 21:01:11 PDT
As far as I've sampled in the bug 113358, we're spending 5+% of time in InlineTextBox::localSelectionRect computing font width. But there is no need to do this when we're selecting the entire line box.
Attachments
Work in progress 1 (888 bytes, patch)
2013-03-26 21:01 PDT, Ryosuke Niwa
no flags
A/B test result with WIP1 (24.77 KB, text/html)
2013-03-26 21:02 PDT, Ryosuke Niwa
no flags
Ready for review (1.70 KB, patch)
2013-03-27 11:00 PDT, Ryosuke Niwa
enrica: review+
Ryosuke Niwa
Comment 1 2013-03-26 21:01:51 PDT
Created attachment 195214 [details] Work in progress 1
Ryosuke Niwa
Comment 2 2013-03-26 21:02:56 PDT
Created attachment 195215 [details] A/B test result with WIP1
Radar WebKit Bug Importer
Comment 3 2013-03-26 21:03:56 PDT
WebKit Review Bot
Comment 4 2013-03-26 21:11:31 PDT
Attachment 195214 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'Source/WebCore/rendering/InlineTextBox.cpp']" exit_code: 1 Source/WebCore/rendering/InlineTextBox.cpp:211: Tests for true/false, null/non-null, and zero/non-zero should all be done without equality comparisons. [readability/comparison_to_zero] [5] Total errors found: 1 in 1 files If any of these errors are false positives, please file a bug against check-webkit-style.
Enrica Casucci
Comment 5 2013-03-27 10:36:54 PDT
Comment on attachment 195214 [details] Work in progress 1 View in context: https://bugs.webkit.org/attachment.cgi?id=195214&action=review Missing ChangeLog file >> Source/WebCore/rendering/InlineTextBox.cpp:211 >> + if (sPos != 0 || ePos != static_cast<int>(m_len)) > > Tests for true/false, null/non-null, and zero/non-zero should all be done without equality comparisons. [readability/comparison_to_zero] [5] Please fix the style issue and add a comment.
Ryosuke Niwa
Comment 6 2013-03-27 10:40:16 PDT
(In reply to comment #5) > (From update of attachment 195214 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=195214&action=review > > Missing ChangeLog file > > >> Source/WebCore/rendering/InlineTextBox.cpp:211 > >> + if (sPos != 0 || ePos != static_cast<int>(m_len)) > > > > Tests for true/false, null/non-null, and zero/non-zero should all be done without equality comparisons. [readability/comparison_to_zero] [5] > > Please fix the style issue and add a comment. Oh, oops. This wasn't up for review. The one on https://bugs.webkit.org/show_bug.cgi?id=113358 is. I'm trying to add the performance test first so that people can verify my assertion that my patch improves the performance.
Ryosuke Niwa
Comment 7 2013-03-27 11:00:47 PDT
Created attachment 195358 [details] Ready for review
Enrica Casucci
Comment 8 2013-03-27 11:05:45 PDT
Comment on attachment 195358 [details] Ready for review View in context: https://bugs.webkit.org/attachment.cgi?id=195358&action=review > Source/WebCore/rendering/InlineTextBox.cpp:209 > + FloatPoint startingPoint = FloatPoint(logicalLeft(), selTop); I would add a comment here about the optimization.
Ryosuke Niwa
Comment 9 2013-03-27 13:49:17 PDT
Note You need to log in before you can comment on or make changes to this bug.