Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

JavaScript ShadowRealm proposal integration #9893

Open
wants to merge 46 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
afc1353
Editorial: make 'module type allowed' take a realm
Ms2ger Sep 19, 2024
002d9fa
Editorial: replace the settings object field in scripts by a realm field
Ms2ger Sep 19, 2024
3d1c1f2
Editorial: redefine scripting enabled/disabled in terms of realms
Ms2ger Nov 16, 2023
b49562c
Editorial: create CSS/JSON modules with realm
Ms2ger Nov 16, 2023
f1dbdc6
Editorial: create JS modules with realm
Ms2ger Nov 16, 2023
50f5d5c
Editorial: create WebAssembly modules with realm
Ms2ger Sep 20, 2024
e14e94d
Editorial: use a realm in resolve a module specifier
Ms2ger Nov 18, 2024
d5286dc
Editorial: pass a realm to 'creating a classic script'
Ms2ger Feb 7, 2024
9e9543b
Editorial: use realms in check if we can run script
Ms2ger Sep 25, 2024
1beeb82
Editorial: don't go through the settings object to report an exceptio…
Ms2ger Sep 26, 2024
84c282f
Editorial: use realms in prepare to run script/clean up after running…
Ms2ger Sep 25, 2024
698addf
Editorial: use realms around 'incumbent'
Ms2ger Sep 25, 2024
eba56c6
Editorial: use realm in HostPromiseRejectionTracker
Ms2ger Sep 26, 2024
dbd4eef
JavaScript ShadowRealm proposal integration
Ms2ger Sep 25, 2024
e976653
Fetch modules directly for ShadowRealms
Ms2ger Nov 16, 2023
8131d27
Start defining ShadowRealmGlobalObject
Ms2ger Dec 13, 2023
4fc8be2
Add link
Ms2ger Dec 15, 2023
5990402
Review
Ms2ger Jan 18, 2024
6e859ee
Better layering for the mutable global prototype chain
Ms2ger Dec 20, 2023
06b190b
Rephrase
Ms2ger Jan 11, 2024
f788ca6
Add context argument to HostInitializeShadowRealm
Ms2ger Jan 31, 2024
097b31b
Rename ShadowRealmGlobalObject
Ms2ger Jan 18, 2024
8f37b91
Add atob, btoa, structuredClone to shadow realms
Ms2ger Jan 18, 2024
d8e1594
Add queueMicrotask
Ms2ger Feb 7, 2024
20bae79
Indentation
Ms2ger Feb 7, 2024
b1021fe
Rename WindowOrWorkerOrShadowRealmGlobalScope to UniversalGlobalScope
Ms2ger Sep 24, 2024
01e83bb
review
Ms2ger Oct 8, 2024
0dc0ee4
Review
Ms2ger Oct 22, 2024
9e48745
review
Ms2ger Oct 22, 2024
ea3c573
Restructure HostInitializeShadowRealm
Ms2ger Nov 4, 2024
7660208
Indentation
Ms2ger Nov 18, 2024
f5194b0
Fix
Ms2ger Nov 19, 2024
873cd6d
Remove unnecessary concept
Ms2ger Nov 19, 2024
f896319
queueing
Ms2ger Nov 20, 2024
eff546f
Better guidance and sectioning
Ms2ger Nov 21, 2024
dc9fddc
Improve the global object creation
Ms2ger Nov 21, 2024
f0e4ee6
Rephrase
nicolo-ribaudo Nov 21, 2024
c8d1b45
address comment
Ms2ger Nov 21, 2024
a12d85e
Note
Ms2ger Nov 21, 2024
2039fa1
link ShadowRealmGlobalScope
Ms2ger Nov 26, 2024
0f65b04
event handlers
Ms2ger Nov 26, 2024
9aece76
Add reportError
Ms2ger Nov 26, 2024
8cf3150
isSecureContext
Ms2ger Nov 26, 2024
acb7665
Fix base url in module specifier resolution
Ms2ger Nov 27, 2024
7449ee0
Fix HostInitializeShadowRealm
Ms2ger Nov 27, 2024
a2fe477
relevant principal *
Ms2ger Nov 27, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Editorial: pass a realm to 'creating a classic script'
  • Loading branch information
Ms2ger committed Nov 18, 2024
commit d5286dca49349a221ba2838ec964848b8276be29
43 changes: 21 additions & 22 deletions source
Original file line number Diff line number Diff line change
Expand Up @@ -63265,8 +63265,8 @@ document.body.append(script1, script2);
<dd>
<ol>
<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> using
<var>source text</var>, <var>settings object</var>, <var>base URL</var>, and
<var>options</var>.</p></li>
<var>source text</var>, <var>settings object</var>'s <span data-x="environment settings
object's realm">realm</span>, <var>base URL</var>, and <var>options</var>.</p></li>

<li><p><span>Mark as ready</span> <var>el</var> given <var>script</var>.</p></li>
</ol>
Expand Down Expand Up @@ -100323,8 +100323,9 @@ location.href = '#foo';</code></pre>
<li><p>Let <var>baseURL</var> be <var>settings</var>'s <span>API base URL</span>.</p></li>

<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> given
<var>scriptSource</var>, <var>settings</var>, <var>baseURL</var>, and the <span>default script
fetch options</span>.</p></li>
<var>scriptSource</var>, <var>settings</var>'s <span data-x="environment settings object's
realm">realm</span>, <var>baseURL</var>, and the <span>default script fetch
options</span>.</p></li>

<li><p>Let <var>evaluationStatus</var> be the result of <span data-x="run a classic
script">running the classic script</span> <var>script</var>.</p></li>
Expand Down Expand Up @@ -107567,9 +107568,9 @@ document.querySelector("button").addEventListener("click", bound);
<span>CORS-cross-origin</span>, and false otherwise.</p></li>

<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> given
<var>sourceText</var>, <var>settingsObject</var>, <var>response</var>'s <span
data-x="concept-response-url">URL</span>, <var>options</var>,
<var>mutedErrors</var>, and <var>url</var>.</p></li>
<var>sourceText</var>, <var>settingsObject</var>'s <span data-x="environment settings object's
realm">realm</span>, <var>response</var>'s <span data-x="concept-response-url">URL</span>,
<var>options</var>, <var>mutedErrors</var>, and <var>url</var>.</p></li>

<li>Run <var>onComplete</var> given <var>script</var>.</li>
</ol>
Expand Down Expand Up @@ -107648,9 +107649,9 @@ document.querySelector("button").addEventListener("click", bound);
decoding</span> <var>bodyBytes</var>.</p></li>

<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> using
<var>sourceText</var>, <var>settingsObject</var>, <var>response</var>'s <span
data-x="concept-response-url">URL</span>, and the <span>default script fetch
options</span>.</p></li>
<var>sourceText</var>, <var>settingsObject</var>'s <span data-x="environment settings object's
realm">realm</span>, <var>response</var>'s <span data-x="concept-response-url">URL</span>, and
the <span>default script fetch options</span>.</p></li>

<li><p>Run <var>onComplete</var> given <var>script</var>.</p></li>
</ol>
Expand Down Expand Up @@ -107729,9 +107730,9 @@ document.querySelector("button").addEventListener("click", bound);
<span>CORS-cross-origin</span>, and false otherwise.</p></li>

<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> given
<var>sourceText</var>, <var>settingsObject</var>, <var>response</var>'s <span
data-x="concept-response-url">URL</span>, the <span>default script fetch options</span>, and
<var>mutedErrors</var>.</p></li>
<var>sourceText</var>, <var>settingsObject</var>'s <span data-x="environment settings object's
realm">realm</span>, <var>response</var>'s <span data-x="concept-response-url">URL</span>, the
<span>default script fetch options</span>, and <var>mutedErrors</var>.</p></li>

<li><p>Return <var>script</var>.</p></li>
</ol>
Expand Down Expand Up @@ -108260,9 +108261,9 @@ document.querySelector("button").addEventListener("click", bound);
<h5 id="creating-scripts">Creating scripts</h5>

<p>To <dfn data-x="creating a classic script">create a classic script</dfn>, given a
<span>string</span> <var>source</var>, an <span>environment settings object</span>
<var>settings</var>, a <span>URL</span> <var>baseURL</var>, a <span>script fetch options</span>
<var>options</var>, an optional boolean <var>mutedErrors</var> (default false), and an optional
<span>string</span> <var>source</var>, a <span>realm</span> <var>realm</var>,
a <span>URL</span> <var>baseURL</var>, a <span>script fetch options</span> <var>options</var>,
an optional boolean <var>mutedErrors</var> (default false), and an optional
<span>URL</span>-or-null <var>sourceURLForWindowScripts</var> (default null):</p>

<ol>
Expand All @@ -108277,14 +108278,13 @@ document.querySelector("button").addEventListener("click", bound);
</li>

<li><p>If <span data-x="concept-realm-noscript">scripting is disabled</span> for
<var>settings</var>'s <span data-x="environment settings object's realm">realm</span>, then set
<var>source</var> to the empty string.</p></li>
<var>realm</var>, then set <var>source</var> to the empty string.</p></li>

<li><p>Let <var>script</var> be a new <span>classic script</span> that this algorithm will
subsequently initialize.</p></li>

<li><p>Set <var>script</var>'s <span data-x="concept-script-realm">realm</span> to
<var>settings</var>'s <span data-x="environment settings object's realm">realm</span>.</p></li>
<var>realm</var>.</p></li>

<li><p>Set <var>script</var>'s <span data-x="concept-script-base-url">base URL</span> to
<var>baseURL</var>.</p></li>
Expand All @@ -108302,8 +108302,7 @@ document.querySelector("button").addEventListener("click", bound);

<li>
<p>Let <var>result</var> be <span data-x="js-ParseScript">ParseScript</span>(<var>source</var>,
<var>settings</var>'s <span data-x="environment settings object's realm">realm</span>,
<var>script</var>).</p>
<var>realm</var>, <var>script</var>).</p>

<p class="note">Passing <var>script</var> as the last parameter here ensures
<var>result</var>.[[HostDefined]] will be <var>script</var>.</p>
Expand Down Expand Up @@ -115268,7 +115267,7 @@ enum <dfn enum>DOMParserSupportedType</dfn> {
</li>

<li><p>Let <var>script</var> be the result of <span>creating a classic script</span> given
<var>handler</var>, <var>settings object</var>, <var>base URL</var>, and <var>fetch
<var>handler</var>, <var>realm</var>, <var>base URL</var>, and <var>fetch
options</var>.</p></li>

<li><p><span data-x="run a classic script">Run the classic script</span>
Expand Down