// Copyright 2018 the Deno authors. All rights reserved. MIT license. import { TypedArray } from "./types"; let logDebug = false; // @internal export function setLogDebug(debug: boolean): void { logDebug = debug; } /** Debug logging for deno. * Enable with the `--log-debug` or `-D` command line flag. * @internal */ // tslint:disable-next-line:no-any export function log(...args: any[]): void { if (logDebug) { console.log("DEBUG JS -", ...args); } } // @internal export function assert(cond: boolean, msg = "assert") { if (!cond) { throw Error(msg); } } // @internal export function typedArrayToArrayBuffer(ta: TypedArray): ArrayBuffer { const ab = ta.buffer.slice(ta.byteOffset, ta.byteOffset + ta.byteLength); return ab as ArrayBuffer; } // @internal export function arrayToStr(ui8: Uint8Array): string { return String.fromCharCode(...ui8); } /** A `Resolvable` is a Promise with the `reject` and `resolve` functions * placed as methods on the promise object itself. It allows you to do: * * const p = createResolvable(); * // ... * p.resolve(42); * * It'd be prettier to make `Resolvable` a class that inherits from `Promise`, * rather than an interface. This is possible in ES2016, however typescript * produces broken code when targeting ES5 code. * * At the time of writing, the GitHub issue is closed in favour of a proposed * solution that is awaiting feedback. * * @see https://github.com/Microsoft/TypeScript/issues/15202 * @see https://github.com/Microsoft/TypeScript/issues/15397 * @internal */ export interface ResolvableMethods { resolve: (value?: T | PromiseLike) => void; // tslint:disable-next-line:no-any reject: (reason?: any) => void; } // @internal export type Resolvable = Promise & ResolvableMethods; // @internal export function createResolvable(): Resolvable { let methods: ResolvableMethods; const promise = new Promise((resolve, reject) => { methods = { resolve, reject }; }); // TypeScript doesn't know that the Promise callback occurs synchronously // therefore use of not null assertion (`!`) return Object.assign(promise, methods!) as Resolvable; } // @internal export function notImplemented(): never { throw new Error("Not implemented"); } // @internal export function unreachable(): never { throw new Error("Code not reachable"); } // @internal export function hexdump(u8: Uint8Array): string { return Array.prototype.map .call(u8, (x: number) => { return ("00" + x.toString(16)).slice(-2); }) .join(" "); } // @internal export function containsOnlyASCII(str: string): boolean { if (typeof str !== "string") { return false; } return /^[\x00-\x7F]*$/.test(str); } // @internal export interface Deferred { promise: Promise; resolve: Function; reject: Function; } /** Create a wrapper around a promise that could be resolved externally. */ // @internal export function deferred(): Deferred { let resolve: Function | undefined; let reject: Function | undefined; const promise = new Promise((res, rej) => { resolve = res; reject = rej; }); return { promise, resolve: resolve!, reject: reject! }; } /** Create a IterableIterator. */ // @internal export class CreateIterableIterator implements IterableIterator { private readonly _iterators: IterableIterator; readonly [Symbol.toStringTag] = "Iterator"; constructor(iterators: IterableIterator) { this._iterators = iterators; } [Symbol.iterator](): IterableIterator { return this; } next(): IteratorResult { return this._iterators.next(); } }