@ngtools/webpack
Version:
Webpack plugin that AoT compiles your Angular components and modules.
313 lines • 44.7 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
*/
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;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.WebpackResourceLoader = void 0;
const node_assert_1 = __importDefault(require("node:assert"));
const node_buffer_1 = require("node:buffer");
const path = __importStar(require("node:path"));
const vm = __importStar(require("node:vm"));
const diagnostics_1 = require("./ivy/diagnostics");
const paths_1 = require("./ivy/paths");
const inline_resource_1 = require("./loaders/inline-resource");
const replace_resources_1 = require("./transformers/replace_resources");
class WebpackResourceLoader {
constructor(shouldCache) {
this._fileDependencies = new Map();
this._reverseDependencies = new Map();
this.modifiedResources = new Set();
this.outputPathCounter = 1;
this.inlineDataLoaderPath = inline_resource_1.InlineAngularResourceLoaderPath;
if (shouldCache) {
this.fileCache = new Map();
this.assetCache = new Map();
}
}
update(parentCompilation, changedFiles) {
var _a, _b, _c, _d, _e;
this._parentCompilation = parentCompilation;
// Update resource cache and modified resources
this.modifiedResources.clear();
if (changedFiles) {
for (const changedFile of changedFiles) {
const changedFileNormalized = (0, paths_1.normalizePath)(changedFile);
(_a = this.assetCache) === null || _a === void 0 ? void 0 : _a.delete(changedFileNormalized);
for (const affectedResource of this.getAffectedResources(changedFile)) {
const affectedResourceNormalized = (0, paths_1.normalizePath)(affectedResource);
(_b = this.fileCache) === null || _b === void 0 ? void 0 : _b.delete(affectedResourceNormalized);
this.modifiedResources.add(affectedResource);
for (const effectedDependencies of this.getResourceDependencies(affectedResourceNormalized)) {
(_c = this.assetCache) === null || _c === void 0 ? void 0 : _c.delete((0, paths_1.normalizePath)(effectedDependencies));
}
}
}
}
else {
(_d = this.fileCache) === null || _d === void 0 ? void 0 : _d.clear();
(_e = this.assetCache) === null || _e === void 0 ? void 0 : _e.clear();
}
// Re-emit all assets for un-effected files
if (this.assetCache) {
for (const [, { name, source, info }] of this.assetCache) {
this._parentCompilation.emitAsset(name, source, info);
}
}
}
clearParentCompilation() {
this._parentCompilation = undefined;
}
getModifiedResourceFiles() {
return this.modifiedResources;
}
getResourceDependencies(filePath) {
return this._fileDependencies.get(filePath) || [];
}
getAffectedResources(file) {
return this._reverseDependencies.get(file) || [];
}
setAffectedResources(file, resources) {
this._reverseDependencies.set(file, new Set(resources));
}
// eslint-disable-next-line max-lines-per-function
async _compile(filePath, data, fileExtension, resourceType, containingFile) {
if (!this._parentCompilation) {
throw new Error('WebpackResourceLoader cannot be used without parentCompilation');
}
const { context, webpack } = this._parentCompilation.compiler;
const { EntryPlugin, NormalModule, WebpackError, library, node, sources, util: { createHash }, } = webpack;
const getEntry = () => {
if (filePath) {
return `${filePath}?${replace_resources_1.NG_COMPONENT_RESOURCE_QUERY}`;
}
else if (resourceType) {
return (
// app.component.ts-2.css?ngResource!=!@ngtools/webpack/src/loaders/inline-resource.js!app.component.ts
`${containingFile}-${this.outputPathCounter}.${fileExtension}` +
`?${replace_resources_1.NG_COMPONENT_RESOURCE_QUERY}!=!${this.inlineDataLoaderPath}!${containingFile}`);
}
else if (data) {
// Create a special URL for reading the resource from memory
return `angular-resource:${resourceType},${createHash('xxhash64')
.update(data)
.digest('hex')}`;
}
throw new Error(`"filePath", "resourceType" or "data" must be specified.`);
};
const entry = getEntry();
// Simple sanity check.
if (filePath === null || filePath === void 0 ? void 0 : filePath.match(/\.[jt]s$/)) {
throw new Error(`Cannot use a JavaScript or TypeScript file (${filePath}) in a component's styleUrls or templateUrl.`);
}
const outputFilePath = filePath ||
`${containingFile}-angular-inline--${this.outputPathCounter++}.${resourceType === 'template' ? 'html' : 'css'}`;
const outputOptions = {
filename: outputFilePath,
library: {
type: 'var',
name: 'resource',
},
};
const childCompiler = this._parentCompilation.createChildCompiler('angular-compiler:resource', outputOptions, [
new node.NodeTemplatePlugin(outputOptions),
new node.NodeTargetPlugin(),
new EntryPlugin(context, entry, { name: 'resource' }),
new library.EnableLibraryPlugin('var'),
]);
childCompiler.hooks.thisCompilation.tap('angular-compiler', (compilation, { normalModuleFactory }) => {
// If no data is provided, the resource will be read from the filesystem
if (data !== undefined) {
normalModuleFactory.hooks.resolveForScheme
.for('angular-resource')
.tap('angular-compiler', (resourceData) => {
if (filePath) {
resourceData.path = filePath;
resourceData.resource = filePath;
}
return true;
});
NormalModule.getCompilationHooks(compilation)
.readResourceForScheme.for('angular-resource')
.tap('angular-compiler', () => data);
compilation[inline_resource_1.InlineAngularResourceSymbol] = data;
}
compilation.hooks.additionalAssets.tap('angular-compiler', () => {
const asset = compilation.assets[outputFilePath];
if (!asset) {
return;
}
try {
const output = this._evaluate(outputFilePath, asset.source().toString());
if (typeof output === 'string') {
compilation.assets[outputFilePath] = new sources.RawSource(output);
}
}
catch (error) {
(0, node_assert_1.default)(error instanceof Error, 'catch clause variable is not an Error instance');
// Use compilation errors, as otherwise webpack will choke
(0, diagnostics_1.addError)(compilation, error.message);
}
});
});
let finalContent;
childCompiler.hooks.compilation.tap('angular-compiler', (childCompilation) => {
childCompilation.hooks.processAssets.tap({ name: 'angular-compiler', stage: webpack.Compilation.PROCESS_ASSETS_STAGE_REPORT }, () => {
var _a;
finalContent = (_a = childCompilation.assets[outputFilePath]) === null || _a === void 0 ? void 0 : _a.source().toString();
for (const { files } of childCompilation.chunks) {
for (const file of files) {
childCompilation.deleteAsset(file);
}
}
});
});
return new Promise((resolve, reject) => {
childCompiler.runAsChild((error, _, childCompilation) => {
var _a, _b;
if (error) {
reject(error);
return;
}
else if (!childCompilation) {
reject(new Error('Unknown child compilation error'));
return;
}
// Workaround to attempt to reduce memory usage of child compilations.
// This removes the child compilation from the main compilation and manually propagates
// all dependencies, warnings, and errors.
const parent = childCompiler.parentCompilation;
if (parent) {
parent.children = parent.children.filter((child) => child !== childCompilation);
let fileDependencies;
for (const dependency of childCompilation.fileDependencies) {
// Skip paths that do not appear to be files (have no extension).
// `fileDependencies` can contain directories and not just files which can
// cause incorrect cache invalidation on rebuilds.
if (!path.extname(dependency)) {
continue;
}
if (data && containingFile && dependency.endsWith(entry)) {
// use containing file if the resource was inline
parent.fileDependencies.add(containingFile);
}
else {
parent.fileDependencies.add(dependency);
}
// Save the dependencies for this resource.
if (filePath) {
const resolvedFile = (0, paths_1.normalizePath)(dependency);
const entry = this._reverseDependencies.get(resolvedFile);
if (entry) {
entry.add(filePath);
}
else {
this._reverseDependencies.set(resolvedFile, new Set([filePath]));
}
if (fileDependencies) {
fileDependencies.add(dependency);
}
else {
fileDependencies = new Set([dependency]);
this._fileDependencies.set(filePath, fileDependencies);
}
}
}
parent.contextDependencies.addAll(childCompilation.contextDependencies);
parent.missingDependencies.addAll(childCompilation.missingDependencies);
parent.buildDependencies.addAll(childCompilation.buildDependencies);
parent.warnings.push(...childCompilation.warnings);
parent.errors.push(...childCompilation.errors);
if (this.assetCache) {
for (const { info, name, source } of childCompilation.getAssets()) {
// Use the originating file as the cache key if present
// Otherwise, generate a cache key based on the generated name
const cacheKey = (_a = info.sourceFilename) !== null && _a !== void 0 ? _a : `!![GENERATED]:${name}`;
this.assetCache.set(cacheKey, { info, name, source });
}
}
}
resolve({
content: finalContent !== null && finalContent !== void 0 ? finalContent : '',
success: ((_b = childCompilation.errors) === null || _b === void 0 ? void 0 : _b.length) === 0,
});
});
});
}
_evaluate(filename, source) {
// Evaluate code
var _a;
// css-loader requires the btoa function to exist to correctly generate inline sourcemaps
const context = {
btoa(input) {
return node_buffer_1.Buffer.from(input).toString('base64');
},
};
try {
vm.runInNewContext(source, context, { filename });
}
catch (_b) {
// Error are propagated through the child compilation.
return null;
}
if (typeof context.resource === 'string') {
return context.resource;
}
else if (typeof ((_a = context.resource) === null || _a === void 0 ? void 0 : _a.default) === 'string') {
return context.resource.default;
}
throw new Error(`The loader "${filename}" didn't return a string.`);
}
async get(filePath) {
var _a;
const normalizedFile = (0, paths_1.normalizePath)(filePath);
let compilationResult = (_a = this.fileCache) === null || _a === void 0 ? void 0 : _a.get(normalizedFile);
if (compilationResult === undefined) {
// cache miss so compile resource
compilationResult = await this._compile(filePath);
// Only cache if compilation was successful
if (this.fileCache && compilationResult.success) {
this.fileCache.set(normalizedFile, compilationResult);
}
}
return compilationResult.content;
}
async process(data, fileExtension, resourceType, containingFile) {
if (data.trim().length === 0) {
return '';
}
const compilationResult = await this._compile(undefined, data, fileExtension, resourceType, containingFile);
return compilationResult.content;
}
}
exports.WebpackResourceLoader = WebpackResourceLoader;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource_loader.js","sourceRoot":"","sources":["../../../../../../../packages/ngtools/webpack/src/resource_loader.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 assert from 'node:assert';\nimport { Buffer } from 'node:buffer';\nimport * as path from 'node:path';\nimport * as vm from 'node:vm';\nimport type { Asset, Compilation } from 'webpack';\nimport { addError } from './ivy/diagnostics';\nimport { normalizePath } from './ivy/paths';\nimport {\n  CompilationWithInlineAngularResource,\n  InlineAngularResourceLoaderPath,\n  InlineAngularResourceSymbol,\n} from './loaders/inline-resource';\nimport { NG_COMPONENT_RESOURCE_QUERY } from './transformers/replace_resources';\n\ninterface CompilationOutput {\n  content: string;\n  map?: string;\n  success: boolean;\n}\n\nexport class WebpackResourceLoader {\n  private _parentCompilation?: Compilation;\n  private _fileDependencies = new Map<string, Set<string>>();\n  private _reverseDependencies = new Map<string, Set<string>>();\n\n  private fileCache?: Map<string, CompilationOutput>;\n  private assetCache?: Map<string, Asset>;\n\n  private modifiedResources = new Set<string>();\n  private outputPathCounter = 1;\n\n  private readonly inlineDataLoaderPath = InlineAngularResourceLoaderPath;\n\n  constructor(shouldCache: boolean) {\n    if (shouldCache) {\n      this.fileCache = new Map();\n      this.assetCache = new Map();\n    }\n  }\n\n  update(parentCompilation: Compilation, changedFiles?: Iterable<string>) {\n    this._parentCompilation = parentCompilation;\n\n    // Update resource cache and modified resources\n    this.modifiedResources.clear();\n\n    if (changedFiles) {\n      for (const changedFile of changedFiles) {\n        const changedFileNormalized = normalizePath(changedFile);\n        this.assetCache?.delete(changedFileNormalized);\n\n        for (const affectedResource of this.getAffectedResources(changedFile)) {\n          const affectedResourceNormalized = normalizePath(affectedResource);\n          this.fileCache?.delete(affectedResourceNormalized);\n          this.modifiedResources.add(affectedResource);\n\n          for (const effectedDependencies of this.getResourceDependencies(\n            affectedResourceNormalized,\n          )) {\n            this.assetCache?.delete(normalizePath(effectedDependencies));\n          }\n        }\n      }\n    } else {\n      this.fileCache?.clear();\n      this.assetCache?.clear();\n    }\n\n    // Re-emit all assets for un-effected files\n    if (this.assetCache) {\n      for (const [, { name, source, info }] of this.assetCache) {\n        this._parentCompilation.emitAsset(name, source, info);\n      }\n    }\n  }\n\n  clearParentCompilation() {\n    this._parentCompilation = undefined;\n  }\n\n  getModifiedResourceFiles() {\n    return this.modifiedResources;\n  }\n\n  getResourceDependencies(filePath: string) {\n    return this._fileDependencies.get(filePath) || [];\n  }\n\n  getAffectedResources(file: string) {\n    return this._reverseDependencies.get(file) || [];\n  }\n\n  setAffectedResources(file: string, resources: Iterable<string>) {\n    this._reverseDependencies.set(file, new Set(resources));\n  }\n\n  // eslint-disable-next-line max-lines-per-function\n  private async _compile(\n    filePath?: string,\n    data?: string,\n    fileExtension?: string,\n    resourceType?: 'style' | 'template',\n    containingFile?: string,\n  ): Promise<CompilationOutput> {\n    if (!this._parentCompilation) {\n      throw new Error('WebpackResourceLoader cannot be used without parentCompilation');\n    }\n\n    const { context, webpack } = this._parentCompilation.compiler;\n    const {\n      EntryPlugin,\n      NormalModule,\n      WebpackError,\n      library,\n      node,\n      sources,\n      util: { createHash },\n    } = webpack;\n\n    const getEntry = (): string => {\n      if (filePath) {\n        return `${filePath}?${NG_COMPONENT_RESOURCE_QUERY}`;\n      } else if (resourceType) {\n        return (\n          // app.component.ts-2.css?ngResource!=!@ngtools/webpack/src/loaders/inline-resource.js!app.component.ts\n          `${containingFile}-${this.outputPathCounter}.${fileExtension}` +\n          `?${NG_COMPONENT_RESOURCE_QUERY}!=!${this.inlineDataLoaderPath}!${containingFile}`\n        );\n      } else if (data) {\n        // Create a special URL for reading the resource from memory\n        return `angular-resource:${resourceType},${createHash('xxhash64')\n          .update(data)\n          .digest('hex')}`;\n      }\n\n      throw new Error(`\"filePath\", \"resourceType\" or \"data\" must be specified.`);\n    };\n\n    const entry = getEntry();\n\n    // Simple sanity check.\n    if (filePath?.match(/\\.[jt]s$/)) {\n      throw new Error(\n        `Cannot use a JavaScript or TypeScript file (${filePath}) in a component's styleUrls or templateUrl.`,\n      );\n    }\n\n    const outputFilePath =\n      filePath ||\n      `${containingFile}-angular-inline--${this.outputPathCounter++}.${\n        resourceType === 'template' ? 'html' : 'css'\n      }`;\n    const outputOptions = {\n      filename: outputFilePath,\n      library: {\n        type: 'var',\n        name: 'resource',\n      },\n    };\n\n    const childCompiler = this._parentCompilation.createChildCompiler(\n      'angular-compiler:resource',\n      outputOptions,\n      [\n        new node.NodeTemplatePlugin(outputOptions),\n        new node.NodeTargetPlugin(),\n        new EntryPlugin(context, entry, { name: 'resource' }),\n        new library.EnableLibraryPlugin('var'),\n      ],\n    );\n\n    childCompiler.hooks.thisCompilation.tap(\n      'angular-compiler',\n      (compilation, { normalModuleFactory }) => {\n        // If no data is provided, the resource will be read from the filesystem\n        if (data !== undefined) {\n          normalModuleFactory.hooks.resolveForScheme\n            .for('angular-resource')\n            .tap('angular-compiler', (resourceData) => {\n              if (filePath) {\n                resourceData.path = filePath;\n                resourceData.resource = filePath;\n              }\n\n              return true;\n            });\n          NormalModule.getCompilationHooks(compilation)\n            .readResourceForScheme.for('angular-resource')\n            .tap('angular-compiler', () => data);\n\n          (compilation as CompilationWithInlineAngularResource)[InlineAngularResourceSymbol] = data;\n        }\n\n        compilation.hooks.additionalAssets.tap('angular-compiler', () => {\n          const asset = compilation.assets[outputFilePath];\n          if (!asset) {\n            return;\n          }\n\n          try {\n            const output = this._evaluate(outputFilePath, asset.source().toString());\n\n            if (typeof output === 'string') {\n              compilation.assets[outputFilePath] = new sources.RawSource(output);\n            }\n          } catch (error) {\n            assert(error instanceof Error, 'catch clause variable is not an Error instance');\n            // Use compilation errors, as otherwise webpack will choke\n            addError(compilation, error.message);\n          }\n        });\n      },\n    );\n\n    let finalContent: string | undefined;\n    childCompiler.hooks.compilation.tap('angular-compiler', (childCompilation) => {\n      childCompilation.hooks.processAssets.tap(\n        { name: 'angular-compiler', stage: webpack.Compilation.PROCESS_ASSETS_STAGE_REPORT },\n        () => {\n          finalContent = childCompilation.assets[outputFilePath]?.source().toString();\n\n          for (const { files } of childCompilation.chunks) {\n            for (const file of files) {\n              childCompilation.deleteAsset(file);\n            }\n          }\n        },\n      );\n    });\n\n    return new Promise<CompilationOutput>((resolve, reject) => {\n      childCompiler.runAsChild((error, _, childCompilation) => {\n        if (error) {\n          reject(error);\n\n          return;\n        } else if (!childCompilation) {\n          reject(new Error('Unknown child compilation error'));\n\n          return;\n        }\n\n        // Workaround to attempt to reduce memory usage of child compilations.\n        // This removes the child compilation from the main compilation and manually propagates\n        // all dependencies, warnings, and errors.\n        const parent = childCompiler.parentCompilation;\n        if (parent) {\n          parent.children = parent.children.filter((child) => child !== childCompilation);\n          let fileDependencies: Set<string> | undefined;\n\n          for (const dependency of childCompilation.fileDependencies) {\n            // Skip paths that do not appear to be files (have no extension).\n            // `fileDependencies` can contain directories and not just files which can\n            // cause incorrect cache invalidation on rebuilds.\n            if (!path.extname(dependency)) {\n              continue;\n            }\n\n            if (data && containingFile && dependency.endsWith(entry)) {\n              // use containing file if the resource was inline\n              parent.fileDependencies.add(containingFile);\n            } else {\n              parent.fileDependencies.add(dependency);\n            }\n\n            // Save the dependencies for this resource.\n            if (filePath) {\n              const resolvedFile = normalizePath(dependency);\n              const entry = this._reverseDependencies.get(resolvedFile);\n              if (entry) {\n                entry.add(filePath);\n              } else {\n                this._reverseDependencies.set(resolvedFile, new Set([filePath]));\n              }\n\n              if (fileDependencies) {\n                fileDependencies.add(dependency);\n              } else {\n                fileDependencies = new Set([dependency]);\n                this._fileDependencies.set(filePath, fileDependencies);\n              }\n            }\n          }\n\n          parent.contextDependencies.addAll(childCompilation.contextDependencies);\n          parent.missingDependencies.addAll(childCompilation.missingDependencies);\n          parent.buildDependencies.addAll(childCompilation.buildDependencies);\n\n          parent.warnings.push(...childCompilation.warnings);\n          parent.errors.push(...childCompilation.errors);\n\n          if (this.assetCache) {\n            for (const { info, name, source } of childCompilation.getAssets()) {\n              // Use the originating file as the cache key if present\n              // Otherwise, generate a cache key based on the generated name\n              const cacheKey = info.sourceFilename ?? `!![GENERATED]:${name}`;\n\n              this.assetCache.set(cacheKey, { info, name, source });\n            }\n          }\n        }\n\n        resolve({\n          content: finalContent ?? '',\n          success: childCompilation.errors?.length === 0,\n        });\n      });\n    });\n  }\n\n  private _evaluate(filename: string, source: string): string | null {\n    // Evaluate code\n\n    // css-loader requires the btoa function to exist to correctly generate inline sourcemaps\n    const context: { btoa: (input: string) => string; resource?: string | { default?: string } } = {\n      btoa(input) {\n        return Buffer.from(input).toString('base64');\n      },\n    };\n\n    try {\n      vm.runInNewContext(source, context, { filename });\n    } catch {\n      // Error are propagated through the child compilation.\n      return null;\n    }\n\n    if (typeof context.resource === 'string') {\n      return context.resource;\n    } else if (typeof context.resource?.default === 'string') {\n      return context.resource.default;\n    }\n\n    throw new Error(`The loader \"${filename}\" didn't return a string.`);\n  }\n\n  async get(filePath: string): Promise<string> {\n    const normalizedFile = normalizePath(filePath);\n    let compilationResult = this.fileCache?.get(normalizedFile);\n\n    if (compilationResult === undefined) {\n      // cache miss so compile resource\n      compilationResult = await this._compile(filePath);\n\n      // Only cache if compilation was successful\n      if (this.fileCache && compilationResult.success) {\n        this.fileCache.set(normalizedFile, compilationResult);\n      }\n    }\n\n    return compilationResult.content;\n  }\n\n  async process(\n    data: string,\n    fileExtension: string | undefined,\n    resourceType: 'template' | 'style',\n    containingFile?: string,\n  ): Promise<string> {\n    if (data.trim().length === 0) {\n      return '';\n    }\n\n    const compilationResult = await this._compile(\n      undefined,\n      data,\n      fileExtension,\n      resourceType,\n      containingFile,\n    );\n\n    return compilationResult.content;\n  }\n}\n"]}
;