All files / ndarray/base/binary-reduce-strided1d/lib set_view_offsets.js

76.92% Statements 40/52
100% Branches 1/1
0% Functions 0/1
76.92% Lines 40/52

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 531x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x                         1x 1x 1x 1x 1x  
/**
* @license Apache-2.0
*
* Copyright (c) 2025 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*    http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
 
'use strict';
 
// MAIN //
 
/**
* Sets view offsets according to a list of index offsets.
*
* ## Notes
*
* -   This function skips the second element in the list of index offsets, as that is assumed to correspond to the output ndarray which does not have a corresponding view. Meaning, the list of views is expected to have `N` elements, and the list of index offsets is expected to have `N+1` elements.
* -   This function mutates the provides view objects.
*
* @private
* @param {Array<Object>} views - list of ndarray-like objects representing ndarray views
* @param {NonNegativeIntegerArray} offsets - list of index offsets
* @returns {Array<Object>} updated views
*/
function setViewOffsets( views, offsets ) {
	var i;
	var j;
	for ( i = 0, j = 0; i < offsets.length; i++ ) {
		if ( i === 2 ) { // note: expected to correspond to the output ndarray which does not have a corresponding view
			continue;
		}
		views[ j ].offset = offsets[ i ];
		j += 1;
	}
	return views;
}
 
 
// EXPORTS //
 
module.exports = setViewOffsets;