/* * @license Apache-2.0 * * Copyright (c) 2023 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. */ // TypeScript Version: 4.1 /// import { ArrayLike } from '@stdlib/types/array'; import { Slice, MultiSlice } from '@stdlib/types/slice'; /** * Slice argument. */ type SliceArgument = Slice | number | null | undefined; /** * Creates a MultiSlice object from a list of MultiSlice constructor arguments. * * @param args - list of constructor arguments * @returns MultiSlice object * * @example * var Slice = require( '@stdlib/slice/ctor' ); * * var s = args2multislice( [ void 0, new Slice( 0, 10, 1 ) ] ); * // returns * * var data = s.data; * // returns [ null, ] * * @example * var Slice = require( '@stdlib/slice/ctor' ); * * var s = args2multislice( [ new Slice( 0, 10, 1 ), void 0 ] ); * // returns * * var data = s.data; * // returns [ , null ] * * @example * var Slice = require( '@stdlib/slice/ctor' ); * * var s = args2multislice( [ new Slice( 0, 10, 1 ), void 0, void 0, new Slice( 0, 10, 1 ) ] ); * // returns * * var data = s.data; * // returns [ , null, null, ] * * @example * var Slice = require( '@stdlib/slice/ctor' ); * * var s = args2multislice( [ void 0, new Slice( 0, 10, 1 ), null, void 0, new Slice( 2, 9, 2 ), null, void 0 ] ); * // returns * * var data = s.data; * // returns [ null, , null, null, , null, null ] */ declare function args2multislice( args: ArrayLike ): MultiSlice; // EXPORTS // export = args2multislice;