Update checked-in dependencies

This commit is contained in:
github-actions[bot] 2024-09-16 17:29:58 +00:00
parent 1afca056e3
commit 6989ba7bd2
3942 changed files with 55190 additions and 132206 deletions

View file

@ -1,79 +1,24 @@
'use strict';
var GetIntrinsic = require('get-intrinsic');
// TODO, semver-major: delete this
var $TypeError = GetIntrinsic('%TypeError%');
var $SyntaxError = GetIntrinsic('%SyntaxError%');
var $TypeError = require('es-errors/type');
var $SyntaxError = require('es-errors/syntax');
var has = require('has');
var isInteger = require('./isInteger');
var isMatchRecord = require('./isMatchRecord');
var isMatchRecord = require('./records/match-record');
var isPropertyDescriptor = require('./records/property-descriptor');
var isIteratorRecord = require('./records/iterator-record');
var isPromiseCapabilityRecord = require('./records/promise-capability-record');
var isAsyncGeneratorRequestRecord = require('./records/async-generator-request-record');
var isRegExpRecord = require('./records/regexp-record');
var predicates = {
// https://262.ecma-international.org/6.0/#sec-property-descriptor-specification-type
'Property Descriptor': function isPropertyDescriptor(Desc) {
var allowed = {
'[[Configurable]]': true,
'[[Enumerable]]': true,
'[[Get]]': true,
'[[Set]]': true,
'[[Value]]': true,
'[[Writable]]': true
};
if (!Desc) {
return false;
}
for (var key in Desc) { // eslint-disable-line
if (has(Desc, key) && !allowed[key]) {
return false;
}
}
var isData = has(Desc, '[[Value]]');
var IsAccessor = has(Desc, '[[Get]]') || has(Desc, '[[Set]]');
if (isData && IsAccessor) {
throw new $TypeError('Property Descriptors may not be both accessor and data descriptors');
}
return true;
},
// https://262.ecma-international.org/13.0/#sec-match-records
'Property Descriptor': isPropertyDescriptor,
'Match Record': isMatchRecord,
'Iterator Record': function isIteratorRecord(value) {
return has(value, '[[Iterator]]') && has(value, '[[NextMethod]]') && has(value, '[[Done]]');
},
'PromiseCapability Record': function isPromiseCapabilityRecord(value) {
return !!value
&& has(value, '[[Resolve]]')
&& typeof value['[[Resolve]]'] === 'function'
&& has(value, '[[Reject]]')
&& typeof value['[[Reject]]'] === 'function'
&& has(value, '[[Promise]]')
&& value['[[Promise]]']
&& typeof value['[[Promise]]'].then === 'function';
},
'AsyncGeneratorRequest Record': function isAsyncGeneratorRequestRecord(value) {
return !!value
&& has(value, '[[Completion]]') // TODO: confirm is a completion record
&& has(value, '[[Capability]]')
&& predicates['PromiseCapability Record'](value['[[Capability]]']);
},
'RegExp Record': function isRegExpRecord(value) {
return value
&& has(value, '[[IgnoreCase]]')
&& typeof value['[[IgnoreCase]]'] === 'boolean'
&& has(value, '[[Multiline]]')
&& typeof value['[[Multiline]]'] === 'boolean'
&& has(value, '[[DotAll]]')
&& typeof value['[[DotAll]]'] === 'boolean'
&& has(value, '[[Unicode]]')
&& typeof value['[[Unicode]]'] === 'boolean'
&& has(value, '[[CapturingGroupsCount]]')
&& typeof value['[[CapturingGroupsCount]]'] === 'number'
&& isInteger(value['[[CapturingGroupsCount]]'])
&& value['[[CapturingGroupsCount]]'] >= 0;
}
'Iterator Record': isIteratorRecord,
'PromiseCapability Record': isPromiseCapabilityRecord,
'AsyncGeneratorRequest Record': isAsyncGeneratorRequestRecord,
'RegExp Record': isRegExpRecord
};
module.exports = function assertRecord(Type, recordType, argumentName, value) {
@ -81,7 +26,7 @@ module.exports = function assertRecord(Type, recordType, argumentName, value) {
if (typeof predicate !== 'function') {
throw new $SyntaxError('unknown record type: ' + recordType);
}
if (Type(value) !== 'Object' || !predicate(value)) {
if (!predicate(value)) {
throw new $TypeError(argumentName + ' must be a ' + recordType);
}
};