HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/pwa.sports-crowd.com/node_modules/@ngtools/webpack/src/paths-plugin.js
"use strict";
/**
 * @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
 */
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
    if (mod && mod.__esModule) return mod;
    var result = {};
    if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
    __setModuleDefault(result, mod);
    return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.TypeScriptPathsPlugin = void 0;
const path = __importStar(require("path"));
class TypeScriptPathsPlugin {
    constructor(options) {
        if (options) {
            this.update(options);
        }
    }
    /**
     * Update the plugin with new path mapping option values.
     * The options will also be preprocessed to reduce the overhead of individual resolve actions
     * during a build.
     *
     * @param options The `paths` and `baseUrl` options from TypeScript's `CompilerOptions`.
     */
    update(options) {
        this.baseUrl = options.baseUrl;
        this.patterns = undefined;
        if (options.paths) {
            for (const [pattern, potentials] of Object.entries(options.paths)) {
                // Ignore any entries that would not result in a new mapping
                if (potentials.length === 0 || potentials.every((potential) => potential === '*')) {
                    continue;
                }
                const starIndex = pattern.indexOf('*');
                let prefix = pattern;
                let suffix;
                if (starIndex > -1) {
                    prefix = pattern.slice(0, starIndex);
                    if (starIndex < pattern.length - 1) {
                        suffix = pattern.slice(starIndex + 1);
                    }
                }
                this.patterns ?? (this.patterns = []);
                this.patterns.push({
                    starIndex,
                    prefix,
                    suffix,
                    potentials: potentials.map((potential) => {
                        const potentialStarIndex = potential.indexOf('*');
                        if (potentialStarIndex === -1) {
                            return { hasStar: false, prefix: potential };
                        }
                        return {
                            hasStar: true,
                            prefix: potential.slice(0, potentialStarIndex),
                            suffix: potentialStarIndex < potential.length - 1
                                ? potential.slice(potentialStarIndex + 1)
                                : undefined,
                        };
                    }),
                });
            }
            // Sort patterns so that exact matches take priority then largest prefix match
            this.patterns?.sort((a, b) => {
                if (a.starIndex === -1) {
                    return -1;
                }
                else if (b.starIndex === -1) {
                    return 1;
                }
                else {
                    return b.starIndex - a.starIndex;
                }
            });
        }
    }
    apply(resolver) {
        const target = resolver.ensureHook('resolve');
        // To support synchronous resolvers this hook cannot be promise based.
        // Webpack supports synchronous resolution with `tap` and `tapAsync` hooks.
        resolver
            .getHook('described-resolve')
            .tapAsync('TypeScriptPathsPlugin', (request, resolveContext, callback) => {
            // Preprocessing of the options will ensure that `patterns` is either undefined or has elements to check
            if (!this.patterns) {
                callback();
                return;
            }
            if (!request || request.typescriptPathMapped) {
                callback();
                return;
            }
            const originalRequest = request.request || request.path;
            if (!originalRequest) {
                callback();
                return;
            }
            // Only work on Javascript/TypeScript issuers.
            if (!request?.context?.issuer?.match(/\.[cm]?[jt]sx?$/)) {
                callback();
                return;
            }
            // Absolute requests are not mapped
            if (path.isAbsolute(originalRequest)) {
                callback();
                return;
            }
            switch (originalRequest[0]) {
                case '.':
                    // Relative requests are not mapped
                    callback();
                    return;
                case '!':
                    // Ignore all webpack special requests
                    if (originalRequest.length > 1 && originalRequest[1] === '!') {
                        callback();
                        return;
                    }
                    break;
            }
            // A generator is used to limit the amount of replacements requests that need to be created.
            // For example, if the first one resolves, any others are not needed and do not need
            // to be created.
            const requests = this.createReplacementRequests(request, originalRequest);
            const tryResolve = () => {
                const next = requests.next();
                if (next.done) {
                    callback();
                    return;
                }
                resolver.doResolve(target, next.value, '', resolveContext, (error, result) => {
                    if (error) {
                        callback(error);
                    }
                    else if (result) {
                        callback(undefined, result);
                    }
                    else {
                        tryResolve();
                    }
                });
            };
            tryResolve();
        });
    }
    *findReplacements(originalRequest) {
        if (!this.patterns) {
            return;
        }
        // check if any path mapping rules are relevant
        for (const { starIndex, prefix, suffix, potentials } of this.patterns) {
            let partial;
            if (starIndex === -1) {
                // No star means an exact match is required
                if (prefix === originalRequest) {
                    partial = '';
                }
            }
            else if (starIndex === 0 && !suffix) {
                // Everything matches a single wildcard pattern ("*")
                partial = originalRequest;
            }
            else if (!suffix) {
                // No suffix means the star is at the end of the pattern
                if (originalRequest.startsWith(prefix)) {
                    partial = originalRequest.slice(prefix.length);
                }
            }
            else {
                // Star was in the middle of the pattern
                if (originalRequest.startsWith(prefix) && originalRequest.endsWith(suffix)) {
                    partial = originalRequest.substring(prefix.length, originalRequest.length - suffix.length);
                }
            }
            // If request was not matched, move on to the next pattern
            if (partial === undefined) {
                continue;
            }
            // Create the full replacement values based on the original request and the potentials
            // for the successfully matched pattern.
            for (const { hasStar, prefix, suffix } of potentials) {
                let replacement = prefix;
                if (hasStar) {
                    replacement += partial;
                    if (suffix) {
                        replacement += suffix;
                    }
                }
                yield replacement;
            }
        }
    }
    *createReplacementRequests(request, originalRequest) {
        for (const replacement of this.findReplacements(originalRequest)) {
            const targetPath = path.resolve(this.baseUrl ?? '', replacement);
            // Resolution in the original callee location, but with the updated request
            // to point to the mapped target location.
            yield {
                ...request,
                request: targetPath,
                typescriptPathMapped: true,
            };
            // If there is no extension. i.e. the target does not refer to an explicit
            // file, then this is a candidate for module/package resolution.
            const canBeModule = path.extname(targetPath) === '';
            if (canBeModule) {
                // Resolution in the target location, preserving the original request.
                // This will work with the `resolve-in-package` resolution hook, supporting
                // package exports for e.g. locally-built APF libraries.
                yield {
                    ...request,
                    path: targetPath,
                    typescriptPathMapped: true,
                };
            }
        }
    }
}
exports.TypeScriptPathsPlugin = TypeScriptPathsPlugin;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paths-plugin.js","sourceRoot":"","sources":["../../../../../../../packages/ngtools/webpack/src/paths-plugin.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 * as path from 'path';\nimport { CompilerOptions } from 'typescript';\nimport type { Resolver } from 'webpack';\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface TypeScriptPathsPluginOptions extends Pick<CompilerOptions, 'paths' | 'baseUrl'> {}\n\n// Extract ResolverRequest type from Webpack types since it is not directly exported\ntype ResolverRequest = NonNullable<Parameters<Parameters<Resolver['resolve']>[4]>[2]>;\n\ninterface PathPluginResolverRequest extends ResolverRequest {\n  context?: {\n    issuer?: string;\n  };\n  typescriptPathMapped?: boolean;\n}\n\ninterface PathPattern {\n  starIndex: number;\n  prefix: string;\n  suffix?: string;\n  potentials: { hasStar: boolean; prefix: string; suffix?: string }[];\n}\n\nexport class TypeScriptPathsPlugin {\n  private baseUrl?: string;\n  private patterns?: PathPattern[];\n\n  constructor(options?: TypeScriptPathsPluginOptions) {\n    if (options) {\n      this.update(options);\n    }\n  }\n\n  /**\n   * Update the plugin with new path mapping option values.\n   * The options will also be preprocessed to reduce the overhead of individual resolve actions\n   * during a build.\n   *\n   * @param options The `paths` and `baseUrl` options from TypeScript's `CompilerOptions`.\n   */\n  update(options: TypeScriptPathsPluginOptions): void {\n    this.baseUrl = options.baseUrl;\n    this.patterns = undefined;\n\n    if (options.paths) {\n      for (const [pattern, potentials] of Object.entries(options.paths)) {\n        // Ignore any entries that would not result in a new mapping\n        if (potentials.length === 0 || potentials.every((potential) => potential === '*')) {\n          continue;\n        }\n\n        const starIndex = pattern.indexOf('*');\n        let prefix = pattern;\n        let suffix;\n        if (starIndex > -1) {\n          prefix = pattern.slice(0, starIndex);\n          if (starIndex < pattern.length - 1) {\n            suffix = pattern.slice(starIndex + 1);\n          }\n        }\n\n        this.patterns ??= [];\n        this.patterns.push({\n          starIndex,\n          prefix,\n          suffix,\n          potentials: potentials.map((potential) => {\n            const potentialStarIndex = potential.indexOf('*');\n            if (potentialStarIndex === -1) {\n              return { hasStar: false, prefix: potential };\n            }\n\n            return {\n              hasStar: true,\n              prefix: potential.slice(0, potentialStarIndex),\n              suffix:\n                potentialStarIndex < potential.length - 1\n                  ? potential.slice(potentialStarIndex + 1)\n                  : undefined,\n            };\n          }),\n        });\n      }\n\n      // Sort patterns so that exact matches take priority then largest prefix match\n      this.patterns?.sort((a, b) => {\n        if (a.starIndex === -1) {\n          return -1;\n        } else if (b.starIndex === -1) {\n          return 1;\n        } else {\n          return b.starIndex - a.starIndex;\n        }\n      });\n    }\n  }\n\n  apply(resolver: Resolver): void {\n    const target = resolver.ensureHook('resolve');\n\n    // To support synchronous resolvers this hook cannot be promise based.\n    // Webpack supports synchronous resolution with `tap` and `tapAsync` hooks.\n    resolver\n      .getHook('described-resolve')\n      .tapAsync(\n        'TypeScriptPathsPlugin',\n        (request: PathPluginResolverRequest, resolveContext, callback) => {\n          // Preprocessing of the options will ensure that `patterns` is either undefined or has elements to check\n          if (!this.patterns) {\n            callback();\n\n            return;\n          }\n\n          if (!request || request.typescriptPathMapped) {\n            callback();\n\n            return;\n          }\n\n          const originalRequest = request.request || request.path;\n          if (!originalRequest) {\n            callback();\n\n            return;\n          }\n\n          // Only work on Javascript/TypeScript issuers.\n          if (!request?.context?.issuer?.match(/\\.[cm]?[jt]sx?$/)) {\n            callback();\n\n            return;\n          }\n\n          // Absolute requests are not mapped\n          if (path.isAbsolute(originalRequest)) {\n            callback();\n\n            return;\n          }\n\n          switch (originalRequest[0]) {\n            case '.':\n              // Relative requests are not mapped\n              callback();\n\n              return;\n            case '!':\n              // Ignore all webpack special requests\n              if (originalRequest.length > 1 && originalRequest[1] === '!') {\n                callback();\n\n                return;\n              }\n              break;\n          }\n\n          // A generator is used to limit the amount of replacements requests that need to be created.\n          // For example, if the first one resolves, any others are not needed and do not need\n          // to be created.\n          const requests = this.createReplacementRequests(request, originalRequest);\n\n          const tryResolve = () => {\n            const next = requests.next();\n            if (next.done) {\n              callback();\n\n              return;\n            }\n\n            resolver.doResolve(\n              target,\n              next.value,\n              '',\n              resolveContext,\n              (error: Error | null | undefined, result: ResolverRequest | null | undefined) => {\n                if (error) {\n                  callback(error);\n                } else if (result) {\n                  callback(undefined, result);\n                } else {\n                  tryResolve();\n                }\n              },\n            );\n          };\n\n          tryResolve();\n        },\n      );\n  }\n\n  *findReplacements(originalRequest: string): IterableIterator<string> {\n    if (!this.patterns) {\n      return;\n    }\n\n    // check if any path mapping rules are relevant\n    for (const { starIndex, prefix, suffix, potentials } of this.patterns) {\n      let partial;\n\n      if (starIndex === -1) {\n        // No star means an exact match is required\n        if (prefix === originalRequest) {\n          partial = '';\n        }\n      } else if (starIndex === 0 && !suffix) {\n        // Everything matches a single wildcard pattern (\"*\")\n        partial = originalRequest;\n      } else if (!suffix) {\n        // No suffix means the star is at the end of the pattern\n        if (originalRequest.startsWith(prefix)) {\n          partial = originalRequest.slice(prefix.length);\n        }\n      } else {\n        // Star was in the middle of the pattern\n        if (originalRequest.startsWith(prefix) && originalRequest.endsWith(suffix)) {\n          partial = originalRequest.substring(\n            prefix.length,\n            originalRequest.length - suffix.length,\n          );\n        }\n      }\n\n      // If request was not matched, move on to the next pattern\n      if (partial === undefined) {\n        continue;\n      }\n\n      // Create the full replacement values based on the original request and the potentials\n      // for the successfully matched pattern.\n      for (const { hasStar, prefix, suffix } of potentials) {\n        let replacement = prefix;\n\n        if (hasStar) {\n          replacement += partial;\n          if (suffix) {\n            replacement += suffix;\n          }\n        }\n\n        yield replacement;\n      }\n    }\n  }\n\n  *createReplacementRequests(\n    request: PathPluginResolverRequest,\n    originalRequest: string,\n  ): IterableIterator<PathPluginResolverRequest> {\n    for (const replacement of this.findReplacements(originalRequest)) {\n      const targetPath = path.resolve(this.baseUrl ?? '', replacement);\n      // Resolution in the original callee location, but with the updated request\n      // to point to the mapped target location.\n      yield {\n        ...request,\n        request: targetPath,\n        typescriptPathMapped: true,\n      };\n\n      // If there is no extension. i.e. the target does not refer to an explicit\n      // file, then this is a candidate for module/package resolution.\n      const canBeModule = path.extname(targetPath) === '';\n      if (canBeModule) {\n        // Resolution in the target location, preserving the original request.\n        // This will work with the `resolve-in-package` resolution hook, supporting\n        // package exports for e.g. locally-built APF libraries.\n        yield {\n          ...request,\n          path: targetPath,\n          typescriptPathMapped: true,\n        };\n      }\n    }\n  }\n}\n"]}