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>
50 lines
1.9 KiB
JavaScript
50 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
|
|
var $TypeError = GetIntrinsic('%TypeError%');
|
|
|
|
var GetPrototypeFromConstructor = require('./GetPrototypeFromConstructor');
|
|
var IsConstructor = require('./IsConstructor');
|
|
var IsDetachedBuffer = require('./IsDetachedBuffer');
|
|
var OrdinarySetPrototypeOf = require('./OrdinarySetPrototypeOf');
|
|
|
|
var isInteger = require('../helpers/isInteger');
|
|
|
|
var isArrayBuffer = require('is-array-buffer');
|
|
var arrayBufferSlice = require('arraybuffer.prototype.slice');
|
|
|
|
// https://262.ecma-international.org/12.0/#sec-clonearraybuffer
|
|
|
|
module.exports = function CloneArrayBuffer(srcBuffer, srcByteOffset, srcLength, cloneConstructor) {
|
|
if (!isArrayBuffer(srcBuffer)) {
|
|
throw new $TypeError('Assertion failed: `srcBuffer` must be an ArrayBuffer instance');
|
|
}
|
|
if (!isInteger(srcByteOffset) || srcByteOffset < 0) {
|
|
throw new $TypeError('Assertion failed: `srcByteOffset` must be a non-negative integer');
|
|
}
|
|
if (!isInteger(srcLength) || srcLength < 0) {
|
|
throw new $TypeError('Assertion failed: `srcLength` must be a non-negative integer');
|
|
}
|
|
if (!IsConstructor(cloneConstructor)) {
|
|
throw new $TypeError('Assertion failed: `cloneConstructor` must be a constructor');
|
|
}
|
|
|
|
// 3. Let targetBuffer be ? AllocateArrayBuffer(cloneConstructor, srcLength).
|
|
var proto = GetPrototypeFromConstructor(cloneConstructor, '%ArrayBufferPrototype%'); // step 3, kinda
|
|
|
|
if (IsDetachedBuffer(srcBuffer)) {
|
|
throw new $TypeError('`srcBuffer` must not be a detached ArrayBuffer'); // step 4
|
|
}
|
|
|
|
/*
|
|
5. Let srcBlock be srcBuffer.[[ArrayBufferData]].
|
|
6. Let targetBlock be targetBuffer.[[ArrayBufferData]].
|
|
7. Perform CopyDataBlockBytes(targetBlock, 0, srcBlock, srcByteOffset, srcLength).
|
|
*/
|
|
var targetBuffer = arrayBufferSlice(srcBuffer, srcByteOffset, srcByteOffset + srcLength); // steps 5-7
|
|
OrdinarySetPrototypeOf(targetBuffer, proto); // step 3
|
|
|
|
return targetBuffer; // step 8
|
|
};
|