123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- "use strict";
- const forEachBail = require("./forEachBail");
- const getPaths = require("./getPaths");
- const { getType, PathType } = require("./util/path");
- module.exports = class SymlinkPlugin {
-
- constructor(source, target) {
- this.source = source;
- this.target = target;
- }
-
- apply(resolver) {
- const target = resolver.ensureHook(this.target);
- const fs = resolver.fileSystem;
- resolver
- .getHook(this.source)
- .tapAsync("SymlinkPlugin", (request, resolveContext, callback) => {
- if (request.ignoreSymlinks) return callback();
- const pathsResult = getPaths( (request.path));
- const pathSegments = pathsResult.segments;
- const paths = pathsResult.paths;
- let containsSymlink = false;
- let idx = -1;
- forEachBail(
- paths,
-
- (path, callback) => {
- idx++;
- if (resolveContext.fileDependencies)
- resolveContext.fileDependencies.add(path);
- fs.readlink(path, (err, result) => {
- if (!err && result) {
- pathSegments[idx] = (result);
- containsSymlink = true;
-
- const resultType = getType(result.toString());
- if (
- resultType === PathType.AbsoluteWin ||
- resultType === PathType.AbsolutePosix
- ) {
- return callback(null, idx);
- }
- }
- callback();
- });
- },
-
- (err, idx) => {
- if (!containsSymlink) return callback();
- const resultSegments =
- typeof idx === "number"
- ? pathSegments.slice(0, idx + 1)
- : pathSegments.slice();
- const result = resultSegments.reduceRight((a, b) => {
- return resolver.join(a, b);
- });
-
- const obj = {
- ...request,
- path: result
- };
- resolver.doResolve(
- target,
- obj,
- "resolved symlink to " + result,
- resolveContext,
- callback
- );
- }
- );
- });
- }
- };
|