1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-12 00:54:02 -05:00

chore: Update dlint (#17031)

Introduces `SafeSetIterator` and `SafeMapIterator` to primordials
This commit is contained in:
Kenta Moriuchi 2022-12-20 11:37:50 +09:00 committed by Bartek Iwańczuk
parent ba1a5424dd
commit 60b0deb726
No known key found for this signature in database
GPG key ID: 0C6BCDDC3B3AD750
31 changed files with 222 additions and 141 deletions

View file

@ -248,31 +248,6 @@
copyPrototype(original.prototype, primordials, `${name}Prototype`); copyPrototype(original.prototype, primordials, `${name}Prototype`);
}); });
// Create copies of abstract intrinsic objects that are not directly exposed
// on the global object.
// Refs: https://tc39.es/ecma262/#sec-%typedarray%-intrinsic-object
[
{ name: "TypedArray", original: Reflect.getPrototypeOf(Uint8Array) },
{
name: "ArrayIterator",
original: {
prototype: Reflect.getPrototypeOf(Array.prototype[Symbol.iterator]()),
},
},
{
name: "StringIterator",
original: {
prototype: Reflect.getPrototypeOf(String.prototype[Symbol.iterator]()),
},
},
].forEach(({ name, original }) => {
primordials[name] = original;
// The static %TypedArray% methods require a valid `this`, but can't be bound,
// as they need a subclass constructor as the receiver:
copyPrototype(original, primordials, name);
copyPrototype(original.prototype, primordials, `${name}Prototype`);
});
const { const {
ArrayPrototypeForEach, ArrayPrototypeForEach,
ArrayPrototypeMap, ArrayPrototypeMap,
@ -291,6 +266,43 @@
WeakSet, WeakSet,
} = primordials; } = primordials;
// Create copies of abstract intrinsic objects that are not directly exposed
// on the global object.
// Refs: https://tc39.es/ecma262/#sec-%typedarray%-intrinsic-object
[
{ name: "TypedArray", original: Reflect.getPrototypeOf(Uint8Array) },
{
name: "ArrayIterator",
original: {
prototype: Reflect.getPrototypeOf(Array.prototype[Symbol.iterator]()),
},
},
{
name: "SetIterator",
original: {
prototype: Reflect.getPrototypeOf(new Set()[Symbol.iterator]()),
},
},
{
name: "MapIterator",
original: {
prototype: Reflect.getPrototypeOf(new Map()[Symbol.iterator]()),
},
},
{
name: "StringIterator",
original: {
prototype: Reflect.getPrototypeOf(String.prototype[Symbol.iterator]()),
},
},
].forEach(({ name, original }) => {
primordials[name] = original;
// The static %TypedArray% methods require a valid `this`, but can't be bound,
// as they need a subclass constructor as the receiver:
copyPrototype(original, primordials, name);
copyPrototype(original.prototype, primordials, `${name}Prototype`);
});
// Because these functions are used by `makeSafe`, which is exposed // Because these functions are used by `makeSafe`, which is exposed
// on the `primordials` object, it's important to use const references // on the `primordials` object, it's important to use const references
// to the primordials that they use: // to the primordials that they use:
@ -316,6 +328,14 @@
primordials.ArrayPrototypeSymbolIterator, primordials.ArrayPrototypeSymbolIterator,
primordials.ArrayIteratorPrototypeNext, primordials.ArrayIteratorPrototypeNext,
); );
primordials.SafeSetIterator = createSafeIterator(
primordials.SetPrototypeSymbolIterator,
primordials.SetIteratorPrototypeNext,
);
primordials.SafeMapIterator = createSafeIterator(
primordials.MapPrototypeSymbolIterator,
primordials.MapIteratorPrototypeNext,
);
primordials.SafeStringIterator = createSafeIterator( primordials.SafeStringIterator = createSafeIterator(
primordials.StringPrototypeSymbolIterator, primordials.StringPrototypeSymbolIterator,
primordials.StringIteratorPrototypeNext, primordials.StringIteratorPrototypeNext,

View file

@ -16,6 +16,7 @@
ArrayPrototypeIndexOf, ArrayPrototypeIndexOf,
ArrayPrototypeSplice, ArrayPrototypeSplice,
ArrayPrototypePush, ArrayPrototypePush,
SafeArrayIterator,
Symbol, Symbol,
Uint8Array, Uint8Array,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -43,7 +44,7 @@
} }
function dispatch(source, name, data) { function dispatch(source, name, data) {
for (const channel of channels) { for (const channel of new SafeArrayIterator(channels)) {
if (channel === source) continue; // Don't self-send. if (channel === source) continue; // Don't self-send.
if (channel[_name] !== name) continue; if (channel[_name] !== name) continue;
if (channel[_closed]) continue; if (channel[_closed]) continue;

View file

@ -6,6 +6,7 @@
const webidl = window.__bootstrap.webidl; const webidl = window.__bootstrap.webidl;
const { const {
Symbol, Symbol,
SafeArrayIterator,
TypeError, TypeError,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -114,7 +115,7 @@
const varyHeader = getHeader(innerResponse.headerList, "vary"); const varyHeader = getHeader(innerResponse.headerList, "vary");
if (varyHeader) { if (varyHeader) {
const fieldValues = varyHeader.split(","); const fieldValues = varyHeader.split(",");
for (const field of fieldValues) { for (const field of new SafeArrayIterator(fieldValues)) {
if (field.trim() === "*") { if (field.trim() === "*") {
throw new TypeError("Vary header must not contain '*'"); throw new TypeError("Vary header must not contain '*'");
} }

View file

@ -56,6 +56,7 @@
RegExpPrototypeTest, RegExpPrototypeTest,
RegExpPrototypeToString, RegExpPrototypeToString,
SafeArrayIterator, SafeArrayIterator,
SafeStringIterator,
SafeSet, SafeSet,
SetPrototype, SetPrototype,
SetPrototypeEntries, SetPrototypeEntries,
@ -206,7 +207,7 @@
str = StringPrototypeNormalize(colors.stripColor(str), "NFC"); str = StringPrototypeNormalize(colors.stripColor(str), "NFC");
let width = 0; let width = 0;
for (const ch of str) { for (const ch of new SafeStringIterator(str)) {
width += isFullWidthCodePoint(StringPrototypeCodePointAt(ch, 0)) ? 2 : 1; width += isFullWidthCodePoint(StringPrototypeCodePointAt(ch, 0)) ? 2 : 1;
} }
@ -276,7 +277,7 @@
}` + }` +
`${tableChars.rightMiddle}\n`; `${tableChars.rightMiddle}\n`;
for (const row of rows) { for (const row of new SafeArrayIterator(rows)) {
result += `${renderRow(row, columnWidths, columnRightAlign)}\n`; result += `${renderRow(row, columnWidths, columnRightAlign)}\n`;
} }
@ -994,7 +995,7 @@
} }
const refMap = new Map(); const refMap = new Map();
for (const cause of causes) { for (const cause of new SafeArrayIterator(causes)) {
if (circular !== undefined) { if (circular !== undefined) {
const index = MapPrototypeGet(circular, cause); const index = MapPrototypeGet(circular, cause);
if (index !== undefined) { if (index !== undefined) {
@ -1171,7 +1172,7 @@
inspectOptions.indentLevel++; inspectOptions.indentLevel++;
for (const key of stringKeys) { for (const key of new SafeArrayIterator(stringKeys)) {
if (inspectOptions.getters) { if (inspectOptions.getters) {
let propertyValue; let propertyValue;
let error = null; let error = null;
@ -1207,7 +1208,7 @@
} }
} }
for (const key of symbolKeys) { for (const key of new SafeArrayIterator(symbolKeys)) {
if ( if (
!inspectOptions.showHidden && !inspectOptions.showHidden &&
!propertyIsEnumerable(value, key) !propertyIsEnumerable(value, key)
@ -1639,7 +1640,7 @@
currentPart = ""; currentPart = "";
} }
for (const [key, value] of rawEntries) { for (const [key, value] of new SafeArrayIterator(rawEntries)) {
if (key == "background-color") { if (key == "background-color") {
if (value != null) { if (value != null) {
css.backgroundColor = value; css.backgroundColor = value;
@ -1660,7 +1661,11 @@
} }
} else if (key == "text-decoration-line") { } else if (key == "text-decoration-line") {
css.textDecorationLine = []; css.textDecorationLine = [];
for (const lineType of StringPrototypeSplit(value, /\s+/g)) { for (
const lineType of new SafeArrayIterator(
StringPrototypeSplit(value, /\s+/g),
)
) {
if ( if (
ArrayPrototypeIncludes( ArrayPrototypeIncludes(
["line-through", "overline", "underline"], ["line-through", "overline", "underline"],
@ -1678,7 +1683,11 @@
} else if (key == "text-decoration") { } else if (key == "text-decoration") {
css.textDecorationColor = null; css.textDecorationColor = null;
css.textDecorationLine = []; css.textDecorationLine = [];
for (const arg of StringPrototypeSplit(value, /\s+/g)) { for (
const arg of new SafeArrayIterator(
StringPrototypeSplit(value, /\s+/g),
)
) {
const maybeColor = parseCssColor(arg); const maybeColor = parseCssColor(arg);
if (maybeColor != null) { if (maybeColor != null) {
css.textDecorationColor = maybeColor; css.textDecorationColor = maybeColor;
@ -2135,7 +2144,7 @@
} else { } else {
const valueObj = value || {}; const valueObj = value || {};
const keys = properties || ObjectKeys(valueObj); const keys = properties || ObjectKeys(valueObj);
for (const k of keys) { for (const k of new SafeArrayIterator(keys)) {
if (!primitive && ReflectHas(valueObj, k)) { if (!primitive && ReflectHas(valueObj, k)) {
if (!(ReflectHas(objectValues, k))) { if (!(ReflectHas(objectValues, k))) {
objectValues[k] = ArrayPrototypeFill(new Array(numRows), ""); objectValues[k] = ArrayPrototypeFill(new Array(numRows), "");
@ -2330,7 +2339,7 @@
function wrapConsole(consoleFromDeno, consoleFromV8) { function wrapConsole(consoleFromDeno, consoleFromV8) {
const callConsole = core.callConsole; const callConsole = core.callConsole;
for (const key of ObjectKeys(consoleFromV8)) { for (const key of new SafeArrayIterator(ObjectKeys(consoleFromV8))) {
if (ObjectPrototypeHasOwnProperty(consoleFromDeno, key)) { if (ObjectPrototypeHasOwnProperty(consoleFromDeno, key)) {
consoleFromDeno[key] = FunctionPrototypeBind( consoleFromDeno[key] = FunctionPrototypeBind(
callConsole, callConsole,

View file

@ -34,6 +34,7 @@
StringPrototypeToUpperCase, StringPrototypeToUpperCase,
StringPrototypeCharCodeAt, StringPrototypeCharCodeAt,
StringFromCharCode, StringFromCharCode,
SafeArrayIterator,
Symbol, Symbol,
SymbolFor, SymbolFor,
SyntaxError, SyntaxError,
@ -4052,7 +4053,7 @@
} }
const pkcs8Der = ops.op_export_pkcs8_ed25519( const pkcs8Der = ops.op_export_pkcs8_ed25519(
new Uint8Array([0x04, 0x22, ...innerKey]), new Uint8Array([0x04, 0x22, ...new SafeArrayIterator(innerKey)]),
); );
pkcs8Der[15] = 0x20; pkcs8Der[15] = 0x20;
return pkcs8Der.buffer; return pkcs8Der.buffer;
@ -4115,7 +4116,7 @@
} }
const pkcs8Der = ops.op_export_pkcs8_x25519( const pkcs8Der = ops.op_export_pkcs8_x25519(
new Uint8Array([0x04, 0x22, ...innerKey]), new Uint8Array([0x04, 0x22, ...new SafeArrayIterator(innerKey)]),
); );
pkcs8Der[15] = 0x20; pkcs8Der[15] = 0x20;
return pkcs8Der.buffer; return pkcs8Der.buffer;

View file

@ -68,7 +68,7 @@
*/ */
function fillHeaders(headers, object) { function fillHeaders(headers, object) {
if (ArrayIsArray(object)) { if (ArrayIsArray(object)) {
for (const header of object) { for (const header of new SafeArrayIterator(object)) {
if (header.length !== 2) { if (header.length !== 2) {
throw new TypeError( throw new TypeError(
`Invalid header. Length must be 2, but is ${header.length}`, `Invalid header. Length must be 2, but is ${header.length}`,
@ -205,7 +205,7 @@
// spec but produce the same result. // spec but produce the same result.
const headers = {}; const headers = {};
const cookies = []; const cookies = [];
for (const entry of list) { for (const entry of new SafeArrayIterator(list)) {
const name = byteLowerCase(entry[0]); const name = byteLowerCase(entry[0]);
const value = entry[1]; const value = entry[1];
if (value === null) throw new TypeError("Unreachable"); if (value === null) throw new TypeError("Unreachable");
@ -405,6 +405,7 @@
[SymbolFor("Deno.privateCustomInspect")](inspect) { [SymbolFor("Deno.privateCustomInspect")](inspect) {
const headers = {}; const headers = {};
// deno-lint-ignore prefer-primordials
for (const header of this) { for (const header of this) {
headers[header[0]] = header[1]; headers[header[0]] = header[1];
} }

View file

@ -25,6 +25,7 @@
MathRandom, MathRandom,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
Symbol, Symbol,
SafeArrayIterator,
StringFromCharCode, StringFromCharCode,
StringPrototypeTrim, StringPrototypeTrim,
StringPrototypeSlice, StringPrototypeSlice,
@ -162,7 +163,7 @@
context: "Argument 1", context: "Argument 1",
}); });
for (const entry of this[entryList]) { for (const entry of new SafeArrayIterator(this[entryList])) {
if (entry.name === name) return entry.value; if (entry.name === name) return entry.value;
} }
return null; return null;
@ -183,7 +184,7 @@
}); });
const returnList = []; const returnList = [];
for (const entry of this[entryList]) { for (const entry of new SafeArrayIterator(this[entryList])) {
if (entry.name === name) ArrayPrototypePush(returnList, entry.value); if (entry.name === name) ArrayPrototypePush(returnList, entry.value);
} }
return returnList; return returnList;
@ -203,7 +204,7 @@
context: "Argument 1", context: "Argument 1",
}); });
for (const entry of this[entryList]) { for (const entry of new SafeArrayIterator(this[entryList])) {
if (entry.name === name) return true; if (entry.name === name) return true;
} }
return false; return false;
@ -298,6 +299,7 @@
const chunks = []; const chunks = [];
const prefix = `--${boundary}\r\nContent-Disposition: form-data; name="`; const prefix = `--${boundary}\r\nContent-Disposition: form-data; name="`;
// deno-lint-ignore prefer-primordials
for (const [name, value] of formData) { for (const [name, value] of formData) {
if (typeof value === "string") { if (typeof value === "string") {
ArrayPrototypePush( ArrayPrototypePush(
@ -372,7 +374,7 @@
#parseHeaders(headersText) { #parseHeaders(headersText) {
const headers = new Headers(); const headers = new Headers();
const rawHeaders = StringPrototypeSplit(headersText, "\r\n"); const rawHeaders = StringPrototypeSplit(headersText, "\r\n");
for (const rawHeader of rawHeaders) { for (const rawHeader of new SafeArrayIterator(rawHeaders)) {
const sepIndex = StringPrototypeIndexOf(rawHeader, ":"); const sepIndex = StringPrototypeIndexOf(rawHeader, ":");
if (sepIndex < 0) { if (sepIndex < 0) {
continue; // Skip this header continue; // Skip this header

View file

@ -6,18 +6,20 @@
const ops = core.ops; const ops = core.ops;
const __bootstrap = window.__bootstrap; const __bootstrap = window.__bootstrap;
const { const {
ObjectDefineProperty,
ArrayPrototypeMap, ArrayPrototypeMap,
ArrayPrototypeJoin,
ObjectDefineProperty,
ObjectPrototypeHasOwnProperty,
ObjectPrototypeIsPrototypeOf,
Number, Number,
NumberIsSafeInteger, NumberIsSafeInteger,
ArrayPrototypeJoin,
ObjectPrototypeIsPrototypeOf,
TypeError, TypeError,
Int32Array, Int32Array,
Uint32Array, Uint32Array,
BigInt64Array, BigInt64Array,
BigUint64Array, BigUint64Array,
Function, Function,
ReflectHas,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
const U32_BUFFER = new Uint32Array(2); const U32_BUFFER = new Uint32Array(2);
@ -273,7 +275,11 @@
constructor(path, symbols) { constructor(path, symbols) {
[this.#rid, this.symbols] = ops.op_ffi_load({ path, symbols }); [this.#rid, this.symbols] = ops.op_ffi_load({ path, symbols });
for (const symbol in symbols) { for (const symbol in symbols) {
if ("type" in symbols[symbol]) { if (!ObjectPrototypeHasOwnProperty(symbols, symbol)) {
continue;
}
if (ReflectHas(symbols[symbol], "type")) {
const type = symbols[symbol].type; const type = symbols[symbol].type;
if (type === "void") { if (type === "void") {
throw new TypeError( throw new TypeError(

View file

@ -27,11 +27,11 @@
} = window.__bootstrap.webSocket; } = window.__bootstrap.webSocket;
const { _ws } = window.__bootstrap.http; const { _ws } = window.__bootstrap.http;
const { const {
Function,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
Promise, PromisePrototype,
PromisePrototypeCatch, PromisePrototypeCatch,
PromisePrototypeThen, PromisePrototypeThen,
SafeArrayIterator,
SafePromiseAll, SafePromiseAll,
TypedArrayPrototypeSubarray, TypedArrayPrototypeSubarray,
TypeError, TypeError,
@ -140,7 +140,7 @@
// status-line = HTTP-version SP status-code SP reason-phrase CRLF // status-line = HTTP-version SP status-code SP reason-phrase CRLF
// Date header: https://datatracker.ietf.org/doc/html/rfc7231#section-7.1.1.2 // Date header: https://datatracker.ietf.org/doc/html/rfc7231#section-7.1.1.2
let str = `HTTP/1.1 ${status} ${statusCodes[status]}\r\nDate: ${date}\r\n`; let str = `HTTP/1.1 ${status} ${statusCodes[status]}\r\nDate: ${date}\r\n`;
for (const [name, value] of headerList) { for (const [name, value] of new SafeArrayIterator(headerList)) {
// header-field = field-name ":" OWS field-value OWS // header-field = field-name ":" OWS field-value OWS
str += `${name}: ${value}\r\n`; str += `${name}: ${value}\r\n`;
} }
@ -439,10 +439,10 @@
return async function serve(arg1, arg2) { return async function serve(arg1, arg2) {
let options = undefined; let options = undefined;
let handler = undefined; let handler = undefined;
if (arg1 instanceof Function) { if (typeof arg1 === "function") {
handler = arg1; handler = arg1;
options = arg2; options = arg2;
} else if (arg2 instanceof Function) { } else if (typeof arg2 === "function") {
handler = arg2; handler = arg2;
options = arg1; options = arg1;
} else { } else {
@ -456,7 +456,7 @@
} }
handler = options.handler; handler = options.handler;
} }
if (!(handler instanceof Function)) { if (typeof handler !== "function") {
throw new TypeError("A handler function must be provided."); throw new TypeError("A handler function must be provided.");
} }
if (options === undefined) { if (options === undefined) {
@ -570,7 +570,7 @@
let resp; let resp;
try { try {
resp = handler(req); resp = handler(req);
if (resp instanceof Promise) { if (ObjectPrototypeIsPrototypeOf(PromisePrototype, resp)) {
PromisePrototypeCatch( PromisePrototypeCatch(
PromisePrototypeThen( PromisePrototypeThen(
resp, resp,

View file

@ -45,10 +45,10 @@
ArrayPrototypeSome, ArrayPrototypeSome,
Error, Error,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
SafeSetIterator,
Set, Set,
SetPrototypeAdd, SetPrototypeAdd,
SetPrototypeDelete, SetPrototypeDelete,
SetPrototypeValues,
StringPrototypeIncludes, StringPrototypeIncludes,
StringPrototypeToLowerCase, StringPrototypeToLowerCase,
StringPrototypeSplit, StringPrototypeSplit,
@ -153,7 +153,7 @@
if (!this.#closed) { if (!this.#closed) {
this.#closed = true; this.#closed = true;
core.close(this.#rid); core.close(this.#rid);
for (const rid of SetPrototypeValues(this.managedResources)) { for (const rid of new SafeSetIterator(this.managedResources)) {
SetPrototypeDelete(this.managedResources, rid); SetPrototypeDelete(this.managedResources, rid);
core.close(rid); core.close(rid);
} }

View file

@ -194,7 +194,7 @@
context: "Argument 1", context: "Argument 1",
}); });
const values = []; const values = [];
for (const entry of this[_list]) { for (const entry of new SafeArrayIterator(this[_list])) {
if (entry[0] === name) { if (entry[0] === name) {
ArrayPrototypePush(values, entry[1]); ArrayPrototypePush(values, entry[1]);
} }
@ -214,7 +214,7 @@
prefix, prefix,
context: "Argument 1", context: "Argument 1",
}); });
for (const entry of this[_list]) { for (const entry of new SafeArrayIterator(this[_list])) {
if (entry[0] === name) { if (entry[0] === name) {
return entry[1]; return entry[1];
} }

View file

@ -20,6 +20,7 @@
RegExp, RegExp,
RegExpPrototypeExec, RegExpPrototypeExec,
RegExpPrototypeTest, RegExpPrototypeTest,
SafeArrayIterator,
Symbol, Symbol,
SymbolFor, SymbolFor,
TypeError, TypeError,
@ -71,7 +72,7 @@
const components = ops.op_urlpattern_parse(input, baseURL); const components = ops.op_urlpattern_parse(input, baseURL);
for (const key of ObjectKeys(components)) { for (const key of new SafeArrayIterator(ObjectKeys(components))) {
try { try {
components[key].regexp = new RegExp( components[key].regexp = new RegExp(
components[key].regexpString, components[key].regexpString,
@ -155,7 +156,7 @@
const [values] = res; const [values] = res;
for (const key of ObjectKeys(values)) { for (const key of new SafeArrayIterator(ObjectKeys(values))) {
if (!RegExpPrototypeTest(this[_components][key].regexp, values[key])) { if (!RegExpPrototypeTest(this[_components][key].regexp, values[key])) {
return false; return false;
} }
@ -201,7 +202,7 @@
const result = { inputs }; const result = { inputs };
/** @type {string} */ /** @type {string} */
for (const key of ObjectKeys(values)) { for (const key of new SafeArrayIterator(ObjectKeys(values))) {
/** @type {Component} */ /** @type {Component} */
const component = this[_components][key]; const component = this[_components][key];
const input = values[key]; const input = values[key];

View file

@ -19,6 +19,7 @@
ObjectEntries, ObjectEntries,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
ObjectSetPrototypeOf, ObjectSetPrototypeOf,
SafeArrayIterator,
Symbol, Symbol,
SymbolFor, SymbolFor,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -166,7 +167,8 @@
const DOMExceptionPrototype = DOMException.prototype; const DOMExceptionPrototype = DOMException.prototype;
for ( for (
const [key, value] of ObjectEntries({ const [key, value] of new SafeArrayIterator(
ObjectEntries({
INDEX_SIZE_ERR, INDEX_SIZE_ERR,
DOMSTRING_SIZE_ERR, DOMSTRING_SIZE_ERR,
HIERARCHY_REQUEST_ERR, HIERARCHY_REQUEST_ERR,
@ -192,7 +194,8 @@
TIMEOUT_ERR, TIMEOUT_ERR,
INVALID_NODE_TYPE_ERR, INVALID_NODE_TYPE_ERR,
DATA_CLONE_ERR, DATA_CLONE_ERR,
}) }),
)
) { ) {
const desc = { value, enumerable: true }; const desc = { value, enumerable: true };
ObjectDefineProperty(DOMException, key, desc); ObjectDefineProperty(DOMException, key, desc);

View file

@ -16,6 +16,8 @@
MapPrototypeHas, MapPrototypeHas,
MapPrototypeSet, MapPrototypeSet,
RegExpPrototypeTest, RegExpPrototypeTest,
SafeArrayIterator,
SafeMapIterator,
StringPrototypeReplaceAll, StringPrototypeReplaceAll,
StringPrototypeToLowerCase, StringPrototypeToLowerCase,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -195,7 +197,7 @@
*/ */
function serializeMimeType(mimeType) { function serializeMimeType(mimeType) {
let serialization = essence(mimeType); let serialization = essence(mimeType);
for (const param of mimeType.parameters) { for (const param of new SafeMapIterator(mimeType.parameters)) {
serialization += `;${param[0]}=`; serialization += `;${param[0]}=`;
let value = param[1]; let value = param[1];
if (!RegExpPrototypeTest(HTTP_TOKEN_CODE_POINT_RE, value)) { if (!RegExpPrototypeTest(HTTP_TOKEN_CODE_POINT_RE, value)) {
@ -221,7 +223,7 @@
let charset = null; let charset = null;
let essence_ = null; let essence_ = null;
let mimeType = null; let mimeType = null;
for (const value of headerValues) { for (const value of new SafeArrayIterator(headerValues)) {
const temporaryMimeType = parseMimeType(value); const temporaryMimeType = parseMimeType(value);
if ( if (
temporaryMimeType === null || temporaryMimeType === null ||

View file

@ -428,7 +428,7 @@
Ctor, Ctor,
props, props,
) { ) {
for (const prop of props) { for (const prop of new SafeArrayIterator(props)) {
ReflectDefineProperty(Ctor.prototype, prop, { enumerable: true }); ReflectDefineProperty(Ctor.prototype, prop, { enumerable: true });
} }
} }
@ -969,7 +969,7 @@
listeners[type] = []; listeners[type] = [];
} }
for (const listener of listeners[type]) { for (const listener of new SafeArrayIterator(listeners[type])) {
if ( if (
((typeof listener.options === "boolean" && ((typeof listener.options === "boolean" &&
listener.options === options.capture) || listener.options === options.capture) ||
@ -1334,9 +1334,12 @@
[SymbolFor("Deno.privateCustomInspect")](inspect) { [SymbolFor("Deno.privateCustomInspect")](inspect) {
return inspect(consoleInternal.createFilteredInspectProxy({ return inspect(consoleInternal.createFilteredInspectProxy({
object: this, object: this,
evaluate: this instanceof PromiseRejectionEvent, evaluate: ObjectPrototypeIsPrototypeOf(
PromiseRejectionEvent.prototype,
this,
),
keys: [ keys: [
...EVENT_PROPS, ...new SafeArrayIterator(EVENT_PROPS),
"promise", "promise",
"reason", "reason",
], ],
@ -1451,7 +1454,7 @@
colno = jsError.frames[0].columnNumber; colno = jsError.frames[0].columnNumber;
} else { } else {
const jsError = core.destructureError(new Error()); const jsError = core.destructureError(new Error());
for (const frame of jsError.frames) { for (const frame of new SafeArrayIterator(jsError.frames)) {
if ( if (
typeof frame.fileName == "string" && typeof frame.fileName == "string" &&
!StringPrototypeStartsWith(frame.fileName, "deno:") !StringPrototypeStartsWith(frame.fileName, "deno:")

View file

@ -9,6 +9,8 @@
const { Event, setIsTrusted, defineEventHandler } = window.__bootstrap.event; const { Event, setIsTrusted, defineEventHandler } = window.__bootstrap.event;
const { EventTarget, listenerCount } = window.__bootstrap.eventTarget; const { EventTarget, listenerCount } = window.__bootstrap.eventTarget;
const { const {
SafeArrayIterator,
SafeSetIterator,
Set, Set,
SetPrototypeAdd, SetPrototypeAdd,
SetPrototypeDelete, SetPrototypeDelete,
@ -76,7 +78,7 @@
} }
this[abortReason] = reason; this[abortReason] = reason;
if (this[abortAlgos] !== null) { if (this[abortAlgos] !== null) {
for (const algorithm of this[abortAlgos]) { for (const algorithm of new SafeSetIterator(this[abortAlgos])) {
algorithm(); algorithm();
} }
this[abortAlgos] = null; this[abortAlgos] = null;
@ -124,14 +126,14 @@
// only be used by Deno internals, which use it to essentially cancel async // only be used by Deno internals, which use it to essentially cancel async
// ops which would block the event loop. // ops which would block the event loop.
addEventListener(...args) { addEventListener(...args) {
super.addEventListener(...args); super.addEventListener(...new SafeArrayIterator(args));
if (this[timerId] !== null && listenerCount(this, "abort") > 0) { if (this[timerId] !== null && listenerCount(this, "abort") > 0) {
refTimer(this[timerId]); refTimer(this[timerId]);
} }
} }
removeEventListener(...args) { removeEventListener(...args) {
super.removeEventListener(...args); super.removeEventListener(...new SafeArrayIterator(args));
if (this[timerId] !== null && listenerCount(this, "abort") === 0) { if (this[timerId] !== null && listenerCount(this, "abort") === 0) {
unrefTimer(this[timerId]); unrefTimer(this[timerId]);
} }

View file

@ -13,7 +13,10 @@
const ops = core.ops; const ops = core.ops;
const webidl = window.__bootstrap.webidl; const webidl = window.__bootstrap.webidl;
const { DOMException } = window.__bootstrap.domException; const { DOMException } = window.__bootstrap.domException;
const { TypeError } = window.__bootstrap.primordials; const {
ObjectPrototypeIsPrototypeOf,
TypeErrorPrototype,
} = window.__bootstrap.primordials;
/** /**
* @param {string} data * @param {string} data
@ -29,7 +32,7 @@
try { try {
return ops.op_base64_atob(data); return ops.op_base64_atob(data);
} catch (e) { } catch (e) {
if (e instanceof TypeError) { if (ObjectPrototypeIsPrototypeOf(TypeErrorPrototype, e)) {
throw new DOMException( throw new DOMException(
"Failed to decode base64: invalid character", "Failed to decode base64: invalid character",
"InvalidCharacterError", "InvalidCharacterError",
@ -53,7 +56,7 @@
try { try {
return ops.op_base64_btoa(data); return ops.op_base64_btoa(data);
} catch (e) { } catch (e) {
if (e instanceof TypeError) { if (ObjectPrototypeIsPrototypeOf(TypeErrorPrototype, e)) {
throw new DOMException( throw new DOMException(
"The string to be encoded contains characters outside of the Latin1 range.", "The string to be encoded contains characters outside of the Latin1 range.",
"InvalidCharacterError", "InvalidCharacterError",

View file

@ -42,6 +42,7 @@
queueMicrotask, queueMicrotask,
RangeError, RangeError,
ReflectHas, ReflectHas,
SafeArrayIterator,
SafePromiseAll, SafePromiseAll,
SharedArrayBuffer, SharedArrayBuffer,
Symbol, Symbol,
@ -769,7 +770,7 @@
} }
function readableStreamIsUnrefable(stream) { function readableStreamIsUnrefable(stream) {
return _isUnref in stream; return ReflectHas(stream, _isUnref);
} }
function readableStreamForRidUnrefableRef(stream) { function readableStreamForRidUnrefableRef(stream) {
@ -858,7 +859,7 @@
const finalBuffer = new Uint8Array(totalLength); const finalBuffer = new Uint8Array(totalLength);
let i = 0; let i = 0;
for (const chunk of chunks) { for (const chunk of new SafeArrayIterator(chunks)) {
TypedArrayPrototypeSet(finalBuffer, chunk, i); TypedArrayPrototypeSet(finalBuffer, chunk, i);
i += chunk.byteLength; i += chunk.byteLength;
} }
@ -1345,7 +1346,7 @@
if (reader !== undefined && isReadableStreamBYOBReader(reader)) { if (reader !== undefined && isReadableStreamBYOBReader(reader)) {
const readIntoRequests = reader[_readIntoRequests]; const readIntoRequests = reader[_readIntoRequests];
reader[_readIntoRequests] = []; reader[_readIntoRequests] = [];
for (const readIntoRequest of readIntoRequests) { for (const readIntoRequest of new SafeArrayIterator(readIntoRequests)) {
readIntoRequest.closeSteps(undefined); readIntoRequest.closeSteps(undefined);
} }
} }
@ -1371,7 +1372,7 @@
/** @type {Array<ReadRequest<R>>} */ /** @type {Array<ReadRequest<R>>} */
const readRequests = reader[_readRequests]; const readRequests = reader[_readRequests];
reader[_readRequests] = []; reader[_readRequests] = [];
for (const readRequest of readRequests) { for (const readRequest of new SafeArrayIterator(readRequests)) {
readRequest.closeSteps(); readRequest.closeSteps();
} }
} }
@ -1593,7 +1594,7 @@
function readableStreamDefaultReaderErrorReadRequests(reader, e) { function readableStreamDefaultReaderErrorReadRequests(reader, e) {
const readRequests = reader[_readRequests]; const readRequests = reader[_readRequests];
reader[_readRequests] = []; reader[_readRequests] = [];
for (const readRequest of readRequests) { for (const readRequest of new SafeArrayIterator(readRequests)) {
readRequest.errorSteps(e); readRequest.errorSteps(e);
} }
} }
@ -2613,7 +2614,7 @@
function readableStreamBYOBReaderErrorReadIntoRequests(reader, e) { function readableStreamBYOBReaderErrorReadIntoRequests(reader, e) {
const readIntoRequests = reader[_readIntoRequests]; const readIntoRequests = reader[_readIntoRequests];
reader[_readIntoRequests] = []; reader[_readIntoRequests] = [];
for (const readIntoRequest of readIntoRequests) { for (const readIntoRequest of new SafeArrayIterator(readIntoRequests)) {
readIntoRequest.errorSteps(e); readIntoRequest.errorSteps(e);
} }
} }
@ -4237,7 +4238,7 @@
stream[_state] = "errored"; stream[_state] = "errored";
stream[_controller][_errorSteps](); stream[_controller][_errorSteps]();
const storedError = stream[_storedError]; const storedError = stream[_storedError];
for (const writeRequest of stream[_writeRequests]) { for (const writeRequest of new SafeArrayIterator(stream[_writeRequests])) {
writeRequest.reject(storedError); writeRequest.reject(storedError);
} }
stream[_writeRequests] = []; stream[_writeRequests] = [];

View file

@ -26,6 +26,7 @@
MathMin, MathMin,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
RegExpPrototypeTest, RegExpPrototypeTest,
SafeArrayIterator,
StringPrototypeCharAt, StringPrototypeCharAt,
StringPrototypeToLowerCase, StringPrototypeToLowerCase,
StringPrototypeSlice, StringPrototypeSlice,
@ -94,7 +95,7 @@
/** @param {(BlobReference | Blob)[]} parts */ /** @param {(BlobReference | Blob)[]} parts */
async function* toIterator(parts) { async function* toIterator(parts) {
for (const part of parts) { for (const part of new SafeArrayIterator(parts)) {
yield* part.stream(); yield* part.stream();
} }
} }
@ -110,7 +111,7 @@
/** @type {(BlobReference|Blob)[]} */ /** @type {(BlobReference|Blob)[]} */
const processedParts = []; const processedParts = [];
let size = 0; let size = 0;
for (const element of parts) { for (const element of new SafeArrayIterator(parts)) {
if (ObjectPrototypeIsPrototypeOf(ArrayBufferPrototype, element)) { if (ObjectPrototypeIsPrototypeOf(ArrayBufferPrototype, element)) {
const chunk = new Uint8Array(ArrayBufferPrototypeSlice(element, 0)); const chunk = new Uint8Array(ArrayBufferPrototypeSlice(element, 0));
ArrayPrototypePush(processedParts, BlobReference.fromUint8Array(chunk)); ArrayPrototypePush(processedParts, BlobReference.fromUint8Array(chunk));
@ -158,7 +159,7 @@
* @returns {string[]} * @returns {string[]}
*/ */
function getParts(blob, bag = []) { function getParts(blob, bag = []) {
for (const part of blob[_parts]) { for (const part of new SafeArrayIterator(blob[_parts])) {
if (ObjectPrototypeIsPrototypeOf(BlobPrototype, part)) { if (ObjectPrototypeIsPrototypeOf(BlobPrototype, part)) {
getParts(part, bag); getParts(part, bag);
} else { } else {
@ -275,7 +276,7 @@
const blobParts = []; const blobParts = [];
let added = 0; let added = 0;
for (const part of this[_parts]) { for (const part of new SafeArrayIterator(this[_parts])) {
// don't add the overflow to new blobParts // don't add the overflow to new blobParts
if (added >= span) { if (added >= span) {
// Could maybe be possible to remove variable `added` // Could maybe be possible to remove variable `added`
@ -349,6 +350,7 @@
const bytes = new Uint8Array(size); const bytes = new Uint8Array(size);
const partIterator = toIterator(this[_parts]); const partIterator = toIterator(this[_parts]);
let offset = 0; let offset = 0;
// deno-lint-ignore prefer-primordials
for await (const chunk of partIterator) { for await (const chunk of partIterator) {
const byteLength = chunk.byteLength; const byteLength = chunk.byteLength;
if (byteLength > 0) { if (byteLength > 0) {
@ -598,7 +600,7 @@
const parts = []; const parts = [];
let totalSize = 0; let totalSize = 0;
for (const { uuid, size } of blobData.parts) { for (const { uuid, size } of new SafeArrayIterator(blobData.parts)) {
ArrayPrototypePush(parts, new BlobReference(uuid, size)); ArrayPrototypePush(parts, new BlobReference(uuid, size));
totalSize += size; totalSize += size;
} }

View file

@ -158,7 +158,7 @@
); );
const bytes = new Uint8Array(size); const bytes = new Uint8Array(size);
let offs = 0; let offs = 0;
for (const chunk of chunks) { for (const chunk of new SafeArrayIterator(chunks)) {
TypedArrayPrototypeSet(bytes, chunk, offs); TypedArrayPrototypeSet(bytes, chunk, offs);
offs += chunk.byteLength; offs += chunk.byteLength;
} }

View file

@ -22,6 +22,7 @@
ArrayPrototypePush, ArrayPrototypePush,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
ObjectSetPrototypeOf, ObjectSetPrototypeOf,
SafeArrayIterator,
Symbol, Symbol,
SymbolFor, SymbolFor,
SymbolIterator, SymbolIterator,
@ -204,7 +205,9 @@
const arrayBufferIdsInTransferables = []; const arrayBufferIdsInTransferables = [];
const transferredArrayBuffers = []; const transferredArrayBuffers = [];
for (const transferable of messageData.transferables) { for (
const transferable of new SafeArrayIterator(messageData.transferables)
) {
switch (transferable.kind) { switch (transferable.kind) {
case "messagePort": { case "messagePort": {
const port = createMessagePort(transferable.data); const port = createMessagePort(transferable.data);
@ -271,7 +274,7 @@
const serializedTransferables = []; const serializedTransferables = [];
let arrayBufferI = 0; let arrayBufferI = 0;
for (const transferable of transferables) { for (const transferable of new SafeArrayIterator(transferables)) {
if (ObjectPrototypeIsPrototypeOf(MessagePortPrototype, transferable)) { if (ObjectPrototypeIsPrototypeOf(MessagePortPrototype, transferable)) {
webidl.assertBranded(transferable, MessagePortPrototype); webidl.assertBranded(transferable, MessagePortPrototype);
const id = transferable[_id]; const id = transferable[_id];

View file

@ -316,7 +316,7 @@
context: "Argument 1", context: "Argument 1",
}); });
const requiredFeatures = descriptor.requiredFeatures ?? []; const requiredFeatures = descriptor.requiredFeatures ?? [];
for (const feature of requiredFeatures) { for (const feature of new SafeArrayIterator(requiredFeatures)) {
if (!SetPrototypeHas(this[_adapter].features[_features], feature)) { if (!SetPrototypeHas(this[_adapter].features[_features], feature)) {
throw new TypeError( throw new TypeError(
`${prefix}: nonGuaranteedFeatures must be a subset of the adapter features.`, `${prefix}: nonGuaranteedFeatures must be a subset of the adapter features.`,
@ -1046,7 +1046,7 @@
context: "Argument 1", context: "Argument 1",
}); });
const device = assertDevice(this, { prefix, context: "this" }); const device = assertDevice(this, { prefix, context: "this" });
for (const entry of descriptor.entries) { for (const entry of new SafeArrayIterator(descriptor.entries)) {
let i = 0; let i = 0;
if (entry.buffer) i++; if (entry.buffer) i++;
if (entry.sampler) i++; if (entry.sampler) i++;
@ -1591,7 +1591,7 @@
device.rid, device.rid,
commandBufferRids, commandBufferRids,
); );
for (const commandBuffer of commandBuffers) { for (const commandBuffer of new SafeArrayIterator(commandBuffers)) {
commandBuffer[_rid] = undefined; commandBuffer[_rid] = undefined;
} }
device.pushError(err); device.pushError(err);
@ -1934,7 +1934,7 @@
if (!mappedRanges) { if (!mappedRanges) {
throw new DOMException(`${prefix}: invalid state.`, "OperationError"); throw new DOMException(`${prefix}: invalid state.`, "OperationError");
} }
for (const [buffer, _rid, start] of mappedRanges) { for (const [buffer, _rid, start] of new SafeArrayIterator(mappedRanges)) {
// TODO(lucacasonato): is this logic correct? // TODO(lucacasonato): is this logic correct?
const end = start + buffer.byteLength; const end = start + buffer.byteLength;
if ( if (
@ -2002,7 +2002,7 @@
if (!mappedRanges) { if (!mappedRanges) {
throw new DOMException(`${prefix}: invalid state.`, "OperationError"); throw new DOMException(`${prefix}: invalid state.`, "OperationError");
} }
for (const [buffer, mappedRid] of mappedRanges) { for (const [buffer, mappedRid] of new SafeArrayIterator(mappedRanges)) {
const { err } = ops.op_webgpu_buffer_unmap( const { err } = ops.op_webgpu_buffer_unmap(
bufferRid, bufferRid,
mappedRid, mappedRid,

View file

@ -60,6 +60,7 @@
ReflectHas, ReflectHas,
ReflectOwnKeys, ReflectOwnKeys,
RegExpPrototypeTest, RegExpPrototypeTest,
SafeArrayIterator,
Set, Set,
// TODO(lucacasonato): add SharedArrayBuffer to primordials // TODO(lucacasonato): add SharedArrayBuffer to primordials
// SharedArrayBuffer, // SharedArrayBuffer,
@ -632,8 +633,8 @@
function createDictionaryConverter(name, ...dictionaries) { function createDictionaryConverter(name, ...dictionaries) {
let hasRequiredKey = false; let hasRequiredKey = false;
const allMembers = []; const allMembers = [];
for (const members of dictionaries) { for (const members of new SafeArrayIterator(dictionaries)) {
for (const member of members) { for (const member of new SafeArrayIterator(members)) {
if (member.required) { if (member.required) {
hasRequiredKey = true; hasRequiredKey = true;
} }
@ -648,7 +649,7 @@
}); });
const defaultValues = {}; const defaultValues = {};
for (const member of allMembers) { for (const member of new SafeArrayIterator(allMembers)) {
if (ReflectHas(member, "defaultValue")) { if (ReflectHas(member, "defaultValue")) {
const idlMemberValue = member.defaultValue; const idlMemberValue = member.defaultValue;
const imvType = typeof idlMemberValue; const imvType = typeof idlMemberValue;
@ -694,7 +695,7 @@
return idlDict; return idlDict;
} }
for (const member of allMembers) { for (const member of new SafeArrayIterator(allMembers)) {
const key = member.key; const key = member.key;
let esMemberValue; let esMemberValue;
@ -820,7 +821,7 @@
} }
// Slow path if Proxy (e.g: in WPT tests) // Slow path if Proxy (e.g: in WPT tests)
const keys = ReflectOwnKeys(V); const keys = ReflectOwnKeys(V);
for (const key of keys) { for (const key of new SafeArrayIterator(keys)) {
const desc = ObjectGetOwnPropertyDescriptor(V, key); const desc = ObjectGetOwnPropertyDescriptor(V, key);
if (desc !== undefined && desc.enumerable === true) { if (desc !== undefined && desc.enumerable === true) {
const typedKey = keyConverter(key, opts); const typedKey = keyConverter(key, opts);
@ -890,7 +891,7 @@
} }
function define(target, source) { function define(target, source) {
for (const key of ReflectOwnKeys(source)) { for (const key of new SafeArrayIterator(ReflectOwnKeys(source))) {
const descriptor = ReflectGetOwnPropertyDescriptor(source, key); const descriptor = ReflectGetOwnPropertyDescriptor(source, key);
if (descriptor && !ReflectDefineProperty(target, key, descriptor)) { if (descriptor && !ReflectDefineProperty(target, key, descriptor)) {
throw new TypeError(`Cannot redefine property: ${String(key)}`); throw new TypeError(`Cannot redefine property: ${String(key)}`);

View file

@ -20,6 +20,7 @@
PromiseResolve, PromiseResolve,
PromiseReject, PromiseReject,
ReflectHas, ReflectHas,
SafeArrayIterator,
SymbolFor, SymbolFor,
TypeError, TypeError,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -233,7 +234,9 @@
function serializePermissions(permissions) { function serializePermissions(permissions) {
if (typeof permissions == "object" && permissions != null) { if (typeof permissions == "object" && permissions != null) {
const serializedPermissions = {}; const serializedPermissions = {};
for (const key of ["read", "write", "run", "ffi"]) { for (
const key of new SafeArrayIterator(["read", "write", "run", "ffi"])
) {
if (ArrayIsArray(permissions[key])) { if (ArrayIsArray(permissions[key])) {
serializedPermissions[key] = ArrayPrototypeMap( serializedPermissions[key] = ArrayPrototypeMap(
permissions[key], permissions[key],
@ -243,7 +246,9 @@
serializedPermissions[key] = permissions[key]; serializedPermissions[key] = permissions[key];
} }
} }
for (const key of ["env", "hrtime", "net", "sys"]) { for (
const key of new SafeArrayIterator(["env", "hrtime", "net", "sys"])
) {
if (ArrayIsArray(permissions[key])) { if (ArrayIsArray(permissions[key])) {
serializedPermissions[key] = ArrayPrototypeSlice(permissions[key]); serializedPermissions[key] = ArrayPrototypeSlice(permissions[key]);
} else { } else {

View file

@ -12,6 +12,7 @@
Uint8Array, Uint8Array,
ArrayPrototypePush, ArrayPrototypePush,
MathMin, MathMin,
SafeArrayIterator,
TypedArrayPrototypeSubarray, TypedArrayPrototypeSubarray,
TypedArrayPrototypeSet, TypedArrayPrototypeSet,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -156,14 +157,14 @@
function concatBuffers(buffers) { function concatBuffers(buffers) {
let totalLen = 0; let totalLen = 0;
for (const buf of buffers) { for (const buf of new SafeArrayIterator(buffers)) {
totalLen += buf.byteLength; totalLen += buf.byteLength;
} }
const contents = new Uint8Array(totalLen); const contents = new Uint8Array(totalLen);
let n = 0; let n = 0;
for (const buf of buffers) { for (const buf of new SafeArrayIterator(buffers)) {
TypedArrayPrototypeSet(contents, buf, n); TypedArrayPrototypeSet(contents, buf, n);
n += buf.byteLength; n += buf.byteLength;
} }

View file

@ -9,6 +9,7 @@
DatePrototype, DatePrototype,
MathTrunc, MathTrunc,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
SafeArrayIterator,
SymbolAsyncIterator, SymbolAsyncIterator,
SymbolIterator, SymbolIterator,
Function, Function,
@ -211,7 +212,7 @@
let offset = 0; let offset = 0;
let str = let str =
'const unix = Deno.build.os === "darwin" || Deno.build.os === "linux"; return {'; 'const unix = Deno.build.os === "darwin" || Deno.build.os === "linux"; return {';
for (let [name, type] of ObjectEntries(types)) { for (let [name, type] of new SafeArrayIterator(ObjectEntries(types))) {
const optional = type.startsWith("?"); const optional = type.startsWith("?");
if (optional) type = type.slice(1); if (optional) type = type.slice(1);

View file

@ -13,6 +13,7 @@
ArrayPrototypeSlice, ArrayPrototypeSlice,
TypeError, TypeError,
ObjectEntries, ObjectEntries,
SafeArrayIterator,
String, String,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -111,7 +112,10 @@
stdin = "inherit", stdin = "inherit",
}) { }) {
if (cmd[0] != null) { if (cmd[0] != null) {
cmd = [pathFromURL(cmd[0]), ...ArrayPrototypeSlice(cmd, 1)]; cmd = [
pathFromURL(cmd[0]),
...new SafeArrayIterator(ArrayPrototypeSlice(cmd, 1)),
];
} }
const res = opRun({ const res = opRun({
cmd: ArrayPrototypeMap(cmd, String), cmd: ArrayPrototypeMap(cmd, String),

View file

@ -5,7 +5,9 @@
const core = window.Deno.core; const core = window.Deno.core;
const ops = core.ops; const ops = core.ops;
const { const {
SafeSetIterator,
Set, Set,
SetPrototypeDelete,
SymbolFor, SymbolFor,
TypeError, TypeError,
} = window.__bootstrap.primordials; } = window.__bootstrap.primordials;
@ -60,7 +62,7 @@
checkSignalListenerType(listener); checkSignalListenerType(listener);
const sigData = getSignalData(signo); const sigData = getSignalData(signo);
sigData.listeners.delete(listener); SetPrototypeDelete(sigData.listeners, listener);
if (sigData.listeners.size === 0 && sigData.rid) { if (sigData.listeners.size === 0 && sigData.rid) {
unbindSignal(sigData.rid); unbindSignal(sigData.rid);
@ -73,7 +75,7 @@
if (await pollSignal(sigData.rid)) { if (await pollSignal(sigData.rid)) {
return; return;
} }
for (const listener of sigData.listeners) { for (const listener of new SafeSetIterator(sigData.listeners)) {
listener(); listener();
} }
} }

View file

@ -10,6 +10,7 @@
const { const {
ArrayPrototypeMap, ArrayPrototypeMap,
ObjectEntries, ObjectEntries,
ObjectPrototypeIsPrototypeOf,
String, String,
TypeError, TypeError,
PromisePrototypeThen, PromisePrototypeThen,
@ -21,6 +22,7 @@
readableStreamForRidUnrefable, readableStreamForRidUnrefable,
readableStreamForRidUnrefableRef, readableStreamForRidUnrefableRef,
readableStreamForRidUnrefableUnref, readableStreamForRidUnrefableUnref,
ReadableStreamPrototype,
writableStreamForRid, writableStreamForRid,
} = window.__bootstrap.streams; } = window.__bootstrap.streams;
@ -65,7 +67,9 @@
} }
function collectOutput(readableStream) { function collectOutput(readableStream) {
if (!(readableStream instanceof ReadableStream)) { if (
!(ObjectPrototypeIsPrototypeOf(ReadableStreamPrototype, readableStream))
) {
return null; return null;
} }

View file

@ -19,6 +19,7 @@ delete Intl.v8BreakIterator;
ArrayPrototypeMap, ArrayPrototypeMap,
DateNow, DateNow,
Error, Error,
ErrorPrototype,
FunctionPrototypeCall, FunctionPrototypeCall,
FunctionPrototypeBind, FunctionPrototypeBind,
ObjectAssign, ObjectAssign,
@ -32,6 +33,7 @@ delete Intl.v8BreakIterator;
SymbolFor, SymbolFor,
SymbolIterator, SymbolIterator,
PromisePrototypeThen, PromisePrototypeThen,
SafeArrayIterator,
SafeWeakMap, SafeWeakMap,
TypeError, TypeError,
WeakMapPrototypeDelete, WeakMapPrototypeDelete,
@ -204,7 +206,7 @@ delete Intl.v8BreakIterator;
); );
loadedMainWorkerScript = true; loadedMainWorkerScript = true;
for (const { url, script } of scripts) { for (const { url, script } of new SafeArrayIterator(scripts)) {
const err = core.evalContext(script, url)[1]; const err = core.evalContext(script, url)[1];
if (err !== null) { if (err !== null) {
throw err.thrown; throw err.thrown;
@ -217,7 +219,7 @@ delete Intl.v8BreakIterator;
} }
function formatException(error) { function formatException(error) {
if (error instanceof Error) { if (ObjectPrototypeIsPrototypeOf(ErrorPrototype, error)) {
return null; return null;
} else if (typeof error == "string") { } else if (typeof error == "string") {
return `Uncaught ${ return `Uncaught ${

@ -1 +1 @@
Subproject commit 17fd391b8f305d1e74ce7508c824176f09ab63d0 Subproject commit 3e5b0cea163cc0f2b3b0c7cedffc112cc49d6a78