|
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) { |
|
if (kind === "m") throw new TypeError("Private method is not writable"); |
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter"); |
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it"); |
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value; |
|
}; |
|
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) { |
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter"); |
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it"); |
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); |
|
}; |
|
var _FileFromPath_path, _FileFromPath_start; |
|
import { statSync, createReadStream, promises as fs } from "fs"; |
|
import { basename } from "path"; |
|
import DOMException from "node-domexception"; |
|
import { File } from "./File.js"; |
|
import isPlainObject from "./isPlainObject.js"; |
|
export * from "./isFile.js"; |
|
const MESSAGE = "The requested file could not be read, " |
|
+ "typically due to permission problems that have occurred after a reference " |
|
+ "to a file was acquired."; |
|
class FileFromPath { |
|
constructor(input) { |
|
_FileFromPath_path.set(this, void 0); |
|
_FileFromPath_start.set(this, void 0); |
|
__classPrivateFieldSet(this, _FileFromPath_path, input.path, "f"); |
|
__classPrivateFieldSet(this, _FileFromPath_start, input.start || 0, "f"); |
|
this.name = basename(__classPrivateFieldGet(this, _FileFromPath_path, "f")); |
|
this.size = input.size; |
|
this.lastModified = input.lastModified; |
|
} |
|
slice(start, end) { |
|
return new FileFromPath({ |
|
path: __classPrivateFieldGet(this, _FileFromPath_path, "f"), |
|
lastModified: this.lastModified, |
|
size: end - start, |
|
start |
|
}); |
|
} |
|
async *stream() { |
|
const { mtimeMs } = await fs.stat(__classPrivateFieldGet(this, _FileFromPath_path, "f")); |
|
if (mtimeMs > this.lastModified) { |
|
throw new DOMException(MESSAGE, "NotReadableError"); |
|
} |
|
if (this.size) { |
|
yield* createReadStream(__classPrivateFieldGet(this, _FileFromPath_path, "f"), { |
|
start: __classPrivateFieldGet(this, _FileFromPath_start, "f"), |
|
end: __classPrivateFieldGet(this, _FileFromPath_start, "f") + this.size - 1 |
|
}); |
|
} |
|
} |
|
get [(_FileFromPath_path = new WeakMap(), _FileFromPath_start = new WeakMap(), Symbol.toStringTag)]() { |
|
return "File"; |
|
} |
|
} |
|
function createFileFromPath(path, { mtimeMs, size }, filenameOrOptions, options = {}) { |
|
let filename; |
|
if (isPlainObject(filenameOrOptions)) { |
|
[options, filename] = [filenameOrOptions, undefined]; |
|
} |
|
else { |
|
filename = filenameOrOptions; |
|
} |
|
const file = new FileFromPath({ path, size, lastModified: mtimeMs }); |
|
if (!filename) { |
|
filename = file.name; |
|
} |
|
return new File([file], filename, { |
|
...options, lastModified: file.lastModified |
|
}); |
|
} |
|
export function fileFromPathSync(path, filenameOrOptions, options = {}) { |
|
const stats = statSync(path); |
|
return createFileFromPath(path, stats, filenameOrOptions, options); |
|
} |
|
export async function fileFromPath(path, filenameOrOptions, options) { |
|
const stats = await fs.stat(path); |
|
return createFileFromPath(path, stats, filenameOrOptions, options); |
|
} |
|
|