std/bytes/repeat.ts

48 lines
1.3 KiB
TypeScript
Raw Normal View History

// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
// This module is browser compatible.
import { copy } from "./copy.ts";
/**
* Returns a new byte slice composed of `count` repetitions of the `source`
* array.
*
* @param source Source array to repeat.
* @param count Number of times to repeat the source array.
* @returns A new byte slice composed of `count` repetitions of the `source`
* array.
*
* @example Basic usage
* ```ts
* import { repeat } from "@std/bytes/repeat";
* import { assertEquals } from "@std/assert";
*
* const source = new Uint8Array([0, 1, 2]);
*
* assertEquals(repeat(source, 3), new Uint8Array([0, 1, 2, 0, 1, 2, 0, 1, 2]));
* ```
*
* @example Zero count
* ```ts
* import { repeat } from "@std/bytes/repeat";
* import { assertEquals } from "@std/assert";
*
* const source = new Uint8Array([0, 1, 2]);
*
* assertEquals(repeat(source, 0), new Uint8Array());
* ```
*/
export function repeat(source: Uint8Array, count: number): Uint8Array {
if (count < 0 || !Number.isInteger(count)) {
throw new RangeError("Count must be a non-negative integer");
}
const repeated = new Uint8Array(source.length * count);
let offset = 0;
while (offset < repeated.length) {
offset += copy(source, repeated, offset);
}
return repeated;
}