source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/execution/create_compile_function.js@ 6a3a178

Last change on this file since 6a3a178 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 13.5 KB
Line 
1(function (factory) {
2 if (typeof module === "object" && typeof module.exports === "object") {
3 var v = factory(require, exports);
4 if (v !== undefined) module.exports = v;
5 }
6 else if (typeof define === "function" && define.amd) {
7 define("@angular/compiler-cli/ngcc/src/execution/create_compile_function", ["require", "exports", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/packages/entry_point_bundle", "@angular/compiler-cli/ngcc/src/packages/source_file_cache"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.getCreateCompileFn = void 0;
13 /**
14 * @license
15 * Copyright Google LLC All Rights Reserved.
16 *
17 * Use of this source code is governed by an MIT-style license that can be
18 * found in the LICENSE file at https://angular.io/license
19 */
20 var ts = require("typescript");
21 var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
22 var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
23 var entry_point_bundle_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point_bundle");
24 var source_file_cache_1 = require("@angular/compiler-cli/ngcc/src/packages/source_file_cache");
25 /**
26 * The function for creating the `compile()` function.
27 */
28 function getCreateCompileFn(fileSystem, logger, fileWriter, enableI18nLegacyMessageIdFormat, tsConfig, pathMappings) {
29 return function (beforeWritingFiles, onTaskCompleted) {
30 var Transformer = require('../packages/transformer').Transformer;
31 var transformer = new Transformer(fileSystem, logger, tsConfig);
32 var sharedFileCache = new source_file_cache_1.SharedFileCache(fileSystem);
33 var moduleResolutionCache = source_file_cache_1.createModuleResolutionCache(fileSystem);
34 return function (task) {
35 var entryPoint = task.entryPoint, formatProperty = task.formatProperty, formatPropertiesToMarkAsProcessed = task.formatPropertiesToMarkAsProcessed, processDts = task.processDts;
36 var isCore = entryPoint.name === '@angular/core'; // Are we compiling the Angular core?
37 var packageJson = entryPoint.packageJson;
38 var formatPath = packageJson[formatProperty];
39 var format = entry_point_1.getEntryPointFormat(fileSystem, entryPoint, formatProperty);
40 // All properties listed in `propertiesToProcess` are guaranteed to point to a format-path
41 // (i.e. they are defined in `entryPoint.packageJson`). Furthermore, they are also guaranteed
42 // to be among `SUPPORTED_FORMAT_PROPERTIES`.
43 // Based on the above, `formatPath` should always be defined and `getEntryPointFormat()`
44 // should always return a format here (and not `undefined`) unless `formatPath` points to a
45 // missing or empty file.
46 if (!formatPath || !format) {
47 onTaskCompleted(task, 1 /* Failed */, "property `" + formatProperty + "` pointing to a missing or empty file: " + formatPath);
48 return;
49 }
50 logger.info("Compiling " + entryPoint.name + " : " + formatProperty + " as " + format);
51 var bundle = entry_point_bundle_1.makeEntryPointBundle(fileSystem, entryPoint, sharedFileCache, moduleResolutionCache, formatPath, isCore, format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);
52 var result = transformer.transform(bundle);
53 if (result.success) {
54 if (result.diagnostics.length > 0) {
55 logger.warn(diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host)));
56 }
57 var writeBundle = function () {
58 fileWriter.writeBundle(bundle, result.transformedFiles, formatPropertiesToMarkAsProcessed);
59 logger.debug(" Successfully compiled " + entryPoint.name + " : " + formatProperty);
60 onTaskCompleted(task, 0 /* Processed */, null);
61 };
62 var beforeWritingResult = beforeWritingFiles(result.transformedFiles);
63 return (beforeWritingResult instanceof Promise) ?
64 beforeWritingResult.then(writeBundle) :
65 writeBundle();
66 }
67 else {
68 var errors = diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host));
69 onTaskCompleted(task, 1 /* Failed */, "compilation errors:\n" + errors);
70 }
71 };
72 };
73 }
74 exports.getCreateCompileFn = getCreateCompileFn;
75});
76//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_compile_function.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/create_compile_function.ts"],"names":[],"mappings":";;;;;;;;;;;;IACA;;;;;;OAMG;IACH,+BAAiC;IAEjC,2EAAuE;IAIvE,mFAA4D;IAC5D,iGAAoE;IACpE,+FAA2F;IAO3F;;OAEG;IACH,SAAgB,kBAAkB,CAC9B,UAAsB,EAAE,MAAc,EAAE,UAAsB,EAC9D,+BAAwC,EAAE,QAAkC,EAC5E,YAAoC;QACtC,OAAO,UAAC,kBAAkB,EAAE,eAAe;YAClC,IAAA,WAAW,GAAI,OAAO,CAAC,yBAAyB,CAAC,YAAtC,CAAuC;YACzD,IAAM,WAAW,GAAG,IAAI,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;YAClE,IAAM,eAAe,GAAG,IAAI,mCAAe,CAAC,UAAU,CAAC,CAAC;YACxD,IAAM,qBAAqB,GAAG,+CAA2B,CAAC,UAAU,CAAC,CAAC;YAEtE,OAAO,UAAC,IAAU;gBACT,IAAA,UAAU,GAAmE,IAAI,WAAvE,EAAE,cAAc,GAAmD,IAAI,eAAvD,EAAE,iCAAiC,GAAgB,IAAI,kCAApB,EAAE,UAAU,GAAI,IAAI,WAAR,CAAS;gBAEzF,IAAM,MAAM,GAAG,UAAU,CAAC,IAAI,KAAK,eAAe,CAAC,CAAE,qCAAqC;gBAC1F,IAAM,WAAW,GAAG,UAAU,CAAC,WAAW,CAAC;gBAC3C,IAAM,UAAU,GAAG,WAAW,CAAC,cAAc,CAAC,CAAC;gBAC/C,IAAM,MAAM,GAAG,iCAAmB,CAAC,UAAU,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC;gBAE3E,0FAA0F;gBAC1F,6FAA6F;gBAC7F,6CAA6C;gBAC7C,wFAAwF;gBACxF,2FAA2F;gBAC3F,yBAAyB;gBACzB,IAAI,CAAC,UAAU,IAAI,CAAC,MAAM,EAAE;oBAC1B,eAAe,CACX,IAAI,kBACJ,eAAc,cAAc,+CAA2C,UAAY,CAAC,CAAC;oBACzF,OAAO;iBACR;gBAED,MAAM,CAAC,IAAI,CAAC,eAAa,UAAU,CAAC,IAAI,WAAM,cAAc,YAAO,MAAQ,CAAC,CAAC;gBAE7E,IAAM,MAAM,GAAG,yCAAoB,CAC/B,UAAU,EAAE,UAAU,EAAE,eAAe,EAAE,qBAAqB,EAAE,UAAU,EAAE,MAAM,EAClF,MAAM,EAAE,UAAU,EAAE,YAAY,EAAE,IAAI,EAAE,+BAA+B,CAAC,CAAC;gBAE7E,IAAM,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC7C,IAAI,MAAM,CAAC,OAAO,EAAE;oBAClB,IAAI,MAAM,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;wBACjC,MAAM,CAAC,IAAI,CAAC,qCAAuB,CAC/B,EAAE,CAAC,oCAAoC,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qBACpF;oBAED,IAAM,WAAW,GAAG;wBAClB,UAAU,CAAC,WAAW,CAClB,MAAM,EAAE,MAAM,CAAC,gBAAgB,EAAE,iCAAiC,CAAC,CAAC;wBAExE,MAAM,CAAC,KAAK,CAAC,6BAA2B,UAAU,CAAC,IAAI,WAAM,cAAgB,CAAC,CAAC;wBAC/E,eAAe,CAAC,IAAI,qBAAmC,IAAI,CAAC,CAAC;oBAC/D,CAAC,CAAC;oBAEF,IAAM,mBAAmB,GAAG,kBAAkB,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;oBAExE,OAAO,CAAC,mBAAmB,YAAY,OAAO,CAAC,CAAC,CAAC;wBAC7C,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAA0C,CAAA,CAAC;wBAC/E,WAAW,EAAE,CAAC;iBACnB;qBAAM;oBACL,IAAM,MAAM,GAAG,qCAAuB,CAClC,EAAE,CAAC,oCAAoC,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;oBAClF,eAAe,CAAC,IAAI,kBAAgC,0BAAwB,MAAQ,CAAC,CAAC;iBACvF;YACH,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAhED,gDAgEC","sourcesContent":["\n/**\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 */\nimport * as ts from 'typescript';\n\nimport {replaceTsWithNgInErrors} from '../../../src/ngtsc/diagnostics';\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {getEntryPointFormat} from '../packages/entry_point';\nimport {makeEntryPointBundle} from '../packages/entry_point_bundle';\nimport {createModuleResolutionCache, SharedFileCache} from '../packages/source_file_cache';\nimport {PathMappings} from '../path_mappings';\nimport {FileWriter} from '../writing/file_writer';\n\nimport {CreateCompileFn} from './api';\nimport {Task, TaskProcessingOutcome} from './tasks/api';\n\n/**\n * The function for creating the `compile()` function.\n */\nexport function getCreateCompileFn(\n    fileSystem: FileSystem, logger: Logger, fileWriter: FileWriter,\n    enableI18nLegacyMessageIdFormat: boolean, tsConfig: ParsedConfiguration|null,\n    pathMappings: PathMappings|undefined): CreateCompileFn {\n  return (beforeWritingFiles, onTaskCompleted) => {\n    const {Transformer} = require('../packages/transformer');\n    const transformer = new Transformer(fileSystem, logger, tsConfig);\n    const sharedFileCache = new SharedFileCache(fileSystem);\n    const moduleResolutionCache = createModuleResolutionCache(fileSystem);\n\n    return (task: Task) => {\n      const {entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts} = task;\n\n      const isCore = entryPoint.name === '@angular/core';  // Are we compiling the Angular core?\n      const packageJson = entryPoint.packageJson;\n      const formatPath = packageJson[formatProperty];\n      const format = getEntryPointFormat(fileSystem, entryPoint, formatProperty);\n\n      // All properties listed in `propertiesToProcess` are guaranteed to point to a format-path\n      // (i.e. they are defined in `entryPoint.packageJson`). Furthermore, they are also guaranteed\n      // to be among `SUPPORTED_FORMAT_PROPERTIES`.\n      // Based on the above, `formatPath` should always be defined and `getEntryPointFormat()`\n      // should always return a format here (and not `undefined`) unless `formatPath` points to a\n      // missing or empty file.\n      if (!formatPath || !format) {\n        onTaskCompleted(\n            task, TaskProcessingOutcome.Failed,\n            `property \\`${formatProperty}\\` pointing to a missing or empty file: ${formatPath}`);\n        return;\n      }\n\n      logger.info(`Compiling ${entryPoint.name} : ${formatProperty} as ${format}`);\n\n      const bundle = makeEntryPointBundle(\n          fileSystem, entryPoint, sharedFileCache, moduleResolutionCache, formatPath, isCore,\n          format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);\n\n      const result = transformer.transform(bundle);\n      if (result.success) {\n        if (result.diagnostics.length > 0) {\n          logger.warn(replaceTsWithNgInErrors(\n              ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host)));\n        }\n\n        const writeBundle = () => {\n          fileWriter.writeBundle(\n              bundle, result.transformedFiles, formatPropertiesToMarkAsProcessed);\n\n          logger.debug(`  Successfully compiled ${entryPoint.name} : ${formatProperty}`);\n          onTaskCompleted(task, TaskProcessingOutcome.Processed, null);\n        };\n\n        const beforeWritingResult = beforeWritingFiles(result.transformedFiles);\n\n        return (beforeWritingResult instanceof Promise) ?\n            beforeWritingResult.then(writeBundle) as ReturnType<typeof beforeWritingFiles>:\n            writeBundle();\n      } else {\n        const errors = replaceTsWithNgInErrors(\n            ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host));\n        onTaskCompleted(task, TaskProcessingOutcome.Failed, `compilation errors:\\n${errors}`);\n      }\n    };\n  };\n}\n"]}
Note: See TracBrowser for help on using the repository browser.