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/resource_loader.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;
};
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) {
        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);
                this.assetCache?.delete(changedFileNormalized);
                for (const affectedResource of this.getAffectedResources(changedFile)) {
                    const affectedResourceNormalized = (0, paths_1.normalizePath)(affectedResource);
                    this.fileCache?.delete(affectedResourceNormalized);
                    this.modifiedResources.add(affectedResource);
                    for (const effectedDependencies of this.getResourceDependencies(affectedResourceNormalized)) {
                        this.assetCache?.delete((0, paths_1.normalizePath)(effectedDependencies));
                    }
                }
            }
        }
        else {
            this.fileCache?.clear();
            this.assetCache?.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, 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?.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(),
            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 }, () => {
                finalContent = childCompilation.assets[outputFilePath]?.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) => {
                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 = info.sourceFilename ?? `!![GENERATED]:${name}`;
                            this.assetCache.set(cacheKey, { info, name, source });
                        }
                    }
                }
                resolve({
                    content: finalContent ?? '',
                    success: childCompilation.errors?.length === 0,
                });
            });
        });
    }
    _evaluate(filename, source) {
        // Evaluate code
        // 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 {
            // Error are propagated through the child compilation.
            return null;
        }
        if (typeof context.resource === 'string') {
            return context.resource;
        }
        else if (typeof context.resource?.default === 'string') {
            return context.resource.default;
        }
        throw new Error(`The loader "${filename}" didn't return a string.`);
    }
    async get(filePath) {
        const normalizedFile = (0, paths_1.normalizePath)(filePath);
        let compilationResult = this.fileCache?.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      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(),\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"]}