@angular/localize 10.1.4 → 10.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/bundles/localize-init.umd.js +1 -1
  2. package/bundles/localize-init.umd.min.js +1 -1
  3. package/bundles/localize-init.umd.min.js.map +1 -1
  4. package/bundles/localize.umd.js +1 -1
  5. package/bundles/localize.umd.min.js +1 -1
  6. package/bundles/localize.umd.min.js.map +1 -1
  7. package/fesm2015/init.js +1 -1
  8. package/fesm2015/localize.js +1 -1
  9. package/init.d.ts +1 -1
  10. package/package.json +3 -3
  11. package/schematics/ng-add/index.js +1 -1
  12. package/src/tools/src/diagnostics.d.ts +2 -0
  13. package/src/tools/src/diagnostics.js +3 -1
  14. package/src/tools/src/extract/extraction.d.ts +2 -0
  15. package/src/tools/src/extract/extraction.js +5 -3
  16. package/src/tools/src/extract/main.d.ts +7 -3
  17. package/src/tools/src/extract/main.js +10 -10
  18. package/src/tools/src/extract/source_files/es2015_extract_plugin.d.ts +2 -1
  19. package/src/tools/src/extract/source_files/es2015_extract_plugin.js +5 -12
  20. package/src/tools/src/extract/source_files/es5_extract_plugin.d.ts +2 -1
  21. package/src/tools/src/extract/source_files/es5_extract_plugin.js +5 -12
  22. package/src/tools/src/extract/translation_files/utils.d.ts +22 -0
  23. package/src/tools/src/extract/translation_files/utils.js +53 -0
  24. package/src/tools/src/extract/translation_files/xliff1_translation_serializer.d.ts +4 -2
  25. package/src/tools/src/extract/translation_files/xliff1_translation_serializer.js +95 -17
  26. package/src/tools/src/extract/translation_files/xliff2_translation_serializer.d.ts +4 -2
  27. package/src/tools/src/extract/translation_files/xliff2_translation_serializer.js +67 -20
  28. package/src/tools/src/extract/translation_files/xmb_translation_serializer.d.ts +4 -2
  29. package/src/tools/src/extract/translation_files/xmb_translation_serializer.js +6 -3
  30. package/src/tools/src/source_file_utils.d.ts +48 -21
  31. package/src/tools/src/source_file_utils.js +56 -17
  32. package/src/tools/src/translate/source_files/es2015_translate_plugin.d.ts +8 -1
  33. package/src/tools/src/translate/source_files/es2015_translate_plugin.js +19 -4
  34. package/src/tools/src/translate/source_files/es5_translate_plugin.d.ts +8 -1
  35. package/src/tools/src/translate/source_files/es5_translate_plugin.js +20 -5
  36. package/src/tools/src/translate/source_files/locale_plugin.d.ts +1 -0
  37. package/src/tools/src/translate/source_files/locale_plugin.js +2 -1
  38. package/src/tools/src/translate/source_files/source_file_translation_handler.js +3 -3
  39. package/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser.d.ts +1 -0
  40. package/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser.js +2 -1
  41. package/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser.d.ts +1 -0
  42. package/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser.js +2 -1
  43. package/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser.d.ts +1 -0
  44. package/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser.js +2 -1
  45. package/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser.d.ts +1 -0
  46. package/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser.js +2 -1
@@ -1,4 +1,12 @@
1
1
  /// <amd-module name="@angular/localize/src/tools/src/source_file_utils" />
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ import { FileSystem } from '@angular/compiler-cli/src/ngtsc/file_system';
2
10
  import { ɵParsedTranslation, ɵSourceLocation } from '@angular/localize';
3
11
  import { NodePath } from '@babel/traverse';
4
12
  import * as t from '@babel/types';
@@ -19,13 +27,16 @@ export declare function isLocalize(expression: NodePath, localizeName: string):
19
27
  export declare function isNamedIdentifier(expression: NodePath, name: string): expression is NodePath<t.Identifier>;
20
28
  /**
21
29
  * Is the given `identifier` declared globally.
30
+ *
22
31
  * @param identifier The identifier to check.
32
+ * @publicApi used by CLI
23
33
  */
24
34
  export declare function isGlobalIdentifier(identifier: NodePath<t.Identifier>): boolean;
25
35
  /**
26
36
  * Build a translated expression to replace the call to `$localize`.
27
37
  * @param messageParts The static parts of the message.
28
38
  * @param substitutions The expressions to substitute into the message.
39
+ * @publicApi used by CLI
29
40
  */
30
41
  export declare function buildLocalizeReplacement(messageParts: TemplateStringsArray, substitutions: readonly t.Expression[]): t.Expression;
31
42
  /**
@@ -35,23 +46,38 @@ export declare function buildLocalizeReplacement(messageParts: TemplateStringsAr
35
46
  * to a helper function like `__makeTemplateObject`.
36
47
  *
37
48
  * @param call The AST node of the call to process.
49
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
50
+ * the "current" FileSystem.
51
+ * @publicApi used by CLI
52
+ */
53
+ export declare function unwrapMessagePartsFromLocalizeCall(call: NodePath<t.CallExpression>, fs?: FileSystem): [TemplateStringsArray, (ɵSourceLocation | undefined)[]];
54
+ /**
55
+ * Parse the localize call expression to extract the arguments that hold the substition expressions.
56
+ *
57
+ * @param call The AST node of the call to process.
58
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
59
+ * the "current" FileSystem.
60
+ * @publicApi used by CLI
38
61
  */
39
- export declare function unwrapMessagePartsFromLocalizeCall(call: NodePath<t.CallExpression>): [
40
- TemplateStringsArray,
41
- (ɵSourceLocation | undefined)[]
42
- ];
43
- export declare function unwrapSubstitutionsFromLocalizeCall(call: NodePath<t.CallExpression>): [
44
- t.Expression[],
45
- (ɵSourceLocation | undefined)[]
46
- ];
47
- export declare function unwrapMessagePartsFromTemplateLiteral(elements: NodePath<t.TemplateElement>[]): [
48
- TemplateStringsArray,
49
- (ɵSourceLocation | undefined)[]
50
- ];
51
- export declare function unwrapExpressionsFromTemplateLiteral(quasi: NodePath<t.TemplateLiteral>): [
52
- t.Expression[],
53
- (ɵSourceLocation | undefined)[]
54
- ];
62
+ export declare function unwrapSubstitutionsFromLocalizeCall(call: NodePath<t.CallExpression>, fs?: FileSystem): [t.Expression[], (ɵSourceLocation | undefined)[]];
63
+ /**
64
+ * Parse the tagged template literal to extract the message parts.
65
+ *
66
+ * @param elements The elements of the template literal to process.
67
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
68
+ * the "current" FileSystem.
69
+ * @publicApi used by CLI
70
+ */
71
+ export declare function unwrapMessagePartsFromTemplateLiteral(elements: NodePath<t.TemplateElement>[], fs?: FileSystem): [TemplateStringsArray, (ɵSourceLocation | undefined)[]];
72
+ /**
73
+ * Parse the tagged template literal to extract the interpolation expressions.
74
+ *
75
+ * @param quasi The AST node of the template literal to process.
76
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
77
+ * the "current" FileSystem.
78
+ * @publicApi used by CLI
79
+ */
80
+ export declare function unwrapExpressionsFromTemplateLiteral(quasi: NodePath<t.TemplateLiteral>, fs?: FileSystem): [t.Expression[], (ɵSourceLocation | undefined)[]];
55
81
  /**
56
82
  * Wrap the given `expression` in parentheses if it is a binary expression.
57
83
  *
@@ -62,12 +88,12 @@ export declare function unwrapExpressionsFromTemplateLiteral(quasi: NodePath<t.T
62
88
  export declare function wrapInParensIfNecessary(expression: t.Expression): t.Expression;
63
89
  /**
64
90
  * Extract the string values from an `array` of string literals.
91
+ *
65
92
  * @param array The array to unwrap.
93
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
94
+ * the "current" FileSystem.
66
95
  */
67
- export declare function unwrapStringLiteralArray(array: NodePath<t.Expression>): [
68
- string[],
69
- (ɵSourceLocation | undefined)[]
70
- ];
96
+ export declare function unwrapStringLiteralArray(array: NodePath<t.Expression>, fs?: FileSystem): [string[], (ɵSourceLocation | undefined)[]];
71
97
  /**
72
98
  * This expression is believed to be a call to a "lazy-load" template object helper function.
73
99
  * This is expected to be of the form:
@@ -107,6 +133,7 @@ export interface TranslatePluginOptions {
107
133
  * Translate the text of the given message, using the given translations.
108
134
  *
109
135
  * Logs as warning if the translation is not available
136
+ * @publicApi used by CLI
110
137
  */
111
138
  export declare function translate(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, messageParts: TemplateStringsArray, substitutions: readonly any[], missingTranslation: DiagnosticHandlingStrategy): [TemplateStringsArray, readonly any[]];
112
139
  export declare class BabelParseError extends Error {
@@ -116,5 +143,5 @@ export declare class BabelParseError extends Error {
116
143
  }
117
144
  export declare function isBabelParseError(e: any): e is BabelParseError;
118
145
  export declare function buildCodeFrameError(path: NodePath, e: BabelParseError): string;
119
- export declare function getLocation(startPath: NodePath, endPath?: NodePath): ɵSourceLocation | undefined;
146
+ export declare function getLocation(fs: FileSystem, startPath: NodePath, endPath?: NodePath): ɵSourceLocation | undefined;
120
147
  export declare function serializeLocationPosition(location: ɵSourceLocation): string;
@@ -43,7 +43,9 @@
43
43
  exports.isNamedIdentifier = isNamedIdentifier;
44
44
  /**
45
45
  * Is the given `identifier` declared globally.
46
+ *
46
47
  * @param identifier The identifier to check.
48
+ * @publicApi used by CLI
47
49
  */
48
50
  function isGlobalIdentifier(identifier) {
49
51
  return !identifier.scope || !identifier.scope.hasBinding(identifier.node.name);
@@ -53,6 +55,7 @@
53
55
  * Build a translated expression to replace the call to `$localize`.
54
56
  * @param messageParts The static parts of the message.
55
57
  * @param substitutions The expressions to substitute into the message.
58
+ * @publicApi used by CLI
56
59
  */
57
60
  function buildLocalizeReplacement(messageParts, substitutions) {
58
61
  var mappedString = t.stringLiteral(messageParts[0]);
@@ -71,8 +74,12 @@
71
74
  * to a helper function like `__makeTemplateObject`.
72
75
  *
73
76
  * @param call The AST node of the call to process.
77
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
78
+ * the "current" FileSystem.
79
+ * @publicApi used by CLI
74
80
  */
75
- function unwrapMessagePartsFromLocalizeCall(call) {
81
+ function unwrapMessagePartsFromLocalizeCall(call, fs) {
82
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
76
83
  var cooked = call.get('arguments')[0];
77
84
  if (cooked === undefined) {
78
85
  throw new BabelParseError(call.node, '`$localize` called without any arguments.');
@@ -130,23 +137,41 @@
130
137
  // If there is no second argument then assume that raw and cooked are the same
131
138
  raw = arg2 !== undefined ? arg2 : cooked;
132
139
  }
133
- var _b = tslib_1.__read(unwrapStringLiteralArray(cooked), 1), cookedStrings = _b[0];
134
- var _c = tslib_1.__read(unwrapStringLiteralArray(raw), 2), rawStrings = _c[0], rawLocations = _c[1];
140
+ var _b = tslib_1.__read(unwrapStringLiteralArray(cooked, fs), 1), cookedStrings = _b[0];
141
+ var _c = tslib_1.__read(unwrapStringLiteralArray(raw, fs), 2), rawStrings = _c[0], rawLocations = _c[1];
135
142
  return [localize_1.ɵmakeTemplateObject(cookedStrings, rawStrings), rawLocations];
136
143
  }
137
144
  exports.unwrapMessagePartsFromLocalizeCall = unwrapMessagePartsFromLocalizeCall;
138
- function unwrapSubstitutionsFromLocalizeCall(call) {
145
+ /**
146
+ * Parse the localize call expression to extract the arguments that hold the substition expressions.
147
+ *
148
+ * @param call The AST node of the call to process.
149
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
150
+ * the "current" FileSystem.
151
+ * @publicApi used by CLI
152
+ */
153
+ function unwrapSubstitutionsFromLocalizeCall(call, fs) {
154
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
139
155
  var expressions = call.get('arguments').splice(1);
140
156
  if (!isArrayOfExpressions(expressions)) {
141
157
  var badExpression = expressions.find(function (expression) { return !expression.isExpression(); });
142
158
  throw new BabelParseError(badExpression.node, 'Invalid substitutions for `$localize` (expected all substitution arguments to be expressions).');
143
159
  }
144
160
  return [
145
- expressions.map(function (path) { return path.node; }), expressions.map(function (expression) { return getLocation(expression); })
161
+ expressions.map(function (path) { return path.node; }), expressions.map(function (expression) { return getLocation(fs, expression); })
146
162
  ];
147
163
  }
148
164
  exports.unwrapSubstitutionsFromLocalizeCall = unwrapSubstitutionsFromLocalizeCall;
149
- function unwrapMessagePartsFromTemplateLiteral(elements) {
165
+ /**
166
+ * Parse the tagged template literal to extract the message parts.
167
+ *
168
+ * @param elements The elements of the template literal to process.
169
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
170
+ * the "current" FileSystem.
171
+ * @publicApi used by CLI
172
+ */
173
+ function unwrapMessagePartsFromTemplateLiteral(elements, fs) {
174
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
150
175
  var cooked = elements.map(function (q) {
151
176
  if (q.node.value.cooked === undefined) {
152
177
  throw new BabelParseError(q.node, "Unexpected undefined message part in \"" + elements.map(function (q) { return q.node.value.cooked; }) + "\"");
@@ -154,12 +179,21 @@
154
179
  return q.node.value.cooked;
155
180
  });
156
181
  var raw = elements.map(function (q) { return q.node.value.raw; });
157
- var locations = elements.map(function (q) { return getLocation(q); });
182
+ var locations = elements.map(function (q) { return getLocation(fs, q); });
158
183
  return [localize_1.ɵmakeTemplateObject(cooked, raw), locations];
159
184
  }
160
185
  exports.unwrapMessagePartsFromTemplateLiteral = unwrapMessagePartsFromTemplateLiteral;
161
- function unwrapExpressionsFromTemplateLiteral(quasi) {
162
- return [quasi.node.expressions, quasi.get('expressions').map(function (e) { return getLocation(e); })];
186
+ /**
187
+ * Parse the tagged template literal to extract the interpolation expressions.
188
+ *
189
+ * @param quasi The AST node of the template literal to process.
190
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
191
+ * the "current" FileSystem.
192
+ * @publicApi used by CLI
193
+ */
194
+ function unwrapExpressionsFromTemplateLiteral(quasi, fs) {
195
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
196
+ return [quasi.node.expressions, quasi.get('expressions').map(function (e) { return getLocation(fs, e); })];
163
197
  }
164
198
  exports.unwrapExpressionsFromTemplateLiteral = unwrapExpressionsFromTemplateLiteral;
165
199
  /**
@@ -180,14 +214,18 @@
180
214
  exports.wrapInParensIfNecessary = wrapInParensIfNecessary;
181
215
  /**
182
216
  * Extract the string values from an `array` of string literals.
217
+ *
183
218
  * @param array The array to unwrap.
219
+ * @param fs The file system to use when computing source-map paths. If not provided then it uses
220
+ * the "current" FileSystem.
184
221
  */
185
- function unwrapStringLiteralArray(array) {
222
+ function unwrapStringLiteralArray(array, fs) {
223
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
186
224
  if (!isStringLiteralArray(array.node)) {
187
225
  throw new BabelParseError(array.node, 'Unexpected messageParts for `$localize` (expected an array of strings).');
188
226
  }
189
227
  var elements = array.get('elements');
190
- return [elements.map(function (str) { return str.node.value; }), elements.map(function (str) { return getLocation(str); })];
228
+ return [elements.map(function (str) { return str.node.value; }), elements.map(function (str) { return getLocation(fs, str); })];
191
229
  }
192
230
  exports.unwrapStringLiteralArray = unwrapStringLiteralArray;
193
231
  /**
@@ -296,6 +334,7 @@
296
334
  * Translate the text of the given message, using the given translations.
297
335
  *
298
336
  * Logs as warning if the translation is not available
337
+ * @publicApi used by CLI
299
338
  */
300
339
  function translate(diagnostics, translations, messageParts, substitutions, missingTranslation) {
301
340
  try {
@@ -338,13 +377,13 @@
338
377
  return filename + ": " + message;
339
378
  }
340
379
  exports.buildCodeFrameError = buildCodeFrameError;
341
- function getLocation(startPath, endPath) {
380
+ function getLocation(fs, startPath, endPath) {
342
381
  var startLocation = startPath.node.loc;
343
- var file = getFileFromPath(startPath);
382
+ var file = getFileFromPath(fs, startPath);
344
383
  if (!startLocation || !file) {
345
384
  return undefined;
346
385
  }
347
- var endLocation = endPath && getFileFromPath(endPath) === file && endPath.node.loc || startLocation;
386
+ var endLocation = endPath && getFileFromPath(fs, endPath) === file && endPath.node.loc || startLocation;
348
387
  return {
349
388
  start: getLineAndColumn(startLocation.start),
350
389
  end: getLineAndColumn(endLocation.end),
@@ -360,11 +399,11 @@
360
399
  return "" + (location.start.line + 1) + endLineString;
361
400
  }
362
401
  exports.serializeLocationPosition = serializeLocationPosition;
363
- function getFileFromPath(path) {
402
+ function getFileFromPath(fs, path) {
364
403
  var _a;
365
404
  var opts = path === null || path === void 0 ? void 0 : path.hub.file.opts;
366
405
  return (opts === null || opts === void 0 ? void 0 : opts.filename) ?
367
- file_system_1.resolve((_a = opts.generatorOpts.sourceRoot) !== null && _a !== void 0 ? _a : opts.cwd, file_system_1.relative(opts.cwd, opts.filename)) :
406
+ fs.resolve((_a = opts.generatorOpts.sourceRoot) !== null && _a !== void 0 ? _a : opts.cwd, fs.relative(opts.cwd, opts.filename)) :
368
407
  null;
369
408
  }
370
409
  function getLineAndColumn(loc) {
@@ -378,4 +417,4 @@
378
417
  return path.hub.file.code.substring(path.node.start, path.node.end);
379
418
  }
380
419
  });
381
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/tools/src/source_file_utils.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 */\nimport {AbsoluteFsPath, relative, resolve} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {ɵisMissingTranslationError, ɵmakeTemplateObject, ɵParsedTranslation, ɵSourceLocation, ɵtranslate} from '@angular/localize';\nimport {NodePath} from '@babel/traverse';\nimport * as t from '@babel/types';\n\nimport {DiagnosticHandlingStrategy, Diagnostics} from './diagnostics';\n\n/**\n * Is the given `expression` the global `$localize` identifier?\n *\n * @param expression The expression to check.\n * @param localizeName The configured name of `$localize`.\n */\nexport function isLocalize(\n    expression: NodePath, localizeName: string): expression is NodePath<t.Identifier> {\n  return isNamedIdentifier(expression, localizeName) && isGlobalIdentifier(expression);\n}\n\n/**\n * Is the given `expression` an identifier with the correct `name`?\n *\n * @param expression The expression to check.\n * @param name The name of the identifier we are looking for.\n */\nexport function isNamedIdentifier(\n    expression: NodePath, name: string): expression is NodePath<t.Identifier> {\n  return expression.isIdentifier() && expression.node.name === name;\n}\n\n/**\n * Is the given `identifier` declared globally.\n * @param identifier The identifier to check.\n */\nexport function isGlobalIdentifier(identifier: NodePath<t.Identifier>) {\n  return !identifier.scope || !identifier.scope.hasBinding(identifier.node.name);\n}\n\n/**\n * Build a translated expression to replace the call to `$localize`.\n * @param messageParts The static parts of the message.\n * @param substitutions The expressions to substitute into the message.\n */\nexport function buildLocalizeReplacement(\n    messageParts: TemplateStringsArray, substitutions: readonly t.Expression[]): t.Expression {\n  let mappedString: t.Expression = t.stringLiteral(messageParts[0]);\n  for (let i = 1; i < messageParts.length; i++) {\n    mappedString =\n        t.binaryExpression('+', mappedString, wrapInParensIfNecessary(substitutions[i - 1]));\n    mappedString = t.binaryExpression('+', mappedString, t.stringLiteral(messageParts[i]));\n  }\n  return mappedString;\n}\n\n/**\n * Extract the message parts from the given `call` (to `$localize`).\n *\n * The message parts will either by the first argument to the `call` or it will be wrapped in call\n * to a helper function like `__makeTemplateObject`.\n *\n * @param call The AST node of the call to process.\n */\nexport function unwrapMessagePartsFromLocalizeCall(call: NodePath<t.CallExpression>):\n    [TemplateStringsArray, (ɵSourceLocation | undefined)[]] {\n  let cooked = call.get('arguments')[0];\n\n  if (cooked === undefined) {\n    throw new BabelParseError(call.node, '`$localize` called without any arguments.');\n  }\n  if (!cooked.isExpression()) {\n    throw new BabelParseError(\n        cooked.node, 'Unexpected argument to `$localize` (expected an array).');\n  }\n\n  // If there is no call to `__makeTemplateObject(...)`, then `raw` must be the same as `cooked`.\n  let raw = cooked;\n\n  // Check for cached call of the form `x || x = __makeTemplateObject(...)`\n  if (cooked.isLogicalExpression() && cooked.node.operator === '||' &&\n      cooked.get('left').isIdentifier()) {\n    const right = cooked.get('right');\n    if (right.isAssignmentExpression()) {\n      cooked = right.get('right');\n      if (!cooked.isExpression()) {\n        throw new BabelParseError(\n            cooked.node, 'Unexpected \"makeTemplateObject()\" function (expected an expression).');\n      }\n    } else if (right.isSequenceExpression()) {\n      const expressions = right.get('expressions');\n      if (expressions.length > 2) {\n        // This is a minified sequence expression, where the first two expressions in the sequence\n        // are assignments of the cooked and raw arrays respectively.\n        const [first, second] = expressions;\n        if (first.isAssignmentExpression() && second.isAssignmentExpression()) {\n          cooked = first.get('right');\n          if (!cooked.isExpression()) {\n            throw new BabelParseError(\n                first.node, 'Unexpected cooked value, expected an expression.');\n          }\n          raw = second.get('right');\n          if (!raw.isExpression()) {\n            throw new BabelParseError(second.node, 'Unexpected raw value, expected an expression.');\n          }\n        }\n      }\n    }\n  }\n\n  // Check for `__makeTemplateObject(cooked, raw)` or `__templateObject()` calls.\n  if (cooked.isCallExpression()) {\n    let call = cooked;\n    if (call.get('arguments').length === 0) {\n      // No arguments so perhaps it is a `__templateObject()` call.\n      // Unwrap this to get the `_taggedTemplateLiteral(cooked, raw)` call.\n      call = unwrapLazyLoadHelperCall(call);\n    }\n\n    cooked = call.get('arguments')[0];\n    if (!cooked.isExpression()) {\n      throw new BabelParseError(\n          cooked.node,\n          'Unexpected `cooked` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    const arg2 = call.get('arguments')[1];\n    if (arg2 && !arg2.isExpression()) {\n      throw new BabelParseError(\n          arg2.node,\n          'Unexpected `raw` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    // If there is no second argument then assume that raw and cooked are the same\n    raw = arg2 !== undefined ? arg2 : cooked;\n  }\n\n  const [cookedStrings] = unwrapStringLiteralArray(cooked);\n  const [rawStrings, rawLocations] = unwrapStringLiteralArray(raw);\n  return [ɵmakeTemplateObject(cookedStrings, rawStrings), rawLocations];\n}\n\n\nexport function unwrapSubstitutionsFromLocalizeCall(call: NodePath<t.CallExpression>):\n    [t.Expression[], (ɵSourceLocation | undefined)[]] {\n  const expressions = call.get('arguments').splice(1);\n  if (!isArrayOfExpressions(expressions)) {\n    const badExpression = expressions.find(expression => !expression.isExpression())!;\n    throw new BabelParseError(\n        badExpression.node,\n        'Invalid substitutions for `$localize` (expected all substitution arguments to be expressions).');\n  }\n  return [\n    expressions.map(path => path.node), expressions.map(expression => getLocation(expression))\n  ];\n}\n\nexport function unwrapMessagePartsFromTemplateLiteral(elements: NodePath<t.TemplateElement>[]):\n    [TemplateStringsArray, (ɵSourceLocation | undefined)[]] {\n  const cooked = elements.map(q => {\n    if (q.node.value.cooked === undefined) {\n      throw new BabelParseError(\n          q.node,\n          `Unexpected undefined message part in \"${elements.map(q => q.node.value.cooked)}\"`);\n    }\n    return q.node.value.cooked;\n  });\n  const raw = elements.map(q => q.node.value.raw);\n  const locations = elements.map(q => getLocation(q));\n  return [ɵmakeTemplateObject(cooked, raw), locations];\n}\n\nexport function unwrapExpressionsFromTemplateLiteral(quasi: NodePath<t.TemplateLiteral>):\n    [t.Expression[], (ɵSourceLocation | undefined)[]] {\n  return [quasi.node.expressions, quasi.get('expressions').map(e => getLocation(e))];\n}\n\n/**\n * Wrap the given `expression` in parentheses if it is a binary expression.\n *\n * This ensures that this expression is evaluated correctly if it is embedded in another expression.\n *\n * @param expression The expression to potentially wrap.\n */\nexport function wrapInParensIfNecessary(expression: t.Expression): t.Expression {\n  if (t.isBinaryExpression(expression)) {\n    return t.parenthesizedExpression(expression);\n  } else {\n    return expression;\n  }\n}\n\n/**\n * Extract the string values from an `array` of string literals.\n * @param array The array to unwrap.\n */\nexport function unwrapStringLiteralArray(array: NodePath<t.Expression>):\n    [string[], (ɵSourceLocation | undefined)[]] {\n  if (!isStringLiteralArray(array.node)) {\n    throw new BabelParseError(\n        array.node, 'Unexpected messageParts for `$localize` (expected an array of strings).');\n  }\n  const elements = array.get('elements') as NodePath<t.StringLiteral>[];\n  return [elements.map(str => str.node.value), elements.map(str => getLocation(str))];\n}\n\n/**\n * This expression is believed to be a call to a \"lazy-load\" template object helper function.\n * This is expected to be of the form:\n *\n * ```ts\n *  function _templateObject() {\n *    var e = _taggedTemplateLiteral(['cooked string', 'raw string']);\n *    return _templateObject = function() { return e }, e\n *  }\n * ```\n *\n * We unwrap this to return the call to `_taggedTemplateLiteral()`.\n *\n * @param call the call expression to unwrap\n * @returns the  call expression\n */\nexport function unwrapLazyLoadHelperCall(call: NodePath<t.CallExpression>):\n    NodePath<t.CallExpression> {\n  const callee = call.get('callee');\n  if (!callee.isIdentifier()) {\n    throw new BabelParseError(\n        callee.node,\n        'Unexpected lazy-load helper call (expected a call of the form `_templateObject()`).');\n  }\n  const lazyLoadBinding = call.scope.getBinding(callee.node.name);\n  if (!lazyLoadBinding) {\n    throw new BabelParseError(callee.node, 'Missing declaration for lazy-load helper function');\n  }\n  const lazyLoadFn = lazyLoadBinding.path;\n  if (!lazyLoadFn.isFunctionDeclaration()) {\n    throw new BabelParseError(\n        lazyLoadFn.node, 'Unexpected expression (expected a function declaration');\n  }\n  const returnedNode = getReturnedExpression(lazyLoadFn);\n\n  if (returnedNode.isCallExpression()) {\n    return returnedNode;\n  }\n\n  if (returnedNode.isIdentifier()) {\n    const identifierName = returnedNode.node.name;\n    const declaration = returnedNode.scope.getBinding(identifierName);\n    if (declaration === undefined) {\n      throw new BabelParseError(\n          returnedNode.node, 'Missing declaration for return value from helper.');\n    }\n    if (!declaration.path.isVariableDeclarator()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected helper return value declaration (expected a variable declaration).');\n    }\n    const initializer = declaration.path.get('init');\n    if (!initializer.isCallExpression()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected return value from helper (expected a call expression).');\n    }\n\n    // Remove the lazy load helper if this is the only reference to it.\n    if (lazyLoadBinding.references === 1) {\n      lazyLoadFn.remove();\n    }\n\n    return initializer;\n  }\n  return call;\n}\n\nfunction getReturnedExpression(fn: NodePath<t.FunctionDeclaration>): NodePath<t.Expression> {\n  const bodyStatements = fn.get('body').get('body');\n  for (const statement of bodyStatements) {\n    if (statement.isReturnStatement()) {\n      const argument = statement.get('argument');\n      if (argument.isSequenceExpression()) {\n        const expressions = argument.get('expressions');\n        return Array.isArray(expressions) ? expressions[expressions.length - 1] : expressions;\n      } else if (argument.isExpression()) {\n        return argument;\n      } else {\n        throw new BabelParseError(\n            statement.node, 'Invalid return argument in helper function (expected an expression).');\n      }\n    }\n  }\n  throw new BabelParseError(fn.node, 'Missing return statement in helper function.');\n}\n\n/**\n * Is the given `node` an array of literal strings?\n *\n * @param node The node to test.\n */\nexport function isStringLiteralArray(node: t.Node): node is t.Expression&\n    {elements: t.StringLiteral[]} {\n  return t.isArrayExpression(node) && node.elements.every(element => t.isStringLiteral(element));\n}\n\n/**\n * Are all the given `nodes` expressions?\n * @param nodes The nodes to test.\n */\nexport function isArrayOfExpressions(paths: NodePath<t.Node>[]): paths is NodePath<t.Expression>[] {\n  return paths.every(element => element.isExpression());\n}\n\n/** Options that affect how the `makeEsXXXTranslatePlugin()` functions work. */\nexport interface TranslatePluginOptions {\n  missingTranslation?: DiagnosticHandlingStrategy;\n  localizeName?: string;\n}\n\n/**\n * Translate the text of the given message, using the given translations.\n *\n * Logs as warning if the translation is not available\n */\nexport function translate(\n    diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>,\n    messageParts: TemplateStringsArray, substitutions: readonly any[],\n    missingTranslation: DiagnosticHandlingStrategy): [TemplateStringsArray, readonly any[]] {\n  try {\n    return ɵtranslate(translations, messageParts, substitutions);\n  } catch (e) {\n    if (ɵisMissingTranslationError(e)) {\n      diagnostics.add(missingTranslation, e.message);\n      // Return the parsed message because this will have the meta blocks stripped\n      return [\n        ɵmakeTemplateObject(e.parsedMessage.messageParts, e.parsedMessage.messageParts),\n        substitutions\n      ];\n    } else {\n      diagnostics.error(e.message);\n      return [messageParts, substitutions];\n    }\n  }\n}\n\nexport class BabelParseError extends Error {\n  private readonly type = 'BabelParseError';\n  constructor(public node: t.Node, message: string) {\n    super(message);\n  }\n}\n\nexport function isBabelParseError(e: any): e is BabelParseError {\n  return e.type === 'BabelParseError';\n}\n\nexport function buildCodeFrameError(path: NodePath, e: BabelParseError): string {\n  const filename = path.hub.file.opts.filename || '(unknown file)';\n  const message = path.hub.file.buildCodeFrameError(e.node, e.message).message;\n  return `${filename}: ${message}`;\n}\n\nexport function getLocation(startPath: NodePath, endPath?: NodePath): ɵSourceLocation|undefined {\n  const startLocation = startPath.node.loc;\n  const file = getFileFromPath(startPath);\n  if (!startLocation || !file) {\n    return undefined;\n  }\n\n  const endLocation =\n      endPath && getFileFromPath(endPath) === file && endPath.node.loc || startLocation;\n\n  return {\n    start: getLineAndColumn(startLocation.start),\n    end: getLineAndColumn(endLocation.end),\n    file,\n    text: getText(startPath),\n  };\n}\n\nexport function serializeLocationPosition(location: ɵSourceLocation): string {\n  const endLineString = location.end !== undefined && location.end.line !== location.start.line ?\n      `,${location.end.line + 1}` :\n      '';\n  return `${location.start.line + 1}${endLineString}`;\n}\n\nfunction getFileFromPath(path: NodePath|undefined): AbsoluteFsPath|null {\n  const opts = path?.hub.file.opts;\n  return opts?.filename ?\n      resolve(opts.generatorOpts.sourceRoot ?? opts.cwd, relative(opts.cwd, opts.filename)) :\n      null;\n}\n\nfunction getLineAndColumn(loc: {line: number, column: number}): {line: number, column: number} {\n  // Note we want 0-based line numbers but Babel returns 1-based.\n  return {line: loc.line - 1, column: loc.column};\n}\n\nfunction getText(path: NodePath): string|undefined {\n  if (path.node.start === null || path.node.end === null) {\n    return undefined;\n  }\n  return path.hub.file.code.substring(path.node.start, path.node.end);\n}\n"]}
420
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/tools/src/source_file_utils.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 */\nimport {AbsoluteFsPath, FileSystem, getFileSystem} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {ɵisMissingTranslationError, ɵmakeTemplateObject, ɵParsedTranslation, ɵSourceLocation, ɵtranslate} from '@angular/localize';\nimport {NodePath} from '@babel/traverse';\nimport * as t from '@babel/types';\n\nimport {DiagnosticHandlingStrategy, Diagnostics} from './diagnostics';\n\n/**\n * Is the given `expression` the global `$localize` identifier?\n *\n * @param expression The expression to check.\n * @param localizeName The configured name of `$localize`.\n */\nexport function isLocalize(\n    expression: NodePath, localizeName: string): expression is NodePath<t.Identifier> {\n  return isNamedIdentifier(expression, localizeName) && isGlobalIdentifier(expression);\n}\n\n/**\n * Is the given `expression` an identifier with the correct `name`?\n *\n * @param expression The expression to check.\n * @param name The name of the identifier we are looking for.\n */\nexport function isNamedIdentifier(\n    expression: NodePath, name: string): expression is NodePath<t.Identifier> {\n  return expression.isIdentifier() && expression.node.name === name;\n}\n\n/**\n * Is the given `identifier` declared globally.\n *\n * @param identifier The identifier to check.\n * @publicApi used by CLI\n */\nexport function isGlobalIdentifier(identifier: NodePath<t.Identifier>) {\n  return !identifier.scope || !identifier.scope.hasBinding(identifier.node.name);\n}\n\n/**\n * Build a translated expression to replace the call to `$localize`.\n * @param messageParts The static parts of the message.\n * @param substitutions The expressions to substitute into the message.\n * @publicApi used by CLI\n */\nexport function buildLocalizeReplacement(\n    messageParts: TemplateStringsArray, substitutions: readonly t.Expression[]): t.Expression {\n  let mappedString: t.Expression = t.stringLiteral(messageParts[0]);\n  for (let i = 1; i < messageParts.length; i++) {\n    mappedString =\n        t.binaryExpression('+', mappedString, wrapInParensIfNecessary(substitutions[i - 1]));\n    mappedString = t.binaryExpression('+', mappedString, t.stringLiteral(messageParts[i]));\n  }\n  return mappedString;\n}\n\n/**\n * Extract the message parts from the given `call` (to `$localize`).\n *\n * The message parts will either by the first argument to the `call` or it will be wrapped in call\n * to a helper function like `__makeTemplateObject`.\n *\n * @param call The AST node of the call to process.\n * @param fs The file system to use when computing source-map paths. If not provided then it uses\n *     the \"current\" FileSystem.\n * @publicApi used by CLI\n */\nexport function unwrapMessagePartsFromLocalizeCall(\n    call: NodePath<t.CallExpression>,\n    fs: FileSystem = getFileSystem(),\n    ): [TemplateStringsArray, (ɵSourceLocation | undefined)[]] {\n  let cooked = call.get('arguments')[0];\n\n  if (cooked === undefined) {\n    throw new BabelParseError(call.node, '`$localize` called without any arguments.');\n  }\n  if (!cooked.isExpression()) {\n    throw new BabelParseError(\n        cooked.node, 'Unexpected argument to `$localize` (expected an array).');\n  }\n\n  // If there is no call to `__makeTemplateObject(...)`, then `raw` must be the same as `cooked`.\n  let raw = cooked;\n\n  // Check for cached call of the form `x || x = __makeTemplateObject(...)`\n  if (cooked.isLogicalExpression() && cooked.node.operator === '||' &&\n      cooked.get('left').isIdentifier()) {\n    const right = cooked.get('right');\n    if (right.isAssignmentExpression()) {\n      cooked = right.get('right');\n      if (!cooked.isExpression()) {\n        throw new BabelParseError(\n            cooked.node, 'Unexpected \"makeTemplateObject()\" function (expected an expression).');\n      }\n    } else if (right.isSequenceExpression()) {\n      const expressions = right.get('expressions');\n      if (expressions.length > 2) {\n        // This is a minified sequence expression, where the first two expressions in the sequence\n        // are assignments of the cooked and raw arrays respectively.\n        const [first, second] = expressions;\n        if (first.isAssignmentExpression() && second.isAssignmentExpression()) {\n          cooked = first.get('right');\n          if (!cooked.isExpression()) {\n            throw new BabelParseError(\n                first.node, 'Unexpected cooked value, expected an expression.');\n          }\n          raw = second.get('right');\n          if (!raw.isExpression()) {\n            throw new BabelParseError(second.node, 'Unexpected raw value, expected an expression.');\n          }\n        }\n      }\n    }\n  }\n\n  // Check for `__makeTemplateObject(cooked, raw)` or `__templateObject()` calls.\n  if (cooked.isCallExpression()) {\n    let call = cooked;\n    if (call.get('arguments').length === 0) {\n      // No arguments so perhaps it is a `__templateObject()` call.\n      // Unwrap this to get the `_taggedTemplateLiteral(cooked, raw)` call.\n      call = unwrapLazyLoadHelperCall(call);\n    }\n\n    cooked = call.get('arguments')[0];\n    if (!cooked.isExpression()) {\n      throw new BabelParseError(\n          cooked.node,\n          'Unexpected `cooked` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    const arg2 = call.get('arguments')[1];\n    if (arg2 && !arg2.isExpression()) {\n      throw new BabelParseError(\n          arg2.node,\n          'Unexpected `raw` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    // If there is no second argument then assume that raw and cooked are the same\n    raw = arg2 !== undefined ? arg2 : cooked;\n  }\n\n  const [cookedStrings] = unwrapStringLiteralArray(cooked, fs);\n  const [rawStrings, rawLocations] = unwrapStringLiteralArray(raw, fs);\n  return [ɵmakeTemplateObject(cookedStrings, rawStrings), rawLocations];\n}\n\n/**\n * Parse the localize call expression to extract the arguments that hold the substition expressions.\n *\n * @param call The AST node of the call to process.\n * @param fs The file system to use when computing source-map paths. If not provided then it uses\n *     the \"current\" FileSystem.\n * @publicApi used by CLI\n */\nexport function unwrapSubstitutionsFromLocalizeCall(\n    call: NodePath<t.CallExpression>,\n    fs: FileSystem = getFileSystem()): [t.Expression[], (ɵSourceLocation | undefined)[]] {\n  const expressions = call.get('arguments').splice(1);\n  if (!isArrayOfExpressions(expressions)) {\n    const badExpression = expressions.find(expression => !expression.isExpression())!;\n    throw new BabelParseError(\n        badExpression.node,\n        'Invalid substitutions for `$localize` (expected all substitution arguments to be expressions).');\n  }\n  return [\n    expressions.map(path => path.node), expressions.map(expression => getLocation(fs, expression))\n  ];\n}\n\n/**\n * Parse the tagged template literal to extract the message parts.\n *\n * @param elements The elements of the template literal to process.\n * @param fs The file system to use when computing source-map paths. If not provided then it uses\n *     the \"current\" FileSystem.\n * @publicApi used by CLI\n */\nexport function unwrapMessagePartsFromTemplateLiteral(\n    elements: NodePath<t.TemplateElement>[],\n    fs: FileSystem = getFileSystem()): [TemplateStringsArray, (ɵSourceLocation | undefined)[]] {\n  const cooked = elements.map(q => {\n    if (q.node.value.cooked === undefined) {\n      throw new BabelParseError(\n          q.node,\n          `Unexpected undefined message part in \"${elements.map(q => q.node.value.cooked)}\"`);\n    }\n    return q.node.value.cooked;\n  });\n  const raw = elements.map(q => q.node.value.raw);\n  const locations = elements.map(q => getLocation(fs, q));\n  return [ɵmakeTemplateObject(cooked, raw), locations];\n}\n\n/**\n * Parse the tagged template literal to extract the interpolation expressions.\n *\n * @param quasi The AST node of the template literal to process.\n * @param fs The file system to use when computing source-map paths. If not provided then it uses\n *     the \"current\" FileSystem.\n * @publicApi used by CLI\n */\nexport function unwrapExpressionsFromTemplateLiteral(\n    quasi: NodePath<t.TemplateLiteral>,\n    fs: FileSystem = getFileSystem()): [t.Expression[], (ɵSourceLocation | undefined)[]] {\n  return [quasi.node.expressions, quasi.get('expressions').map(e => getLocation(fs, e))];\n}\n\n/**\n * Wrap the given `expression` in parentheses if it is a binary expression.\n *\n * This ensures that this expression is evaluated correctly if it is embedded in another expression.\n *\n * @param expression The expression to potentially wrap.\n */\nexport function wrapInParensIfNecessary(expression: t.Expression): t.Expression {\n  if (t.isBinaryExpression(expression)) {\n    return t.parenthesizedExpression(expression);\n  } else {\n    return expression;\n  }\n}\n\n/**\n * Extract the string values from an `array` of string literals.\n *\n * @param array The array to unwrap.\n * @param fs The file system to use when computing source-map paths. If not provided then it uses\n *     the \"current\" FileSystem.\n */\nexport function unwrapStringLiteralArray(\n    array: NodePath<t.Expression>,\n    fs: FileSystem = getFileSystem()): [string[], (ɵSourceLocation | undefined)[]] {\n  if (!isStringLiteralArray(array.node)) {\n    throw new BabelParseError(\n        array.node, 'Unexpected messageParts for `$localize` (expected an array of strings).');\n  }\n  const elements = array.get('elements') as NodePath<t.StringLiteral>[];\n  return [elements.map(str => str.node.value), elements.map(str => getLocation(fs, str))];\n}\n\n/**\n * This expression is believed to be a call to a \"lazy-load\" template object helper function.\n * This is expected to be of the form:\n *\n * ```ts\n *  function _templateObject() {\n *    var e = _taggedTemplateLiteral(['cooked string', 'raw string']);\n *    return _templateObject = function() { return e }, e\n *  }\n * ```\n *\n * We unwrap this to return the call to `_taggedTemplateLiteral()`.\n *\n * @param call the call expression to unwrap\n * @returns the  call expression\n */\nexport function unwrapLazyLoadHelperCall(call: NodePath<t.CallExpression>):\n    NodePath<t.CallExpression> {\n  const callee = call.get('callee');\n  if (!callee.isIdentifier()) {\n    throw new BabelParseError(\n        callee.node,\n        'Unexpected lazy-load helper call (expected a call of the form `_templateObject()`).');\n  }\n  const lazyLoadBinding = call.scope.getBinding(callee.node.name);\n  if (!lazyLoadBinding) {\n    throw new BabelParseError(callee.node, 'Missing declaration for lazy-load helper function');\n  }\n  const lazyLoadFn = lazyLoadBinding.path;\n  if (!lazyLoadFn.isFunctionDeclaration()) {\n    throw new BabelParseError(\n        lazyLoadFn.node, 'Unexpected expression (expected a function declaration');\n  }\n  const returnedNode = getReturnedExpression(lazyLoadFn);\n\n  if (returnedNode.isCallExpression()) {\n    return returnedNode;\n  }\n\n  if (returnedNode.isIdentifier()) {\n    const identifierName = returnedNode.node.name;\n    const declaration = returnedNode.scope.getBinding(identifierName);\n    if (declaration === undefined) {\n      throw new BabelParseError(\n          returnedNode.node, 'Missing declaration for return value from helper.');\n    }\n    if (!declaration.path.isVariableDeclarator()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected helper return value declaration (expected a variable declaration).');\n    }\n    const initializer = declaration.path.get('init');\n    if (!initializer.isCallExpression()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected return value from helper (expected a call expression).');\n    }\n\n    // Remove the lazy load helper if this is the only reference to it.\n    if (lazyLoadBinding.references === 1) {\n      lazyLoadFn.remove();\n    }\n\n    return initializer;\n  }\n  return call;\n}\n\nfunction getReturnedExpression(fn: NodePath<t.FunctionDeclaration>): NodePath<t.Expression> {\n  const bodyStatements = fn.get('body').get('body');\n  for (const statement of bodyStatements) {\n    if (statement.isReturnStatement()) {\n      const argument = statement.get('argument');\n      if (argument.isSequenceExpression()) {\n        const expressions = argument.get('expressions');\n        return Array.isArray(expressions) ? expressions[expressions.length - 1] : expressions;\n      } else if (argument.isExpression()) {\n        return argument;\n      } else {\n        throw new BabelParseError(\n            statement.node, 'Invalid return argument in helper function (expected an expression).');\n      }\n    }\n  }\n  throw new BabelParseError(fn.node, 'Missing return statement in helper function.');\n}\n\n/**\n * Is the given `node` an array of literal strings?\n *\n * @param node The node to test.\n */\nexport function isStringLiteralArray(node: t.Node): node is t.Expression&\n    {elements: t.StringLiteral[]} {\n  return t.isArrayExpression(node) && node.elements.every(element => t.isStringLiteral(element));\n}\n\n/**\n * Are all the given `nodes` expressions?\n * @param nodes The nodes to test.\n */\nexport function isArrayOfExpressions(paths: NodePath<t.Node>[]): paths is NodePath<t.Expression>[] {\n  return paths.every(element => element.isExpression());\n}\n\n/** Options that affect how the `makeEsXXXTranslatePlugin()` functions work. */\nexport interface TranslatePluginOptions {\n  missingTranslation?: DiagnosticHandlingStrategy;\n  localizeName?: string;\n}\n\n/**\n * Translate the text of the given message, using the given translations.\n *\n * Logs as warning if the translation is not available\n * @publicApi used by CLI\n */\nexport function translate(\n    diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>,\n    messageParts: TemplateStringsArray, substitutions: readonly any[],\n    missingTranslation: DiagnosticHandlingStrategy): [TemplateStringsArray, readonly any[]] {\n  try {\n    return ɵtranslate(translations, messageParts, substitutions);\n  } catch (e) {\n    if (ɵisMissingTranslationError(e)) {\n      diagnostics.add(missingTranslation, e.message);\n      // Return the parsed message because this will have the meta blocks stripped\n      return [\n        ɵmakeTemplateObject(e.parsedMessage.messageParts, e.parsedMessage.messageParts),\n        substitutions\n      ];\n    } else {\n      diagnostics.error(e.message);\n      return [messageParts, substitutions];\n    }\n  }\n}\n\nexport class BabelParseError extends Error {\n  private readonly type = 'BabelParseError';\n  constructor(public node: t.Node, message: string) {\n    super(message);\n  }\n}\n\nexport function isBabelParseError(e: any): e is BabelParseError {\n  return e.type === 'BabelParseError';\n}\n\nexport function buildCodeFrameError(path: NodePath, e: BabelParseError): string {\n  const filename = path.hub.file.opts.filename || '(unknown file)';\n  const message = path.hub.file.buildCodeFrameError(e.node, e.message).message;\n  return `${filename}: ${message}`;\n}\n\nexport function getLocation(\n    fs: FileSystem, startPath: NodePath, endPath?: NodePath): ɵSourceLocation|undefined {\n  const startLocation = startPath.node.loc;\n  const file = getFileFromPath(fs, startPath);\n  if (!startLocation || !file) {\n    return undefined;\n  }\n\n  const endLocation =\n      endPath && getFileFromPath(fs, endPath) === file && endPath.node.loc || startLocation;\n\n  return {\n    start: getLineAndColumn(startLocation.start),\n    end: getLineAndColumn(endLocation.end),\n    file,\n    text: getText(startPath),\n  };\n}\n\nexport function serializeLocationPosition(location: ɵSourceLocation): string {\n  const endLineString = location.end !== undefined && location.end.line !== location.start.line ?\n      `,${location.end.line + 1}` :\n      '';\n  return `${location.start.line + 1}${endLineString}`;\n}\n\nfunction getFileFromPath(fs: FileSystem, path: NodePath|undefined): AbsoluteFsPath|null {\n  const opts = path?.hub.file.opts;\n  return opts?.filename ?\n      fs.resolve(opts.generatorOpts.sourceRoot ?? opts.cwd, fs.relative(opts.cwd, opts.filename)) :\n      null;\n}\n\nfunction getLineAndColumn(loc: {line: number, column: number}): {line: number, column: number} {\n  // Note we want 0-based line numbers but Babel returns 1-based.\n  return {line: loc.line - 1, column: loc.column};\n}\n\nfunction getText(path: NodePath): string|undefined {\n  if (path.node.start === null || path.node.end === null) {\n    return undefined;\n  }\n  return path.hub.file.code.substring(path.node.start, path.node.end);\n}\n"]}
@@ -6,8 +6,15 @@
6
6
  * Use of this source code is governed by an MIT-style license that can be
7
7
  * found in the LICENSE file at https://angular.io/license
8
8
  */
9
+ import { FileSystem } from '@angular/compiler-cli/src/ngtsc/file_system';
9
10
  import { ɵParsedTranslation } from '@angular/localize';
10
11
  import { PluginObj } from '@babel/core';
11
12
  import { Diagnostics } from '../../diagnostics';
12
13
  import { TranslatePluginOptions } from '../../source_file_utils';
13
- export declare function makeEs2015TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions): PluginObj;
14
+ /**
15
+ * Create a Babel plugin that can be used to do compile-time translation of `$localize` tagged
16
+ * messages.
17
+ *
18
+ * @publicApi used by CLI
19
+ */
20
+ export declare function makeEs2015TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions, fs?: FileSystem): PluginObj;
@@ -4,23 +4,38 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/localize/src/tools/src/translate/source_files/es2015_translate_plugin", ["require", "exports", "tslib", "@angular/localize/src/tools/src/source_file_utils"], factory);
7
+ define("@angular/localize/src/tools/src/translate/source_files/es2015_translate_plugin", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/localize/src/tools/src/source_file_utils"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.makeEs2015TranslatePlugin = void 0;
13
13
  var tslib_1 = require("tslib");
14
+ /**
15
+ * @license
16
+ * Copyright Google LLC All Rights Reserved.
17
+ *
18
+ * Use of this source code is governed by an MIT-style license that can be
19
+ * found in the LICENSE file at https://angular.io/license
20
+ */
21
+ var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
14
22
  var source_file_utils_1 = require("@angular/localize/src/tools/src/source_file_utils");
15
- function makeEs2015TranslatePlugin(diagnostics, translations, _a) {
23
+ /**
24
+ * Create a Babel plugin that can be used to do compile-time translation of `$localize` tagged
25
+ * messages.
26
+ *
27
+ * @publicApi used by CLI
28
+ */
29
+ function makeEs2015TranslatePlugin(diagnostics, translations, _a, fs) {
16
30
  var _b = _a === void 0 ? {} : _a, _c = _b.missingTranslation, missingTranslation = _c === void 0 ? 'error' : _c, _d = _b.localizeName, localizeName = _d === void 0 ? '$localize' : _d;
31
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
17
32
  return {
18
33
  visitor: {
19
34
  TaggedTemplateExpression: function (path) {
20
35
  try {
21
36
  var tag = path.get('tag');
22
37
  if (source_file_utils_1.isLocalize(tag, localizeName)) {
23
- var _a = tslib_1.__read(source_file_utils_1.unwrapMessagePartsFromTemplateLiteral(path.get('quasi').get('quasis')), 1), messageParts = _a[0];
38
+ var _a = tslib_1.__read(source_file_utils_1.unwrapMessagePartsFromTemplateLiteral(path.get('quasi').get('quasis'), fs), 1), messageParts = _a[0];
24
39
  var translated = source_file_utils_1.translate(diagnostics, translations, messageParts, path.node.quasi.expressions, missingTranslation);
25
40
  path.replaceWith(source_file_utils_1.buildLocalizeReplacement(translated[0], translated[1]));
26
41
  }
@@ -42,4 +57,4 @@
42
57
  }
43
58
  exports.makeEs2015TranslatePlugin = makeEs2015TranslatePlugin;
44
59
  });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQWFBLHVGQUErTDtJQUUvTCxTQUFnQix5QkFBeUIsQ0FDckMsV0FBd0IsRUFBRSxZQUFnRCxFQUMxRSxFQUF1RjtZQUF2RixxQkFBcUYsRUFBRSxLQUFBLEVBQXRGLDBCQUE0QixFQUE1QixrQkFBa0IsbUJBQUcsT0FBTyxLQUFBLEVBQUUsb0JBQTBCLEVBQTFCLFlBQVksbUJBQUcsV0FBVyxLQUFBO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1Asd0JBQXdCLEVBQXhCLFVBQXlCLElBQXdDO29CQUMvRCxJQUFJO3dCQUNGLElBQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7d0JBQzVCLElBQUksOEJBQVUsQ0FBQyxHQUFHLEVBQUUsWUFBWSxDQUFDLEVBQUU7NEJBQzNCLElBQUEsS0FBQSxlQUNGLHlEQUFxQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUEsRUFEbkUsWUFBWSxRQUN1RCxDQUFDOzRCQUMzRSxJQUFNLFVBQVUsR0FBRyw2QkFBUyxDQUN4QixXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQ3BFLGtCQUFrQixDQUFDLENBQUM7NEJBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsNENBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzFFO3FCQUNGO29CQUFDLE9BQU8sQ0FBQyxFQUFFO3dCQUNWLElBQUkscUNBQWlCLENBQUMsQ0FBQyxDQUFDLEVBQUU7NEJBQ3hCLCtFQUErRTs0QkFDL0UsOEVBQThFOzRCQUM5RSwrQ0FBK0M7NEJBQy9DLE1BQU0sdUNBQW1CLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO3lCQUNwQzs2QkFBTTs0QkFDTCxNQUFNLENBQUMsQ0FBQzt5QkFDVDtxQkFDRjtnQkFDSCxDQUFDO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQTlCRCw4REE4QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtOb2RlUGF0aCwgUGx1Z2luT2JqfSBmcm9tICdAYmFiZWwvY29yZSc7XG5pbXBvcnQge1RhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbn0gZnJvbSAnQGJhYmVsL3R5cGVzJztcblxuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vZGlhZ25vc3RpY3MnO1xuXG5pbXBvcnQge2J1aWxkQ29kZUZyYW1lRXJyb3IsIGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCwgaXNCYWJlbFBhcnNlRXJyb3IsIGlzTG9jYWxpemUsIHRyYW5zbGF0ZSwgVHJhbnNsYXRlUGx1Z2luT3B0aW9ucywgdW53cmFwTWVzc2FnZVBhcnRzRnJvbVRlbXBsYXRlTGl0ZXJhbH0gZnJvbSAnLi4vLi4vc291cmNlX2ZpbGVfdXRpbHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gbWFrZUVzMjAxNVRyYW5zbGF0ZVBsdWdpbihcbiAgICBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9uczogUmVjb3JkPHN0cmluZywgybVQYXJzZWRUcmFuc2xhdGlvbj4sXG4gICAge21pc3NpbmdUcmFuc2xhdGlvbiA9ICdlcnJvcicsIGxvY2FsaXplTmFtZSA9ICckbG9jYWxpemUnfTogVHJhbnNsYXRlUGx1Z2luT3B0aW9ucyA9IHt9KTpcbiAgICBQbHVnaW5PYmoge1xuICByZXR1cm4ge1xuICAgIHZpc2l0b3I6IHtcbiAgICAgIFRhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbihwYXRoOiBOb2RlUGF0aDxUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgdGFnID0gcGF0aC5nZXQoJ3RhZycpO1xuICAgICAgICAgIGlmIChpc0xvY2FsaXplKHRhZywgbG9jYWxpemVOYW1lKSkge1xuICAgICAgICAgICAgY29uc3QgW21lc3NhZ2VQYXJ0c10gPVxuICAgICAgICAgICAgICAgIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21UZW1wbGF0ZUxpdGVyYWwocGF0aC5nZXQoJ3F1YXNpJykuZ2V0KCdxdWFzaXMnKSk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID0gdHJhbnNsYXRlKFxuICAgICAgICAgICAgICAgIGRpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnMsIG1lc3NhZ2VQYXJ0cywgcGF0aC5ub2RlLnF1YXNpLmV4cHJlc3Npb25zLFxuICAgICAgICAgICAgICAgIG1pc3NpbmdUcmFuc2xhdGlvbik7XG4gICAgICAgICAgICBwYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICAvLyBJZiB3ZSBnZXQgYSBCYWJlbFBhcnNlRXJyb3IgaGVyZSB0aGVuIHNvbWV0aGluZyB3ZW50IHdyb25nIHdpdGggQmFiZWwgaXRzZWxmXG4gICAgICAgICAgICAvLyBzaW5jZSB0aGVyZSBtdXN0IGJlIHNvbWV0aGluZyB3cm9uZyB3aXRoIHRoZSBzdHJ1Y3R1cmUgb2YgdGhlIEFTVCBnZW5lcmF0ZWRcbiAgICAgICAgICAgIC8vIGJ5IEJhYmVsIHBhcnNpbmcgYSBUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24uXG4gICAgICAgICAgICB0aHJvdyBidWlsZENvZGVGcmFtZUVycm9yKHBhdGgsIGUpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfTtcbn1cbiJdfQ==
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILDJFQUFzRjtJQU90Rix1RkFBK0w7SUFFL0w7Ozs7O09BS0c7SUFDSCxTQUFnQix5QkFBeUIsQ0FDckMsV0FBd0IsRUFBRSxZQUFnRCxFQUMxRSxFQUF1RixFQUN2RixFQUFnQztZQURoQyxxQkFBcUYsRUFBRSxLQUFBLEVBQXRGLDBCQUE0QixFQUE1QixrQkFBa0IsbUJBQUcsT0FBTyxLQUFBLEVBQUUsb0JBQTBCLEVBQTFCLFlBQVksbUJBQUcsV0FBVyxLQUFBO1FBQ3pELG1CQUFBLEVBQUEsS0FBaUIsMkJBQWEsRUFBRTtRQUNsQyxPQUFPO1lBQ0wsT0FBTyxFQUFFO2dCQUNQLHdCQUF3QixFQUF4QixVQUF5QixJQUF3QztvQkFDL0QsSUFBSTt3QkFDRixJQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO3dCQUM1QixJQUFJLDhCQUFVLENBQUMsR0FBRyxFQUFFLFlBQVksQ0FBQyxFQUFFOzRCQUMzQixJQUFBLEtBQUEsZUFDRix5REFBcUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBQSxFQUR2RSxZQUFZLFFBQzJELENBQUM7NEJBQy9FLElBQU0sVUFBVSxHQUFHLDZCQUFTLENBQ3hCLFdBQVcsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFDcEUsa0JBQWtCLENBQUMsQ0FBQzs0QkFDeEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyw0Q0FBd0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDMUU7cUJBQ0Y7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsSUFBSSxxQ0FBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRTs0QkFDeEIsK0VBQStFOzRCQUMvRSw4RUFBOEU7NEJBQzlFLCtDQUErQzs0QkFDL0MsTUFBTSx1Q0FBbUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7eUJBQ3BDOzZCQUFNOzRCQUNMLE1BQU0sQ0FBQyxDQUFDO3lCQUNUO3FCQUNGO2dCQUNILENBQUM7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0lBOUJELDhEQThCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtGaWxlU3lzdGVtLCBnZXRGaWxlU3lzdGVtfSBmcm9tICdAYW5ndWxhci9jb21waWxlci1jbGkvc3JjL25ndHNjL2ZpbGVfc3lzdGVtJztcbmltcG9ydCB7ybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtOb2RlUGF0aCwgUGx1Z2luT2JqfSBmcm9tICdAYmFiZWwvY29yZSc7XG5pbXBvcnQge1RhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbn0gZnJvbSAnQGJhYmVsL3R5cGVzJztcblxuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vZGlhZ25vc3RpY3MnO1xuXG5pbXBvcnQge2J1aWxkQ29kZUZyYW1lRXJyb3IsIGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCwgaXNCYWJlbFBhcnNlRXJyb3IsIGlzTG9jYWxpemUsIHRyYW5zbGF0ZSwgVHJhbnNsYXRlUGx1Z2luT3B0aW9ucywgdW53cmFwTWVzc2FnZVBhcnRzRnJvbVRlbXBsYXRlTGl0ZXJhbH0gZnJvbSAnLi4vLi4vc291cmNlX2ZpbGVfdXRpbHMnO1xuXG4vKipcbiAqIENyZWF0ZSBhIEJhYmVsIHBsdWdpbiB0aGF0IGNhbiBiZSB1c2VkIHRvIGRvIGNvbXBpbGUtdGltZSB0cmFuc2xhdGlvbiBvZiBgJGxvY2FsaXplYCB0YWdnZWRcbiAqIG1lc3NhZ2VzLlxuICpcbiAqIEBwdWJsaWNBcGkgdXNlZCBieSBDTElcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFczIwMTVUcmFuc2xhdGVQbHVnaW4oXG4gICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnM6IFJlY29yZDxzdHJpbmcsIMm1UGFyc2VkVHJhbnNsYXRpb24+LFxuICAgIHttaXNzaW5nVHJhbnNsYXRpb24gPSAnZXJyb3InLCBsb2NhbGl6ZU5hbWUgPSAnJGxvY2FsaXplJ306IFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMgPSB7fSxcbiAgICBmczogRmlsZVN5c3RlbSA9IGdldEZpbGVTeXN0ZW0oKSk6IFBsdWdpbk9iaiB7XG4gIHJldHVybiB7XG4gICAgdmlzaXRvcjoge1xuICAgICAgVGFnZ2VkVGVtcGxhdGVFeHByZXNzaW9uKHBhdGg6IE5vZGVQYXRoPFRhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbj4pIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCB0YWcgPSBwYXRoLmdldCgndGFnJyk7XG4gICAgICAgICAgaWYgKGlzTG9jYWxpemUodGFnLCBsb2NhbGl6ZU5hbWUpKSB7XG4gICAgICAgICAgICBjb25zdCBbbWVzc2FnZVBhcnRzXSA9XG4gICAgICAgICAgICAgICAgdW53cmFwTWVzc2FnZVBhcnRzRnJvbVRlbXBsYXRlTGl0ZXJhbChwYXRoLmdldCgncXVhc2knKS5nZXQoJ3F1YXNpcycpLCBmcyk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID0gdHJhbnNsYXRlKFxuICAgICAgICAgICAgICAgIGRpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnMsIG1lc3NhZ2VQYXJ0cywgcGF0aC5ub2RlLnF1YXNpLmV4cHJlc3Npb25zLFxuICAgICAgICAgICAgICAgIG1pc3NpbmdUcmFuc2xhdGlvbik7XG4gICAgICAgICAgICBwYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICAvLyBJZiB3ZSBnZXQgYSBCYWJlbFBhcnNlRXJyb3IgaGVyZSB0aGVuIHNvbWV0aGluZyB3ZW50IHdyb25nIHdpdGggQmFiZWwgaXRzZWxmXG4gICAgICAgICAgICAvLyBzaW5jZSB0aGVyZSBtdXN0IGJlIHNvbWV0aGluZyB3cm9uZyB3aXRoIHRoZSBzdHJ1Y3R1cmUgb2YgdGhlIEFTVCBnZW5lcmF0ZWRcbiAgICAgICAgICAgIC8vIGJ5IEJhYmVsIHBhcnNpbmcgYSBUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24uXG4gICAgICAgICAgICB0aHJvdyBidWlsZENvZGVGcmFtZUVycm9yKHBhdGgsIGUpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfTtcbn1cbiJdfQ==
@@ -6,8 +6,15 @@
6
6
  * Use of this source code is governed by an MIT-style license that can be
7
7
  * found in the LICENSE file at https://angular.io/license
8
8
  */
9
+ import { FileSystem } from '@angular/compiler-cli/src/ngtsc/file_system';
9
10
  import { ɵParsedTranslation } from '@angular/localize';
10
11
  import { PluginObj } from '@babel/core';
11
12
  import { Diagnostics } from '../../diagnostics';
12
13
  import { TranslatePluginOptions } from '../../source_file_utils';
13
- export declare function makeEs5TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions): PluginObj;
14
+ /**
15
+ * Create a Babel plugin that can be used to do compile-time translation of `$localize` tagged
16
+ * messages.
17
+ *
18
+ * @publicApi used by CLI
19
+ */
20
+ export declare function makeEs5TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions, fs?: FileSystem): PluginObj;
@@ -4,24 +4,39 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/localize/src/tools/src/translate/source_files/es5_translate_plugin", ["require", "exports", "tslib", "@angular/localize/src/tools/src/source_file_utils"], factory);
7
+ define("@angular/localize/src/tools/src/translate/source_files/es5_translate_plugin", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/localize/src/tools/src/source_file_utils"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.makeEs5TranslatePlugin = void 0;
13
13
  var tslib_1 = require("tslib");
14
+ /**
15
+ * @license
16
+ * Copyright Google LLC All Rights Reserved.
17
+ *
18
+ * Use of this source code is governed by an MIT-style license that can be
19
+ * found in the LICENSE file at https://angular.io/license
20
+ */
21
+ var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
14
22
  var source_file_utils_1 = require("@angular/localize/src/tools/src/source_file_utils");
15
- function makeEs5TranslatePlugin(diagnostics, translations, _a) {
23
+ /**
24
+ * Create a Babel plugin that can be used to do compile-time translation of `$localize` tagged
25
+ * messages.
26
+ *
27
+ * @publicApi used by CLI
28
+ */
29
+ function makeEs5TranslatePlugin(diagnostics, translations, _a, fs) {
16
30
  var _b = _a === void 0 ? {} : _a, _c = _b.missingTranslation, missingTranslation = _c === void 0 ? 'error' : _c, _d = _b.localizeName, localizeName = _d === void 0 ? '$localize' : _d;
31
+ if (fs === void 0) { fs = file_system_1.getFileSystem(); }
17
32
  return {
18
33
  visitor: {
19
34
  CallExpression: function (callPath) {
20
35
  try {
21
36
  var calleePath = callPath.get('callee');
22
37
  if (source_file_utils_1.isLocalize(calleePath, localizeName)) {
23
- var _a = tslib_1.__read(source_file_utils_1.unwrapMessagePartsFromLocalizeCall(callPath), 1), messageParts = _a[0];
24
- var _b = tslib_1.__read(source_file_utils_1.unwrapSubstitutionsFromLocalizeCall(callPath), 1), expressions = _b[0];
38
+ var _a = tslib_1.__read(source_file_utils_1.unwrapMessagePartsFromLocalizeCall(callPath, fs), 1), messageParts = _a[0];
39
+ var _b = tslib_1.__read(source_file_utils_1.unwrapSubstitutionsFromLocalizeCall(callPath, fs), 1), expressions = _b[0];
25
40
  var translated = source_file_utils_1.translate(diagnostics, translations, messageParts, expressions, missingTranslation);
26
41
  callPath.replaceWith(source_file_utils_1.buildLocalizeReplacement(translated[0], translated[1]));
27
42
  }
@@ -40,4 +55,4 @@
40
55
  }
41
56
  exports.makeEs5TranslatePlugin = makeEs5TranslatePlugin;
42
57
  });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQWFBLHVGQUFpTztJQUVqTyxTQUFnQixzQkFBc0IsQ0FDbEMsV0FBd0IsRUFBRSxZQUFnRCxFQUMxRSxFQUF1RjtZQUF2RixxQkFBcUYsRUFBRSxLQUFBLEVBQXRGLDBCQUE0QixFQUE1QixrQkFBa0IsbUJBQUcsT0FBTyxLQUFBLEVBQUUsb0JBQTBCLEVBQTFCLFlBQVksbUJBQUcsV0FBVyxLQUFBO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1AsY0FBYyxFQUFkLFVBQWUsUUFBa0M7b0JBQy9DLElBQUk7d0JBQ0YsSUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDMUMsSUFBSSw4QkFBVSxDQUFDLFVBQVUsRUFBRSxZQUFZLENBQUMsRUFBRTs0QkFDbEMsSUFBQSxLQUFBLGVBQWlCLHNEQUFrQyxDQUFDLFFBQVEsQ0FBQyxJQUFBLEVBQTVELFlBQVksUUFBZ0QsQ0FBQzs0QkFDOUQsSUFBQSxLQUFBLGVBQWdCLHVEQUFtQyxDQUFDLFFBQVEsQ0FBQyxJQUFBLEVBQTVELFdBQVcsUUFBaUQsQ0FBQzs0QkFDcEUsSUFBTSxVQUFVLEdBQ1osNkJBQVMsQ0FBQyxXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzs0QkFDeEYsUUFBUSxDQUFDLFdBQVcsQ0FBQyw0Q0FBd0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDOUU7cUJBQ0Y7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsSUFBSSxxQ0FBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRTs0QkFDeEIsV0FBVyxDQUFDLEtBQUssQ0FBQyx1Q0FBbUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDckQ7NkJBQU07NEJBQ0wsTUFBTSxDQUFDLENBQUM7eUJBQ1Q7cUJBQ0Y7Z0JBQ0gsQ0FBQzthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUExQkQsd0RBMEJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplJztcbmltcG9ydCB7Tm9kZVBhdGgsIFBsdWdpbk9ian0gZnJvbSAnQGJhYmVsL2NvcmUnO1xuaW1wb3J0IHtDYWxsRXhwcmVzc2lvbn0gZnJvbSAnQGJhYmVsL3R5cGVzJztcblxuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vZGlhZ25vc3RpY3MnO1xuXG5pbXBvcnQge2J1aWxkQ29kZUZyYW1lRXJyb3IsIGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCwgaXNCYWJlbFBhcnNlRXJyb3IsIGlzTG9jYWxpemUsIHRyYW5zbGF0ZSwgVHJhbnNsYXRlUGx1Z2luT3B0aW9ucywgdW53cmFwTWVzc2FnZVBhcnRzRnJvbUxvY2FsaXplQ2FsbCwgdW53cmFwU3Vic3RpdHV0aW9uc0Zyb21Mb2NhbGl6ZUNhbGx9IGZyb20gJy4uLy4uL3NvdXJjZV9maWxlX3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFczVUcmFuc2xhdGVQbHVnaW4oXG4gICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnM6IFJlY29yZDxzdHJpbmcsIMm1UGFyc2VkVHJhbnNsYXRpb24+LFxuICAgIHttaXNzaW5nVHJhbnNsYXRpb24gPSAnZXJyb3InLCBsb2NhbGl6ZU5hbWUgPSAnJGxvY2FsaXplJ306IFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMgPSB7fSk6XG4gICAgUGx1Z2luT2JqIHtcbiAgcmV0dXJuIHtcbiAgICB2aXNpdG9yOiB7XG4gICAgICBDYWxsRXhwcmVzc2lvbihjYWxsUGF0aDogTm9kZVBhdGg8Q2FsbEV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FsbGVlUGF0aCA9IGNhbGxQYXRoLmdldCgnY2FsbGVlJyk7XG4gICAgICAgICAgaWYgKGlzTG9jYWxpemUoY2FsbGVlUGF0aCwgbG9jYWxpemVOYW1lKSkge1xuICAgICAgICAgICAgY29uc3QgW21lc3NhZ2VQYXJ0c10gPSB1bndyYXBNZXNzYWdlUGFydHNGcm9tTG9jYWxpemVDYWxsKGNhbGxQYXRoKTtcbiAgICAgICAgICAgIGNvbnN0IFtleHByZXNzaW9uc10gPSB1bndyYXBTdWJzdGl0dXRpb25zRnJvbUxvY2FsaXplQ2FsbChjYWxsUGF0aCk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID1cbiAgICAgICAgICAgICAgICB0cmFuc2xhdGUoZGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9ucywgbWVzc2FnZVBhcnRzLCBleHByZXNzaW9ucywgbWlzc2luZ1RyYW5zbGF0aW9uKTtcbiAgICAgICAgICAgIGNhbGxQYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICBkaWFnbm9zdGljcy5lcnJvcihidWlsZENvZGVGcmFtZUVycm9yKGNhbGxQYXRoLCBlKSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRocm93IGU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9O1xufVxuIl19
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILDJFQUFzRjtJQU90Rix1RkFBaU87SUFFak87Ozs7O09BS0c7SUFDSCxTQUFnQixzQkFBc0IsQ0FDbEMsV0FBd0IsRUFBRSxZQUFnRCxFQUMxRSxFQUF1RixFQUN2RixFQUFnQztZQURoQyxxQkFBcUYsRUFBRSxLQUFBLEVBQXRGLDBCQUE0QixFQUE1QixrQkFBa0IsbUJBQUcsT0FBTyxLQUFBLEVBQUUsb0JBQTBCLEVBQTFCLFlBQVksbUJBQUcsV0FBVyxLQUFBO1FBQ3pELG1CQUFBLEVBQUEsS0FBaUIsMkJBQWEsRUFBRTtRQUNsQyxPQUFPO1lBQ0wsT0FBTyxFQUFFO2dCQUNQLGNBQWMsRUFBZCxVQUFlLFFBQWtDO29CQUMvQyxJQUFJO3dCQUNGLElBQU0sVUFBVSxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7d0JBQzFDLElBQUksOEJBQVUsQ0FBQyxVQUFVLEVBQUUsWUFBWSxDQUFDLEVBQUU7NEJBQ2xDLElBQUEsS0FBQSxlQUFpQixzREFBa0MsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLElBQUEsRUFBaEUsWUFBWSxRQUFvRCxDQUFDOzRCQUNsRSxJQUFBLEtBQUEsZUFBZ0IsdURBQW1DLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxJQUFBLEVBQWhFLFdBQVcsUUFBcUQsQ0FBQzs0QkFDeEUsSUFBTSxVQUFVLEdBQ1osNkJBQVMsQ0FBQyxXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzs0QkFDeEYsUUFBUSxDQUFDLFdBQVcsQ0FBQyw0Q0FBd0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDOUU7cUJBQ0Y7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsSUFBSSxxQ0FBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRTs0QkFDeEIsV0FBVyxDQUFDLEtBQUssQ0FBQyx1Q0FBbUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDckQ7NkJBQU07NEJBQ0wsTUFBTSxDQUFDLENBQUM7eUJBQ1Q7cUJBQ0Y7Z0JBQ0gsQ0FBQzthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUExQkQsd0RBMEJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0ZpbGVTeXN0ZW0sIGdldEZpbGVTeXN0ZW19IGZyb20gJ0Bhbmd1bGFyL2NvbXBpbGVyLWNsaS9zcmMvbmd0c2MvZmlsZV9zeXN0ZW0nO1xuaW1wb3J0IHvJtVBhcnNlZFRyYW5zbGF0aW9ufSBmcm9tICdAYW5ndWxhci9sb2NhbGl6ZSc7XG5pbXBvcnQge05vZGVQYXRoLCBQbHVnaW5PYmp9IGZyb20gJ0BiYWJlbC9jb3JlJztcbmltcG9ydCB7Q2FsbEV4cHJlc3Npb259IGZyb20gJ0BiYWJlbC90eXBlcyc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcblxuaW1wb3J0IHtidWlsZENvZGVGcmFtZUVycm9yLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0xvY2FsaXplLCB0cmFuc2xhdGUsIFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21Mb2NhbGl6ZUNhbGwsIHVud3JhcFN1YnN0aXR1dGlvbnNGcm9tTG9jYWxpemVDYWxsfSBmcm9tICcuLi8uLi9zb3VyY2VfZmlsZV91dGlscyc7XG5cbi8qKlxuICogQ3JlYXRlIGEgQmFiZWwgcGx1Z2luIHRoYXQgY2FuIGJlIHVzZWQgdG8gZG8gY29tcGlsZS10aW1lIHRyYW5zbGF0aW9uIG9mIGAkbG9jYWxpemVgIHRhZ2dlZFxuICogbWVzc2FnZXMuXG4gKlxuICogQHB1YmxpY0FwaSB1c2VkIGJ5IENMSVxuICovXG5leHBvcnQgZnVuY3Rpb24gbWFrZUVzNVRyYW5zbGF0ZVBsdWdpbihcbiAgICBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9uczogUmVjb3JkPHN0cmluZywgybVQYXJzZWRUcmFuc2xhdGlvbj4sXG4gICAge21pc3NpbmdUcmFuc2xhdGlvbiA9ICdlcnJvcicsIGxvY2FsaXplTmFtZSA9ICckbG9jYWxpemUnfTogVHJhbnNsYXRlUGx1Z2luT3B0aW9ucyA9IHt9LFxuICAgIGZzOiBGaWxlU3lzdGVtID0gZ2V0RmlsZVN5c3RlbSgpKTogUGx1Z2luT2JqIHtcbiAgcmV0dXJuIHtcbiAgICB2aXNpdG9yOiB7XG4gICAgICBDYWxsRXhwcmVzc2lvbihjYWxsUGF0aDogTm9kZVBhdGg8Q2FsbEV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FsbGVlUGF0aCA9IGNhbGxQYXRoLmdldCgnY2FsbGVlJyk7XG4gICAgICAgICAgaWYgKGlzTG9jYWxpemUoY2FsbGVlUGF0aCwgbG9jYWxpemVOYW1lKSkge1xuICAgICAgICAgICAgY29uc3QgW21lc3NhZ2VQYXJ0c10gPSB1bndyYXBNZXNzYWdlUGFydHNGcm9tTG9jYWxpemVDYWxsKGNhbGxQYXRoLCBmcyk7XG4gICAgICAgICAgICBjb25zdCBbZXhwcmVzc2lvbnNdID0gdW53cmFwU3Vic3RpdHV0aW9uc0Zyb21Mb2NhbGl6ZUNhbGwoY2FsbFBhdGgsIGZzKTtcbiAgICAgICAgICAgIGNvbnN0IHRyYW5zbGF0ZWQgPVxuICAgICAgICAgICAgICAgIHRyYW5zbGF0ZShkaWFnbm9zdGljcywgdHJhbnNsYXRpb25zLCBtZXNzYWdlUGFydHMsIGV4cHJlc3Npb25zLCBtaXNzaW5nVHJhbnNsYXRpb24pO1xuICAgICAgICAgICAgY2FsbFBhdGgucmVwbGFjZVdpdGgoYnVpbGRMb2NhbGl6ZVJlcGxhY2VtZW50KHRyYW5zbGF0ZWRbMF0sIHRyYW5zbGF0ZWRbMV0pKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICBpZiAoaXNCYWJlbFBhcnNlRXJyb3IoZSkpIHtcbiAgICAgICAgICAgIGRpYWdub3N0aWNzLmVycm9yKGJ1aWxkQ29kZUZyYW1lRXJyb3IoY2FsbFBhdGgsIGUpKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH07XG59XG4iXX0=
@@ -19,5 +19,6 @@ import { TranslatePluginOptions } from '../../source_file_utils';
19
19
  *
20
20
  * @param locale The name of the locale to inline into the code.
21
21
  * @param options Additional options including the name of the `$localize` function.
22
+ * @publicApi used by CLI
22
23
  */
23
24
  export declare function makeLocalePlugin(locale: string, { localizeName }?: TranslatePluginOptions): PluginObj;