WebKit Bugzilla
New
Browse
Search+
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
236818
Add percent decoding to Scroll to Text Fragment parsing.
https://bugs.webkit.org/show_bug.cgi?id=236818
Summary
Add percent decoding to Scroll to Text Fragment parsing.
Megan Gardner
Reported
2022-02-17 17:32:06 PST
Add percent decoding to Scroll to Text Fragment parsing.
Attachments
Patch
(5.69 KB, patch)
2022-02-17 17:34 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch
(12.47 KB, patch)
2022-02-18 13:34 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch
(11.86 KB, patch)
2022-02-18 14:07 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch
(11.81 KB, patch)
2022-02-18 14:36 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch for landing
(11.79 KB, patch)
2022-02-18 16:04 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch
(11.79 KB, patch)
2022-02-22 10:19 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch
(14.56 KB, patch)
2022-02-24 09:58 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Patch for landing
(15.14 KB, patch)
2022-02-24 12:01 PST
,
Megan Gardner
no flags
Details
Formatted Diff
Diff
Show Obsolete
(7)
View All
Add attachment
proposed patch, testcase, etc.
Megan Gardner
Comment 1
2022-02-17 17:34:57 PST
Created
attachment 452453
[details]
Patch
Alex Christensen
Comment 2
2022-02-17 17:45:02 PST
Comment on
attachment 452453
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=452453&action=review
Needs tests.
> Source/WTF/wtf/Vector.h:753 > + removeFirst();
This is a very slow operation in a Vector. takeLast is O(1) but this is O(n). If you need this, use a Deque, but you probably don't. It looks like you're already using a Deque.
> Source/WebCore/dom/FragmentDirectiveParser.cpp:106 > + if (prefix)
nit: if (auto prefix = ...) Then it's in the scope of the if statement.
Megan Gardner
Comment 3
2022-02-18 13:34:41 PST
Created
attachment 452575
[details]
Patch
Chris Dumez
Comment 4
2022-02-18 13:38:39 PST
Comment on
attachment 452575
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=452575&action=review
> Source/WTF/wtf/Vector.h:750 > + // Very slow, should not be used in common code paths or vectors of large N values.
Very slow, exactly so let's not do that. This is what Deque is for. Also, where is this used in your patch?
> Source/WebCore/dom/FragmentDirectiveParser.cpp:106 > + if (auto prefix = WTF::URLParser::formURLDecode(tokens.takeFirst()))
You are calling takeFirst() here but tokens seems to be a Deque, not a Vector?
Chris Dumez
Comment 5
2022-02-18 13:41:36 PST
Comment on
attachment 452575
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=452575&action=review
> Source/WebCore/dom/FragmentDirectiveParser.cpp:107 > + parsedTextDirective.prefix = prefix.value();
= WTFMove(*prefix);
> Source/WebCore/dom/FragmentDirectiveParser.cpp:116 > + parsedTextDirective.suffix = suffix.value();
= WTFMove(*suffix);
> Source/WebCore/dom/FragmentDirectiveParser.cpp:127 > + parsedTextDirective.textStart = start.value();
ditto.
> Source/WebCore/dom/FragmentDirectiveParser.cpp:134 > + parsedTextDirective.textEnd = end.value();
ditto.
Chris Dumez
Comment 6
2022-02-18 13:42:35 PST
Comment on
attachment 452575
[details]
Patch r- because of Vector::takeFirst() (which doesn't seem needed)
Megan Gardner
Comment 7
2022-02-18 14:07:29 PST
Created
attachment 452579
[details]
Patch
Chris Dumez
Comment 8
2022-02-18 14:10:41 PST
Comment on
attachment 452579
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=452579&action=review
> Source/WTF/ChangeLog:12 > + (WTF::Vector::takeFirst):
nit: Still here.
> Source/WebCore/dom/FragmentDirectiveParser.cpp:107 > + parsedTextDirective.prefix = prefix.value();
Didn't WTFMove(*prefix) work? Seems this iteration didn't take this part of the feedback into account. Same comment applies below.
Megan Gardner
Comment 9
2022-02-18 14:36:44 PST
Created
attachment 452584
[details]
Patch
Chris Dumez
Comment 10
2022-02-18 16:02:28 PST
Comment on
attachment 452584
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=452584&action=review
r=me
> Source/WebCore/dom/FragmentDirectiveParser.cpp:132 > +
nit: Weird extra line.
Megan Gardner
Comment 11
2022-02-18 16:04:25 PST
Created
attachment 452595
[details]
Patch for landing
EWS
Comment 12
2022-02-18 19:28:49 PST
Found 1 new test failure: http/wpt/push-api/onpush-disabled.html
Megan Gardner
Comment 13
2022-02-22 10:19:49 PST
Created
attachment 452883
[details]
Patch
Megan Gardner
Comment 14
2022-02-24 09:58:02 PST
Created
attachment 453113
[details]
Patch
Megan Gardner
Comment 15
2022-02-24 12:01:38 PST
Created
attachment 453122
[details]
Patch for landing
EWS
Comment 16
2022-02-24 13:15:46 PST
Committed
r290455
(
247756@main
): <
https://commits.webkit.org/247756@main
> All reviewed patches have been landed. Closing bug and clearing flags on
attachment 453122
[details]
.
Radar WebKit Bug Importer
Comment 17
2022-02-24 13:16:22 PST
<
rdar://problem/89435775
>
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