mirror of
https://github.com/github/codeql-action.git
synced 2025-12-28 18:20:08 +08:00
* Bump the npm group with 2 updates Bumps the npm group with 2 updates: [eslint](https://github.com/eslint/eslint) and [eslint-plugin-import](https://github.com/import-js/eslint-plugin-import). Updates `eslint` from 8.45.0 to 8.46.0 - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v8.45.0...v8.46.0) Updates `eslint-plugin-import` from 2.27.5 to 2.28.0 - [Release notes](https://github.com/import-js/eslint-plugin-import/releases) - [Changelog](https://github.com/import-js/eslint-plugin-import/blob/main/CHANGELOG.md) - [Commits](https://github.com/import-js/eslint-plugin-import/compare/v2.27.5...v2.28.0) --- updated-dependencies: - dependency-name: eslint dependency-type: direct:development update-type: version-update:semver-minor dependency-group: npm - dependency-name: eslint-plugin-import dependency-type: direct:development update-type: version-update:semver-minor dependency-group: npm ... Signed-off-by: dependabot[bot] <support@github.com> * Update checked-in dependencies --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
88 lines
2.8 KiB
JavaScript
88 lines
2.8 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
|
|
var $TypeError = GetIntrinsic('%TypeError%');
|
|
var $SyntaxError = GetIntrinsic('%SyntaxError%');
|
|
|
|
var has = require('has');
|
|
var isInteger = require('./isInteger');
|
|
|
|
var isMatchRecord = require('./isMatchRecord');
|
|
|
|
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
|
|
'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;
|
|
}
|
|
};
|
|
|
|
module.exports = function assertRecord(Type, recordType, argumentName, value) {
|
|
var predicate = predicates[recordType];
|
|
if (typeof predicate !== 'function') {
|
|
throw new $SyntaxError('unknown record type: ' + recordType);
|
|
}
|
|
if (Type(value) !== 'Object' || !predicate(value)) {
|
|
throw new $TypeError(argumentName + ' must be a ' + recordType);
|
|
}
|
|
};
|