@angular/compiler 16.0.0-next.4 → 16.0.0-next.5

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 (122) hide show
  1. package/esm2022/src/compiler_util/expression_converter.mjs +759 -0
  2. package/{esm2020 → esm2022}/src/expression_parser/parser.mjs +3 -2
  3. package/esm2022/src/i18n/digest.mjs +357 -0
  4. package/esm2022/src/i18n/i18n_ast.mjs +184 -0
  5. package/{esm2020 → esm2022}/src/render3/partial/class_metadata.mjs +1 -1
  6. package/{esm2020 → esm2022}/src/render3/partial/directive.mjs +1 -1
  7. package/{esm2020 → esm2022}/src/render3/partial/factory.mjs +1 -1
  8. package/{esm2020 → esm2022}/src/render3/partial/injectable.mjs +1 -1
  9. package/{esm2020 → esm2022}/src/render3/partial/injector.mjs +1 -1
  10. package/{esm2020 → esm2022}/src/render3/partial/ng_module.mjs +1 -1
  11. package/{esm2020 → esm2022}/src/render3/partial/pipe.mjs +1 -1
  12. package/esm2022/src/render3/r3_identifiers.mjs +214 -0
  13. package/esm2022/src/render3/view/i18n/meta.mjs +243 -0
  14. package/esm2022/src/render3/view/style_parser.mjs +86 -0
  15. package/{esm2020 → esm2022}/src/version.mjs +1 -1
  16. package/{fesm2020 → fesm2022}/compiler.mjs +221 -238
  17. package/fesm2022/compiler.mjs.map +1 -0
  18. package/{fesm2015 → fesm2022}/testing.mjs +1 -1
  19. package/index.d.ts +1 -1
  20. package/package.json +9 -17
  21. package/testing/index.d.ts +1 -1
  22. package/esm2020/src/compiler_util/expression_converter.mjs +0 -759
  23. package/esm2020/src/i18n/digest.mjs +0 -357
  24. package/esm2020/src/i18n/i18n_ast.mjs +0 -184
  25. package/esm2020/src/render3/r3_identifiers.mjs +0 -214
  26. package/esm2020/src/render3/view/i18n/meta.mjs +0 -244
  27. package/esm2020/src/render3/view/style_parser.mjs +0 -103
  28. package/fesm2015/compiler.mjs +0 -22352
  29. package/fesm2015/compiler.mjs.map +0 -1
  30. package/fesm2020/compiler.mjs.map +0 -1
  31. package/fesm2020/testing.mjs +0 -39
  32. package/fesm2020/testing.mjs.map +0 -1
  33. /package/{esm2020 → esm2022}/compiler.mjs +0 -0
  34. /package/{esm2020 → esm2022}/index.mjs +0 -0
  35. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  36. /package/{esm2020 → esm2022}/src/assertions.mjs +0 -0
  37. /package/{esm2020 → esm2022}/src/chars.mjs +0 -0
  38. /package/{esm2020 → esm2022}/src/compiler.mjs +0 -0
  39. /package/{esm2020 → esm2022}/src/compiler_facade_interface.mjs +0 -0
  40. /package/{esm2020 → esm2022}/src/config.mjs +0 -0
  41. /package/{esm2020 → esm2022}/src/constant_pool.mjs +0 -0
  42. /package/{esm2020 → esm2022}/src/core.mjs +0 -0
  43. /package/{esm2020 → esm2022}/src/expression_parser/ast.mjs +0 -0
  44. /package/{esm2020 → esm2022}/src/expression_parser/lexer.mjs +0 -0
  45. /package/{esm2020 → esm2022}/src/i18n/big_integer.mjs +0 -0
  46. /package/{esm2020 → esm2022}/src/i18n/extractor_merger.mjs +0 -0
  47. /package/{esm2020 → esm2022}/src/i18n/i18n_html_parser.mjs +0 -0
  48. /package/{esm2020 → esm2022}/src/i18n/i18n_parser.mjs +0 -0
  49. /package/{esm2020 → esm2022}/src/i18n/index.mjs +0 -0
  50. /package/{esm2020 → esm2022}/src/i18n/message_bundle.mjs +0 -0
  51. /package/{esm2020 → esm2022}/src/i18n/parse_util.mjs +0 -0
  52. /package/{esm2020 → esm2022}/src/i18n/serializers/placeholder.mjs +0 -0
  53. /package/{esm2020 → esm2022}/src/i18n/serializers/serializer.mjs +0 -0
  54. /package/{esm2020 → esm2022}/src/i18n/serializers/xliff.mjs +0 -0
  55. /package/{esm2020 → esm2022}/src/i18n/serializers/xliff2.mjs +0 -0
  56. /package/{esm2020 → esm2022}/src/i18n/serializers/xmb.mjs +0 -0
  57. /package/{esm2020 → esm2022}/src/i18n/serializers/xml_helper.mjs +0 -0
  58. /package/{esm2020 → esm2022}/src/i18n/serializers/xtb.mjs +0 -0
  59. /package/{esm2020 → esm2022}/src/i18n/translation_bundle.mjs +0 -0
  60. /package/{esm2020 → esm2022}/src/injectable_compiler_2.mjs +0 -0
  61. /package/{esm2020 → esm2022}/src/jit_compiler_facade.mjs +0 -0
  62. /package/{esm2020 → esm2022}/src/ml_parser/ast.mjs +0 -0
  63. /package/{esm2020 → esm2022}/src/ml_parser/entities.mjs +0 -0
  64. /package/{esm2020 → esm2022}/src/ml_parser/html_parser.mjs +0 -0
  65. /package/{esm2020 → esm2022}/src/ml_parser/html_tags.mjs +0 -0
  66. /package/{esm2020 → esm2022}/src/ml_parser/html_whitespaces.mjs +0 -0
  67. /package/{esm2020 → esm2022}/src/ml_parser/icu_ast_expander.mjs +0 -0
  68. /package/{esm2020 → esm2022}/src/ml_parser/interpolation_config.mjs +0 -0
  69. /package/{esm2020 → esm2022}/src/ml_parser/lexer.mjs +0 -0
  70. /package/{esm2020 → esm2022}/src/ml_parser/parser.mjs +0 -0
  71. /package/{esm2020 → esm2022}/src/ml_parser/tags.mjs +0 -0
  72. /package/{esm2020 → esm2022}/src/ml_parser/tokens.mjs +0 -0
  73. /package/{esm2020 → esm2022}/src/ml_parser/xml_parser.mjs +0 -0
  74. /package/{esm2020 → esm2022}/src/ml_parser/xml_tags.mjs +0 -0
  75. /package/{esm2020 → esm2022}/src/output/abstract_emitter.mjs +0 -0
  76. /package/{esm2020 → esm2022}/src/output/abstract_js_emitter.mjs +0 -0
  77. /package/{esm2020 → esm2022}/src/output/map_util.mjs +0 -0
  78. /package/{esm2020 → esm2022}/src/output/output_ast.mjs +0 -0
  79. /package/{esm2020 → esm2022}/src/output/output_jit.mjs +0 -0
  80. /package/{esm2020 → esm2022}/src/output/output_jit_trusted_types.mjs +0 -0
  81. /package/{esm2020 → esm2022}/src/output/source_map.mjs +0 -0
  82. /package/{esm2020 → esm2022}/src/parse_util.mjs +0 -0
  83. /package/{esm2020 → esm2022}/src/render3/partial/api.mjs +0 -0
  84. /package/{esm2020 → esm2022}/src/render3/partial/component.mjs +0 -0
  85. /package/{esm2020 → esm2022}/src/render3/partial/util.mjs +0 -0
  86. /package/{esm2020 → esm2022}/src/render3/r3_ast.mjs +0 -0
  87. /package/{esm2020 → esm2022}/src/render3/r3_class_metadata_compiler.mjs +0 -0
  88. /package/{esm2020 → esm2022}/src/render3/r3_factory.mjs +0 -0
  89. /package/{esm2020 → esm2022}/src/render3/r3_injector_compiler.mjs +0 -0
  90. /package/{esm2020 → esm2022}/src/render3/r3_jit.mjs +0 -0
  91. /package/{esm2020 → esm2022}/src/render3/r3_module_compiler.mjs +0 -0
  92. /package/{esm2020 → esm2022}/src/render3/r3_pipe_compiler.mjs +0 -0
  93. /package/{esm2020 → esm2022}/src/render3/r3_template_transform.mjs +0 -0
  94. /package/{esm2020 → esm2022}/src/render3/util.mjs +0 -0
  95. /package/{esm2020 → esm2022}/src/render3/view/api.mjs +0 -0
  96. /package/{esm2020 → esm2022}/src/render3/view/compiler.mjs +0 -0
  97. /package/{esm2020 → esm2022}/src/render3/view/i18n/context.mjs +0 -0
  98. /package/{esm2020 → esm2022}/src/render3/view/i18n/get_msg_utils.mjs +0 -0
  99. /package/{esm2020 → esm2022}/src/render3/view/i18n/icu_serializer.mjs +0 -0
  100. /package/{esm2020 → esm2022}/src/render3/view/i18n/localize_utils.mjs +0 -0
  101. /package/{esm2020 → esm2022}/src/render3/view/i18n/util.mjs +0 -0
  102. /package/{esm2020 → esm2022}/src/render3/view/styling_builder.mjs +0 -0
  103. /package/{esm2020 → esm2022}/src/render3/view/t2_api.mjs +0 -0
  104. /package/{esm2020 → esm2022}/src/render3/view/t2_binder.mjs +0 -0
  105. /package/{esm2020 → esm2022}/src/render3/view/template.mjs +0 -0
  106. /package/{esm2020 → esm2022}/src/render3/view/util.mjs +0 -0
  107. /package/{esm2020 → esm2022}/src/resource_loader.mjs +0 -0
  108. /package/{esm2020 → esm2022}/src/schema/dom_element_schema_registry.mjs +0 -0
  109. /package/{esm2020 → esm2022}/src/schema/dom_security_schema.mjs +0 -0
  110. /package/{esm2020 → esm2022}/src/schema/element_schema_registry.mjs +0 -0
  111. /package/{esm2020 → esm2022}/src/schema/trusted_types_sinks.mjs +0 -0
  112. /package/{esm2020 → esm2022}/src/selector.mjs +0 -0
  113. /package/{esm2020 → esm2022}/src/shadow_css.mjs +0 -0
  114. /package/{esm2020 → esm2022}/src/style_url_resolver.mjs +0 -0
  115. /package/{esm2020 → esm2022}/src/template_parser/binding_parser.mjs +0 -0
  116. /package/{esm2020 → esm2022}/src/template_parser/template_preparser.mjs +0 -0
  117. /package/{esm2020 → esm2022}/src/util.mjs +0 -0
  118. /package/{esm2020 → esm2022}/testing/index.mjs +0 -0
  119. /package/{esm2020 → esm2022}/testing/public_api.mjs +0 -0
  120. /package/{esm2020 → esm2022}/testing/src/testing.mjs +0 -0
  121. /package/{esm2020 → esm2022}/testing/testing.mjs +0 -0
  122. /package/{fesm2015 → fesm2022}/testing.mjs.map +0 -0
@@ -0,0 +1,357 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { BigIntExponentiation } from './big_integer';
9
+ /**
10
+ * A lazily created TextEncoder instance for converting strings into UTF-8 bytes
11
+ */
12
+ let textEncoder;
13
+ /**
14
+ * Return the message id or compute it using the XLIFF1 digest.
15
+ */
16
+ export function digest(message) {
17
+ return message.id || computeDigest(message);
18
+ }
19
+ /**
20
+ * Compute the message id using the XLIFF1 digest.
21
+ */
22
+ export function computeDigest(message) {
23
+ return sha1(serializeNodes(message.nodes).join('') + `[${message.meaning}]`);
24
+ }
25
+ /**
26
+ * Return the message id or compute it using the XLIFF2/XMB/$localize digest.
27
+ */
28
+ export function decimalDigest(message) {
29
+ return message.id || computeDecimalDigest(message);
30
+ }
31
+ /**
32
+ * Compute the message id using the XLIFF2/XMB/$localize digest.
33
+ */
34
+ export function computeDecimalDigest(message) {
35
+ const visitor = new _SerializerIgnoreIcuExpVisitor();
36
+ const parts = message.nodes.map(a => a.visit(visitor, null));
37
+ return computeMsgId(parts.join(''), message.meaning);
38
+ }
39
+ /**
40
+ * Serialize the i18n ast to something xml-like in order to generate an UID.
41
+ *
42
+ * The visitor is also used in the i18n parser tests
43
+ *
44
+ * @internal
45
+ */
46
+ class _SerializerVisitor {
47
+ visitText(text, context) {
48
+ return text.value;
49
+ }
50
+ visitContainer(container, context) {
51
+ return `[${container.children.map(child => child.visit(this)).join(', ')}]`;
52
+ }
53
+ visitIcu(icu, context) {
54
+ const strCases = Object.keys(icu.cases).map((k) => `${k} {${icu.cases[k].visit(this)}}`);
55
+ return `{${icu.expression}, ${icu.type}, ${strCases.join(', ')}}`;
56
+ }
57
+ visitTagPlaceholder(ph, context) {
58
+ return ph.isVoid ?
59
+ `<ph tag name="${ph.startName}"/>` :
60
+ `<ph tag name="${ph.startName}">${ph.children.map(child => child.visit(this)).join(', ')}</ph name="${ph.closeName}">`;
61
+ }
62
+ visitPlaceholder(ph, context) {
63
+ return ph.value ? `<ph name="${ph.name}">${ph.value}</ph>` : `<ph name="${ph.name}"/>`;
64
+ }
65
+ visitIcuPlaceholder(ph, context) {
66
+ return `<ph icu name="${ph.name}">${ph.value.visit(this)}</ph>`;
67
+ }
68
+ }
69
+ const serializerVisitor = new _SerializerVisitor();
70
+ export function serializeNodes(nodes) {
71
+ return nodes.map(a => a.visit(serializerVisitor, null));
72
+ }
73
+ /**
74
+ * Serialize the i18n ast to something xml-like in order to generate an UID.
75
+ *
76
+ * Ignore the ICU expressions so that message IDs stays identical if only the expression changes.
77
+ *
78
+ * @internal
79
+ */
80
+ class _SerializerIgnoreIcuExpVisitor extends _SerializerVisitor {
81
+ visitIcu(icu, context) {
82
+ let strCases = Object.keys(icu.cases).map((k) => `${k} {${icu.cases[k].visit(this)}}`);
83
+ // Do not take the expression into account
84
+ return `{${icu.type}, ${strCases.join(', ')}}`;
85
+ }
86
+ }
87
+ /**
88
+ * Compute the SHA1 of the given string
89
+ *
90
+ * see https://csrc.nist.gov/publications/fips/fips180-4/fips-180-4.pdf
91
+ *
92
+ * WARNING: this function has not been designed not tested with security in mind.
93
+ * DO NOT USE IT IN A SECURITY SENSITIVE CONTEXT.
94
+ */
95
+ export function sha1(str) {
96
+ textEncoder ??= new TextEncoder();
97
+ const utf8 = [...textEncoder.encode(str)];
98
+ const words32 = bytesToWords32(utf8, Endian.Big);
99
+ const len = utf8.length * 8;
100
+ const w = new Uint32Array(80);
101
+ let a = 0x67452301, b = 0xefcdab89, c = 0x98badcfe, d = 0x10325476, e = 0xc3d2e1f0;
102
+ words32[len >> 5] |= 0x80 << (24 - len % 32);
103
+ words32[((len + 64 >> 9) << 4) + 15] = len;
104
+ for (let i = 0; i < words32.length; i += 16) {
105
+ const h0 = a, h1 = b, h2 = c, h3 = d, h4 = e;
106
+ for (let j = 0; j < 80; j++) {
107
+ if (j < 16) {
108
+ w[j] = words32[i + j];
109
+ }
110
+ else {
111
+ w[j] = rol32(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);
112
+ }
113
+ const fkVal = fk(j, b, c, d);
114
+ const f = fkVal[0];
115
+ const k = fkVal[1];
116
+ const temp = [rol32(a, 5), f, e, k, w[j]].reduce(add32);
117
+ e = d;
118
+ d = c;
119
+ c = rol32(b, 30);
120
+ b = a;
121
+ a = temp;
122
+ }
123
+ a = add32(a, h0);
124
+ b = add32(b, h1);
125
+ c = add32(c, h2);
126
+ d = add32(d, h3);
127
+ e = add32(e, h4);
128
+ }
129
+ // Convert the output parts to a 160-bit hexadecimal string
130
+ return toHexU32(a) + toHexU32(b) + toHexU32(c) + toHexU32(d) + toHexU32(e);
131
+ }
132
+ /**
133
+ * Convert and format a number as a string representing a 32-bit unsigned hexadecimal number.
134
+ * @param value The value to format as a string.
135
+ * @returns A hexadecimal string representing the value.
136
+ */
137
+ function toHexU32(value) {
138
+ // unsigned right shift of zero ensures an unsigned 32-bit number
139
+ return (value >>> 0).toString(16).padStart(8, '0');
140
+ }
141
+ function fk(index, b, c, d) {
142
+ if (index < 20) {
143
+ return [(b & c) | (~b & d), 0x5a827999];
144
+ }
145
+ if (index < 40) {
146
+ return [b ^ c ^ d, 0x6ed9eba1];
147
+ }
148
+ if (index < 60) {
149
+ return [(b & c) | (b & d) | (c & d), 0x8f1bbcdc];
150
+ }
151
+ return [b ^ c ^ d, 0xca62c1d6];
152
+ }
153
+ /**
154
+ * Compute the fingerprint of the given string
155
+ *
156
+ * The output is 64 bit number encoded as a decimal string
157
+ *
158
+ * based on:
159
+ * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/GoogleJsMessageIdGenerator.java
160
+ */
161
+ export function fingerprint(str) {
162
+ textEncoder ??= new TextEncoder();
163
+ const utf8 = textEncoder.encode(str);
164
+ const view = new DataView(utf8.buffer, utf8.byteOffset, utf8.byteLength);
165
+ let hi = hash32(view, utf8.length, 0);
166
+ let lo = hash32(view, utf8.length, 102072);
167
+ if (hi == 0 && (lo == 0 || lo == 1)) {
168
+ hi = hi ^ 0x130f9bef;
169
+ lo = lo ^ -0x6b5f56d8;
170
+ }
171
+ return [hi, lo];
172
+ }
173
+ export function computeMsgId(msg, meaning = '') {
174
+ let msgFingerprint = fingerprint(msg);
175
+ if (meaning) {
176
+ const meaningFingerprint = fingerprint(meaning);
177
+ msgFingerprint = add64(rol64(msgFingerprint, 1), meaningFingerprint);
178
+ }
179
+ const hi = msgFingerprint[0];
180
+ const lo = msgFingerprint[1];
181
+ return wordsToDecimalString(hi & 0x7fffffff, lo);
182
+ }
183
+ function hash32(view, length, c) {
184
+ let a = 0x9e3779b9, b = 0x9e3779b9;
185
+ let index = 0;
186
+ const end = length - 12;
187
+ for (; index <= end; index += 12) {
188
+ a += view.getUint32(index, true);
189
+ b += view.getUint32(index + 4, true);
190
+ c += view.getUint32(index + 8, true);
191
+ const res = mix(a, b, c);
192
+ a = res[0], b = res[1], c = res[2];
193
+ }
194
+ const remainder = length - index;
195
+ // the first byte of c is reserved for the length
196
+ c += length;
197
+ if (remainder >= 4) {
198
+ a += view.getUint32(index, true);
199
+ index += 4;
200
+ if (remainder >= 8) {
201
+ b += view.getUint32(index, true);
202
+ index += 4;
203
+ // Partial 32-bit word for c
204
+ if (remainder >= 9) {
205
+ c += view.getUint8(index++) << 8;
206
+ }
207
+ if (remainder >= 10) {
208
+ c += view.getUint8(index++) << 16;
209
+ }
210
+ if (remainder === 11) {
211
+ c += view.getUint8(index++) << 24;
212
+ }
213
+ }
214
+ else {
215
+ // Partial 32-bit word for b
216
+ if (remainder >= 5) {
217
+ b += view.getUint8(index++);
218
+ }
219
+ if (remainder >= 6) {
220
+ b += view.getUint8(index++) << 8;
221
+ }
222
+ if (remainder === 7) {
223
+ b += view.getUint8(index++) << 16;
224
+ }
225
+ }
226
+ }
227
+ else {
228
+ // Partial 32-bit word for a
229
+ if (remainder >= 1) {
230
+ a += view.getUint8(index++);
231
+ }
232
+ if (remainder >= 2) {
233
+ a += view.getUint8(index++) << 8;
234
+ }
235
+ if (remainder === 3) {
236
+ a += view.getUint8(index++) << 16;
237
+ }
238
+ }
239
+ return mix(a, b, c)[2];
240
+ }
241
+ // clang-format off
242
+ function mix(a, b, c) {
243
+ a -= b;
244
+ a -= c;
245
+ a ^= c >>> 13;
246
+ b -= c;
247
+ b -= a;
248
+ b ^= a << 8;
249
+ c -= a;
250
+ c -= b;
251
+ c ^= b >>> 13;
252
+ a -= b;
253
+ a -= c;
254
+ a ^= c >>> 12;
255
+ b -= c;
256
+ b -= a;
257
+ b ^= a << 16;
258
+ c -= a;
259
+ c -= b;
260
+ c ^= b >>> 5;
261
+ a -= b;
262
+ a -= c;
263
+ a ^= c >>> 3;
264
+ b -= c;
265
+ b -= a;
266
+ b ^= a << 10;
267
+ c -= a;
268
+ c -= b;
269
+ c ^= b >>> 15;
270
+ return [a, b, c];
271
+ }
272
+ // clang-format on
273
+ // Utils
274
+ var Endian;
275
+ (function (Endian) {
276
+ Endian[Endian["Little"] = 0] = "Little";
277
+ Endian[Endian["Big"] = 1] = "Big";
278
+ })(Endian || (Endian = {}));
279
+ function add32(a, b) {
280
+ return add32to64(a, b)[1];
281
+ }
282
+ function add32to64(a, b) {
283
+ const low = (a & 0xffff) + (b & 0xffff);
284
+ const high = (a >>> 16) + (b >>> 16) + (low >>> 16);
285
+ return [high >>> 16, (high << 16) | (low & 0xffff)];
286
+ }
287
+ function add64(a, b) {
288
+ const ah = a[0], al = a[1];
289
+ const bh = b[0], bl = b[1];
290
+ const result = add32to64(al, bl);
291
+ const carry = result[0];
292
+ const l = result[1];
293
+ const h = add32(add32(ah, bh), carry);
294
+ return [h, l];
295
+ }
296
+ // Rotate a 32b number left `count` position
297
+ function rol32(a, count) {
298
+ return (a << count) | (a >>> (32 - count));
299
+ }
300
+ // Rotate a 64b number left `count` position
301
+ function rol64(num, count) {
302
+ const hi = num[0], lo = num[1];
303
+ const h = (hi << count) | (lo >>> (32 - count));
304
+ const l = (lo << count) | (hi >>> (32 - count));
305
+ return [h, l];
306
+ }
307
+ function bytesToWords32(bytes, endian) {
308
+ const size = (bytes.length + 3) >>> 2;
309
+ const words32 = [];
310
+ for (let i = 0; i < size; i++) {
311
+ words32[i] = wordAt(bytes, i * 4, endian);
312
+ }
313
+ return words32;
314
+ }
315
+ function byteAt(bytes, index) {
316
+ return index >= bytes.length ? 0 : bytes[index];
317
+ }
318
+ function wordAt(bytes, index, endian) {
319
+ let word = 0;
320
+ if (endian === Endian.Big) {
321
+ for (let i = 0; i < 4; i++) {
322
+ word += byteAt(bytes, index + i) << (24 - 8 * i);
323
+ }
324
+ }
325
+ else {
326
+ for (let i = 0; i < 4; i++) {
327
+ word += byteAt(bytes, index + i) << 8 * i;
328
+ }
329
+ }
330
+ return word;
331
+ }
332
+ /**
333
+ * Create a shared exponentiation pool for base-256 computations. This shared pool provides memoized
334
+ * power-of-256 results with memoized power-of-two computations for efficient multiplication.
335
+ *
336
+ * For our purposes, this can be safely stored as a global without memory concerns. The reason is
337
+ * that we encode two words, so only need the 0th (for the low word) and 4th (for the high word)
338
+ * exponent.
339
+ */
340
+ const base256 = new BigIntExponentiation(256);
341
+ /**
342
+ * Represents two 32-bit words as a single decimal number. This requires a big integer storage
343
+ * model as JS numbers are not accurate enough to represent the 64-bit number.
344
+ *
345
+ * Based on https://www.danvk.org/hex2dec.html
346
+ */
347
+ function wordsToDecimalString(hi, lo) {
348
+ // Encode the four bytes in lo in the lower digits of the decimal number.
349
+ // Note: the multiplication results in lo itself but represented by a big integer using its
350
+ // decimal digits.
351
+ const decimal = base256.toThePowerOf(0).multiplyBy(lo);
352
+ // Encode the four bytes in hi above the four lo bytes. lo is a maximum of (2^8)^4, which is why
353
+ // this multiplication factor is applied.
354
+ base256.toThePowerOf(4).multiplyByAndAddTo(hi, decimal);
355
+ return decimal.toString();
356
+ }
357
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digest.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/i18n/digest.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 {Byte} from '../util';\n\nimport {BigIntExponentiation} from './big_integer';\nimport * as i18n from './i18n_ast';\n\n/**\n * A lazily created TextEncoder instance for converting strings into UTF-8 bytes\n */\nlet textEncoder: TextEncoder|undefined;\n\n/**\n * Return the message id or compute it using the XLIFF1 digest.\n */\nexport function digest(message: i18n.Message): string {\n  return message.id || computeDigest(message);\n}\n\n/**\n * Compute the message id using the XLIFF1 digest.\n */\nexport function computeDigest(message: i18n.Message): string {\n  return sha1(serializeNodes(message.nodes).join('') + `[${message.meaning}]`);\n}\n\n/**\n * Return the message id or compute it using the XLIFF2/XMB/$localize digest.\n */\nexport function decimalDigest(message: i18n.Message): string {\n  return message.id || computeDecimalDigest(message);\n}\n\n/**\n * Compute the message id using the XLIFF2/XMB/$localize digest.\n */\nexport function computeDecimalDigest(message: i18n.Message): string {\n  const visitor = new _SerializerIgnoreIcuExpVisitor();\n  const parts = message.nodes.map(a => a.visit(visitor, null));\n  return computeMsgId(parts.join(''), message.meaning);\n}\n\n/**\n * Serialize the i18n ast to something xml-like in order to generate an UID.\n *\n * The visitor is also used in the i18n parser tests\n *\n * @internal\n */\nclass _SerializerVisitor implements i18n.Visitor {\n  visitText(text: i18n.Text, context: any): any {\n    return text.value;\n  }\n\n  visitContainer(container: i18n.Container, context: any): any {\n    return `[${container.children.map(child => child.visit(this)).join(', ')}]`;\n  }\n\n  visitIcu(icu: i18n.Icu, context: any): any {\n    const strCases =\n        Object.keys(icu.cases).map((k: string) => `${k} {${icu.cases[k].visit(this)}}`);\n    return `{${icu.expression}, ${icu.type}, ${strCases.join(', ')}}`;\n  }\n\n  visitTagPlaceholder(ph: i18n.TagPlaceholder, context: any): any {\n    return ph.isVoid ?\n        `<ph tag name=\"${ph.startName}\"/>` :\n        `<ph tag name=\"${ph.startName}\">${\n            ph.children.map(child => child.visit(this)).join(', ')}</ph name=\"${ph.closeName}\">`;\n  }\n\n  visitPlaceholder(ph: i18n.Placeholder, context: any): any {\n    return ph.value ? `<ph name=\"${ph.name}\">${ph.value}</ph>` : `<ph name=\"${ph.name}\"/>`;\n  }\n\n  visitIcuPlaceholder(ph: i18n.IcuPlaceholder, context?: any): any {\n    return `<ph icu name=\"${ph.name}\">${ph.value.visit(this)}</ph>`;\n  }\n}\n\nconst serializerVisitor = new _SerializerVisitor();\n\nexport function serializeNodes(nodes: i18n.Node[]): string[] {\n  return nodes.map(a => a.visit(serializerVisitor, null));\n}\n\n/**\n * Serialize the i18n ast to something xml-like in order to generate an UID.\n *\n * Ignore the ICU expressions so that message IDs stays identical if only the expression changes.\n *\n * @internal\n */\nclass _SerializerIgnoreIcuExpVisitor extends _SerializerVisitor {\n  override visitIcu(icu: i18n.Icu, context: any): any {\n    let strCases = Object.keys(icu.cases).map((k: string) => `${k} {${icu.cases[k].visit(this)}}`);\n    // Do not take the expression into account\n    return `{${icu.type}, ${strCases.join(', ')}}`;\n  }\n}\n\n/**\n * Compute the SHA1 of the given string\n *\n * see https://csrc.nist.gov/publications/fips/fips180-4/fips-180-4.pdf\n *\n * WARNING: this function has not been designed not tested with security in mind.\n *          DO NOT USE IT IN A SECURITY SENSITIVE CONTEXT.\n */\nexport function sha1(str: string): string {\n  textEncoder ??= new TextEncoder();\n  const utf8 = [...textEncoder.encode(str)];\n  const words32 = bytesToWords32(utf8, Endian.Big);\n  const len = utf8.length * 8;\n\n  const w = new Uint32Array(80);\n  let a = 0x67452301, b = 0xefcdab89, c = 0x98badcfe, d = 0x10325476, e = 0xc3d2e1f0;\n\n  words32[len >> 5] |= 0x80 << (24 - len % 32);\n  words32[((len + 64 >> 9) << 4) + 15] = len;\n\n  for (let i = 0; i < words32.length; i += 16) {\n    const h0 = a, h1 = b, h2 = c, h3 = d, h4 = e;\n\n    for (let j = 0; j < 80; j++) {\n      if (j < 16) {\n        w[j] = words32[i + j];\n      } else {\n        w[j] = rol32(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);\n      }\n\n      const fkVal = fk(j, b, c, d);\n      const f = fkVal[0];\n      const k = fkVal[1];\n      const temp = [rol32(a, 5), f, e, k, w[j]].reduce(add32);\n      e = d;\n      d = c;\n      c = rol32(b, 30);\n      b = a;\n      a = temp;\n    }\n    a = add32(a, h0);\n    b = add32(b, h1);\n    c = add32(c, h2);\n    d = add32(d, h3);\n    e = add32(e, h4);\n  }\n\n  // Convert the output parts to a 160-bit hexadecimal string\n  return toHexU32(a) + toHexU32(b) + toHexU32(c) + toHexU32(d) + toHexU32(e);\n}\n\n/**\n * Convert and format a number as a string representing a 32-bit unsigned hexadecimal number.\n * @param value The value to format as a string.\n * @returns A hexadecimal string representing the value.\n */\nfunction toHexU32(value: number): string {\n  // unsigned right shift of zero ensures an unsigned 32-bit number\n  return (value >>> 0).toString(16).padStart(8, '0');\n}\n\nfunction fk(index: number, b: number, c: number, d: number): [number, number] {\n  if (index < 20) {\n    return [(b & c) | (~b & d), 0x5a827999];\n  }\n\n  if (index < 40) {\n    return [b ^ c ^ d, 0x6ed9eba1];\n  }\n\n  if (index < 60) {\n    return [(b & c) | (b & d) | (c & d), 0x8f1bbcdc];\n  }\n\n  return [b ^ c ^ d, 0xca62c1d6];\n}\n\n/**\n * Compute the fingerprint of the given string\n *\n * The output is 64 bit number encoded as a decimal string\n *\n * based on:\n * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/GoogleJsMessageIdGenerator.java\n */\nexport function fingerprint(str: string): [number, number] {\n  textEncoder ??= new TextEncoder();\n  const utf8 = textEncoder.encode(str);\n  const view = new DataView(utf8.buffer, utf8.byteOffset, utf8.byteLength);\n\n  let hi = hash32(view, utf8.length, 0);\n  let lo = hash32(view, utf8.length, 102072);\n\n  if (hi == 0 && (lo == 0 || lo == 1)) {\n    hi = hi ^ 0x130f9bef;\n    lo = lo ^ -0x6b5f56d8;\n  }\n\n  return [hi, lo];\n}\n\nexport function computeMsgId(msg: string, meaning: string = ''): string {\n  let msgFingerprint = fingerprint(msg);\n\n  if (meaning) {\n    const meaningFingerprint = fingerprint(meaning);\n    msgFingerprint = add64(rol64(msgFingerprint, 1), meaningFingerprint);\n  }\n\n  const hi = msgFingerprint[0];\n  const lo = msgFingerprint[1];\n\n  return wordsToDecimalString(hi & 0x7fffffff, lo);\n}\n\nfunction hash32(view: DataView, length: number, c: number): number {\n  let a = 0x9e3779b9, b = 0x9e3779b9;\n  let index = 0;\n\n  const end = length - 12;\n  for (; index <= end; index += 12) {\n    a += view.getUint32(index, true);\n    b += view.getUint32(index + 4, true);\n    c += view.getUint32(index + 8, true);\n    const res = mix(a, b, c);\n    a = res[0], b = res[1], c = res[2];\n  }\n\n  const remainder = length - index;\n\n  // the first byte of c is reserved for the length\n  c += length;\n\n  if (remainder >= 4) {\n    a += view.getUint32(index, true);\n    index += 4;\n\n    if (remainder >= 8) {\n      b += view.getUint32(index, true);\n      index += 4;\n\n      // Partial 32-bit word for c\n      if (remainder >= 9) {\n        c += view.getUint8(index++) << 8;\n      }\n      if (remainder >= 10) {\n        c += view.getUint8(index++) << 16;\n      }\n      if (remainder === 11) {\n        c += view.getUint8(index++) << 24;\n      }\n    } else {\n      // Partial 32-bit word for b\n      if (remainder >= 5) {\n        b += view.getUint8(index++);\n      }\n      if (remainder >= 6) {\n        b += view.getUint8(index++) << 8;\n      }\n      if (remainder === 7) {\n        b += view.getUint8(index++) << 16;\n      }\n    }\n  } else {\n    // Partial 32-bit word for a\n    if (remainder >= 1) {\n      a += view.getUint8(index++);\n    }\n    if (remainder >= 2) {\n      a += view.getUint8(index++) << 8;\n    }\n    if (remainder === 3) {\n      a += view.getUint8(index++) << 16;\n    }\n  }\n\n  return mix(a, b, c)[2];\n}\n\n// clang-format off\nfunction mix(a: number, b: number, c: number): [number, number, number] {\n  a -= b; a -= c; a ^= c >>> 13;\n  b -= c; b -= a; b ^= a << 8;\n  c -= a; c -= b; c ^= b >>> 13;\n  a -= b; a -= c; a ^= c >>> 12;\n  b -= c; b -= a; b ^= a << 16;\n  c -= a; c -= b; c ^= b >>> 5;\n  a -= b; a -= c; a ^= c >>> 3;\n  b -= c; b -= a; b ^= a << 10;\n  c -= a; c -= b; c ^= b >>> 15;\n  return [a, b, c];\n}\n// clang-format on\n\n// Utils\n\nenum Endian {\n  Little,\n  Big,\n}\n\nfunction add32(a: number, b: number): number {\n  return add32to64(a, b)[1];\n}\n\nfunction add32to64(a: number, b: number): [number, number] {\n  const low = (a & 0xffff) + (b & 0xffff);\n  const high = (a >>> 16) + (b >>> 16) + (low >>> 16);\n  return [high >>> 16, (high << 16) | (low & 0xffff)];\n}\n\nfunction add64(a: [number, number], b: [number, number]): [number, number] {\n  const ah = a[0], al = a[1];\n  const bh = b[0], bl = b[1];\n  const result = add32to64(al, bl);\n  const carry = result[0];\n  const l = result[1];\n  const h = add32(add32(ah, bh), carry);\n  return [h, l];\n}\n\n// Rotate a 32b number left `count` position\nfunction rol32(a: number, count: number): number {\n  return (a << count) | (a >>> (32 - count));\n}\n\n// Rotate a 64b number left `count` position\nfunction rol64(num: [number, number], count: number): [number, number] {\n  const hi = num[0], lo = num[1];\n  const h = (hi << count) | (lo >>> (32 - count));\n  const l = (lo << count) | (hi >>> (32 - count));\n  return [h, l];\n}\n\nfunction bytesToWords32(bytes: Byte[], endian: Endian): number[] {\n  const size = (bytes.length + 3) >>> 2;\n  const words32 = [];\n\n  for (let i = 0; i < size; i++) {\n    words32[i] = wordAt(bytes, i * 4, endian);\n  }\n\n  return words32;\n}\n\nfunction byteAt(bytes: Byte[], index: number): Byte {\n  return index >= bytes.length ? 0 : bytes[index];\n}\n\nfunction wordAt(bytes: Byte[], index: number, endian: Endian): number {\n  let word = 0;\n  if (endian === Endian.Big) {\n    for (let i = 0; i < 4; i++) {\n      word += byteAt(bytes, index + i) << (24 - 8 * i);\n    }\n  } else {\n    for (let i = 0; i < 4; i++) {\n      word += byteAt(bytes, index + i) << 8 * i;\n    }\n  }\n  return word;\n}\n\n/**\n * Create a shared exponentiation pool for base-256 computations. This shared pool provides memoized\n * power-of-256 results with memoized power-of-two computations for efficient multiplication.\n *\n * For our purposes, this can be safely stored as a global without memory concerns. The reason is\n * that we encode two words, so only need the 0th (for the low word) and 4th (for the high word)\n * exponent.\n */\nconst base256 = new BigIntExponentiation(256);\n\n/**\n * Represents two 32-bit words as a single decimal number. This requires a big integer storage\n * model as JS numbers are not accurate enough to represent the 64-bit number.\n *\n * Based on https://www.danvk.org/hex2dec.html\n */\nfunction wordsToDecimalString(hi: number, lo: number): string {\n  // Encode the four bytes in lo in the lower digits of the decimal number.\n  // Note: the multiplication results in lo itself but represented by a big integer using its\n  // decimal digits.\n  const decimal = base256.toThePowerOf(0).multiplyBy(lo);\n\n  // Encode the four bytes in hi above the four lo bytes. lo is a maximum of (2^8)^4, which is why\n  // this multiplication factor is applied.\n  base256.toThePowerOf(4).multiplyByAndAddTo(hi, decimal);\n\n  return decimal.toString();\n}\n"]}
@@ -0,0 +1,184 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ export class Message {
9
+ /**
10
+ * @param nodes message AST
11
+ * @param placeholders maps placeholder names to static content and their source spans
12
+ * @param placeholderToMessage maps placeholder names to messages (used for nested ICU messages)
13
+ * @param meaning
14
+ * @param description
15
+ * @param customId
16
+ */
17
+ constructor(nodes, placeholders, placeholderToMessage, meaning, description, customId) {
18
+ this.nodes = nodes;
19
+ this.placeholders = placeholders;
20
+ this.placeholderToMessage = placeholderToMessage;
21
+ this.meaning = meaning;
22
+ this.description = description;
23
+ this.customId = customId;
24
+ /** The ids to use if there are no custom id and if `i18nLegacyMessageIdFormat` is not empty */
25
+ this.legacyIds = [];
26
+ this.id = this.customId;
27
+ this.messageString = serializeMessage(this.nodes);
28
+ if (nodes.length) {
29
+ this.sources = [{
30
+ filePath: nodes[0].sourceSpan.start.file.url,
31
+ startLine: nodes[0].sourceSpan.start.line + 1,
32
+ startCol: nodes[0].sourceSpan.start.col + 1,
33
+ endLine: nodes[nodes.length - 1].sourceSpan.end.line + 1,
34
+ endCol: nodes[0].sourceSpan.start.col + 1
35
+ }];
36
+ }
37
+ else {
38
+ this.sources = [];
39
+ }
40
+ }
41
+ }
42
+ export class Text {
43
+ constructor(value, sourceSpan) {
44
+ this.value = value;
45
+ this.sourceSpan = sourceSpan;
46
+ }
47
+ visit(visitor, context) {
48
+ return visitor.visitText(this, context);
49
+ }
50
+ }
51
+ // TODO(vicb): do we really need this node (vs an array) ?
52
+ export class Container {
53
+ constructor(children, sourceSpan) {
54
+ this.children = children;
55
+ this.sourceSpan = sourceSpan;
56
+ }
57
+ visit(visitor, context) {
58
+ return visitor.visitContainer(this, context);
59
+ }
60
+ }
61
+ export class Icu {
62
+ constructor(expression, type, cases, sourceSpan) {
63
+ this.expression = expression;
64
+ this.type = type;
65
+ this.cases = cases;
66
+ this.sourceSpan = sourceSpan;
67
+ }
68
+ visit(visitor, context) {
69
+ return visitor.visitIcu(this, context);
70
+ }
71
+ }
72
+ export class TagPlaceholder {
73
+ constructor(tag, attrs, startName, closeName, children, isVoid,
74
+ // TODO sourceSpan should cover all (we need a startSourceSpan and endSourceSpan)
75
+ sourceSpan, startSourceSpan, endSourceSpan) {
76
+ this.tag = tag;
77
+ this.attrs = attrs;
78
+ this.startName = startName;
79
+ this.closeName = closeName;
80
+ this.children = children;
81
+ this.isVoid = isVoid;
82
+ this.sourceSpan = sourceSpan;
83
+ this.startSourceSpan = startSourceSpan;
84
+ this.endSourceSpan = endSourceSpan;
85
+ }
86
+ visit(visitor, context) {
87
+ return visitor.visitTagPlaceholder(this, context);
88
+ }
89
+ }
90
+ export class Placeholder {
91
+ constructor(value, name, sourceSpan) {
92
+ this.value = value;
93
+ this.name = name;
94
+ this.sourceSpan = sourceSpan;
95
+ }
96
+ visit(visitor, context) {
97
+ return visitor.visitPlaceholder(this, context);
98
+ }
99
+ }
100
+ export class IcuPlaceholder {
101
+ constructor(value, name, sourceSpan) {
102
+ this.value = value;
103
+ this.name = name;
104
+ this.sourceSpan = sourceSpan;
105
+ }
106
+ visit(visitor, context) {
107
+ return visitor.visitIcuPlaceholder(this, context);
108
+ }
109
+ }
110
+ // Clone the AST
111
+ export class CloneVisitor {
112
+ visitText(text, context) {
113
+ return new Text(text.value, text.sourceSpan);
114
+ }
115
+ visitContainer(container, context) {
116
+ const children = container.children.map(n => n.visit(this, context));
117
+ return new Container(children, container.sourceSpan);
118
+ }
119
+ visitIcu(icu, context) {
120
+ const cases = {};
121
+ Object.keys(icu.cases).forEach(key => cases[key] = icu.cases[key].visit(this, context));
122
+ const msg = new Icu(icu.expression, icu.type, cases, icu.sourceSpan);
123
+ msg.expressionPlaceholder = icu.expressionPlaceholder;
124
+ return msg;
125
+ }
126
+ visitTagPlaceholder(ph, context) {
127
+ const children = ph.children.map(n => n.visit(this, context));
128
+ return new TagPlaceholder(ph.tag, ph.attrs, ph.startName, ph.closeName, children, ph.isVoid, ph.sourceSpan, ph.startSourceSpan, ph.endSourceSpan);
129
+ }
130
+ visitPlaceholder(ph, context) {
131
+ return new Placeholder(ph.value, ph.name, ph.sourceSpan);
132
+ }
133
+ visitIcuPlaceholder(ph, context) {
134
+ return new IcuPlaceholder(ph.value, ph.name, ph.sourceSpan);
135
+ }
136
+ }
137
+ // Visit all the nodes recursively
138
+ export class RecurseVisitor {
139
+ visitText(text, context) { }
140
+ visitContainer(container, context) {
141
+ container.children.forEach(child => child.visit(this));
142
+ }
143
+ visitIcu(icu, context) {
144
+ Object.keys(icu.cases).forEach(k => {
145
+ icu.cases[k].visit(this);
146
+ });
147
+ }
148
+ visitTagPlaceholder(ph, context) {
149
+ ph.children.forEach(child => child.visit(this));
150
+ }
151
+ visitPlaceholder(ph, context) { }
152
+ visitIcuPlaceholder(ph, context) { }
153
+ }
154
+ /**
155
+ * Serialize the message to the Localize backtick string format that would appear in compiled code.
156
+ */
157
+ function serializeMessage(messageNodes) {
158
+ const visitor = new LocalizeMessageStringVisitor();
159
+ const str = messageNodes.map(n => n.visit(visitor)).join('');
160
+ return str;
161
+ }
162
+ class LocalizeMessageStringVisitor {
163
+ visitText(text) {
164
+ return text.value;
165
+ }
166
+ visitContainer(container) {
167
+ return container.children.map(child => child.visit(this)).join('');
168
+ }
169
+ visitIcu(icu) {
170
+ const strCases = Object.keys(icu.cases).map((k) => `${k} {${icu.cases[k].visit(this)}}`);
171
+ return `{${icu.expressionPlaceholder}, ${icu.type}, ${strCases.join(' ')}}`;
172
+ }
173
+ visitTagPlaceholder(ph) {
174
+ const children = ph.children.map(child => child.visit(this)).join('');
175
+ return `{$${ph.startName}}${children}{$${ph.closeName}}`;
176
+ }
177
+ visitPlaceholder(ph) {
178
+ return `{$${ph.name}}`;
179
+ }
180
+ visitIcuPlaceholder(ph) {
181
+ return `{$${ph.name}}`;
182
+ }
183
+ }
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n_ast.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/i18n/i18n_ast.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 {ParseSourceSpan} from '../parse_util';\n\n/**\n * Describes the text contents of a placeholder as it appears in an ICU expression, including its\n * source span information.\n */\nexport interface MessagePlaceholder {\n  /** The text contents of the placeholder */\n  text: string;\n\n  /** The source span of the placeholder */\n  sourceSpan: ParseSourceSpan;\n}\n\nexport class Message {\n  sources: MessageSpan[];\n  id: string;\n  /** The ids to use if there are no custom id and if `i18nLegacyMessageIdFormat` is not empty */\n  legacyIds: string[] = [];\n\n  messageString: string;\n\n  /**\n   * @param nodes message AST\n   * @param placeholders maps placeholder names to static content and their source spans\n   * @param placeholderToMessage maps placeholder names to messages (used for nested ICU messages)\n   * @param meaning\n   * @param description\n   * @param customId\n   */\n  constructor(\n      public nodes: Node[], public placeholders: {[phName: string]: MessagePlaceholder},\n      public placeholderToMessage: {[phName: string]: Message}, public meaning: string,\n      public description: string, public customId: string) {\n    this.id = this.customId;\n    this.messageString = serializeMessage(this.nodes);\n\n    if (nodes.length) {\n      this.sources = [{\n        filePath: nodes[0].sourceSpan.start.file.url,\n        startLine: nodes[0].sourceSpan.start.line + 1,\n        startCol: nodes[0].sourceSpan.start.col + 1,\n        endLine: nodes[nodes.length - 1].sourceSpan.end.line + 1,\n        endCol: nodes[0].sourceSpan.start.col + 1\n      }];\n    } else {\n      this.sources = [];\n    }\n  }\n}\n\n// line and columns indexes are 1 based\nexport interface MessageSpan {\n  filePath: string;\n  startLine: number;\n  startCol: number;\n  endLine: number;\n  endCol: number;\n}\n\nexport interface Node {\n  sourceSpan: ParseSourceSpan;\n  visit(visitor: Visitor, context?: any): any;\n}\n\nexport class Text implements Node {\n  constructor(public value: string, public sourceSpan: ParseSourceSpan) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitText(this, context);\n  }\n}\n\n// TODO(vicb): do we really need this node (vs an array) ?\nexport class Container implements Node {\n  constructor(public children: Node[], public sourceSpan: ParseSourceSpan) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitContainer(this, context);\n  }\n}\n\nexport class Icu implements Node {\n  // TODO(issue/24571): remove '!'.\n  public expressionPlaceholder!: string;\n  constructor(\n      public expression: string, public type: string, public cases: {[k: string]: Node},\n      public sourceSpan: ParseSourceSpan) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitIcu(this, context);\n  }\n}\n\nexport class TagPlaceholder implements Node {\n  constructor(\n      public tag: string, public attrs: {[k: string]: string}, public startName: string,\n      public closeName: string, public children: Node[], public isVoid: boolean,\n      // TODO sourceSpan should cover all (we need a startSourceSpan and endSourceSpan)\n      public sourceSpan: ParseSourceSpan, public startSourceSpan: ParseSourceSpan|null,\n      public endSourceSpan: ParseSourceSpan|null) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitTagPlaceholder(this, context);\n  }\n}\n\nexport class Placeholder implements Node {\n  constructor(public value: string, public name: string, public sourceSpan: ParseSourceSpan) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitPlaceholder(this, context);\n  }\n}\n\nexport class IcuPlaceholder implements Node {\n  /** Used to capture a message computed from a previous processing pass (see `setI18nRefs()`). */\n  previousMessage?: Message;\n  constructor(public value: Icu, public name: string, public sourceSpan: ParseSourceSpan) {}\n\n  visit(visitor: Visitor, context?: any): any {\n    return visitor.visitIcuPlaceholder(this, context);\n  }\n}\n\n/**\n * Each HTML node that is affect by an i18n tag will also have an `i18n` property that is of type\n * `I18nMeta`.\n * This information is either a `Message`, which indicates it is the root of an i18n message, or a\n * `Node`, which indicates is it part of a containing `Message`.\n */\nexport type I18nMeta = Message|Node;\n\nexport interface Visitor {\n  visitText(text: Text, context?: any): any;\n  visitContainer(container: Container, context?: any): any;\n  visitIcu(icu: Icu, context?: any): any;\n  visitTagPlaceholder(ph: TagPlaceholder, context?: any): any;\n  visitPlaceholder(ph: Placeholder, context?: any): any;\n  visitIcuPlaceholder(ph: IcuPlaceholder, context?: any): any;\n}\n\n// Clone the AST\nexport class CloneVisitor implements Visitor {\n  visitText(text: Text, context?: any): Text {\n    return new Text(text.value, text.sourceSpan);\n  }\n\n  visitContainer(container: Container, context?: any): Container {\n    const children = container.children.map(n => n.visit(this, context));\n    return new Container(children, container.sourceSpan);\n  }\n\n  visitIcu(icu: Icu, context?: any): Icu {\n    const cases: {[k: string]: Node} = {};\n    Object.keys(icu.cases).forEach(key => cases[key] = icu.cases[key].visit(this, context));\n    const msg = new Icu(icu.expression, icu.type, cases, icu.sourceSpan);\n    msg.expressionPlaceholder = icu.expressionPlaceholder;\n    return msg;\n  }\n\n  visitTagPlaceholder(ph: TagPlaceholder, context?: any): TagPlaceholder {\n    const children = ph.children.map(n => n.visit(this, context));\n    return new TagPlaceholder(\n        ph.tag, ph.attrs, ph.startName, ph.closeName, children, ph.isVoid, ph.sourceSpan,\n        ph.startSourceSpan, ph.endSourceSpan);\n  }\n\n  visitPlaceholder(ph: Placeholder, context?: any): Placeholder {\n    return new Placeholder(ph.value, ph.name, ph.sourceSpan);\n  }\n\n  visitIcuPlaceholder(ph: IcuPlaceholder, context?: any): IcuPlaceholder {\n    return new IcuPlaceholder(ph.value, ph.name, ph.sourceSpan);\n  }\n}\n\n// Visit all the nodes recursively\nexport class RecurseVisitor implements Visitor {\n  visitText(text: Text, context?: any): any {}\n\n  visitContainer(container: Container, context?: any): any {\n    container.children.forEach(child => child.visit(this));\n  }\n\n  visitIcu(icu: Icu, context?: any): any {\n    Object.keys(icu.cases).forEach(k => {\n      icu.cases[k].visit(this);\n    });\n  }\n\n  visitTagPlaceholder(ph: TagPlaceholder, context?: any): any {\n    ph.children.forEach(child => child.visit(this));\n  }\n\n  visitPlaceholder(ph: Placeholder, context?: any): any {}\n\n  visitIcuPlaceholder(ph: IcuPlaceholder, context?: any): any {}\n}\n\n\n/**\n * Serialize the message to the Localize backtick string format that would appear in compiled code.\n */\nfunction serializeMessage(messageNodes: Node[]): string {\n  const visitor = new LocalizeMessageStringVisitor();\n  const str = messageNodes.map(n => n.visit(visitor)).join('');\n  return str;\n}\n\nclass LocalizeMessageStringVisitor implements Visitor {\n  visitText(text: Text): any {\n    return text.value;\n  }\n\n  visitContainer(container: Container): any {\n    return container.children.map(child => child.visit(this)).join('');\n  }\n\n  visitIcu(icu: Icu): any {\n    const strCases =\n        Object.keys(icu.cases).map((k: string) => `${k} {${icu.cases[k].visit(this)}}`);\n    return `{${icu.expressionPlaceholder}, ${icu.type}, ${strCases.join(' ')}}`;\n  }\n\n  visitTagPlaceholder(ph: TagPlaceholder): any {\n    const children = ph.children.map(child => child.visit(this)).join('');\n    return `{$${ph.startName}}${children}{$${ph.closeName}}`;\n  }\n\n  visitPlaceholder(ph: Placeholder): any {\n    return `{$${ph.name}}`;\n  }\n\n  visitIcuPlaceholder(ph: IcuPlaceholder): any {\n    return `{$${ph.name}}`;\n  }\n}\n"]}
@@ -19,7 +19,7 @@ const MINIMUM_PARTIAL_LINKER_VERSION = '12.0.0';
19
19
  export function compileDeclareClassMetadata(metadata) {
20
20
  const definitionMap = new DefinitionMap();
21
21
  definitionMap.set('minVersion', o.literal(MINIMUM_PARTIAL_LINKER_VERSION));
22
- definitionMap.set('version', o.literal('16.0.0-next.4'));
22
+ definitionMap.set('version', o.literal('16.0.0-next.5'));
23
23
  definitionMap.set('ngImport', o.importExpr(R3.core));
24
24
  definitionMap.set('type', metadata.type);
25
25
  definitionMap.set('decorators', metadata.decorators);
@@ -35,7 +35,7 @@ export function compileDeclareDirectiveFromMetadata(meta) {
35
35
  export function createDirectiveDefinitionMap(meta) {
36
36
  const definitionMap = new DefinitionMap();
37
37
  definitionMap.set('minVersion', o.literal(MINIMUM_PARTIAL_LINKER_VERSION));
38
- definitionMap.set('version', o.literal('16.0.0-next.4'));
38
+ definitionMap.set('version', o.literal('16.0.0-next.5'));
39
39
  // e.g. `type: MyDirective`
40
40
  definitionMap.set('type', meta.internalType);
41
41
  if (meta.isStandalone) {