Skip to content

Commit

Permalink
Make the Location object deal when it does not have a browsing context
Browse files Browse the repository at this point in the history
  • Loading branch information
annevk committed Oct 9, 2018
1 parent a6c8281 commit 356fd38
Showing 1 changed file with 79 additions and 40 deletions.
119 changes: 79 additions & 40 deletions source
Original file line number Diff line number Diff line change
Expand Up @@ -81078,11 +81078,15 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface

<p>A <code>Location</code> object has an associated <dfn>relevant <code>Document</code></dfn>,
which is this <code>Location</code> object's associated <code>Document</code> object's <span
data-x="concept-document-bc">browsing context</span>'s <span>active document</span>.</p>
data-x="concept-document-bc">browsing context</span>'s <span>active document</span>, if this
<code>Location</code> object's associated <code>Document</code> object's <span
data-x="concept-document-bc">browsing context</span> is a <span>browsing context</span>, and null
otherwise.</p>

<p>A <code>Location</code> object has an associated <dfn data-x="concept-location-url">url</dfn>,
which is this <code>Location</code> object's <span>relevant <code>Document</code></span>'s <span
data-x="concept-document-url">URL</span>.</p>
data-x="concept-document-url">URL</span>, if this <code>Location</code> object's <span>relevant
<code>Document</code></span> is non-null, and <code>about:blank</code> otherwise.</p>

<p>A <code>Location</code> object has an associated <dfn
data-x="concept-location-ancestor-origins-list">ancestor origins list</dfn>. When a
Expand Down Expand Up @@ -81165,10 +81169,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>Return this <code>Location</code> object's <span data-x="concept-location-url">url</span>,
<span data-x="concept-url-serializer">serialized</span>.</p></li>
Expand All @@ -81177,6 +81181,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
<p>The <code data-x="dom-location-href">href</code> attribute's setter must run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p><span data-x="parse a url">Parse</span> the given value relative to the <span>entry
settings object</span>. If that failed, throw a <code>TypeError</code> exception.</p></li>

Expand All @@ -81191,10 +81198,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>Return the <span data-x="serialization of an origin">serialization</span> of this
<code>Location</code> object's <span data-x="concept-location-url">url</span>'s <span
Expand All @@ -81205,10 +81212,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>Return this <code>Location</code> object's <span
data-x="concept-location-url">url</span>'s <span data-x="concept-url-scheme">scheme</span>,
Expand All @@ -81219,6 +81226,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand Down Expand Up @@ -81250,10 +81260,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>Let <var>url</var> be this <code>Location</code> object's <span
data-x="concept-location-url">url</span>.</p></li>
Expand All @@ -81274,6 +81284,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
<p>The <code data-x="dom-location-host">host</code> attribute's setter must run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand All @@ -81296,10 +81309,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>If this <code>Location</code> object's <span data-x="concept-location-url">url</span>'s
<span data-x="concept-url-host">host</span> is null, return the empty string.</p></li>
Expand All @@ -81313,6 +81326,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand All @@ -81335,10 +81351,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>If this <code>Location</code> object's <span data-x="concept-location-url">url</span>'s
<span data-x="concept-url-port">port</span> is null, return the empty string.</p></li>
Expand All @@ -81351,6 +81367,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
<p>The <code data-x="dom-location-port">port</code> attribute's setter must run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand All @@ -81376,10 +81395,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>Let <var>url</var> be this <code>Location</code> object's <span
data-x="concept-location-url">url</span>.</p></li>
Expand All @@ -81399,6 +81418,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand All @@ -81424,10 +81446,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>If this <code>Location</code> object's <span data-x="concept-location-url">url</span>'s
<span data-x="concept-url-query">query</span> is either null or the empty string, return the
Expand All @@ -81442,6 +81464,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand Down Expand Up @@ -81477,10 +81502,10 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
<span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
non-null and its <span>origin</span> is not <span>same origin-domain</span> with the <span>entry
settings object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw
a <span>"<code>SecurityError</code>"</span> <code>DOMException</code>.</p></li>

<li><p>If this <code>Location</code> object's <span data-x="concept-location-url">url</span>'s
<span data-x="concept-url-fragment">fragment</span> is either null or the empty string, return
Expand All @@ -81494,6 +81519,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
<p>The <code data-x="dom-location-hash">hash</code> attribute's setter must run these steps:</p>

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand Down Expand Up @@ -81525,6 +81553,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
method is invoked, the user agent must run the following steps:

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand All @@ -81536,21 +81567,21 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface

<li><p><span><code>Location</code>-object navigate</span> to the <span>resulting URL
record</span>.</p></li>

</ol>

<p>When the <dfn><code data-x="dom-location-replace">replace(<var>url</var>)</code></dfn>
method is invoked, the user agent must run the following steps:

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return.</p></li>

<li><p><span data-x="parse a url">Parse</span> <var>url</var> relative to the <span>entry
settings object</span>. If that failed, throw a <span>"<code>SyntaxError</code>"</span>
<code>DOMException</code>.</p></li>

<li><p><span><code>Location</code>-object navigate</span> to the <span>resulting URL
record</span> with the <var>replacement flag</var> set.</p></li>

</ol>

<p class="note">The <code data-x="dom-location-replace">replace()</code> method intentionally has
Expand All @@ -81560,6 +81591,11 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
user agent must run the appropriate steps from the following list:</p>

<dl class="switch">
<dt>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null</dt>

<dd><p>Return.</p></li>

<dt>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span></dt>
Expand Down Expand Up @@ -81615,6 +81651,9 @@ interface <dfn>Location</dfn> { // but see also <a href="#the-location-interface
getter must run these steps:

<ol>
<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span> is
null, then return « ».</p></li>

<li><p>If this <code>Location</code> object's <span>relevant <code>Document</code></span>'s
<span>origin</span> is not <span>same origin-domain</span> with the <span>entry settings
object</span>'s <span data-x="concept-settings-object-origin">origin</span>, then throw a
Expand Down

0 comments on commit 356fd38

Please sign in to comment.