@angular-devkit/core
Version:
Angular DevKit - Core Utility Library
213 lines • 28.1 kB
JavaScript
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.NodeJsSyncHost = exports.NodeJsAsyncHost = void 0;
const node_fs_1 = require("node:fs");
const node_path_1 = require("node:path");
const rxjs_1 = require("rxjs");
const src_1 = require("../src");
async function exists(path) {
try {
await node_fs_1.promises.access(path, node_fs_1.constants.F_OK);
return true;
}
catch {
return false;
}
}
// This will only be initialized if the watch() method is called.
// Otherwise chokidar appears only in type positions, and shouldn't be referenced
// in the JavaScript output.
let FSWatcher;
function loadFSWatcher() {
if (!FSWatcher) {
try {
FSWatcher = require('chokidar').FSWatcher;
}
catch (e) {
if (e.code !== 'MODULE_NOT_FOUND') {
throw new Error('As of angular-devkit version 8.0, the "chokidar" package ' +
'must be installed in order to use watch() features.');
}
throw e;
}
}
}
/**
* An implementation of the Virtual FS using Node as the background. There are two versions; one
* synchronous and one asynchronous.
*/
class NodeJsAsyncHost {
get capabilities() {
return { synchronous: false };
}
write(path, content) {
return (0, rxjs_1.from)(node_fs_1.promises.mkdir((0, src_1.getSystemPath)((0, src_1.dirname)(path)), { recursive: true })).pipe((0, rxjs_1.mergeMap)(() => node_fs_1.promises.writeFile((0, src_1.getSystemPath)(path), new Uint8Array(content))));
}
read(path) {
return (0, rxjs_1.from)(node_fs_1.promises.readFile((0, src_1.getSystemPath)(path))).pipe((0, rxjs_1.map)((buffer) => new Uint8Array(buffer).buffer));
}
delete(path) {
return (0, rxjs_1.from)(node_fs_1.promises.rm((0, src_1.getSystemPath)(path), { force: true, recursive: true, maxRetries: 3 }));
}
rename(from, to) {
return (0, rxjs_1.from)(node_fs_1.promises.rename((0, src_1.getSystemPath)(from), (0, src_1.getSystemPath)(to)));
}
list(path) {
return (0, rxjs_1.from)(node_fs_1.promises.readdir((0, src_1.getSystemPath)(path))).pipe((0, rxjs_1.map)((names) => names.map((name) => (0, src_1.fragment)(name))));
}
exists(path) {
return (0, rxjs_1.from)(exists((0, src_1.getSystemPath)(path)));
}
isDirectory(path) {
return this.stat(path).pipe((0, rxjs_1.map)((stat) => stat.isDirectory()));
}
isFile(path) {
return this.stat(path).pipe((0, rxjs_1.map)((stat) => stat.isFile()));
}
// Some hosts may not support stat.
stat(path) {
return (0, rxjs_1.from)(node_fs_1.promises.stat((0, src_1.getSystemPath)(path)));
}
// Some hosts may not support watching.
watch(path, _options) {
return new rxjs_1.Observable((obs) => {
loadFSWatcher();
const watcher = new FSWatcher({ persistent: true });
watcher.add((0, src_1.getSystemPath)(path));
watcher
.on('change', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 0 /* virtualFs.HostWatchEventType.Changed */,
});
})
.on('add', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 1 /* virtualFs.HostWatchEventType.Created */,
});
})
.on('unlink', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 2 /* virtualFs.HostWatchEventType.Deleted */,
});
});
return () => {
void watcher.close();
};
}).pipe((0, rxjs_1.publish)(), (0, rxjs_1.refCount)());
}
}
exports.NodeJsAsyncHost = NodeJsAsyncHost;
/**
* An implementation of the Virtual FS using Node as the backend, synchronously.
*/
class NodeJsSyncHost {
get capabilities() {
return { synchronous: true };
}
write(path, content) {
return new rxjs_1.Observable((obs) => {
(0, node_fs_1.mkdirSync)((0, src_1.getSystemPath)((0, src_1.dirname)(path)), { recursive: true });
(0, node_fs_1.writeFileSync)((0, src_1.getSystemPath)(path), new Uint8Array(content));
obs.next();
obs.complete();
});
}
read(path) {
return new rxjs_1.Observable((obs) => {
const buffer = (0, node_fs_1.readFileSync)((0, src_1.getSystemPath)(path));
obs.next(new Uint8Array(buffer).buffer);
obs.complete();
});
}
delete(path) {
return new rxjs_1.Observable((obs) => {
(0, node_fs_1.rmSync)((0, src_1.getSystemPath)(path), { force: true, recursive: true, maxRetries: 3 });
obs.complete();
});
}
rename(from, to) {
return new rxjs_1.Observable((obs) => {
const toSystemPath = (0, src_1.getSystemPath)(to);
(0, node_fs_1.mkdirSync)((0, node_path_1.dirname)(toSystemPath), { recursive: true });
(0, node_fs_1.renameSync)((0, src_1.getSystemPath)(from), toSystemPath);
obs.next();
obs.complete();
});
}
list(path) {
return new rxjs_1.Observable((obs) => {
const names = (0, node_fs_1.readdirSync)((0, src_1.getSystemPath)(path));
obs.next(names.map((name) => (0, src_1.fragment)(name)));
obs.complete();
});
}
exists(path) {
return new rxjs_1.Observable((obs) => {
obs.next((0, node_fs_1.existsSync)((0, src_1.getSystemPath)(path)));
obs.complete();
});
}
isDirectory(path) {
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
return this.stat(path).pipe((0, rxjs_1.map)((stat) => stat.isDirectory()));
}
isFile(path) {
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
return this.stat(path).pipe((0, rxjs_1.map)((stat) => stat.isFile()));
}
// Some hosts may not support stat.
stat(path) {
return new rxjs_1.Observable((obs) => {
obs.next((0, node_fs_1.statSync)((0, src_1.getSystemPath)(path)));
obs.complete();
});
}
// Some hosts may not support watching.
watch(path, _options) {
return new rxjs_1.Observable((obs) => {
loadFSWatcher();
const watcher = new FSWatcher({ persistent: false });
watcher.add((0, src_1.getSystemPath)(path));
watcher
.on('change', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 0 /* virtualFs.HostWatchEventType.Changed */,
});
})
.on('add', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 1 /* virtualFs.HostWatchEventType.Created */,
});
})
.on('unlink', (path) => {
obs.next({
path: (0, src_1.normalize)(path),
time: new Date(),
type: 2 /* virtualFs.HostWatchEventType.Deleted */,
});
});
return () => {
void watcher.close();
};
}).pipe((0, rxjs_1.publish)(), (0, rxjs_1.refCount)());
}
}
exports.NodeJsSyncHost = NodeJsSyncHost;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../../../../../packages/angular_devkit/core/node/host.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  PathLike,\n  Stats,\n  constants,\n  existsSync,\n  promises as fsPromises,\n  mkdirSync,\n  readFileSync,\n  readdirSync,\n  renameSync,\n  rmSync,\n  statSync,\n  writeFileSync,\n} from 'node:fs';\nimport { dirname as pathDirname } from 'node:path';\nimport { Observable, map, mergeMap, from as observableFrom, publish, refCount } from 'rxjs';\nimport { Path, PathFragment, dirname, fragment, getSystemPath, normalize, virtualFs } from '../src';\n\nasync function exists(path: PathLike): Promise<boolean> {\n  try {\n    await fsPromises.access(path, constants.F_OK);\n\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n// This will only be initialized if the watch() method is called.\n// Otherwise chokidar appears only in type positions, and shouldn't be referenced\n// in the JavaScript output.\nlet FSWatcher: typeof import('chokidar').FSWatcher;\nfunction loadFSWatcher() {\n  if (!FSWatcher) {\n    try {\n      FSWatcher = require('chokidar').FSWatcher;\n    } catch (e) {\n      if ((e as NodeJS.ErrnoException).code !== 'MODULE_NOT_FOUND') {\n        throw new Error(\n          'As of angular-devkit version 8.0, the \"chokidar\" package ' +\n            'must be installed in order to use watch() features.',\n        );\n      }\n      throw e;\n    }\n  }\n}\n\n/**\n * An implementation of the Virtual FS using Node as the background. There are two versions; one\n * synchronous and one asynchronous.\n */\nexport class NodeJsAsyncHost implements virtualFs.Host<Stats> {\n  get capabilities(): virtualFs.HostCapabilities {\n    return { synchronous: false };\n  }\n\n  write(path: Path, content: virtualFs.FileBuffer): Observable<void> {\n    return observableFrom(fsPromises.mkdir(getSystemPath(dirname(path)), { recursive: true })).pipe(\n      mergeMap(() => fsPromises.writeFile(getSystemPath(path), new Uint8Array(content))),\n    );\n  }\n\n  read(path: Path): Observable<virtualFs.FileBuffer> {\n    return observableFrom(fsPromises.readFile(getSystemPath(path))).pipe(\n      map((buffer) => new Uint8Array(buffer).buffer as virtualFs.FileBuffer),\n    );\n  }\n\n  delete(path: Path): Observable<void> {\n    return observableFrom(\n      fsPromises.rm(getSystemPath(path), { force: true, recursive: true, maxRetries: 3 }),\n    );\n  }\n\n  rename(from: Path, to: Path): Observable<void> {\n    return observableFrom(fsPromises.rename(getSystemPath(from), getSystemPath(to)));\n  }\n\n  list(path: Path): Observable<PathFragment[]> {\n    return observableFrom(fsPromises.readdir(getSystemPath(path))).pipe(\n      map((names) => names.map((name) => fragment(name))),\n    );\n  }\n\n  exists(path: Path): Observable<boolean> {\n    return observableFrom(exists(getSystemPath(path)));\n  }\n\n  isDirectory(path: Path): Observable<boolean> {\n    return this.stat(path).pipe(map((stat) => stat.isDirectory()));\n  }\n\n  isFile(path: Path): Observable<boolean> {\n    return this.stat(path).pipe(map((stat) => stat.isFile()));\n  }\n\n  // Some hosts may not support stat.\n  stat(path: Path): Observable<virtualFs.Stats<Stats>> {\n    return observableFrom(fsPromises.stat(getSystemPath(path)));\n  }\n\n  // Some hosts may not support watching.\n  watch(\n    path: Path,\n    _options?: virtualFs.HostWatchOptions,\n  ): Observable<virtualFs.HostWatchEvent> | null {\n    return new Observable<virtualFs.HostWatchEvent>((obs) => {\n      loadFSWatcher();\n      const watcher = new FSWatcher({ persistent: true });\n      watcher.add(getSystemPath(path));\n\n      watcher\n        .on('change', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Changed,\n          });\n        })\n        .on('add', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Created,\n          });\n        })\n        .on('unlink', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Deleted,\n          });\n        });\n\n      return () => {\n        void watcher.close();\n      };\n    }).pipe(publish(), refCount());\n  }\n}\n\n/**\n * An implementation of the Virtual FS using Node as the backend, synchronously.\n */\nexport class NodeJsSyncHost implements virtualFs.Host<Stats> {\n  get capabilities(): virtualFs.HostCapabilities {\n    return { synchronous: true };\n  }\n\n  write(path: Path, content: virtualFs.FileBuffer): Observable<void> {\n    return new Observable((obs) => {\n      mkdirSync(getSystemPath(dirname(path)), { recursive: true });\n      writeFileSync(getSystemPath(path), new Uint8Array(content));\n      obs.next();\n      obs.complete();\n    });\n  }\n\n  read(path: Path): Observable<virtualFs.FileBuffer> {\n    return new Observable((obs) => {\n      const buffer = readFileSync(getSystemPath(path));\n\n      obs.next(new Uint8Array(buffer).buffer as virtualFs.FileBuffer);\n      obs.complete();\n    });\n  }\n\n  delete(path: Path): Observable<void> {\n    return new Observable<void>((obs) => {\n      rmSync(getSystemPath(path), { force: true, recursive: true, maxRetries: 3 });\n\n      obs.complete();\n    });\n  }\n\n  rename(from: Path, to: Path): Observable<void> {\n    return new Observable((obs) => {\n      const toSystemPath = getSystemPath(to);\n      mkdirSync(pathDirname(toSystemPath), { recursive: true });\n      renameSync(getSystemPath(from), toSystemPath);\n      obs.next();\n      obs.complete();\n    });\n  }\n\n  list(path: Path): Observable<PathFragment[]> {\n    return new Observable((obs) => {\n      const names = readdirSync(getSystemPath(path));\n      obs.next(names.map((name) => fragment(name)));\n      obs.complete();\n    });\n  }\n\n  exists(path: Path): Observable<boolean> {\n    return new Observable((obs) => {\n      obs.next(existsSync(getSystemPath(path)));\n      obs.complete();\n    });\n  }\n\n  isDirectory(path: Path): Observable<boolean> {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    return this.stat(path)!.pipe(map((stat) => stat.isDirectory()));\n  }\n\n  isFile(path: Path): Observable<boolean> {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    return this.stat(path)!.pipe(map((stat) => stat.isFile()));\n  }\n\n  // Some hosts may not support stat.\n  stat(path: Path): Observable<virtualFs.Stats<Stats>> {\n    return new Observable((obs) => {\n      obs.next(statSync(getSystemPath(path)));\n      obs.complete();\n    });\n  }\n\n  // Some hosts may not support watching.\n  watch(\n    path: Path,\n    _options?: virtualFs.HostWatchOptions,\n  ): Observable<virtualFs.HostWatchEvent> | null {\n    return new Observable<virtualFs.HostWatchEvent>((obs) => {\n      loadFSWatcher();\n      const watcher = new FSWatcher({ persistent: false });\n      watcher.add(getSystemPath(path));\n\n      watcher\n        .on('change', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Changed,\n          });\n        })\n        .on('add', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Created,\n          });\n        })\n        .on('unlink', (path) => {\n          obs.next({\n            path: normalize(path),\n            time: new Date(),\n            type: virtualFs.HostWatchEventType.Deleted,\n          });\n        });\n\n      return () => {\n        void watcher.close();\n      };\n    }).pipe(publish(), refCount());\n  }\n}\n"]}
;