mirror of
https://github.com/github/codeql-action.git
synced 2025-12-30 03:00:13 +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>
60 lines
1.5 KiB
JavaScript
60 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
|
|
var $RangeError = GetIntrinsic('%RangeError%');
|
|
var $TypeError = GetIntrinsic('%TypeError%');
|
|
|
|
var ToIndex = require('./ToIndex');
|
|
|
|
var isTypedArray = require('is-typed-array');
|
|
var typedArrayByteOffset = require('typed-array-byte-offset');
|
|
var typedArrayLength = require('typed-array-length');
|
|
var whichTypedArray = require('which-typed-array');
|
|
|
|
var table60 = {
|
|
__proto__: null,
|
|
$Int8Array: 1,
|
|
$Uint8Array: 1,
|
|
$Uint8ClampedArray: 1,
|
|
$Int16Array: 2,
|
|
$Uint16Array: 2,
|
|
$Int32Array: 4,
|
|
$Uint32Array: 4,
|
|
$BigInt64Array: 8,
|
|
$BigUint64Array: 8,
|
|
$Float32Array: 4,
|
|
$Float64Array: 8
|
|
};
|
|
|
|
// https://262.ecma-international.org/12.0/#sec-validateatomicaccess
|
|
|
|
module.exports = function ValidateAtomicAccess(typedArray, requestIndex) {
|
|
if (!isTypedArray(typedArray)) {
|
|
throw new $TypeError('Assertion failed: `typedArray` must be a TypedArray'); // step 1
|
|
}
|
|
|
|
var length = typedArrayLength(typedArray); // step 2
|
|
|
|
var accessIndex = ToIndex(requestIndex); // step 3
|
|
|
|
/*
|
|
// this assertion can never be reached
|
|
if (!(accessIndex >= 0)) {
|
|
throw new $TypeError('Assertion failed: accessIndex >= 0'); // step 4
|
|
}
|
|
*/
|
|
|
|
if (accessIndex >= length) {
|
|
throw new $RangeError('index out of range'); // step 5
|
|
}
|
|
|
|
var arrayTypeName = whichTypedArray(typedArray); // step 6
|
|
|
|
var elementSize = table60['$' + arrayTypeName]; // step 7
|
|
|
|
var offset = typedArrayByteOffset(typedArray); // step 8
|
|
|
|
return (accessIndex * elementSize) + offset; // step 9
|
|
};
|