flow like the river
This commit is contained in:
commit
013fe673f3
42435 changed files with 5764238 additions and 0 deletions
42
VISUALIZACION/node_modules/es-abstract/2023/ValidateAtomicAccess.js
generated
vendored
Executable file
42
VISUALIZACION/node_modules/es-abstract/2023/ValidateAtomicAccess.js
generated
vendored
Executable file
|
|
@ -0,0 +1,42 @@
|
|||
'use strict';
|
||||
|
||||
var GetIntrinsic = require('get-intrinsic');
|
||||
|
||||
var $RangeError = GetIntrinsic('%RangeError%');
|
||||
var $TypeError = GetIntrinsic('%TypeError%');
|
||||
|
||||
var ToIndex = require('./ToIndex');
|
||||
var TypedArrayElementSize = require('./TypedArrayElementSize');
|
||||
|
||||
var isTypedArray = require('is-typed-array');
|
||||
var typedArrayByteOffset = require('typed-array-byte-offset');
|
||||
var typedArrayLength = require('typed-array-length');
|
||||
|
||||
// https://262.ecma-international.org/13.0/#sec-validateatomicaccess
|
||||
|
||||
module.exports = function ValidateAtomicAccess(typedArray, requestIndex) {
|
||||
if (!isTypedArray(typedArray)) {
|
||||
throw new $TypeError('Assertion failed: `typedArray` must be a TypedArray');
|
||||
}
|
||||
|
||||
var length = typedArrayLength(typedArray); // step 1
|
||||
|
||||
var accessIndex = ToIndex(requestIndex); // step 2
|
||||
|
||||
/*
|
||||
// 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 4
|
||||
}
|
||||
|
||||
var elementSize = TypedArrayElementSize(typedArray); // step 5
|
||||
|
||||
var offset = typedArrayByteOffset(typedArray); // step 6
|
||||
|
||||
return (accessIndex * elementSize) + offset; // step 7
|
||||
};
|
||||
Loading…
Add table
Add a link
Reference in a new issue