browserfs
Version:
A filesystem in your browser!
39 lines • 12.3 kB
JavaScript
;
var api_error_1 = require('./api_error');
var BaseFile = (function () {
function BaseFile() {
}
BaseFile.prototype.sync = function (cb) {
cb(new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP));
};
BaseFile.prototype.syncSync = function () {
throw new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP);
};
BaseFile.prototype.datasync = function (cb) {
this.sync(cb);
};
BaseFile.prototype.datasyncSync = function () {
return this.syncSync();
};
BaseFile.prototype.chown = function (uid, gid, cb) {
cb(new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP));
};
BaseFile.prototype.chownSync = function (uid, gid) {
throw new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP);
};
BaseFile.prototype.chmod = function (mode, cb) {
cb(new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP));
};
BaseFile.prototype.chmodSync = function (mode) {
throw new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP);
};
BaseFile.prototype.utimes = function (atime, mtime, cb) {
cb(new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP));
};
BaseFile.prototype.utimesSync = function (atime, mtime) {
throw new api_error_1.ApiError(api_error_1.ErrorCode.ENOTSUP);
};
return BaseFile;
}());
exports.BaseFile = BaseFile;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.js","sourceRoot":"","sources":["../../../src/core/file.ts"],"names":[],"mappings":";AAAA,0BAAkC,aAAa,CAAC,CAAA;AAiKhD;IAAA;IA+BA,CAAC;IA9BQ,uBAAI,GAAX,UAAY,EAA0B;QACpC,EAAE,CAAC,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACtC,CAAC;IACM,2BAAQ,GAAf;QACE,MAAM,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IACM,2BAAQ,GAAf,UAAgB,EAA0B;QACxC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChB,CAAC;IACM,+BAAY,GAAnB;QACE,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IACM,wBAAK,GAAZ,UAAa,GAAW,EAAE,GAAW,EAAE,EAA0B;QAC/D,EAAE,CAAC,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACtC,CAAC;IACM,4BAAS,GAAhB,UAAiB,GAAW,EAAE,GAAW;QACvC,MAAM,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IACM,wBAAK,GAAZ,UAAa,IAAY,EAAE,EAA0B;QACnD,EAAE,CAAC,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACtC,CAAC;IACM,4BAAS,GAAhB,UAAiB,IAAY;QAC3B,MAAM,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IACM,yBAAM,GAAb,UAAc,KAAW,EAAE,KAAW,EAAE,EAA0B;QAChE,EAAE,CAAC,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACtC,CAAC;IACM,6BAAU,GAAjB,UAAkB,KAAW,EAAE,KAAW;QACxC,MAAM,IAAI,oBAAQ,CAAC,qBAAS,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IACH,eAAC;AAAD,CAAC,AA/BD,IA+BC;AA/BY,gBAAQ,WA+BpB,CAAA","sourcesContent":["import {ApiError, ErrorCode} from './api_error';\nimport Stats from './node_fs_stats';\n\nexport interface File {\n  /**\n   * **Core**: Get the current file position.\n   * @return [Number]\n   */\n  getPos(): number;\n  /**\n   * **Core**: Asynchronous `stat`.\n   * @param [Function(BrowserFS.ApiError, BrowserFS.node.fs.Stats)] cb\n   */\n  stat(cb: (err: ApiError, stats?: Stats) => any): void;\n  /**\n   * **Core**: Synchronous `stat`.\n   * @param [Function(BrowserFS.ApiError, BrowserFS.node.fs.Stats)] cb\n   */\n  statSync(): Stats;\n  /**\n   * **Core**: Asynchronous close.\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  close(cb: (err?: ApiError) => void): void;\n  /**\n   * **Core**: Synchronous close.\n   */\n  closeSync(): void;\n  /**\n   * **Core**: Asynchronous truncate.\n   * @param [Number] len\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  truncate(len: number, cb: (err?: ApiError) => void): void;\n  /**\n   * **Core**: Synchronous truncate.\n   * @param [Number] len\n   */\n  truncateSync(len: number): void;\n  /**\n   * **Core**: Asynchronous sync.\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  sync(cb: (e?: ApiError) => void): void;\n  /**\n   * **Core**: Synchronous sync.\n   */\n  syncSync(): void;\n  /**\n   * **Core**: Write buffer to the file.\n   * Note that it is unsafe to use fs.write multiple times on the same file\n   * without waiting for the callback.\n   * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n   *  the file.\n   * @param [Number] offset Offset in the buffer to start reading data from.\n   * @param [Number] length The amount of bytes to write to the file.\n   * @param [Number] position Offset from the beginning of the file where this\n   *   data should be written. If position is null, the data will be written at\n   *   the current position.\n   * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)]\n   *   cb The number specifies the number of bytes written into the file.\n   */\n  write(buffer: NodeBuffer, offset: number, length: number, position: number, cb: (err: ApiError, written?: number, buffer?: NodeBuffer) => any): void;\n  /**\n   * **Core**: Write buffer to the file.\n   * Note that it is unsafe to use fs.writeSync multiple times on the same file\n   * without waiting for it to return.\n   * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n   *  the file.\n   * @param [Number] offset Offset in the buffer to start reading data from.\n   * @param [Number] length The amount of bytes to write to the file.\n   * @param [Number] position Offset from the beginning of the file where this\n   *   data should be written. If position is null, the data will be written at\n   *   the current position.\n   * @return [Number]\n   */\n  writeSync(buffer: NodeBuffer, offset: number, length: number, position: number): number;\n  /**\n   * **Core**: Read data from the file.\n   * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n   *   written to.\n   * @param [Number] offset The offset within the buffer where writing will\n   *   start.\n   * @param [Number] length An integer specifying the number of bytes to read.\n   * @param [Number] position An integer specifying where to begin reading from\n   *   in the file. If position is null, data will be read from the current file\n   *   position.\n   * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)] cb The\n   *   number is the number of bytes read\n   */\n  read(buffer: NodeBuffer, offset: number, length: number, position: number, cb: (err: ApiError, bytesRead?: number, buffer?: NodeBuffer) => void): void;\n  /**\n   * **Core**: Read data from the file.\n   * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n   *   written to.\n   * @param [Number] offset The offset within the buffer where writing will\n   *   start.\n   * @param [Number] length An integer specifying the number of bytes to read.\n   * @param [Number] position An integer specifying where to begin reading from\n   *   in the file. If position is null, data will be read from the current file\n   *   position.\n   * @return [Number]\n   */\n  readSync(buffer: NodeBuffer, offset: number, length: number, position: number): number;\n  /**\n   * **Supplementary**: Asynchronous `datasync`.\n   *\n   * Default implementation maps to `sync`.\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  datasync(cb: (e?: ApiError) => void): void;\n  /**\n   * **Supplementary**: Synchronous `datasync`.\n   *\n   * Default implementation maps to `syncSync`.\n   */\n  datasyncSync(): void;\n  /**\n   * **Optional**: Asynchronous `chown`.\n   * @param [Number] uid\n   * @param [Number] gid\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  chown(uid: number, gid: number, cb: (e?: ApiError) => void): void;\n  /**\n   * **Optional**: Synchronous `chown`.\n   * @param [Number] uid\n   * @param [Number] gid\n   */\n  chownSync(uid: number, gid: number): void;\n  /**\n   * **Optional**: Asynchronous `fchmod`.\n   * @param [Number] mode\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  chmod(mode: number, cb: (e?: ApiError) => void): void;\n  /**\n   * **Optional**: Synchronous `fchmod`.\n   * @param [Number] mode\n   */\n  chmodSync(mode: number): void;\n  /**\n   * **Optional**: Change the file timestamps of the file.\n   * @param [Date] atime\n   * @param [Date] mtime\n   * @param [Function(BrowserFS.ApiError)] cb\n   */\n  utimes(atime: Date, mtime: Date, cb: (e?: ApiError) => void): void;\n  /**\n   * **Optional**: Change the file timestamps of the file.\n   * @param [Date] atime\n   * @param [Date] mtime\n   */\n  utimesSync(atime: Date, mtime: Date): void;\n}\n\n/**\n * Base class that contains shared implementations of functions for the file\n * object.\n * @class\n */\nexport class BaseFile {\n  public sync(cb: (e?: ApiError) => void): void {\n    cb(new ApiError(ErrorCode.ENOTSUP));\n  }\n  public syncSync(): void {\n    throw new ApiError(ErrorCode.ENOTSUP);\n  }\n  public datasync(cb: (e?: ApiError) => void): void {\n    this.sync(cb);\n  }\n  public datasyncSync(): void {\n    return this.syncSync();\n  }\n  public chown(uid: number, gid: number, cb: (e?: ApiError) => void): void {\n    cb(new ApiError(ErrorCode.ENOTSUP));\n  }\n  public chownSync(uid: number, gid: number): void {\n    throw new ApiError(ErrorCode.ENOTSUP);\n  }\n  public chmod(mode: number, cb: (e?: ApiError) => void): void {\n    cb(new ApiError(ErrorCode.ENOTSUP));\n  }\n  public chmodSync(mode: number): void {\n    throw new ApiError(ErrorCode.ENOTSUP);\n  }\n  public utimes(atime: Date, mtime: Date, cb: (e?: ApiError) => void): void {\n    cb(new ApiError(ErrorCode.ENOTSUP));\n  }\n  public utimesSync(atime: Date, mtime: Date): void {\n    throw new ApiError(ErrorCode.ENOTSUP);\n  }\n}\n"]}