Spaces:
Sleeping
Sleeping
; | |
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | |
if (k2 === undefined) k2 = k; | |
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); | |
}) : (function(o, m, k, k2) { | |
if (k2 === undefined) k2 = k; | |
o[k2] = m[k]; | |
})); | |
var __exportStar = (this && this.__exportStar) || function(m, exports) { | |
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | |
}; | |
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 __importDefault = (this && this.__importDefault) || function (mod) { | |
return (mod && mod.__esModule) ? mod : { "default": mod }; | |
}; | |
var _FileFromPath_path, _FileFromPath_start; | |
Object.defineProperty(exports, "__esModule", { value: true }); | |
exports.fileFromPath = exports.fileFromPathSync = void 0; | |
const fs_1 = require("fs"); | |
const path_1 = require("path"); | |
const node_domexception_1 = __importDefault(require("node-domexception")); | |
const File_1 = require("./File"); | |
const isPlainObject_1 = __importDefault(require("./isPlainObject")); | |
__exportStar(require("./isFile"), exports); | |
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 = (0, path_1.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_1.promises.stat(__classPrivateFieldGet(this, _FileFromPath_path, "f")); | |
if (mtimeMs > this.lastModified) { | |
throw new node_domexception_1.default(MESSAGE, "NotReadableError"); | |
} | |
if (this.size) { | |
yield* (0, fs_1.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 ((0, isPlainObject_1.default)(filenameOrOptions)) { | |
[options, filename] = [filenameOrOptions, undefined]; | |
} | |
else { | |
filename = filenameOrOptions; | |
} | |
const file = new FileFromPath({ path, size, lastModified: mtimeMs }); | |
if (!filename) { | |
filename = file.name; | |
} | |
return new File_1.File([file], filename, { | |
...options, lastModified: file.lastModified | |
}); | |
} | |
function fileFromPathSync(path, filenameOrOptions, options = {}) { | |
const stats = (0, fs_1.statSync)(path); | |
return createFileFromPath(path, stats, filenameOrOptions, options); | |
} | |
exports.fileFromPathSync = fileFromPathSync; | |
async function fileFromPath(path, filenameOrOptions, options) { | |
const stats = await fs_1.promises.stat(path); | |
return createFileFromPath(path, stats, filenameOrOptions, options); | |
} | |
exports.fileFromPath = fileFromPath; | |