[6a3a178] | 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 | (function (factory) {
|
---|
| 9 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
| 10 | var v = factory(require, exports);
|
---|
| 11 | if (v !== undefined) module.exports = v;
|
---|
| 12 | }
|
---|
| 13 | else if (typeof define === "function" && define.amd) {
|
---|
| 14 | define("@angular/compiler/src/i18n/digest", ["require", "exports", "tslib", "@angular/compiler/src/util", "@angular/compiler/src/i18n/big_integer"], factory);
|
---|
| 15 | }
|
---|
| 16 | })(function (require, exports) {
|
---|
| 17 | "use strict";
|
---|
| 18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
| 19 | exports.computeMsgId = exports.fingerprint = exports.sha1 = exports.serializeNodes = exports.computeDecimalDigest = exports.decimalDigest = exports.computeDigest = exports.digest = void 0;
|
---|
| 20 | var tslib_1 = require("tslib");
|
---|
| 21 | var util_1 = require("@angular/compiler/src/util");
|
---|
| 22 | var big_integer_1 = require("@angular/compiler/src/i18n/big_integer");
|
---|
| 23 | /**
|
---|
| 24 | * Return the message id or compute it using the XLIFF1 digest.
|
---|
| 25 | */
|
---|
| 26 | function digest(message) {
|
---|
| 27 | return message.id || computeDigest(message);
|
---|
| 28 | }
|
---|
| 29 | exports.digest = digest;
|
---|
| 30 | /**
|
---|
| 31 | * Compute the message id using the XLIFF1 digest.
|
---|
| 32 | */
|
---|
| 33 | function computeDigest(message) {
|
---|
| 34 | return sha1(serializeNodes(message.nodes).join('') + ("[" + message.meaning + "]"));
|
---|
| 35 | }
|
---|
| 36 | exports.computeDigest = computeDigest;
|
---|
| 37 | /**
|
---|
| 38 | * Return the message id or compute it using the XLIFF2/XMB/$localize digest.
|
---|
| 39 | */
|
---|
| 40 | function decimalDigest(message) {
|
---|
| 41 | return message.id || computeDecimalDigest(message);
|
---|
| 42 | }
|
---|
| 43 | exports.decimalDigest = decimalDigest;
|
---|
| 44 | /**
|
---|
| 45 | * Compute the message id using the XLIFF2/XMB/$localize digest.
|
---|
| 46 | */
|
---|
| 47 | function computeDecimalDigest(message) {
|
---|
| 48 | var visitor = new _SerializerIgnoreIcuExpVisitor();
|
---|
| 49 | var parts = message.nodes.map(function (a) { return a.visit(visitor, null); });
|
---|
| 50 | return computeMsgId(parts.join(''), message.meaning);
|
---|
| 51 | }
|
---|
| 52 | exports.computeDecimalDigest = computeDecimalDigest;
|
---|
| 53 | /**
|
---|
| 54 | * Serialize the i18n ast to something xml-like in order to generate an UID.
|
---|
| 55 | *
|
---|
| 56 | * The visitor is also used in the i18n parser tests
|
---|
| 57 | *
|
---|
| 58 | * @internal
|
---|
| 59 | */
|
---|
| 60 | var _SerializerVisitor = /** @class */ (function () {
|
---|
| 61 | function _SerializerVisitor() {
|
---|
| 62 | }
|
---|
| 63 | _SerializerVisitor.prototype.visitText = function (text, context) {
|
---|
| 64 | return text.value;
|
---|
| 65 | };
|
---|
| 66 | _SerializerVisitor.prototype.visitContainer = function (container, context) {
|
---|
| 67 | var _this = this;
|
---|
| 68 | return "[" + container.children.map(function (child) { return child.visit(_this); }).join(', ') + "]";
|
---|
| 69 | };
|
---|
| 70 | _SerializerVisitor.prototype.visitIcu = function (icu, context) {
|
---|
| 71 | var _this = this;
|
---|
| 72 | var strCases = Object.keys(icu.cases).map(function (k) { return k + " {" + icu.cases[k].visit(_this) + "}"; });
|
---|
| 73 | return "{" + icu.expression + ", " + icu.type + ", " + strCases.join(', ') + "}";
|
---|
| 74 | };
|
---|
| 75 | _SerializerVisitor.prototype.visitTagPlaceholder = function (ph, context) {
|
---|
| 76 | var _this = this;
|
---|
| 77 | return ph.isVoid ?
|
---|
| 78 | "<ph tag name=\"" + ph.startName + "\"/>" :
|
---|
| 79 | "<ph tag name=\"" + ph.startName + "\">" + ph.children.map(function (child) { return child.visit(_this); }).join(', ') + "</ph name=\"" + ph.closeName + "\">";
|
---|
| 80 | };
|
---|
| 81 | _SerializerVisitor.prototype.visitPlaceholder = function (ph, context) {
|
---|
| 82 | return ph.value ? "<ph name=\"" + ph.name + "\">" + ph.value + "</ph>" : "<ph name=\"" + ph.name + "\"/>";
|
---|
| 83 | };
|
---|
| 84 | _SerializerVisitor.prototype.visitIcuPlaceholder = function (ph, context) {
|
---|
| 85 | return "<ph icu name=\"" + ph.name + "\">" + ph.value.visit(this) + "</ph>";
|
---|
| 86 | };
|
---|
| 87 | return _SerializerVisitor;
|
---|
| 88 | }());
|
---|
| 89 | var serializerVisitor = new _SerializerVisitor();
|
---|
| 90 | function serializeNodes(nodes) {
|
---|
| 91 | return nodes.map(function (a) { return a.visit(serializerVisitor, null); });
|
---|
| 92 | }
|
---|
| 93 | exports.serializeNodes = serializeNodes;
|
---|
| 94 | /**
|
---|
| 95 | * Serialize the i18n ast to something xml-like in order to generate an UID.
|
---|
| 96 | *
|
---|
| 97 | * Ignore the ICU expressions so that message IDs stays identical if only the expression changes.
|
---|
| 98 | *
|
---|
| 99 | * @internal
|
---|
| 100 | */
|
---|
| 101 | var _SerializerIgnoreIcuExpVisitor = /** @class */ (function (_super) {
|
---|
| 102 | tslib_1.__extends(_SerializerIgnoreIcuExpVisitor, _super);
|
---|
| 103 | function _SerializerIgnoreIcuExpVisitor() {
|
---|
| 104 | return _super !== null && _super.apply(this, arguments) || this;
|
---|
| 105 | }
|
---|
| 106 | _SerializerIgnoreIcuExpVisitor.prototype.visitIcu = function (icu, context) {
|
---|
| 107 | var _this = this;
|
---|
| 108 | var strCases = Object.keys(icu.cases).map(function (k) { return k + " {" + icu.cases[k].visit(_this) + "}"; });
|
---|
| 109 | // Do not take the expression into account
|
---|
| 110 | return "{" + icu.type + ", " + strCases.join(', ') + "}";
|
---|
| 111 | };
|
---|
| 112 | return _SerializerIgnoreIcuExpVisitor;
|
---|
| 113 | }(_SerializerVisitor));
|
---|
| 114 | /**
|
---|
| 115 | * Compute the SHA1 of the given string
|
---|
| 116 | *
|
---|
| 117 | * see https://csrc.nist.gov/publications/fips/fips180-4/fips-180-4.pdf
|
---|
| 118 | *
|
---|
| 119 | * WARNING: this function has not been designed not tested with security in mind.
|
---|
| 120 | * DO NOT USE IT IN A SECURITY SENSITIVE CONTEXT.
|
---|
| 121 | */
|
---|
| 122 | function sha1(str) {
|
---|
| 123 | var utf8 = util_1.utf8Encode(str);
|
---|
| 124 | var words32 = bytesToWords32(utf8, Endian.Big);
|
---|
| 125 | var len = utf8.length * 8;
|
---|
| 126 | var w = util_1.newArray(80);
|
---|
| 127 | var a = 0x67452301, b = 0xefcdab89, c = 0x98badcfe, d = 0x10325476, e = 0xc3d2e1f0;
|
---|
| 128 | words32[len >> 5] |= 0x80 << (24 - len % 32);
|
---|
| 129 | words32[((len + 64 >> 9) << 4) + 15] = len;
|
---|
| 130 | for (var i = 0; i < words32.length; i += 16) {
|
---|
| 131 | var h0 = a, h1 = b, h2 = c, h3 = d, h4 = e;
|
---|
| 132 | for (var j = 0; j < 80; j++) {
|
---|
| 133 | if (j < 16) {
|
---|
| 134 | w[j] = words32[i + j];
|
---|
| 135 | }
|
---|
| 136 | else {
|
---|
| 137 | w[j] = rol32(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);
|
---|
| 138 | }
|
---|
| 139 | var fkVal = fk(j, b, c, d);
|
---|
| 140 | var f = fkVal[0];
|
---|
| 141 | var k = fkVal[1];
|
---|
| 142 | var temp = [rol32(a, 5), f, e, k, w[j]].reduce(add32);
|
---|
| 143 | e = d;
|
---|
| 144 | d = c;
|
---|
| 145 | c = rol32(b, 30);
|
---|
| 146 | b = a;
|
---|
| 147 | a = temp;
|
---|
| 148 | }
|
---|
| 149 | a = add32(a, h0);
|
---|
| 150 | b = add32(b, h1);
|
---|
| 151 | c = add32(c, h2);
|
---|
| 152 | d = add32(d, h3);
|
---|
| 153 | e = add32(e, h4);
|
---|
| 154 | }
|
---|
| 155 | return bytesToHexString(words32ToByteString([a, b, c, d, e]));
|
---|
| 156 | }
|
---|
| 157 | exports.sha1 = sha1;
|
---|
| 158 | function fk(index, b, c, d) {
|
---|
| 159 | if (index < 20) {
|
---|
| 160 | return [(b & c) | (~b & d), 0x5a827999];
|
---|
| 161 | }
|
---|
| 162 | if (index < 40) {
|
---|
| 163 | return [b ^ c ^ d, 0x6ed9eba1];
|
---|
| 164 | }
|
---|
| 165 | if (index < 60) {
|
---|
| 166 | return [(b & c) | (b & d) | (c & d), 0x8f1bbcdc];
|
---|
| 167 | }
|
---|
| 168 | return [b ^ c ^ d, 0xca62c1d6];
|
---|
| 169 | }
|
---|
| 170 | /**
|
---|
| 171 | * Compute the fingerprint of the given string
|
---|
| 172 | *
|
---|
| 173 | * The output is 64 bit number encoded as a decimal string
|
---|
| 174 | *
|
---|
| 175 | * based on:
|
---|
| 176 | * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/GoogleJsMessageIdGenerator.java
|
---|
| 177 | */
|
---|
| 178 | function fingerprint(str) {
|
---|
| 179 | var utf8 = util_1.utf8Encode(str);
|
---|
| 180 | var hi = hash32(utf8, 0);
|
---|
| 181 | var lo = hash32(utf8, 102072);
|
---|
| 182 | if (hi == 0 && (lo == 0 || lo == 1)) {
|
---|
| 183 | hi = hi ^ 0x130f9bef;
|
---|
| 184 | lo = lo ^ -0x6b5f56d8;
|
---|
| 185 | }
|
---|
| 186 | return [hi, lo];
|
---|
| 187 | }
|
---|
| 188 | exports.fingerprint = fingerprint;
|
---|
| 189 | function computeMsgId(msg, meaning) {
|
---|
| 190 | if (meaning === void 0) { meaning = ''; }
|
---|
| 191 | var msgFingerprint = fingerprint(msg);
|
---|
| 192 | if (meaning) {
|
---|
| 193 | var meaningFingerprint = fingerprint(meaning);
|
---|
| 194 | msgFingerprint = add64(rol64(msgFingerprint, 1), meaningFingerprint);
|
---|
| 195 | }
|
---|
| 196 | var hi = msgFingerprint[0];
|
---|
| 197 | var lo = msgFingerprint[1];
|
---|
| 198 | return wordsToDecimalString(hi & 0x7fffffff, lo);
|
---|
| 199 | }
|
---|
| 200 | exports.computeMsgId = computeMsgId;
|
---|
| 201 | function hash32(bytes, c) {
|
---|
| 202 | var a = 0x9e3779b9, b = 0x9e3779b9;
|
---|
| 203 | var i;
|
---|
| 204 | var len = bytes.length;
|
---|
| 205 | for (i = 0; i + 12 <= len; i += 12) {
|
---|
| 206 | a = add32(a, wordAt(bytes, i, Endian.Little));
|
---|
| 207 | b = add32(b, wordAt(bytes, i + 4, Endian.Little));
|
---|
| 208 | c = add32(c, wordAt(bytes, i + 8, Endian.Little));
|
---|
| 209 | var res = mix(a, b, c);
|
---|
| 210 | a = res[0], b = res[1], c = res[2];
|
---|
| 211 | }
|
---|
| 212 | a = add32(a, wordAt(bytes, i, Endian.Little));
|
---|
| 213 | b = add32(b, wordAt(bytes, i + 4, Endian.Little));
|
---|
| 214 | // the first byte of c is reserved for the length
|
---|
| 215 | c = add32(c, len);
|
---|
| 216 | c = add32(c, wordAt(bytes, i + 8, Endian.Little) << 8);
|
---|
| 217 | return mix(a, b, c)[2];
|
---|
| 218 | }
|
---|
| 219 | // clang-format off
|
---|
| 220 | function mix(a, b, c) {
|
---|
| 221 | a = sub32(a, b);
|
---|
| 222 | a = sub32(a, c);
|
---|
| 223 | a ^= c >>> 13;
|
---|
| 224 | b = sub32(b, c);
|
---|
| 225 | b = sub32(b, a);
|
---|
| 226 | b ^= a << 8;
|
---|
| 227 | c = sub32(c, a);
|
---|
| 228 | c = sub32(c, b);
|
---|
| 229 | c ^= b >>> 13;
|
---|
| 230 | a = sub32(a, b);
|
---|
| 231 | a = sub32(a, c);
|
---|
| 232 | a ^= c >>> 12;
|
---|
| 233 | b = sub32(b, c);
|
---|
| 234 | b = sub32(b, a);
|
---|
| 235 | b ^= a << 16;
|
---|
| 236 | c = sub32(c, a);
|
---|
| 237 | c = sub32(c, b);
|
---|
| 238 | c ^= b >>> 5;
|
---|
| 239 | a = sub32(a, b);
|
---|
| 240 | a = sub32(a, c);
|
---|
| 241 | a ^= c >>> 3;
|
---|
| 242 | b = sub32(b, c);
|
---|
| 243 | b = sub32(b, a);
|
---|
| 244 | b ^= a << 10;
|
---|
| 245 | c = sub32(c, a);
|
---|
| 246 | c = sub32(c, b);
|
---|
| 247 | c ^= b >>> 15;
|
---|
| 248 | return [a, b, c];
|
---|
| 249 | }
|
---|
| 250 | // clang-format on
|
---|
| 251 | // Utils
|
---|
| 252 | var Endian;
|
---|
| 253 | (function (Endian) {
|
---|
| 254 | Endian[Endian["Little"] = 0] = "Little";
|
---|
| 255 | Endian[Endian["Big"] = 1] = "Big";
|
---|
| 256 | })(Endian || (Endian = {}));
|
---|
| 257 | function add32(a, b) {
|
---|
| 258 | return add32to64(a, b)[1];
|
---|
| 259 | }
|
---|
| 260 | function add32to64(a, b) {
|
---|
| 261 | var low = (a & 0xffff) + (b & 0xffff);
|
---|
| 262 | var high = (a >>> 16) + (b >>> 16) + (low >>> 16);
|
---|
| 263 | return [high >>> 16, (high << 16) | (low & 0xffff)];
|
---|
| 264 | }
|
---|
| 265 | function add64(a, b) {
|
---|
| 266 | var ah = a[0], al = a[1];
|
---|
| 267 | var bh = b[0], bl = b[1];
|
---|
| 268 | var result = add32to64(al, bl);
|
---|
| 269 | var carry = result[0];
|
---|
| 270 | var l = result[1];
|
---|
| 271 | var h = add32(add32(ah, bh), carry);
|
---|
| 272 | return [h, l];
|
---|
| 273 | }
|
---|
| 274 | function sub32(a, b) {
|
---|
| 275 | var low = (a & 0xffff) - (b & 0xffff);
|
---|
| 276 | var high = (a >> 16) - (b >> 16) + (low >> 16);
|
---|
| 277 | return (high << 16) | (low & 0xffff);
|
---|
| 278 | }
|
---|
| 279 | // Rotate a 32b number left `count` position
|
---|
| 280 | function rol32(a, count) {
|
---|
| 281 | return (a << count) | (a >>> (32 - count));
|
---|
| 282 | }
|
---|
| 283 | // Rotate a 64b number left `count` position
|
---|
| 284 | function rol64(num, count) {
|
---|
| 285 | var hi = num[0], lo = num[1];
|
---|
| 286 | var h = (hi << count) | (lo >>> (32 - count));
|
---|
| 287 | var l = (lo << count) | (hi >>> (32 - count));
|
---|
| 288 | return [h, l];
|
---|
| 289 | }
|
---|
| 290 | function bytesToWords32(bytes, endian) {
|
---|
| 291 | var size = (bytes.length + 3) >>> 2;
|
---|
| 292 | var words32 = [];
|
---|
| 293 | for (var i = 0; i < size; i++) {
|
---|
| 294 | words32[i] = wordAt(bytes, i * 4, endian);
|
---|
| 295 | }
|
---|
| 296 | return words32;
|
---|
| 297 | }
|
---|
| 298 | function byteAt(bytes, index) {
|
---|
| 299 | return index >= bytes.length ? 0 : bytes[index];
|
---|
| 300 | }
|
---|
| 301 | function wordAt(bytes, index, endian) {
|
---|
| 302 | var word = 0;
|
---|
| 303 | if (endian === Endian.Big) {
|
---|
| 304 | for (var i = 0; i < 4; i++) {
|
---|
| 305 | word += byteAt(bytes, index + i) << (24 - 8 * i);
|
---|
| 306 | }
|
---|
| 307 | }
|
---|
| 308 | else {
|
---|
| 309 | for (var i = 0; i < 4; i++) {
|
---|
| 310 | word += byteAt(bytes, index + i) << 8 * i;
|
---|
| 311 | }
|
---|
| 312 | }
|
---|
| 313 | return word;
|
---|
| 314 | }
|
---|
| 315 | function words32ToByteString(words32) {
|
---|
| 316 | return words32.reduce(function (bytes, word) { return bytes.concat(word32ToByteString(word)); }, []);
|
---|
| 317 | }
|
---|
| 318 | function word32ToByteString(word) {
|
---|
| 319 | var bytes = [];
|
---|
| 320 | for (var i = 0; i < 4; i++) {
|
---|
| 321 | bytes.push((word >>> 8 * (3 - i)) & 0xff);
|
---|
| 322 | }
|
---|
| 323 | return bytes;
|
---|
| 324 | }
|
---|
| 325 | function bytesToHexString(bytes) {
|
---|
| 326 | var hex = '';
|
---|
| 327 | for (var i = 0; i < bytes.length; i++) {
|
---|
| 328 | var b = byteAt(bytes, i);
|
---|
| 329 | hex += (b >>> 4).toString(16) + (b & 0x0f).toString(16);
|
---|
| 330 | }
|
---|
| 331 | return hex.toLowerCase();
|
---|
| 332 | }
|
---|
| 333 | /**
|
---|
| 334 | * Create a shared exponentiation pool for base-256 computations. This shared pool provides memoized
|
---|
| 335 | * power-of-256 results with memoized power-of-two computations for efficient multiplication.
|
---|
| 336 | *
|
---|
| 337 | * For our purposes, this can be safely stored as a global without memory concerns. The reason is
|
---|
| 338 | * that we encode two words, so only need the 0th (for the low word) and 4th (for the high word)
|
---|
| 339 | * exponent.
|
---|
| 340 | */
|
---|
| 341 | var base256 = new big_integer_1.BigIntExponentiation(256);
|
---|
| 342 | /**
|
---|
| 343 | * Represents two 32-bit words as a single decimal number. This requires a big integer storage
|
---|
| 344 | * model as JS numbers are not accurate enough to represent the 64-bit number.
|
---|
| 345 | *
|
---|
| 346 | * Based on https://www.danvk.org/hex2dec.html
|
---|
| 347 | */
|
---|
| 348 | function wordsToDecimalString(hi, lo) {
|
---|
| 349 | // Encode the four bytes in lo in the lower digits of the decimal number.
|
---|
| 350 | // Note: the multiplication results in lo itself but represented by a big integer using its
|
---|
| 351 | // decimal digits.
|
---|
| 352 | var decimal = base256.toThePowerOf(0).multiplyBy(lo);
|
---|
| 353 | // Encode the four bytes in hi above the four lo bytes. lo is a maximum of (2^8)^4, which is why
|
---|
| 354 | // this multiplication factor is applied.
|
---|
| 355 | base256.toThePowerOf(4).multiplyByAndAddTo(hi, decimal);
|
---|
| 356 | return decimal.toString();
|
---|
| 357 | }
|
---|
| 358 | });
|
---|
| 359 | //# 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, newArray, utf8Encode} from '../util';\nimport {BigIntExponentiation} from './big_integer';\n\nimport * as i18n from './i18n_ast';\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  const utf8 = utf8Encode(str);\n  const words32 = bytesToWords32(utf8, Endian.Big);\n  const len = utf8.length * 8;\n\n  const w = newArray(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  return bytesToHexString(words32ToByteString([a, b, c, d, e]));\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  const utf8 = utf8Encode(str);\n\n  let hi = hash32(utf8, 0);\n  let lo = hash32(utf8, 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(bytes: Byte[], c: number): number {\n  let a = 0x9e3779b9, b = 0x9e3779b9;\n  let i: number;\n\n  const len = bytes.length;\n\n  for (i = 0; i + 12 <= len; i += 12) {\n    a = add32(a, wordAt(bytes, i, Endian.Little));\n    b = add32(b, wordAt(bytes, i + 4, Endian.Little));\n    c = add32(c, wordAt(bytes, i + 8, Endian.Little));\n    const res = mix(a, b, c);\n    a = res[0], b = res[1], c = res[2];\n  }\n\n  a = add32(a, wordAt(bytes, i, Endian.Little));\n  b = add32(b, wordAt(bytes, i + 4, Endian.Little));\n  // the first byte of c is reserved for the length\n  c = add32(c, len);\n  c = add32(c, wordAt(bytes, i + 8, Endian.Little) << 8);\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 = sub32(a, b); a = sub32(a, c); a ^= c >>> 13;\n  b = sub32(b, c); b = sub32(b, a); b ^= a << 8;\n  c = sub32(c, a); c = sub32(c, b); c ^= b >>> 13;\n  a = sub32(a, b); a = sub32(a, c); a ^= c >>> 12;\n  b = sub32(b, c); b = sub32(b, a); b ^= a << 16;\n  c = sub32(c, a); c = sub32(c, b); c ^= b >>> 5;\n  a = sub32(a, b); a = sub32(a, c); a ^= c >>> 3;\n  b = sub32(b, c); b = sub32(b, a); b ^= a << 10;\n  c = sub32(c, a); c = sub32(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\nfunction sub32(a: number, b: number): number {\n  const low = (a & 0xffff) - (b & 0xffff);\n  const high = (a >> 16) - (b >> 16) + (low >> 16);\n  return (high << 16) | (low & 0xffff);\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\nfunction words32ToByteString(words32: number[]): Byte[] {\n  return words32.reduce((bytes, word) => bytes.concat(word32ToByteString(word)), [] as Byte[]);\n}\n\nfunction word32ToByteString(word: number): Byte[] {\n  let bytes: Byte[] = [];\n  for (let i = 0; i < 4; i++) {\n    bytes.push((word >>> 8 * (3 - i)) & 0xff);\n  }\n  return bytes;\n}\n\nfunction bytesToHexString(bytes: Byte[]): string {\n  let hex: string = '';\n  for (let i = 0; i < bytes.length; i++) {\n    const b = byteAt(bytes, i);\n    hex += (b >>> 4).toString(16) + (b & 0x0f).toString(16);\n  }\n  return hex.toLowerCase();\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"]} |
---|