Bug 236693

Summary: Draw highlights for Scroll To Text Fragment
Product: WebKit Reporter: Megan Gardner <megan_gardner>
Component: New BugsAssignee: Megan Gardner <megan_gardner>
Status: RESOLVED FIXED    
Severity: Normal CC: cdumez, changseok, darin, esprehn+autocc, ews-watchlist, glenn, kangil.han, kondapallykalyan, pdr, thorton, webkit-bug-importer, wenson_hsieh
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch
ews-feeder: commit-queue-
Patch
ews-feeder: commit-queue-
Patch
ews-feeder: commit-queue-
Patch
ews-feeder: commit-queue-
Patch
none
Patch for landing
none
Patch none

Megan Gardner
Reported 2022-02-16 00:10:59 PST
Draw highlights for Scroll To Text Fragment
Attachments
Patch (18.76 KB, patch)
2022-02-16 00:18 PST, Megan Gardner
no flags
Patch (23.32 KB, patch)
2022-02-16 19:57 PST, Megan Gardner
no flags
Patch (23.43 KB, patch)
2022-02-16 21:09 PST, Megan Gardner
ews-feeder: commit-queue-
Patch (23.28 KB, patch)
2022-02-16 22:57 PST, Megan Gardner
ews-feeder: commit-queue-
Patch (29.90 KB, patch)
2022-02-16 23:37 PST, Megan Gardner
ews-feeder: commit-queue-
Patch (29.82 KB, patch)
2022-02-17 10:38 PST, Megan Gardner
ews-feeder: commit-queue-
Patch (30.31 KB, patch)
2022-02-17 11:38 PST, Megan Gardner
no flags
Patch for landing (30.30 KB, patch)
2022-02-17 15:25 PST, Megan Gardner
no flags
Patch (31.99 KB, patch)
2022-02-17 17:27 PST, Megan Gardner
no flags
Megan Gardner
Comment 1 2022-02-16 00:18:08 PST
Megan Gardner
Comment 2 2022-02-16 19:57:46 PST
Tim Horton
Comment 3 2022-02-16 20:45:53 PST
Comment on attachment 452296 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=452296&action=review > Source/WebCore/dom/Document.h:1629 > + HighlightRegister* fragmentHighlightRegisterIfExists() { return m_fragmentHighlightRegister.get(); } There's a whole lot of highlights members and methods on document now, perhaps in the future we can shuffle them off into their own class? > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:72 > + TemporarySelectionChange selectionChange(document, { range.value() }, { TemporarySelectionOption::DelegateMainFrameScroll, TemporarySelectionOption::SmoothScroll, TemporarySelectionOption::RevealSelectionBounds }); `rangesForFragments` sounds like it finds ranges, not that it does scrolling. I'd expect this to be tucked up in the caller. > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:74 > + // FIXME: add a textIndicator after the scroll has completed. This, too, shouldn't be in here. > Source/WebCore/page/FrameView.cpp:2254 > + // FIXME: Scroll to and bouce the first highlight "bouce". Also, I think this is where you want the scrolling code from above. > Source/WebCore/rendering/RenderReplaced.cpp:190 > + if (!highlightData.setRenderRange(rangeData)) I definitely don't follow why "calculate color" is calling a setter on the highlight (you'd think it would just look up the color?) but this is just semi-duplicating pre-existing code so... ok.
Megan Gardner
Comment 4 2022-02-16 21:09:05 PST
Chris Dumez
Comment 5 2022-02-16 21:27:19 PST
Comment on attachment 452304 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=452304&action=review > Source/WebCore/Modules/highlight/HighlightRegister.cpp:67 > +static ASCIILiteral defaultHighlightKey() We don't really need a function, this could just be a: constexpr auto defaultHighlightKey = "defaultHighlightKey"_s; Usually near the top of the cpp file. > Source/WebCore/Modules/highlight/HighlightRegister.cpp:74 > + if (m_map.contains(defaultHighlightKey())) This is doing multiple hash lookups so it is not very efficient. This would be more efficient: ``` auto addResult = m_map.ensure(defaultHighlightKey, [value]() mutable { return Highlight::create(WTFMove(value)); }); if (!addResult.isNewEntry) addResult.iterator.value->addToSetLike(WTFMove(value)); ``` > Source/WebCore/Modules/highlight/HighlightRegister.h:49 > + nit: Unnecessary extra line. > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:57 > + return resultRange.collapsed() ? std::nullopt : std::make_optional(resultRange); We may want to WTFMove(resultRange) here. > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:64 > + for (auto directive : parsedTextDirectives) { ParsedTextDirective is fairly large (4 Strings). I recommend using auto&. > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:68 > + ranges.append(range.value()); ranges.append(WTFMove(*range)); > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:74 > +} nit: No comment for this one? > Source/WebCore/dom/FragmentDirectiveRangeFinder.cpp:76 > +} // WebCore Usually we use // namespace WebCore > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:29 > +#include "SimpleRange.h" Can this be forward-declared instead? > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:31 > +#include <wtf/text/WTFString.h> Should not be needed? > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:37 > +const Vector<SimpleRange> rangesForFragments(Vector<ParsedTextDirective>& parsedTextDirectives, Document&); Can the first parameter be const? > Source/WebCore/page/FrameView.cpp:2251 > + Too many blank lines. > Source/WebCore/page/FrameView.cpp:2253 > + for (auto range : highlightRanges) SimpleRange doesn't look cheap to copy, I recommend using auto&. > Source/WebCore/rendering/MarkedText.cpp:135 > + for (auto& highlight : fragmentHighlightRegister->map()) { Seems you could iterate over `fragmentHighlightRegister->map().values()` since you're not interested in the keys. > Source/WebCore/rendering/MarkedText.cpp:136 > + for (auto& rangeData : highlight.value->rangesData()) { Then you wouldn't need the .value here. > Source/WebCore/rendering/RenderReplaced.cpp:188 > + for (auto& highlight : highlightRegister->map()) { Could iterate over fragmentHighlightRegister->map().values(). > Source/WebCore/rendering/RenderReplaced.cpp:197 > + OptionSet<StyleColorOptions> styleColorOptions = { StyleColorOptions::UseSystemAppearance }; Not sure we really need a local variable for this. > Source/WebCore/rendering/StyledMarkedText.cpp:75 > + OptionSet<StyleColorOptions> styleColorOptions = { StyleColorOptions::UseSystemAppearance }; Not sure we really need a local variable for this. > Source/WebCore/rendering/StyledMarkedText.cpp:78 > + } then we can drop the curly brackets.
Megan Gardner
Comment 6 2022-02-16 22:57:36 PST
Megan Gardner
Comment 7 2022-02-16 23:37:29 PST
Megan Gardner
Comment 8 2022-02-17 10:38:06 PST
Megan Gardner
Comment 9 2022-02-17 11:38:31 PST
Megan Gardner
Comment 10 2022-02-17 15:25:39 PST
Created attachment 452438 [details] Patch for landing
Megan Gardner
Comment 11 2022-02-17 17:27:11 PST
EWS
Comment 12 2022-02-17 23:56:50 PST
Committed r290116 (247460@main): <https://commits.webkit.org/247460@main> All reviewed patches have been landed. Closing bug and clearing flags on attachment 452451 [details].
Radar WebKit Bug Importer
Comment 13 2022-02-17 23:57:28 PST
Darin Adler
Comment 14 2022-03-04 09:58:09 PST
Comment on attachment 452451 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=452451&action=review > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:28 > +#include "FragmentDirectiveParser.h" Don’t need ParsedTextDirective definition here, a forward declaration should suffice. > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:29 > +#include "SimpleRange.h" Don’t need SimpleRange definition here, a forward declaration should suffice. > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:31 > +#include <wtf/text/WTFString.h> No reason for this include. > Source/WebCore/dom/FragmentDirectiveRangeFinder.h:37 > +const Vector<SimpleRange> rangesForFragments(Vector<ParsedTextDirective>& parsedTextDirectives, Document&); The const on the return value here is not meaningful and should be removed. The passed-in vector should be const&, I think.
Note You need to log in before you can comment on or make changes to this bug.