mirror of
https://github.com/github/codeql-action.git
synced 2025-12-28 02:00:12 +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>
68 lines
2.1 KiB
JavaScript
68 lines
2.1 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
|
|
var $TypeError = GetIntrinsic('%TypeError%');
|
|
|
|
var Call = require('es-abstract/2022/Call');
|
|
var CompletionRecord = require('es-abstract/2022/CompletionRecord');
|
|
var GetMethod = require('es-abstract/2022/GetMethod');
|
|
var Type = require('es-abstract/2022/Type');
|
|
|
|
var assertRecord = require('es-abstract/helpers/assertRecord');
|
|
|
|
// https://262.ecma-international.org/14.0/#sec-iteratorclose
|
|
|
|
module.exports = function IteratorClose(iteratorRecord, completion) {
|
|
assertRecord(Type, 'Iterator Record', 'iteratorRecord', iteratorRecord);
|
|
if (Type(iteratorRecord['[[Iterator]]']) !== 'Object') {
|
|
throw new $TypeError('Assertion failed: iteratorRecord.[[Iterator]] must be an Object'); // step 1
|
|
}
|
|
|
|
if (!(completion instanceof CompletionRecord)) { // step 2
|
|
throw new $TypeError('Assertion failed: completion is not a Completion Record instance');
|
|
}
|
|
var completionThunk = function () {
|
|
var value = completion.value();
|
|
if (completion.type() === 'throw') {
|
|
throw value;
|
|
}
|
|
return value;
|
|
};
|
|
|
|
var iterator = iteratorRecord['[[Iterator]]']; // step 3
|
|
|
|
var iteratorReturn;
|
|
try {
|
|
iteratorReturn = GetMethod(iterator, 'return'); // step 4
|
|
} catch (e) {
|
|
completionThunk(); // throws if `completion` is a throw completion // step 6
|
|
completionThunk = null; // ensure it's not called twice.
|
|
throw e; // step 7
|
|
}
|
|
if (typeof iteratorReturn === 'undefined') {
|
|
return completionThunk(); // step 5.a - 5.b
|
|
}
|
|
|
|
var innerResult;
|
|
try {
|
|
innerResult = Call(iteratorReturn, iterator, []);
|
|
} catch (e) {
|
|
// if we hit here, then "e" is the innerResult completion that needs re-throwing
|
|
|
|
completionThunk(); // throws if `completion` is a throw completion // step 6
|
|
completionThunk = null; // ensure it's not called twice.
|
|
|
|
// if not, then return the innerResult completion
|
|
throw e; // step 7
|
|
}
|
|
var completionRecord = completionThunk(); // if innerResult worked, then throw if the completion does
|
|
completionThunk = null; // ensure it's not called twice.
|
|
|
|
if (Type(innerResult) !== 'Object') {
|
|
throw new $TypeError('iterator .return must return an object');
|
|
}
|
|
|
|
return completionRecord;
|
|
};
|