mirror of
https://github.com/denoland/deno.git
synced 2024-10-31 09:14:20 -04:00
d43b43ca78
Instead of using core/snapshot_creator.rs, instead two crates are introduced which allow building the snapshot during build.rs. Rollup is removed and replaced with our own bundler. This removes the Node build dependency. Modules in //js now use Deno-style imports with file extensions, rather than Node style extensionless imports. This improves incremental build time when changes are made to //js files by about 40 seconds.
31 lines
936 B
TypeScript
31 lines
936 B
TypeScript
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
|
import * as dispatch from "./dispatch.ts";
|
|
import { sendSync } from "./dispatch_json.ts";
|
|
import { assert } from "./util.ts";
|
|
|
|
/** Synchronously collects cryptographically secure random values. The
|
|
* underlying CSPRNG in use is Rust's `rand::rngs::ThreadRng`.
|
|
*
|
|
* const arr = new Uint8Array(32);
|
|
* crypto.getRandomValues(arr);
|
|
*/
|
|
export function getRandomValues<
|
|
T extends
|
|
| Int8Array
|
|
| Uint8Array
|
|
| Uint8ClampedArray
|
|
| Int16Array
|
|
| Uint16Array
|
|
| Int32Array
|
|
| Uint32Array
|
|
>(typedArray: T): T {
|
|
assert(typedArray !== null, "Input must not be null");
|
|
assert(typedArray.length <= 65536, "Input must not be longer than 65536");
|
|
const ui8 = new Uint8Array(
|
|
typedArray.buffer,
|
|
typedArray.byteOffset,
|
|
typedArray.byteLength
|
|
);
|
|
sendSync(dispatch.OP_GET_RANDOM_VALUES, {}, ui8);
|
|
return typedArray;
|
|
}
|