@visulima/fs
Version:
Human friendly file system utilities for Node.js
32 lines (29 loc) • 1.41 kB
JavaScript
import { readFileSync as readFileSync$1 } from 'node:fs';
import { brotliDecompressSync, unzipSync } from 'node:zlib';
import { toPath } from '@visulima/path/utils';
import { R_OK } from './F_OK-JER1LjUr.mjs';
import PermissionError from './PermissionError-CqGMI9qC.mjs';
import isAccessibleSync from './isAccessibleSync-3gnUWUwX.mjs';
import assertValidFileOrDirectoryPath from './assertValidFileOrDirectoryPath-BWWgA1wj.mjs';
var __defProp = Object.defineProperty;
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
const decompressionMethods = {
brotli: brotliDecompressSync,
gzip: unzipSync,
none: /* @__PURE__ */ __name((buffer) => buffer, "none")
};
const readFileSync = /* @__PURE__ */ __name((path, options) => {
assertValidFileOrDirectoryPath(path);
path = toPath(path);
if (!isAccessibleSync(path)) {
throw new PermissionError(`unable to read the non-accessible file: ${path}`);
}
if (!isAccessibleSync(path, R_OK)) {
throw new PermissionError(`invalid access to read file at: ${path}`);
}
const { buffer, compression, encoding, flag } = options ?? {};
const content = readFileSync$1(path, flag ? { encoding, flag } : { encoding });
const decompressed = decompressionMethods[compression ?? "none"](content);
return buffer ? decompressed : decompressed.toString();
}, "readFileSync");
export { readFileSync as default };