// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license. import { notImplemented, intoCallbackAPIWithIntercept, MaybeEmpty, } from "../_utils.ts"; import { fromFileUrl } from "../path.ts"; const { readFile: denoReadFile, readFileSync: denoReadFileSync } = Deno; type ReadFileCallback = ( err: MaybeEmpty, data: MaybeEmpty ) => void; interface ReadFileOptions { encoding?: string | null; flag?: string; } function getEncoding( optOrCallback?: ReadFileOptions | ReadFileCallback ): string | null { if (!optOrCallback || typeof optOrCallback === "function") { return null; } else { if (optOrCallback.encoding) { if ( optOrCallback.encoding === "utf8" || optOrCallback.encoding === "utf-8" ) { return "utf8"; } else if (optOrCallback.encoding === "buffer") { return "buffer"; } else { notImplemented(); } } return null; } } function maybeDecode( data: Uint8Array, encoding: string | null ): string | Uint8Array { if (encoding === "utf8") { return new TextDecoder().decode(data); } return data; } export function readFile( path: string | URL, optOrCallback: ReadFileCallback | ReadFileOptions, callback?: ReadFileCallback ): void { path = path instanceof URL ? fromFileUrl(path) : path; let cb: ReadFileCallback | undefined; if (typeof optOrCallback === "function") { cb = optOrCallback; } else { cb = callback; } const encoding = getEncoding(optOrCallback); intoCallbackAPIWithIntercept( denoReadFile, (data: Uint8Array): string | Uint8Array => maybeDecode(data, encoding), cb, path ); } export function readFileSync( path: string | URL, opt?: ReadFileOptions ): string | Uint8Array { path = path instanceof URL ? fromFileUrl(path) : path; return maybeDecode(denoReadFileSync(path), getEncoding(opt)); }