mirror of
https://github.com/github/codeql-action.git
synced 2025-12-26 17:20:10 +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>
48 lines
1.1 KiB
JavaScript
48 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
var hasSymbols = require('has-symbols')();
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
var callBound = require('call-bind/callBound');
|
|
var isString = require('is-string');
|
|
|
|
var $iterator = GetIntrinsic('%Symbol.iterator%', true);
|
|
var $stringSlice = callBound('String.prototype.slice');
|
|
var $String = GetIntrinsic('%String%');
|
|
|
|
module.exports = function getIteratorMethod(ES, iterable) {
|
|
var usingIterator;
|
|
if (hasSymbols) {
|
|
usingIterator = ES.GetMethod(iterable, $iterator);
|
|
} else if (ES.IsArray(iterable)) {
|
|
usingIterator = function () {
|
|
var i = -1;
|
|
var arr = this; // eslint-disable-line no-invalid-this
|
|
return {
|
|
next: function () {
|
|
i += 1;
|
|
return {
|
|
done: i >= arr.length,
|
|
value: arr[i]
|
|
};
|
|
}
|
|
};
|
|
};
|
|
} else if (isString(iterable)) {
|
|
usingIterator = function () {
|
|
var i = 0;
|
|
return {
|
|
next: function () {
|
|
var nextIndex = ES.AdvanceStringIndex($String(iterable), i, true);
|
|
var value = $stringSlice(iterable, i, nextIndex);
|
|
i = nextIndex;
|
|
return {
|
|
done: nextIndex > iterable.length,
|
|
value: value
|
|
};
|
|
}
|
|
};
|
|
};
|
|
}
|
|
return usingIterator;
|
|
};
|