From 05cc693880a52140aec34fcbad98f7c889013608 Mon Sep 17 00:00:00 2001
From: David Bokan
+spec:html; type:dfn; for:browsing context; text:group; url: https://html.spec.whatwg.org/multipage/browsers.html#tlbc-group
+spec:html; type:dfn; for:/; text:navigable; url: https://html.spec.whatwg.org/multipage/document-sequences.html#navigable
+spec:html; type:dfn; for:/; text:origin; url: https://html.spec.whatwg.org/multipage/browsers.html#concept-origin
+spec:html; type:dfn; text:user navigation involvement; url: https://html.spec.whatwg.org/multipage/browsing-the-web.html#user-navigation-involvement
+spec:html; type:dfn; for:document state; text:initiator origin; url: https://html.spec.whatwg.org/multipage/browsing-the-web.html#document-state-initiator-origin
+spec:html; type:dfn; for:/; text:document state; url: https://html.spec.whatwg.org/multipage/browsing-the-web.html#she-document-state
+spec:html; type:dfn; for:she; text:document; url: https://html.spec.whatwg.org/multipage/browsing-the-web.html#she-document
+
+
{
"document-policy": {
@@ -593,7 +602,7 @@ The section above described how the [=fragment directive=] is separated from the
session history entry.
This section defines how and when navigations and traversals make use of history entry's [=she/directive
-state=] to apply the directives associated with a session history entry to a [=Document=].
+state=] to apply the directives associated with a session history entry to a [=/Document=].
> Monkeypatching [[DOM#interface-document]]:
>
@@ -799,8 +808,7 @@ indicated part, enable a fragment to indicate a [=range=]. Make the followin
>
> 1. Let |directives| be the document's [=Document/uninvoked directives=].
>
-> 1. If |directives| is non-null and |document|'s [=document/allow text
-> fragment scroll=] is true then:
+> 1. If |directives| is non-null then:
> 1. Let |ranges| be a list that is the result of running
> the [=invoke text directives=] steps with |directives| and the document.
> 1. If |ranges| is non-empty, then:
@@ -821,7 +829,7 @@ indicated part, enable a fragment to indicate a [=range=]. Make the followin
>
>
-In scroll to the fragment, handle a indicated part that is a [=range=] and also
+In scroll to the fragment, handle an indicated part that is a [=range=] and also
prevent fragment scrolling if the force-load-at-top policy is enabled. Make the following changes:
> Monkeypatching [[HTML#scrolling-to-a-fragment]]:
@@ -861,7 +869,7 @@ prevent fragment scrolling if the force-load-at-top policy is enabled. Make the
>
Scroll target into view, with behavior set to "auto", block set to
+> 10. Scroll |target| into view, with behavior set to "auto", block set to
> "start", and inline set to "nearest".
>
> text directive user activation
to both Document and Request. This
+ flag is set on a document when created from a user activated navigation and consumed if a text
+ directive is scrolled. If unconsumed, it can be transfered to an outgoing navigation request.
+ This implements the user-activation-through-redirects behavior described in the note below.
+ * Define a series of checks, performed on a document and the user involvement and initiator origin
+ state of a navigation, to determine whether a text directive should be allowed to perform a
+ scroll.
+ * Compute the scroll permission from "finalize a cross document navigation" and from "navigate to
+ a fragment steps" and plumb it through to the "scroll to the fragment" steps where its used to
+ abort a text directive scroll.
+
+
-> [=document/allow text fragment scroll=] is used to determine whether a text fragment will -> perform scrolling when the document is loaded. If it is false, the text fragment can be -> visually indicated but will not be scrolled to. This implements the mitigations discussed in -> [[#scroll-on-navigation]]. ->
->-> The reason we compute and store allow text fragment scroll, rather than performing these -> checks at the time of use, is that it relies on the properties of the navigation while the -> invocation will occur as part of the scroll to the fragment steps which can -> happen outside the context of a navigation. ->
->activation
";
+> * |navigationParams|'s [=user involvement=] is "browser UI
"; or
+> * |navigationParams|'s
+> request's
+> [=request/text directive user activation=] is true.
+> activation
" or "browser
+ UI
"; false otherwise.
+ 1. Set |document|'s [=document/text directive user activation=] to false.
+ 1. If |user involvement| is "browser UI
", return true.
+ + If a navigation originates from browser UI, it's always ok to allow it since it'll be + user triggered and the page/script isn't providing the text snippet. +
++ Note: The intent in this item is to distinguish cases where the app/page is able to + control the URL from those that are fully under the user's control. In the former we + want to prevent scrolling of the text fragment unless the destination is loaded in a + separate browsing context group (so that the source cannot both control the text snippet + and observe side-effects in the navigation). There are some cases where "browser UI" may + be a grey area in this regard. E.g. an "open in new window" context menu item when right + clicking on a link. +
++ See + + sec-fetch-site in [[FETCH-METADATA]] for a related discussion of how this applies. +
+-> If a navigation originates from browser UI, it's always ok to allow it -> since it'll be user triggered and the page/script isn't providing the -> text snippet. ->
->-> Note: Depending on the UA, there can be cases where the -> incumbentNavigationOrigin parameter is null but -> it's not clear that the navigation is to be considered as -> initiated from browser UI. E.g. an "open in new window" context -> menu item when right clicking on a link. The intent in this item -> is to distinguish cases where the app/page is able to set the URL -> from those that are fully under the user's control. In the former -> we want to prevent activation of the text fragment unless the -> destination is loaded in a separate browsing context group (so that -> the source cannot both control the text snippet and observe -> side-effects in the navigation). ->
->-> See -> sec-fetch-site -> in [[FETCH-METADATA]] for a more detailed discussion of how this applies. ->
->In the definition of navigate to a fragment:
-Monkeypatching HTML § 7.4.2.3.3 Fragment navigations:
@@ -1333,7 +1333,7 @@create navigation params by fetching: +
In the definition of create navigation params by fetching:
-Monkeypatching HTML § 7.4.5 Populating a session history entry:
@@ -1392,7 +1392,7 @@-
A same document navigation changed only the fragment. This adds a new session history entry in the navigate to +
A same document navigation changed only the fragment. This adds a new session history entry in the navigate to a fragment steps. However, since only the fragment changed, the new entry’s directive state points to the same state as the first entry, with a value of "bar".
onhashchange = () => console.assert(false, "hashchange doesn’t fire."); @@ -1612,8 +1612,7 @@
Let directives be the document’s uninvoked directives.
- -
If directives is non-null and document’s allow text - fragment scroll is true then:
+If directives is non-null then:
Let ranges be a list that is the result of running @@ -1644,7 +1643,7 @@
In scroll to the fragment, handle a indicated part that is a range and also +
In scroll to the fragment, handle an indicated part that is a range and also prevent fragment scrolling if the force-load-at-top policy is enabled. Make the following changes:
Monkeypatching HTML § 7.4.6.3 Scrolling to a fragment:
@@ -1697,7 +1696,7 @@
Scrolling to a text directive centers it in the block flow direction.- -
Scroll target into view, with behavior set to "auto", block set to +Scroll target into view, with behavior set to "auto", block set to "start", and inline set to "nearest".- scroll a target into view, @@ -1771,7 +1770,7 @@
In the definition of navigate to a fragment:
+In the definition of navigate to a fragment:
Monkeypatching HTML § 7.4.2.3.3 Fragment navigations:
@@ -1893,6 +1892,25 @@+Document's indicated part.
3.5.4. Restricting the Text Fragment
++ This section integrates with HTML navigation to restrict when an indicated text directive will + be allowed to scroll. In summary: ++
+- +
Add a boolean
+text directive user activation
to both Document and Request. This + flag is set on a document when created from a user activated navigation and consumed if a text + directive is scrolled. If unconsumed, it can be transfered to an outgoing navigation request. + This implements the user-activation-through-redirects behavior described in the note below.- +
Define a series of checks, performed on a document and the user involvement and initiator origin + state of a navigation, to determine whether a text directive should be allowed to perform a + scroll.
+- +
Compute the scroll permission from "finalize a cross document navigation" and from "navigate to + a fragment steps" and plumb it through to the "scroll to the fragment" steps where its used to + abort a text directive scroll.
+Amend the definition of a request and of a Document to include a new boolean text directive user activation field:
@@ -1941,116 +1959,405 @@
See redirects.md for a more in-depth discussion.
Amend the create navigation params by fetching steps to transfer the active +document's text directive user activation value into request’s text directive user activation.
-Monkeypatching [HTML]:
-Each Document has an allow text fragment scroll, which is a - boolean, initially false.
--allow text fragment scroll is used to determine whether a text fragment will - perform scrolling when the document is loaded. If it is false, the text fragment can be - visually indicated but will not be scrolled to. This implements the mitigations discussed in § 3.5.2 Scroll On Navigation.
-The reason we compute and store allow text fragment scroll, rather than performing these - checks at the time of use, is that it relies on the properties of the navigation while the - invocation will occur as part of the scroll to the fragment steps which can - happen outside the context of a navigation.
++-+
- +
Assert: this is running in parallel.
+- +
Let documentResource be entry’s document state’s resource.
+- +
Let request be a new request, with
++
+- url +
- entry’s URL +
- ... +
- ... +
- referrer policy +
- entry’s document state’s request referrer policy +
- text directive user activation +
- navigable’s active document's text directive user activation +
- +
Set navigable’s active document's text directive + user activation to false.
+- +
If documentResource is a POST resource, then:
++
+- +
...
+TODO: This should really only prevent potentially observable side-effects like - automatic scrolling. Unobservable effects like a highlight could be safely - allowed in all cases.-Amend the create -and initialize a Document object steps by adding the following steps before returning document:
+Amend the definition of navigation params to include a new field:
+Monkeypatching [HTML]:
-+
+
+- user involvement +
- A user navigation involvement value. +
Initialize the user involvement value everywhere a navigation params is +created. Specifically: initialize it to true in the create navigation params by +fetching case:
+++Monkeypatching [HTML]:
++ To create navigation params by fetching given a session history entry entry, a navigable + navigable, a source snapshot params sourceSnapshotParams, a target snapshot params + targetSnapshotParams, a string cspNavigationType, a navigation ID-or-null navigationId, a + NavigationTimingType navTimingType, and a user navigation + involvement user involvement, perform the following steps. They return a navigation params, + a non-fetch scheme navigation params, or null. +++
+- +
Assert: this is running in parallel.
+- +
...
+- Let resultPolicyContainer be the result of determining navigation params policy container given + response’s URL, entry’s document state’s history policy container, sourceSnapshotParams’s source + policy container, null, and responsePolicyContainer. +
- +
If navigable’s container is an iframe, and response’s timing allow passed flag is set, then + set container’s pending resource-timing start time to null.
+- +
Return a new navigation params, with
++
+- id +
- navigationId +
- ... +
- ... +
- about base URL +
- entry’s document state’s about base URL +
- user involvement +
- user involvement +
Amend the create and initialize a Document object steps to compute and store the text directive +user activation flag:
+++Monkeypatching [HTML]:
++++
+- +
Process link headers given document, navigationParams’s response, and "pre-media".
+- +
+ Set document’s text directive user activation to true if any of the following +conditions hold, false otherwise: +++
+- +
navigationParams’s user involvement is "
+activation
";- +
navigationParams’s user involvement is "
+browser UI
"; or- +
navigationParams’s request’s text directive user activation is true.
+It’s important that text directive user activation not be copyable so that + only one text fragment can be activated per user-activated navigation.+- +
Return document.
++ To check if a text directive can be scrolled; given a Document document, an origin-or-null initiator origin, and user navigation involvement-or-null user involvement, follow these steps: +++
- -
Set document’s text directive user activation by following these sub-steps:
--
+- -
Let is user activated be true if the current navigation was initiated from - a window that had a transient activation at the time the - navigation was initiated, or the UA has reason to believe it comes from a - direct user gesture (e.g. user typed into the address bar).
-TODO: it’d be better to refer to the user-activation flag.-- -
If browsing context is a top-level browsing context and if either of is - user activated or the text directive user activation of navigationParam’s request object is true, set the document’s text directive user activation to true. Otherwise, set it to false.
-It’s important that the flag not be copyable so that only one text fragment can be - activated per user-activated navigation.-If document’s uninvoked directives field is null or empty, return false.
+- +
Let is user involved be true if: document’s text directive user activation is +true, or user involvement is one of "
+activation
" or "browser +UI
"; false otherwise.- +
Set document’s text directive user activation to false.
+- +
If user involvement is "
+browser UI
", return true.++If a navigation originates from browser UI, it’s always ok to allow it since it’ll be + user triggered and the page/script isn’t providing the text snippet.
+Note: The intent in this item is to distinguish cases where the app/page is able to + control the URL from those that are fully under the user’s control. In the former we + want to prevent scrolling of the text fragment unless the destination is loaded in a + separate browsing context group (so that the source cannot both control the text snippet + and observe side-effects in the navigation). There are some cases where "browser UI" may + be a grey area in this regard. E.g. an "open in new window" context menu item when right + clicking on a link.
+See sec-fetch-site in [FETCH-METADATA] for a related discussion of how this applies.
+- +
If is user involved is false, return false.
+- +
If document’s node navigable has a parent, return false.
+- +
If initiator origin is non-null and document’s origin is same origin with initiator origin, return true.
- -
Set document’s allow text fragment scroll by following these sub-steps:
+If document’s browsing context's group's browsing context set has length 1, return true.
+i.e. Only allow navigation from a cross-origin element/script if the + document is loaded in a noopener context. That is, a new top level + browsing context group to which the navigator does not have script access + and which can be placed into a separate process.+- +
Otherwise, return false.
+Amend (the already amended, in § 3.4.1 Invoking Text Directives) scroll to the +fragment steps to add a new parameter, a boolean allow text directive scroll:
+++Monkeypatching HTML § 7.4.6.3 Scrolling to a fragment:
++ To scroll to the fragment given a Document document and boolean allow text + directive scroll: +++
+- +
If document’s indicated part is null, then set document’s target element to null.
+- +
...
+- +
Otherwise:
++
+- +
Assert: document’s indicated part is an element or it is a range.
+- +
...
+- If target is a range, then: +
+
+- +
If allow text directive scroll is false, return.
+- +
Set target to be the first common ancestor of target’s start node and end node.
+- +
...
+Amend the try to scroll to the fragment by adding a boolean flag allow text +directive scroll and replacing the steps of the task queued in step 2:
+++Monkeypatching [HTML]:
++ To try to scroll to the fragment for a Document document, with boolean allow text directive scroll, perform the following steps in parallel: +++
+- +
Wait for an implementation-defined amount of time. (This is intended to allow the user agent + to optimize the user experience in the face of performance concerns.)
+- +
Queue a global task on the navigation and traversal task source given document’s relevant + global object to run these steps:
++
+- +
If document has no parser, or its parser has stopped parsing, or the user + agent has reason to believe the user is no longer interested in scrolling to + the fragment, then abort these steps.
+- +
Scroll to the fragment given document and allow text directive + scroll.
+- +
If document’s indicated part is still null, then try to scroll to the fragment for document and allow text directive scroll.
+Amend the update document for history step application steps to take a boolean allow text directive scroll and use it when scrolling to a fragment:
+++Monkeypatching [HTML]:
++ To update document for history step application given a Document document, a session history + entry entry, a boolean doNotReactivate, integers scriptHistoryLength and scriptHistoryIndex, + an optional list of session history entries entriesForNavigationAPI, and a + boolean allow text directive scroll: +++
+- +
Let documentIsNew be true if document’s latest entry is null; otherwise false.
+- +
...
+- + If documentsEntryChanged is true, then: +
+
+- +
Let oldURL be document’s latest entry’s URL.
+- +
...
+- +
If documentIsNew is true, then:
++
+- +
Try to scroll to the fragment with document and allow text + directive scroll.
+Amend the apply the history step algorithm to take a boolean allow text directive +scroll and pass it through when calling update document for history step application :
+++Monkeypatching [HTML]:
+++To apply the history step given a non-negative integer step to a traversable navigable +traversable, with boolean checkForCancelation, source snapshot params-or-null +sourceSnapshotParams, navigable-or-null initiatorToCheck, user navigation involvement-or-null +userInvolvementForNavigateEvents, and boolean allow text directive scroll (default false) perform the following steps. They +return "initiator-disallowed", "canceled-by-beforeunload", "canceled-by-navigate", or "applied".
++
+- +
While completedChangeJobs does not equal totalChangeJobs:
++
+- +
...
+- + Queue a global task on the navigation and traversal task source given +navigable’s active window to run the steps: +
+
+- +
If changingNavigableContinuation’s update-only is false, then:
++
+- +
...
+- +
Activate history entry targetEntry for navigable.
+- +
Let updateDocument be an algorithm step which performs update document for history +step application given targetEntry’s document, targetEntry, +changingNavigableContinuation’s update-only, scriptHistoryLength, +scriptHistoryIndex, entriesForNavigationAPI, and allow text +directive scroll
+- +
If targetEntry’s document is equal to displayedDocument, then perform +updateDocument.
+- +
Let totalNonchangingJobs be the size of nonchangingNavigablesThatStillNeedUpdates.
+Amend the apply the push/replace history step to take and pass allow text +directive scrolling to apply the history step:
+++Monkeypatching [HTML]:
++ To apply the push/replace history step given a non-negative integer step to a traversable + navigable traversable, with boolean allow text directive scroll (default + false): ++Return the result of applying the history step step to traversable given false, null, null, + null, allow text directive scroll.
+Note: The allow text directive scroll is intentionally not set for traversal and reload cases. +This avoids extensive plumbing and checks for initiator origin and user involvement and history +scroll state should take precedence anyway. The text directive may still be used as the indicated +part of the document so highlights will be restored.
+Amend the finalize a cross-document navigation to take a user involvement parameter and compute and pass allow text directive scrolling to apply the push/replace history +step:
+++Monkeypatching [HTML]:
+++To finalize a cross-document navigation given a navigable navigable, history handling behavior +historyHandling, session history entry historyEntry, and user +navigation involvement user involvement (default "none"):
++
+- +
Assert: this is running on navigable’s traversable navigable’s session history traversal queue.
+- +
...
+- Let allow text directive scroll be the result of checking if a text directive can be scrolled, given historyEntry’s document, historyEntry’s document state’s initiator origin, and user involvement +
- +
Apply the push/replace history step targetStep to traversable, with allow +text directive scroll.
+Amend the navigate algorithm to pass user involvement to the finalize a +cross-document navigation steps:
++-Monkeypatching [HTML]:
+++
+ +- +
...
+- . In parallel, run these steps:
-
- -
If document’s uninvoked directives field is null or empty, set allow text fragment scroll to false and abort these sub-steps.
-- -
Let text directive user activation be the value of document’s text directive user activation and set document’s text directive user activation to false.
-- -
If the navigationParam’s request has a sec-fetch-site header and its value is
-"none"
set allow text fragment scroll to true and abort these sub-steps.--If a navigation originates from browser UI, it’s always ok to allow it - since it’ll be user triggered and the page/script isn’t providing the - text snippet.
-Note: Depending on the UA, there can be cases where the incumbentNavigationOrigin parameter is null but - it’s not clear that the navigation is to be considered as - initiated from browser UI. E.g. an "open in new window" context - menu item when right clicking on a link. The intent in this item - is to distinguish cases where the app/page is able to set the URL - from those that are fully under the user’s control. In the former - we want to prevent activation of the text fragment unless the - destination is loaded in a separate browsing context group (so that - the source cannot both control the text snippet and observe - side-effects in the navigation).
-See sec-fetch-site in [FETCH-METADATA] for a more detailed discussion of how this applies.
-- -
If text directive user activation is false, set allow text fragment scroll to false and abort these sub-steps.
-- -
If the navigationParam’s request has a sec-fetch-site header and its value is
-"same-origin"
set allow text fragment scroll to true and abort these - sub-steps.- -
If document’s browsing context is a top-level browsing - context and its group’s browsing context set has length 1, set allow text fragment scroll to true and abort these sub-steps.
-i.e. Only allow navigation from a cross-origin element/script if the - document is loaded in a noopener context. That is, a new top level - browsing context group to which the navigator does not have script access - and which can be placed into a separate process.-- -
Otherwise, set allow text fragment scroll to false.
+...
+- . Attempt to populate the history entry’s document for historyEntry, given +navigable, "navigate", sourceSnapshotParams, targetSnapshotParams, navigationId, +navigationParams, cspNavigationType, with allowPOST set to true and completionSteps set to +the following step: +
+
- +
Append session history traversal steps to navigable’s traversable to finalize a +cross-document navigation given navigable, historyHandling, historyEntry, and userInvolvement.
+Amend step 2 of the process a navigate fetch steps to additionally set request’s text directive user activation to the value of the active document's text directive user activation and set the active document's value to -false.
+Amend the Navigate to a fragment algorithm to take an initiator origin parameter +and pass the allow text directive scroll flag when scrolling to the fragment:
-Monkeypatching [HTML]:
--
+- -
Set request’s client to sourceBrowsingContext’s active document’s relevant - settings object, destination to "document", mode to "navigate", credentials - mode to "include", use-URL-credentials flag, redirect mode to "manual", - replaces client id to browsingContext’s active document’s relevant settings - object’s id, and text directive user activation to - sourceBrowsingContext’s active document’s text directive user activation. Set sourceBrowsingContext’s active - document’s text directive user activation to false.
-+To navigate to a fragment given a navigable navigable, a URL url, a history handling behavior +historyHandling, a user navigation involvement userInvolvement, a serialized state-or-null +navigationAPIState, navigation ID navigationId, an origin initiator +origin:
++
+- +
Let navigation be navigable’s active window’s navigation API.
+- +
...
+- Update document for history step application given navigable’s active document, historyEntry, true, scriptHistoryIndex, and scriptHistoryLength. +
- +
Update the navigation API entries for a same-document navigation given navigation, historyEntry, and historyHandling.
+- +
Let allow text directive scroll be the result of checking if a text directive can be scrolled, given navigable’s active document, initiator origin, and userInvolvement
+- +
Scroll to the fragment given navigable’s active document, and allow text +directive scroll.
+Amend the try to scroll to the fragment steps by replacing the -steps of the task queued in step 2:
+Amend the navigate algorithm to pass the initiator origin when performing a +fragment navigation:
Monkeypatching [HTML]:
--
+- -
If document has no parser, or its parser has stopped parsing, or the user - agent has reason to believe the user is no longer interested in scrolling to - the fragment, then set document’s allow text fragment scroll to false and abort these steps.
-- -
Scroll to the fragment given in document’s URL. If this does not find an - indicated part, then try to scroll to the fragment for - document.
-- -
Set document’s allow text fragment scroll to false.
-++
+- +
If the navigation must be a replace given url and navigable’s active document, then set historyHandling to "replace".
+- +
If all of the following are true:
++
+- +
documentResource is null;
+- +
response is null;
+- +
url equals navigable’s active session history entry’s URL with exclude fragments set to true; and
+- +
url’s fragment is non-null,
+then:
++
+- +
Navigate to a fragment given navigable, url, historyHandling, userInvolvement, +navigationAPIState, navigationId, and initiatorOriginSnapshot
+- +
Let navigation be navigable’s active window’s navigation API.
+3.5.5. Restricting Scroll on Load
This section defines how the
force-load-at-top
policy is used to prevent all @@ -2073,7 +2380,7 @@<
Amend the update document for history step application steps +
Amend the update document for history step application steps to check the
force-load-at-top
policy and avoid scrolling in a new document if it’s set.@@ -2140,7 +2447,7 @@
The text fragment specification proposes an amendment to HTML § 7.4.2.3.3 Fragment navigations. In summary, if a text directive is present and a match is found in the page, the text fragment takes precedent over the element fragment as the indicated part. We amend the HTML Document’s -indicated part processing model to return a range, rather than an element, that will be scrolled into view.
At a high level, we take a fragment directive string that looks like this:
text=prefix-,foo&unknown&text=bar,baz @@ -2179,8 +2486,8 @@-
If a directive successfully matches to text in the document, it returns a range indicating that match in the document. The invoke text directives steps are the high level API provided by this - section. These return a list of ranges that were matched +
If a directive successfully matches to text in the document, it returns a range indicating that match in the document. The invoke text directives steps are the high level API provided by this + section. These return a list of ranges that were matched by the individual directive matching steps, in the order the directives were specified in the fragment directive string.
If a directive was not matched, it does not add an item to the returned @@ -2190,7 +2497,7 @@
invoke text directives, given as input an ASCII string text directives and a Document document, run these steps:
This algorithm takes as input a text directives, that is the raw text of the fragment directive and the document over which it operates. - It returns a list of ranges that are to be visually + It returns a list of ranges that are to be visually indicated, the first of which will be scrolled into view (if the UA scrolls automatically).@@ -2202,7 +2509,7 @@
strictly splitting the string text directives on "&".
- - +
For each ASCII string directive of directives:
@@ -2226,12 +2533,12 @@
This algorithm takes as input a successfully parsed text directive and a - document in which to search. It returns a range that points to the first + document in which to search. It returns a range that points to the first text passage within the document that matches the searched-for text and satisfies the surrounding context. Returns null if no such passage exists.
end can be null. If omitted, this is an "exact" - search and the returned range will contain a string exactly matching start. If end is - provided, this is a "range" search; the returned range will start with start and end with end. In the normative text below, we’ll call a + search and the returned range will contain a string exactly matching start. If end is + provided, this is a "range" search; the returned range will start with start and end with end. In the normative text below, we’ll call a text passage that matches the provided start and end, regardless of which mode we’re in, the "matching text".
Either or both of prefix and suffix can be null, in which case context on that @@ -2261,7 +2568,7 @@
- -
Let searchRange be a range with start (document, 0) and end (document, document’s length)
+Let searchRange be a range with start (document, 0) and end (document, document’s length)
While searchRange is not collapsed:
@@ -2278,7 +2585,7 @@
Set searchRange’s start to the first boundary point after prefixMatch’s start
- -
Let matchRange be a range whose start is prefixMatch’s end and end is searchRange’s end.
+Let matchRange be a range whose start is prefixMatch’s end and end is searchRange’s end.
Advance matchRange’s start to the next non-whitespace position.
- @@ -2286,7 +2593,7 @@
This can happen if prefixMatch’s end or its subsequent non-whitespace position is at the end of the document.
Assert: matchRange’s start node is a Text
node.
Assert: matchRange’s start node is a Text
node.
Let rangeEndSearchRange be a range whose start is potentialMatch’s end and whose end is searchRange’s end.
+Let rangeEndSearchRange be a range whose start is potentialMatch’s end and whose end is searchRange’s end.
While rangeEndSearchRange is not collapsed:
If parsedValues’s suffix is null, return potentialMatch.
Let suffixRange be a range with start equal to potentialMatch’s end and end equal to searchRange’s end.
+Let suffixRange be a range with start equal to potentialMatch’s end and end equal to searchRange’s end.
Advance suffixRange’s start to the next non-whitespace position.
@@ -2394,14 +2701,14 @@While range is not collapsed:
Let node be range’s start node.
+Let node be range’s start node.
Let offset be range’s start offset.
Set range’s start node to the next node, in shadow-including tree order.
+Set range’s start node to the next node, in shadow-including tree order.
Set range’s start offset to 0.
The basic premise of this algorithm is to walk all searchable text nodes within a block, collecting them into a list. The list is then concatenated into a single string in which we can search, using the node list to - determine offsets with a node so we can return a range.
+ determine offsets with a node so we can return a range.Collection breaks when we hit a block node, e.g. searching over this tree:
<div> a<em>b</em>c<div>d</div>e @@ -2466,12 +2773,12 @@While searchRange is not collapsed:
- -
Let curNode be searchRange’s start node.
+Let curNode be searchRange’s start node.
If curNode is part of a non-searchable subtree:
- -
Set searchRange’s start node to the next node, in shadow-including tree order, that isn’t a shadow-including +
Set searchRange’s start node to the next node, in shadow-including tree order, that isn’t a shadow-including descendant of curNode.
Set searchRange’s start offset to 0.
@@ -2482,7 +2789,7 @@If curNode is not a visible text node:
- -
Set searchRange’s start node to the next node, in shadow-including tree order, that is not a doctype.
+Set searchRange’s start node to the next node, in shadow-including tree order, that is not a doctype.
Set searchRange’s start offset to 0.
- @@ -2513,11 +2820,11 @@
Set curNode to the next node in shadow-including tree order.
- -
Run the find a range from a node list steps given query, searchRange, textNodeList, wordStartBounded and wordEndBounded as input. If the resulting range is not null, then return it.
+Run the find a range from a node list steps given query, searchRange, textNodeList, wordStartBounded and wordEndBounded as input. If the resulting range is not null, then return it.
If curNode is null, then break.
- -
Assert: curNode follows searchRange’s start node.
+Assert: curNode follows searchRange’s start node.
Set searchRange’s start to the boundary point (curNode, 0).
@@ -2561,7 +2868,7 @@
To find a range from a node list given a search string queryString, -a range searchRange, a list ofText
nodes nodes, and booleans wordStartBounded and wordEndBounded, follow these steps: +a range searchRange, a list ofText
nodes nodes, and booleans wordStartBounded and wordEndBounded, follow these steps:Optionally, this will only return a match if the matched text begins and/or ends on a word boundary. For example: @@ -2586,7 +2893,7 @@
Let searchStart be 0.
- -
If the first item in nodes is searchRange’s start node then +
If the first item in nodes is searchRange’s start node then set searchStart to searchRange’s start offset.
Let start and end be boundary points, initially null.
@@ -2625,7 +2932,7 @@
Let endInset be 0.
- -
If the last item in nodes is searchRange’s end node then set endInset to (searchRange’s end node's length − searchRange’s end offset)
+If the last item in nodes is searchRange’s end node then set endInset to (searchRange’s end node's length − searchRange’s end offset)
endInset is the offset from the last position in the last node in the reverse direction. Alternatively, it is the length of the node that’s not included in the range.@@ -2635,7 +2942,7 @@
Assert: start and end are non-null, valid boundary points in searchRange.
- - +
@@ -2972,8 +3279,8 @@Index
Terms defined by this specification
-
- allow text fragment scroll, in § 3.5.4
- CharacterString, in § 3.3.4 +
- check if a text directive can be scrolled, in § 3.5.4
- directives, in § 3.3
- directive state @@ -3027,6 +3334,7 @@
uninvoked directives, in § 3.3.2
- UnknownDirective, in § 3.3.4 +
- user involvement, in § 3.5.4
- valid fragment directive, in § 3.3.4
- value, in § 3.3.1
- visible text node, in § 3.6.1 @@ -3084,6 +3392,7 @@
length
- node
- node document +
- origin
- parent
- parent element
- range @@ -3102,7 +3411,6 @@
[FETCH] defines the following terms:
- request -
- user-activation
- [HTML] defines the following terms: @@ -3119,20 +3427,33 @@
HashChangeEvent
- Location
- active document +
- apply the history step +
- apply the push/replace history step
- being rendered
- browsing context
- browsing context set +
- create navigation params by fetching +
- document +
- document state +
- finalize a cross-document navigation +
- group +
- initiator origin
- language
- multiple
- navigate +
- navigate to a fragment +
- navigation params +
- node navigable +
- origin +
- parent
- restore persisted state +
- same origin
- scroll to the fragment
- select
- serializes as void -
- top-level browsing context -
- transient activation
- try to scroll to the fragment
- update document for history step application +
- user navigation involvement
- [INFRA] defines the following terms: @@ -3576,28 +3897,28 @@