Socket
Socket
Sign inDemoInstall

@angular/localize

Package Overview
Dependencies
3
Maintainers
2
Versions
516
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 9.0.5 to 9.0.6

2

bundles/localize-init.umd.js
/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

/**
* @license Angular v9.0.5
* @license Angular v9.0.6
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -4,0 +4,0 @@ * License: MIT

{
"name": "@angular/localize",
"version": "9.0.5",
"version": "9.0.6",
"description": "Angular - library for localizing messages",

@@ -5,0 +5,0 @@ "main": "./bundles/localize.umd.js",

@@ -21,2 +21,3 @@ /**

error(message: string): void;
formatDiagnostics(message: string): string;
}

@@ -34,2 +34,13 @@ /**

Diagnostics.prototype.error = function (message) { this.messages.push({ type: 'error', message: message }); };
Diagnostics.prototype.formatDiagnostics = function (message) {
var errors = this.messages.filter(function (d) { return d.type === 'error'; }).map(function (d) { return ' - ' + d.message; });
var warnings = this.messages.filter(function (d) { return d.type === 'warning'; }).map(function (d) { return ' - ' + d.message; });
if (errors.length) {
message += '\nERRORS:\n' + errors.join('\n');
}
if (warnings.length) {
message += '\nWARNINGS:\n' + warnings.join('\n');
}
return message;
};
return Diagnostics;

@@ -39,2 +50,2 @@ }());

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhZ25vc3RpY3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL2RpYWdub3N0aWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBRUg7OztPQUdHO0lBQ0g7UUFBQTtZQUNXLGFBQVEsR0FBbUQsRUFBRSxDQUFDO1FBSXpFLENBQUM7UUFIQyxzQkFBSSxrQ0FBUztpQkFBYixjQUFrQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsQ0FBQyxDQUFDLElBQUksS0FBSyxPQUFPLEVBQWxCLENBQWtCLENBQUMsQ0FBQyxDQUFDLENBQUM7OztXQUFBO1FBQ3ZFLDBCQUFJLEdBQUosVUFBSyxPQUFlLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLE9BQU8sU0FBQSxFQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDekUsMkJBQUssR0FBTCxVQUFNLE9BQWUsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsT0FBTyxTQUFBLEVBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRSxrQkFBQztJQUFELENBQUMsQUFMRCxJQUtDO0lBTFksa0NBQVciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogVGhpcyBjbGFzcyBpcyB1c2VkIHRvIGNvbGxlY3QgYW5kIHRoZW4gcmVwb3J0IHdhcm5pbmdzIGFuZCBlcnJvcnMgdGhhdCBvY2N1ciBkdXJpbmcgdGhlIGV4ZWN1dGlvblxuICogb2YgdGhlIHRvb2xzLlxuICovXG5leHBvcnQgY2xhc3MgRGlhZ25vc3RpY3Mge1xuICByZWFkb25seSBtZXNzYWdlczoge3R5cGU6ICd3YXJuaW5nJyB8ICdlcnJvcicsIG1lc3NhZ2U6IHN0cmluZ31bXSA9IFtdO1xuICBnZXQgaGFzRXJyb3JzKCkgeyByZXR1cm4gdGhpcy5tZXNzYWdlcy5zb21lKG0gPT4gbS50eXBlID09PSAnZXJyb3InKTsgfVxuICB3YXJuKG1lc3NhZ2U6IHN0cmluZykgeyB0aGlzLm1lc3NhZ2VzLnB1c2goe3R5cGU6ICd3YXJuaW5nJywgbWVzc2FnZX0pOyB9XG4gIGVycm9yKG1lc3NhZ2U6IHN0cmluZykgeyB0aGlzLm1lc3NhZ2VzLnB1c2goe3R5cGU6ICdlcnJvcicsIG1lc3NhZ2V9KTsgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhZ25vc3RpY3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL2RpYWdub3N0aWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBRUg7OztPQUdHO0lBQ0g7UUFBQTtZQUNXLGFBQVEsR0FBbUQsRUFBRSxDQUFDO1FBZXpFLENBQUM7UUFkQyxzQkFBSSxrQ0FBUztpQkFBYixjQUFrQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsQ0FBQyxDQUFDLElBQUksS0FBSyxPQUFPLEVBQWxCLENBQWtCLENBQUMsQ0FBQyxDQUFDLENBQUM7OztXQUFBO1FBQ3ZFLDBCQUFJLEdBQUosVUFBSyxPQUFlLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLE9BQU8sU0FBQSxFQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDekUsMkJBQUssR0FBTCxVQUFNLE9BQWUsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsT0FBTyxTQUFBLEVBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4RSx1Q0FBaUIsR0FBakIsVUFBa0IsT0FBZTtZQUMvQixJQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBVSxDQUFDLE1BQU0sQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLENBQUMsQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFsQixDQUFrQixDQUFDLENBQUMsR0FBRyxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsS0FBSyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQWpCLENBQWlCLENBQUMsQ0FBQztZQUMzRixJQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBVSxDQUFDLE1BQU0sQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLENBQUMsQ0FBQyxJQUFJLEtBQUssU0FBUyxFQUFwQixDQUFvQixDQUFDLENBQUMsR0FBRyxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsS0FBSyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQWpCLENBQWlCLENBQUMsQ0FBQztZQUMvRixJQUFJLE1BQU0sQ0FBQyxNQUFNLEVBQUU7Z0JBQ2pCLE9BQU8sSUFBSSxhQUFhLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUM5QztZQUNELElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRTtnQkFDbkIsT0FBTyxJQUFJLGVBQWUsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ2xEO1lBQ0QsT0FBTyxPQUFPLENBQUM7UUFDakIsQ0FBQztRQUNILGtCQUFDO0lBQUQsQ0FBQyxBQWhCRCxJQWdCQztJQWhCWSxrQ0FBVyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBUaGlzIGNsYXNzIGlzIHVzZWQgdG8gY29sbGVjdCBhbmQgdGhlbiByZXBvcnQgd2FybmluZ3MgYW5kIGVycm9ycyB0aGF0IG9jY3VyIGR1cmluZyB0aGUgZXhlY3V0aW9uXG4gKiBvZiB0aGUgdG9vbHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBEaWFnbm9zdGljcyB7XG4gIHJlYWRvbmx5IG1lc3NhZ2VzOiB7dHlwZTogJ3dhcm5pbmcnIHwgJ2Vycm9yJywgbWVzc2FnZTogc3RyaW5nfVtdID0gW107XG4gIGdldCBoYXNFcnJvcnMoKSB7IHJldHVybiB0aGlzLm1lc3NhZ2VzLnNvbWUobSA9PiBtLnR5cGUgPT09ICdlcnJvcicpOyB9XG4gIHdhcm4obWVzc2FnZTogc3RyaW5nKSB7IHRoaXMubWVzc2FnZXMucHVzaCh7dHlwZTogJ3dhcm5pbmcnLCBtZXNzYWdlfSk7IH1cbiAgZXJyb3IobWVzc2FnZTogc3RyaW5nKSB7IHRoaXMubWVzc2FnZXMucHVzaCh7dHlwZTogJ2Vycm9yJywgbWVzc2FnZX0pOyB9XG4gIGZvcm1hdERpYWdub3N0aWNzKG1lc3NhZ2U6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3QgZXJyb3JzID0gdGhpcy5tZXNzYWdlcyAhLmZpbHRlcihkID0+IGQudHlwZSA9PT0gJ2Vycm9yJykubWFwKGQgPT4gJyAtICcgKyBkLm1lc3NhZ2UpO1xuICAgIGNvbnN0IHdhcm5pbmdzID0gdGhpcy5tZXNzYWdlcyAhLmZpbHRlcihkID0+IGQudHlwZSA9PT0gJ3dhcm5pbmcnKS5tYXAoZCA9PiAnIC0gJyArIGQubWVzc2FnZSk7XG4gICAgaWYgKGVycm9ycy5sZW5ndGgpIHtcbiAgICAgIG1lc3NhZ2UgKz0gJ1xcbkVSUk9SUzpcXG4nICsgZXJyb3JzLmpvaW4oJ1xcbicpO1xuICAgIH1cbiAgICBpZiAod2FybmluZ3MubGVuZ3RoKSB7XG4gICAgICBtZXNzYWdlICs9ICdcXG5XQVJOSU5HUzpcXG4nICsgd2FybmluZ3Muam9pbignXFxuJyk7XG4gICAgfVxuICAgIHJldHVybiBtZXNzYWdlO1xuICB9XG59XG4iXX0=

@@ -93,3 +93,3 @@ #!/usr/bin/env node

new xliff1_translation_parser_1.Xliff1TranslationParser(),
new xtb_translation_parser_1.XtbTranslationParser(diagnostics),
new xtb_translation_parser_1.XtbTranslationParser(),
new simple_json_translation_parser_1.SimpleJsonTranslationParser(),

@@ -107,2 +107,2 @@ ], diagnostics);

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../../../../packages/localize/src/tools/src/translate/main.ts"],"names":[],"mappings":";;;;;;;;;;;;IACA;;;;;;OAMG;IACH,2BAA6B;IAC7B,6BAA6B;IAC7B,6BAA+B;IAE/B,6HAAgF;IAChF,qFAA4D;IAC5D,0IAA4F;IAE5F,qHAAyE;IACzE,iKAAmH;IACnH,uJAA0G;IAC1G,uJAA0G;IAC1G,iJAAoG;IACpG,mFAAwC;IACxC,2EAA2C;IAE3C,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE;QAC3B,IAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,OAAO,GACT,KAAK;aACA,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,IAAI;YACd,QAAQ,EACJ,wHAAwH;SAC7H,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,QAAQ;YACf,QAAQ,EAAE,IAAI;YACd,QAAQ,EACJ,sGAAsG;SAC3G,CAAC;aAED,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,eAAe;YACtB,QAAQ,EACJ,2KAA2K;SAChL,CAAC;aAED,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,IAAI;YACX,QAAQ,EACJ,mHAAmH;gBACnH,6FAA6F;SAClG,CAAC;aAED,MAAM,CAAC,gBAAgB,EAAE;YACxB,KAAK,EAAE,IAAI;YACX,QAAQ,EACJ,+HAA+H;gBAC/H,qBAAqB;SAC1B,CAAC;aAED,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,IAAI;YACd,QAAQ,EACJ,+JAA+J;SACpK,CAAC;aAED,MAAM,CAAC,GAAG,EAAE;YACX,KAAK,EAAE,oBAAoB;YAC3B,QAAQ,EAAE,qCAAqC;YAC/C,OAAO,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAC;YACvC,OAAO,EAAE,SAAS;SACnB,CAAC;aAED,IAAI,EAAE;aACN,KAAK,CAAC,IAAI,CAAC,CAAC;QAErB,IAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;QACpC,IAAM,eAAe,GACjB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC;QAChF,IAAM,oBAAoB,GAAa,OAAO,CAAC,GAAG,CAAC,CAAC;QACpD,IAAM,YAAY,GAAG,6BAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;QACnD,IAAM,WAAW,GAAG,IAAI,yBAAW,EAAE,CAAC;QACtC,IAAM,kBAAkB,GAA+B,OAAO,CAAC,GAAG,CAAC,CAAC;QACpE,IAAM,YAAY,GAAqB,OAAO,CAAC,GAAG,CAAC,CAAC;QACpD,IAAM,sBAAsB,GAAa,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAEzE,cAAc,CAAC,EAAC,cAAc,gBAAA,EAAE,eAAe,iBAAA,EAAE,oBAAoB,sBAAA,EAAE,sBAAsB,wBAAA;YAC7E,YAAY,cAAA,EAAE,WAAW,aAAA,EAAE,kBAAkB,oBAAA,EAAE,YAAY,cAAA,EAAC,CAAC,CAAC;QAE9E,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,OAAO,CAAC,IAAI,CAAI,CAAC,CAAC,IAAI,UAAK,CAAC,CAAC,OAAS,CAAC,EAAvC,CAAuC,CAAC,CAAC;QAC3E,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAC7C;IA0CD,SAAgB,cAAc,CAAC,EAEyD;YAFxD,kCAAc,EAAE,oCAAe,EAAE,8CAAoB,EACrD,kDAAsB,EAAE,8BAAY,EAAE,4BAAW,EACjD,0CAAkB,EAAE,8BAAY;QAC9D,IAAM,iBAAiB,GAAG,IAAI,sCAAiB,CAC3C;YACE,IAAI,mDAAuB,EAAE;YAC7B,IAAI,mDAAuB,EAAE;YAC7B,IAAI,6CAAoB,CAAC,WAAW,CAAC;YACrC,IAAI,4DAA2B,EAAE;SAClC,EACD,WAAW,CAAC,CAAC;QAEjB,IAAM,iBAAiB,GAAG,IAAI,uBAAU,CACpC;YACE,IAAI,8DAA4B,CAAC,EAAC,kBAAkB,oBAAA,EAAC,CAAC;YACtD,IAAI,mDAAuB,EAAE;SAC9B,EACD,WAAW,CAAC,CAAC;QAEjB,IAAM,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,CAAC;QACjG,cAAc,GAAG,cAAO,CAAC,cAAc,CAAC,CAAC;QACzC,iBAAiB,CAAC,cAAc,CAC5B,eAAe,EAAE,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;IACjF,CAAC;IAvBD,wCAuBC","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as glob from 'glob';\nimport {resolve} from 'path';\nimport * as yargs from 'yargs';\n\nimport {AssetTranslationHandler} from './asset_files/asset_translation_handler';\nimport {getOutputPathFn, OutputPathFn} from './output_path';\nimport {SourceFileTranslationHandler} from './source_files/source_file_translation_handler';\nimport {MissingTranslationStrategy} from './source_files/source_file_utils';\nimport {TranslationLoader} from './translation_files/translation_loader';\nimport {SimpleJsonTranslationParser} from './translation_files/translation_parsers/simple_json_translation_parser';\nimport {Xliff1TranslationParser} from './translation_files/translation_parsers/xliff1_translation_parser';\nimport {Xliff2TranslationParser} from './translation_files/translation_parsers/xliff2_translation_parser';\nimport {XtbTranslationParser} from './translation_files/translation_parsers/xtb_translation_parser';\nimport {Translator} from './translator';\nimport {Diagnostics} from '../diagnostics';\n\nif (require.main === module) {\n  const args = process.argv.slice(2);\n  const options =\n      yargs\n          .option('r', {\n            alias: 'root',\n            required: true,\n            describe:\n                'The root path of the files to translate, either absolute or relative to the current working directory. E.g. `dist/en`.',\n          })\n          .option('s', {\n            alias: 'source',\n            required: true,\n            describe:\n                'A glob pattern indicating what files to translate, relative to the `root` path. E.g. `bundles/**/*`.',\n          })\n\n          .option('l', {\n            alias: 'source-locale',\n            describe:\n                'The source locale of the application. If this is provided then a copy of the application will be created with no translation but just the `$localize` calls stripped out.',\n          })\n\n          .option('t', {\n            alias: 'translations',\n            required: true,\n            array: true,\n            describe:\n                'A list of paths to the translation files to load, either absolute or relative to the current working directory.\\n' +\n                'E.g. \"-t src/locale/messages.en.xlf src/locale/messages.fr.xlf src/locale/messages.de.xlf\".',\n          })\n\n          .option('target-locales', {\n            array: true,\n            describe:\n                'A list of target locales for the translation files, which will override any target locale parsed from the translation file.\\n' +\n                'E.g. \"-t en fr de\".',\n          })\n\n          .option('o', {\n            alias: 'outputPath',\n            required: true,\n            describe:\n                'A output path pattern to where the translated files will be written. The marker `{{LOCALE}}` will be replaced with the target locale. E.g. `dist/{{LOCALE}}`.'\n          })\n\n          .option('m', {\n            alias: 'missingTranslation',\n            describe: 'How to handle missing translations.',\n            choices: ['error', 'warning', 'ignore'],\n            default: 'warning',\n          })\n\n          .help()\n          .parse(args);\n\n  const sourceRootPath = options['r'];\n  const sourceFilePaths =\n      glob.sync(options['s'], {absolute: true, cwd: sourceRootPath, nodir: true});\n  const translationFilePaths: string[] = options['t'];\n  const outputPathFn = getOutputPathFn(options['o']);\n  const diagnostics = new Diagnostics();\n  const missingTranslation: MissingTranslationStrategy = options['m'];\n  const sourceLocale: string|undefined = options['l'];\n  const translationFileLocales: string[] = options['target-locales'] || [];\n\n  translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, translationFileLocales,\n                  outputPathFn, diagnostics, missingTranslation, sourceLocale});\n\n  diagnostics.messages.forEach(m => console.warn(`${m.type}: ${m.message}`));\n  process.exit(diagnostics.hasErrors ? 1 : 0);\n}\n\nexport interface TranslateFilesOptions {\n  /**\n   * The root path of the files to translate, either absolute or relative to the current working\n   * directory. E.g. `dist/en`\n   */\n  sourceRootPath: string;\n  /**\n   * The files to translate, relative to the `root` path.\n   */\n  sourceFilePaths: string[];\n  /**\n   * An array of paths to the translation files to load, either absolute or relative to the current\n   * working directory.\n   */\n  translationFilePaths: string[];\n  /**\n   * A collection of the target locales for the translation files.\n   */\n  translationFileLocales: (string|undefined)[];\n  /**\n   * A function that computes the output path of where the translated files will be written.\n   * The marker `{{LOCALE}}` will be replaced with the target locale. E.g. `dist/{{LOCALE}}`.\n   */\n  outputPathFn: OutputPathFn;\n  /**\n   * An object that will receive any diagnostics messages due to the processing.\n   */\n  diagnostics: Diagnostics;\n  /**\n   * How to handle missing translations.\n   */\n  missingTranslation: MissingTranslationStrategy;\n  /**\n   * The locale of the source files.\n   * If this is provided then a copy of the application will be created with no translation but just\n   * the `$localize` calls stripped out.\n   */\n  sourceLocale?: string;\n}\n\nexport function translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths,\n                                translationFileLocales, outputPathFn, diagnostics,\n                                missingTranslation, sourceLocale}: TranslateFilesOptions) {\n  const translationLoader = new TranslationLoader(\n      [\n        new Xliff2TranslationParser(),\n        new Xliff1TranslationParser(),\n        new XtbTranslationParser(diagnostics),\n        new SimpleJsonTranslationParser(),\n      ],\n      diagnostics);\n\n  const resourceProcessor = new Translator(\n      [\n        new SourceFileTranslationHandler({missingTranslation}),\n        new AssetTranslationHandler(),\n      ],\n      diagnostics);\n\n  const translations = translationLoader.loadBundles(translationFilePaths, translationFileLocales);\n  sourceRootPath = resolve(sourceRootPath);\n  resourceProcessor.translateFiles(\n      sourceFilePaths, sourceRootPath, outputPathFn, translations, sourceLocale);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../../../../packages/localize/src/tools/src/translate/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as glob from 'glob';\nimport {resolve} from 'path';\nimport * as yargs from 'yargs';\n\nimport {AssetTranslationHandler} from './asset_files/asset_translation_handler';\nimport {getOutputPathFn, OutputPathFn} from './output_path';\nimport {SourceFileTranslationHandler} from './source_files/source_file_translation_handler';\nimport {MissingTranslationStrategy} from './source_files/source_file_utils';\nimport {TranslationLoader} from './translation_files/translation_loader';\nimport {SimpleJsonTranslationParser} from './translation_files/translation_parsers/simple_json_translation_parser';\nimport {Xliff1TranslationParser} from './translation_files/translation_parsers/xliff1_translation_parser';\nimport {Xliff2TranslationParser} from './translation_files/translation_parsers/xliff2_translation_parser';\nimport {XtbTranslationParser} from './translation_files/translation_parsers/xtb_translation_parser';\nimport {Translator} from './translator';\nimport {Diagnostics} from '../diagnostics';\n\nif (require.main === module) {\n  const args = process.argv.slice(2);\n  const options =\n      yargs\n          .option('r', {\n            alias: 'root',\n            required: true,\n            describe:\n                'The root path of the files to translate, either absolute or relative to the current working directory. E.g. `dist/en`.',\n          })\n          .option('s', {\n            alias: 'source',\n            required: true,\n            describe:\n                'A glob pattern indicating what files to translate, relative to the `root` path. E.g. `bundles/**/*`.',\n          })\n\n          .option('l', {\n            alias: 'source-locale',\n            describe:\n                'The source locale of the application. If this is provided then a copy of the application will be created with no translation but just the `$localize` calls stripped out.',\n          })\n\n          .option('t', {\n            alias: 'translations',\n            required: true,\n            array: true,\n            describe:\n                'A list of paths to the translation files to load, either absolute or relative to the current working directory.\\n' +\n                'E.g. \"-t src/locale/messages.en.xlf src/locale/messages.fr.xlf src/locale/messages.de.xlf\".',\n          })\n\n          .option('target-locales', {\n            array: true,\n            describe:\n                'A list of target locales for the translation files, which will override any target locale parsed from the translation file.\\n' +\n                'E.g. \"-t en fr de\".',\n          })\n\n          .option('o', {\n            alias: 'outputPath',\n            required: true,\n            describe:\n                'A output path pattern to where the translated files will be written. The marker `{{LOCALE}}` will be replaced with the target locale. E.g. `dist/{{LOCALE}}`.'\n          })\n\n          .option('m', {\n            alias: 'missingTranslation',\n            describe: 'How to handle missing translations.',\n            choices: ['error', 'warning', 'ignore'],\n            default: 'warning',\n          })\n\n          .help()\n          .parse(args);\n\n  const sourceRootPath = options['r'];\n  const sourceFilePaths =\n      glob.sync(options['s'], {absolute: true, cwd: sourceRootPath, nodir: true});\n  const translationFilePaths: string[] = options['t'];\n  const outputPathFn = getOutputPathFn(options['o']);\n  const diagnostics = new Diagnostics();\n  const missingTranslation: MissingTranslationStrategy = options['m'];\n  const sourceLocale: string|undefined = options['l'];\n  const translationFileLocales: string[] = options['target-locales'] || [];\n\n  translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, translationFileLocales,\n                  outputPathFn, diagnostics, missingTranslation, sourceLocale});\n\n  diagnostics.messages.forEach(m => console.warn(`${m.type}: ${m.message}`));\n  process.exit(diagnostics.hasErrors ? 1 : 0);\n}\n\nexport interface TranslateFilesOptions {\n  /**\n   * The root path of the files to translate, either absolute or relative to the current working\n   * directory. E.g. `dist/en`\n   */\n  sourceRootPath: string;\n  /**\n   * The files to translate, relative to the `root` path.\n   */\n  sourceFilePaths: string[];\n  /**\n   * An array of paths to the translation files to load, either absolute or relative to the current\n   * working directory.\n   */\n  translationFilePaths: string[];\n  /**\n   * A collection of the target locales for the translation files.\n   */\n  translationFileLocales: (string|undefined)[];\n  /**\n   * A function that computes the output path of where the translated files will be written.\n   * The marker `{{LOCALE}}` will be replaced with the target locale. E.g. `dist/{{LOCALE}}`.\n   */\n  outputPathFn: OutputPathFn;\n  /**\n   * An object that will receive any diagnostics messages due to the processing.\n   */\n  diagnostics: Diagnostics;\n  /**\n   * How to handle missing translations.\n   */\n  missingTranslation: MissingTranslationStrategy;\n  /**\n   * The locale of the source files.\n   * If this is provided then a copy of the application will be created with no translation but just\n   * the `$localize` calls stripped out.\n   */\n  sourceLocale?: string;\n}\n\nexport function translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths,\n                                translationFileLocales, outputPathFn, diagnostics,\n                                missingTranslation, sourceLocale}: TranslateFilesOptions) {\n  const translationLoader = new TranslationLoader(\n      [\n        new Xliff2TranslationParser(),\n        new Xliff1TranslationParser(),\n        new XtbTranslationParser(),\n        new SimpleJsonTranslationParser(),\n      ],\n      diagnostics);\n\n  const resourceProcessor = new Translator(\n      [\n        new SourceFileTranslationHandler({missingTranslation}),\n        new AssetTranslationHandler(),\n      ],\n      diagnostics);\n\n  const translations = translationLoader.loadBundles(translationFilePaths, translationFileLocales);\n  sourceRootPath = resolve(sourceRootPath);\n  resourceProcessor.translateFiles(\n      sourceFilePaths, sourceRootPath, outputPathFn, translations, sourceLocale);\n}\n"]}

@@ -17,4 +17,5 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_loader" />

private translationParsers;
private diagnostics;
constructor(translationParsers: TranslationParser[], diagnostics: Diagnostics);
/** @deprecated */ private diagnostics?;
constructor(translationParsers: TranslationParser<any>[],
/** @deprecated */ diagnostics?: Diagnostics | undefined);
/**

@@ -21,0 +22,0 @@ * Load and parse the translation files into a collection of `TranslationBundles`.

@@ -18,3 +18,4 @@ (function (factory) {

var TranslationLoader = /** @class */ (function () {
function TranslationLoader(translationParsers, diagnostics) {
function TranslationLoader(translationParsers,
/** @deprecated */ diagnostics) {
this.translationParsers = translationParsers;

@@ -39,20 +40,29 @@ this.diagnostics = diagnostics;

return translationFilePaths.map(function (filePath, index) {
var e_1, _a;
var e_1, _a, _b;
var fileContents = file_utils_1.FileUtils.readFile(filePath);
try {
for (var _b = tslib_1.__values(_this.translationParsers), _c = _b.next(); !_c.done; _c = _b.next()) {
var translationParser = _c.value;
if (translationParser.canParse(filePath, fileContents)) {
var providedLocale = translationFileLocales[index];
var _d = translationParser.parse(filePath, fileContents), parsedLocale = _d.locale, translations = _d.translations;
var locale = providedLocale || parsedLocale;
if (locale === undefined) {
throw new Error("The translation file \"" + filePath + "\" does not contain a target locale and no explicit locale was provided for this file.");
}
if (parsedLocale !== undefined && providedLocale !== undefined &&
parsedLocale !== providedLocale) {
_this.diagnostics.warn("The provided locale \"" + providedLocale + "\" does not match the target locale \"" + parsedLocale + "\" found in the translation file \"" + filePath + "\".");
}
return { locale: locale, translations: translations };
for (var _c = tslib_1.__values(_this.translationParsers), _d = _c.next(); !_d.done; _d = _c.next()) {
var translationParser = _d.value;
var result = translationParser.canParse(filePath, fileContents);
if (!result) {
continue;
}
var _e = translationParser.parse(filePath, fileContents, result), parsedLocale = _e.locale, translations = _e.translations, diagnostics = _e.diagnostics;
if (diagnostics.hasErrors) {
throw new Error(diagnostics.formatDiagnostics("The translation file \"" + filePath + "\" could not be parsed."));
}
var providedLocale = translationFileLocales[index];
var locale = providedLocale || parsedLocale;
if (locale === undefined) {
throw new Error("The translation file \"" + filePath + "\" does not contain a target locale and no explicit locale was provided for this file.");
}
if (parsedLocale !== undefined && providedLocale !== undefined &&
parsedLocale !== providedLocale) {
diagnostics.warn("The provided locale \"" + providedLocale + "\" does not match the target locale \"" + parsedLocale + "\" found in the translation file \"" + filePath + "\".");
}
// If we were passed a diagnostics object then copy the messages over to it.
if (_this.diagnostics) {
(_b = _this.diagnostics.messages).push.apply(_b, tslib_1.__spread(diagnostics.messages));
}
return { locale: locale, translations: translations, diagnostics: diagnostics };
}

@@ -63,3 +73,3 @@ }

try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
}

@@ -75,2 +85,2 @@ finally { if (e_1) throw e_1.error; }

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb25fbG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fbG9hZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQVFBLHlFQUEyQztJQUkzQzs7T0FFRztJQUNIO1FBQ0UsMkJBQW9CLGtCQUF1QyxFQUFVLFdBQXdCO1lBQXpFLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBcUI7WUFBVSxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUFHLENBQUM7UUFFakc7Ozs7Ozs7Ozs7OztXQVlHO1FBQ0gsdUNBQVcsR0FBWCxVQUFZLG9CQUE4QixFQUFFLHNCQUE0QztZQUF4RixpQkF5QkM7WUF2QkMsT0FBTyxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsVUFBQyxRQUFRLEVBQUUsS0FBSzs7Z0JBQzlDLElBQU0sWUFBWSxHQUFHLHNCQUFTLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDOztvQkFDbEQsS0FBZ0MsSUFBQSxLQUFBLGlCQUFBLEtBQUksQ0FBQyxrQkFBa0IsQ0FBQSxnQkFBQSw0QkFBRTt3QkFBcEQsSUFBTSxpQkFBaUIsV0FBQTt3QkFDMUIsSUFBSSxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxFQUFFOzRCQUN0RCxJQUFNLGNBQWMsR0FBRyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsQ0FBQzs0QkFDL0MsSUFBQSxvREFDNkMsRUFENUMsd0JBQW9CLEVBQUUsOEJBQ3NCLENBQUM7NEJBQ3BELElBQU0sTUFBTSxHQUFHLGNBQWMsSUFBSSxZQUFZLENBQUM7NEJBQzlDLElBQUksTUFBTSxLQUFLLFNBQVMsRUFBRTtnQ0FDeEIsTUFBTSxJQUFJLEtBQUssQ0FDWCw0QkFBeUIsUUFBUSwyRkFBdUYsQ0FBQyxDQUFDOzZCQUMvSDs0QkFDRCxJQUFJLFlBQVksS0FBSyxTQUFTLElBQUksY0FBYyxLQUFLLFNBQVM7Z0NBQzFELFlBQVksS0FBSyxjQUFjLEVBQUU7Z0NBQ25DLEtBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUNqQiwyQkFBd0IsY0FBYyw4Q0FBdUMsWUFBWSwyQ0FBb0MsUUFBUSxRQUFJLENBQUMsQ0FBQzs2QkFDaEo7NEJBQ0QsT0FBTyxFQUFDLE1BQU0sUUFBQSxFQUFFLFlBQVksY0FBQSxFQUFDLENBQUM7eUJBQy9CO3FCQUNGOzs7Ozs7Ozs7Z0JBQ0QsTUFBTSxJQUFJLEtBQUssQ0FDWCw2RUFBeUUsUUFBUSxNQUFHLENBQUMsQ0FBQztZQUM1RixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDSCx3QkFBQztJQUFELENBQUMsQUExQ0QsSUEwQ0M7SUExQ1ksOENBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vZGlhZ25vc3RpY3MnO1xuaW1wb3J0IHtGaWxlVXRpbHN9IGZyb20gJy4uLy4uL2ZpbGVfdXRpbHMnO1xuaW1wb3J0IHtUcmFuc2xhdGlvbkJ1bmRsZX0gZnJvbSAnLi4vdHJhbnNsYXRvcic7XG5pbXBvcnQge1RyYW5zbGF0aW9uUGFyc2VyfSBmcm9tICcuL3RyYW5zbGF0aW9uX3BhcnNlcnMvdHJhbnNsYXRpb25fcGFyc2VyJztcblxuLyoqXG4gKiBVc2UgdGhpcyBjbGFzcyB0byBsb2FkIGEgY29sbGVjdGlvbiBvZiB0cmFuc2xhdGlvbiBmaWxlcyBmcm9tIGRpc2suXG4gKi9cbmV4cG9ydCBjbGFzcyBUcmFuc2xhdGlvbkxvYWRlciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRpb25QYXJzZXJzOiBUcmFuc2xhdGlvblBhcnNlcltdLCBwcml2YXRlIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcykge31cblxuICAvKipcbiAgICogTG9hZCBhbmQgcGFyc2UgdGhlIHRyYW5zbGF0aW9uIGZpbGVzIGludG8gYSBjb2xsZWN0aW9uIG9mIGBUcmFuc2xhdGlvbkJ1bmRsZXNgLlxuICAgKlxuICAgKiBJZiB0aGVyZSBpcyBhIGxvY2FsZSBwcm92aWRlZCBpbiBgdHJhbnNsYXRpb25GaWxlTG9jYWxlc2AgdGhlbiB0aGlzIGlzIHVzZWQgcmF0aGVyIHRoYW4gdGhlXG4gICAqIGxvY2FsZSBleHRyYWN0ZWQgZnJvbSB0aGUgZmlsZSBpdHNlbGYuXG4gICAqIElmIHRoZXJlIGlzIG5laXRoZXIgYSBwcm92aWRlZCBsb2NhbGUgbm9yIGEgbG9jYWxlIHBhcnNlZCBmcm9tIHRoZSBmaWxlLCB0aGVuIGFuIGVycm9yIGlzXG4gICAqIHRocm93bi5cbiAgICogSWYgdGhlcmUgYXJlIGJvdGggYSBwcm92aWRlZCBsb2NhbGUgYW5kIGEgbG9jYWxlIHBhcnNlZCBmcm9tIHRoZSBmaWxlLCBhbmQgdGhleSBhcmUgbm90IHRoZVxuICAgKiBzYW1lLCB0aGVuIGEgd2FybmluZyBpcyByZXBvcnRlZCAuXG4gICAqXG4gICAqIEBwYXJhbSB0cmFuc2xhdGlvbkZpbGVQYXRocyBBbiBhcnJheSBvZiBhYnNvbHV0ZSBwYXRocyB0byB0aGUgdHJhbnNsYXRpb24gZmlsZXMuXG4gICAqIEBwYXJhbSB0cmFuc2xhdGlvbkZpbGVMb2NhbGVzIEFuIGFycmF5IG9mIGxvY2FsZXMgZm9yIGVhY2ggb2YgdGhlIHRyYW5zbGF0aW9uIGZpbGVzLlxuICAgKi9cbiAgbG9hZEJ1bmRsZXModHJhbnNsYXRpb25GaWxlUGF0aHM6IHN0cmluZ1tdLCB0cmFuc2xhdGlvbkZpbGVMb2NhbGVzOiAoc3RyaW5nfHVuZGVmaW5lZClbXSk6XG4gICAgICBUcmFuc2xhdGlvbkJ1bmRsZVtdIHtcbiAgICByZXR1cm4gdHJhbnNsYXRpb25GaWxlUGF0aHMubWFwKChmaWxlUGF0aCwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGZpbGVDb250ZW50cyA9IEZpbGVVdGlscy5yZWFkRmlsZShmaWxlUGF0aCk7XG4gICAgICBmb3IgKGNvbnN0IHRyYW5zbGF0aW9uUGFyc2VyIG9mIHRoaXMudHJhbnNsYXRpb25QYXJzZXJzKSB7XG4gICAgICAgIGlmICh0cmFuc2xhdGlvblBhcnNlci5jYW5QYXJzZShmaWxlUGF0aCwgZmlsZUNvbnRlbnRzKSkge1xuICAgICAgICAgIGNvbnN0IHByb3ZpZGVkTG9jYWxlID0gdHJhbnNsYXRpb25GaWxlTG9jYWxlc1tpbmRleF07XG4gICAgICAgICAgY29uc3Qge2xvY2FsZTogcGFyc2VkTG9jYWxlLCB0cmFuc2xhdGlvbnN9ID1cbiAgICAgICAgICAgICAgdHJhbnNsYXRpb25QYXJzZXIucGFyc2UoZmlsZVBhdGgsIGZpbGVDb250ZW50cyk7XG4gICAgICAgICAgY29uc3QgbG9jYWxlID0gcHJvdmlkZWRMb2NhbGUgfHwgcGFyc2VkTG9jYWxlO1xuICAgICAgICAgIGlmIChsb2NhbGUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgICAgIGBUaGUgdHJhbnNsYXRpb24gZmlsZSBcIiR7ZmlsZVBhdGh9XCIgZG9lcyBub3QgY29udGFpbiBhIHRhcmdldCBsb2NhbGUgYW5kIG5vIGV4cGxpY2l0IGxvY2FsZSB3YXMgcHJvdmlkZWQgZm9yIHRoaXMgZmlsZS5gKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgaWYgKHBhcnNlZExvY2FsZSAhPT0gdW5kZWZpbmVkICYmIHByb3ZpZGVkTG9jYWxlICE9PSB1bmRlZmluZWQgJiZcbiAgICAgICAgICAgICAgcGFyc2VkTG9jYWxlICE9PSBwcm92aWRlZExvY2FsZSkge1xuICAgICAgICAgICAgdGhpcy5kaWFnbm9zdGljcy53YXJuKFxuICAgICAgICAgICAgICAgIGBUaGUgcHJvdmlkZWQgbG9jYWxlIFwiJHtwcm92aWRlZExvY2FsZX1cIiBkb2VzIG5vdCBtYXRjaCB0aGUgdGFyZ2V0IGxvY2FsZSBcIiR7cGFyc2VkTG9jYWxlfVwiIGZvdW5kIGluIHRoZSB0cmFuc2xhdGlvbiBmaWxlIFwiJHtmaWxlUGF0aH1cIi5gKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHtsb2NhbGUsIHRyYW5zbGF0aW9uc307XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICBgVGhlcmUgaXMgbm8gXCJUcmFuc2xhdGlvblBhcnNlclwiIHRoYXQgY2FuIHBhcnNlIHRoaXMgdHJhbnNsYXRpb24gZmlsZTogJHtmaWxlUGF0aH0uYCk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb25fbG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fbG9hZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQVFBLHlFQUEyQztJQUkzQzs7T0FFRztJQUNIO1FBQ0UsMkJBQ1ksa0JBQTRDO1FBQ3BELGtCQUFrQixDQUFTLFdBQXlCO1lBRDVDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBMEI7WUFDekIsZ0JBQVcsR0FBWCxXQUFXLENBQWM7UUFBRyxDQUFDO1FBRTVEOzs7Ozs7Ozs7Ozs7V0FZRztRQUNILHVDQUFXLEdBQVgsVUFBWSxvQkFBOEIsRUFBRSxzQkFBNEM7WUFBeEYsaUJBd0NDO1lBdENDLE9BQU8sb0JBQW9CLENBQUMsR0FBRyxDQUFDLFVBQUMsUUFBUSxFQUFFLEtBQUs7O2dCQUM5QyxJQUFNLFlBQVksR0FBRyxzQkFBUyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQzs7b0JBQ2xELEtBQWdDLElBQUEsS0FBQSxpQkFBQSxLQUFJLENBQUMsa0JBQWtCLENBQUEsZ0JBQUEsNEJBQUU7d0JBQXBELElBQU0saUJBQWlCLFdBQUE7d0JBQzFCLElBQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLENBQUM7d0JBQ2xFLElBQUksQ0FBQyxNQUFNLEVBQUU7NEJBQ1gsU0FBUzt5QkFDVjt3QkFFSyxJQUFBLDREQUNxRCxFQURwRCx3QkFBb0IsRUFBRSw4QkFBWSxFQUFFLDRCQUNnQixDQUFDO3dCQUM1RCxJQUFJLFdBQVcsQ0FBQyxTQUFTLEVBQUU7NEJBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsV0FBVyxDQUFDLGlCQUFpQixDQUN6Qyw0QkFBeUIsUUFBUSw0QkFBd0IsQ0FBQyxDQUFDLENBQUM7eUJBQ2pFO3dCQUVELElBQU0sY0FBYyxHQUFHLHNCQUFzQixDQUFDLEtBQUssQ0FBQyxDQUFDO3dCQUNyRCxJQUFNLE1BQU0sR0FBRyxjQUFjLElBQUksWUFBWSxDQUFDO3dCQUM5QyxJQUFJLE1BQU0sS0FBSyxTQUFTLEVBQUU7NEJBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQ1gsNEJBQXlCLFFBQVEsMkZBQXVGLENBQUMsQ0FBQzt5QkFDL0g7d0JBRUQsSUFBSSxZQUFZLEtBQUssU0FBUyxJQUFJLGNBQWMsS0FBSyxTQUFTOzRCQUMxRCxZQUFZLEtBQUssY0FBYyxFQUFFOzRCQUNuQyxXQUFXLENBQUMsSUFBSSxDQUNaLDJCQUF3QixjQUFjLDhDQUF1QyxZQUFZLDJDQUFvQyxRQUFRLFFBQUksQ0FBQyxDQUFDO3lCQUNoSjt3QkFFRCw0RUFBNEU7d0JBQzVFLElBQUksS0FBSSxDQUFDLFdBQVcsRUFBRTs0QkFDcEIsQ0FBQSxLQUFBLEtBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFBLENBQUMsSUFBSSw0QkFBSSxXQUFXLENBQUMsUUFBUSxHQUFFO3lCQUN6RDt3QkFFRCxPQUFPLEVBQUMsTUFBTSxRQUFBLEVBQUUsWUFBWSxjQUFBLEVBQUUsV0FBVyxhQUFBLEVBQUMsQ0FBQztxQkFDNUM7Ozs7Ozs7OztnQkFDRCxNQUFNLElBQUksS0FBSyxDQUNYLDZFQUF5RSxRQUFRLE1BQUcsQ0FBQyxDQUFDO1lBQzVGLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNILHdCQUFDO0lBQUQsQ0FBQyxBQTNERCxJQTJEQztJQTNEWSw4Q0FBaUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0RpYWdub3N0aWNzfSBmcm9tICcuLi8uLi9kaWFnbm9zdGljcyc7XG5pbXBvcnQge0ZpbGVVdGlsc30gZnJvbSAnLi4vLi4vZmlsZV91dGlscyc7XG5pbXBvcnQge1RyYW5zbGF0aW9uQnVuZGxlfSBmcm9tICcuLi90cmFuc2xhdG9yJztcbmltcG9ydCB7VHJhbnNsYXRpb25QYXJzZXJ9IGZyb20gJy4vdHJhbnNsYXRpb25fcGFyc2Vycy90cmFuc2xhdGlvbl9wYXJzZXInO1xuXG4vKipcbiAqIFVzZSB0aGlzIGNsYXNzIHRvIGxvYWQgYSBjb2xsZWN0aW9uIG9mIHRyYW5zbGF0aW9uIGZpbGVzIGZyb20gZGlzay5cbiAqL1xuZXhwb3J0IGNsYXNzIFRyYW5zbGF0aW9uTG9hZGVyIHtcbiAgY29uc3RydWN0b3IoXG4gICAgICBwcml2YXRlIHRyYW5zbGF0aW9uUGFyc2VyczogVHJhbnNsYXRpb25QYXJzZXI8YW55PltdLFxuICAgICAgLyoqIEBkZXByZWNhdGVkICovIHByaXZhdGUgZGlhZ25vc3RpY3M/OiBEaWFnbm9zdGljcykge31cblxuICAvKipcbiAgICogTG9hZCBhbmQgcGFyc2UgdGhlIHRyYW5zbGF0aW9uIGZpbGVzIGludG8gYSBjb2xsZWN0aW9uIG9mIGBUcmFuc2xhdGlvbkJ1bmRsZXNgLlxuICAgKlxuICAgKiBJZiB0aGVyZSBpcyBhIGxvY2FsZSBwcm92aWRlZCBpbiBgdHJhbnNsYXRpb25GaWxlTG9jYWxlc2AgdGhlbiB0aGlzIGlzIHVzZWQgcmF0aGVyIHRoYW4gdGhlXG4gICAqIGxvY2FsZSBleHRyYWN0ZWQgZnJvbSB0aGUgZmlsZSBpdHNlbGYuXG4gICAqIElmIHRoZXJlIGlzIG5laXRoZXIgYSBwcm92aWRlZCBsb2NhbGUgbm9yIGEgbG9jYWxlIHBhcnNlZCBmcm9tIHRoZSBmaWxlLCB0aGVuIGFuIGVycm9yIGlzXG4gICAqIHRocm93bi5cbiAgICogSWYgdGhlcmUgYXJlIGJvdGggYSBwcm92aWRlZCBsb2NhbGUgYW5kIGEgbG9jYWxlIHBhcnNlZCBmcm9tIHRoZSBmaWxlLCBhbmQgdGhleSBhcmUgbm90IHRoZVxuICAgKiBzYW1lLCB0aGVuIGEgd2FybmluZyBpcyByZXBvcnRlZCAuXG4gICAqXG4gICAqIEBwYXJhbSB0cmFuc2xhdGlvbkZpbGVQYXRocyBBbiBhcnJheSBvZiBhYnNvbHV0ZSBwYXRocyB0byB0aGUgdHJhbnNsYXRpb24gZmlsZXMuXG4gICAqIEBwYXJhbSB0cmFuc2xhdGlvbkZpbGVMb2NhbGVzIEFuIGFycmF5IG9mIGxvY2FsZXMgZm9yIGVhY2ggb2YgdGhlIHRyYW5zbGF0aW9uIGZpbGVzLlxuICAgKi9cbiAgbG9hZEJ1bmRsZXModHJhbnNsYXRpb25GaWxlUGF0aHM6IHN0cmluZ1tdLCB0cmFuc2xhdGlvbkZpbGVMb2NhbGVzOiAoc3RyaW5nfHVuZGVmaW5lZClbXSk6XG4gICAgICBUcmFuc2xhdGlvbkJ1bmRsZVtdIHtcbiAgICByZXR1cm4gdHJhbnNsYXRpb25GaWxlUGF0aHMubWFwKChmaWxlUGF0aCwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGZpbGVDb250ZW50cyA9IEZpbGVVdGlscy5yZWFkRmlsZShmaWxlUGF0aCk7XG4gICAgICBmb3IgKGNvbnN0IHRyYW5zbGF0aW9uUGFyc2VyIG9mIHRoaXMudHJhbnNsYXRpb25QYXJzZXJzKSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IHRyYW5zbGF0aW9uUGFyc2VyLmNhblBhcnNlKGZpbGVQYXRoLCBmaWxlQ29udGVudHMpO1xuICAgICAgICBpZiAoIXJlc3VsdCkge1xuICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qge2xvY2FsZTogcGFyc2VkTG9jYWxlLCB0cmFuc2xhdGlvbnMsIGRpYWdub3N0aWNzfSA9XG4gICAgICAgICAgICB0cmFuc2xhdGlvblBhcnNlci5wYXJzZShmaWxlUGF0aCwgZmlsZUNvbnRlbnRzLCByZXN1bHQpO1xuICAgICAgICBpZiAoZGlhZ25vc3RpY3MuaGFzRXJyb3JzKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGRpYWdub3N0aWNzLmZvcm1hdERpYWdub3N0aWNzKFxuICAgICAgICAgICAgICBgVGhlIHRyYW5zbGF0aW9uIGZpbGUgXCIke2ZpbGVQYXRofVwiIGNvdWxkIG5vdCBiZSBwYXJzZWQuYCkpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcHJvdmlkZWRMb2NhbGUgPSB0cmFuc2xhdGlvbkZpbGVMb2NhbGVzW2luZGV4XTtcbiAgICAgICAgY29uc3QgbG9jYWxlID0gcHJvdmlkZWRMb2NhbGUgfHwgcGFyc2VkTG9jYWxlO1xuICAgICAgICBpZiAobG9jYWxlID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgICAgIGBUaGUgdHJhbnNsYXRpb24gZmlsZSBcIiR7ZmlsZVBhdGh9XCIgZG9lcyBub3QgY29udGFpbiBhIHRhcmdldCBsb2NhbGUgYW5kIG5vIGV4cGxpY2l0IGxvY2FsZSB3YXMgcHJvdmlkZWQgZm9yIHRoaXMgZmlsZS5gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChwYXJzZWRMb2NhbGUgIT09IHVuZGVmaW5lZCAmJiBwcm92aWRlZExvY2FsZSAhPT0gdW5kZWZpbmVkICYmXG4gICAgICAgICAgICBwYXJzZWRMb2NhbGUgIT09IHByb3ZpZGVkTG9jYWxlKSB7XG4gICAgICAgICAgZGlhZ25vc3RpY3Mud2FybihcbiAgICAgICAgICAgICAgYFRoZSBwcm92aWRlZCBsb2NhbGUgXCIke3Byb3ZpZGVkTG9jYWxlfVwiIGRvZXMgbm90IG1hdGNoIHRoZSB0YXJnZXQgbG9jYWxlIFwiJHtwYXJzZWRMb2NhbGV9XCIgZm91bmQgaW4gdGhlIHRyYW5zbGF0aW9uIGZpbGUgXCIke2ZpbGVQYXRofVwiLmApO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gSWYgd2Ugd2VyZSBwYXNzZWQgYSBkaWFnbm9zdGljcyBvYmplY3QgdGhlbiBjb3B5IHRoZSBtZXNzYWdlcyBvdmVyIHRvIGl0LlxuICAgICAgICBpZiAodGhpcy5kaWFnbm9zdGljcykge1xuICAgICAgICAgIHRoaXMuZGlhZ25vc3RpY3MubWVzc2FnZXMucHVzaCguLi5kaWFnbm9zdGljcy5tZXNzYWdlcyk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4ge2xvY2FsZSwgdHJhbnNsYXRpb25zLCBkaWFnbm9zdGljc307XG4gICAgICB9XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgYFRoZXJlIGlzIG5vIFwiVHJhbnNsYXRpb25QYXJzZXJcIiB0aGF0IGNhbiBwYXJzZSB0aGlzIHRyYW5zbGF0aW9uIGZpbGU6ICR7ZmlsZVBhdGh9LmApO1xuICAgIH0pO1xuICB9XG59XG4iXX0=

@@ -7,3 +7,3 @@ (function (factory) {

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser", ["require", "exports", "@angular/localize", "path"], factory);
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser", ["require", "exports", "@angular/localize", "path", "@angular/localize/src/tools/src/diagnostics"], factory);
}

@@ -22,2 +22,3 @@ })(function (require, exports) {

var path_1 = require("path");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
/**

@@ -47,3 +48,3 @@ * A translation parser that can parse JSON that has the form:

}
return { locale: parsedLocale, translations: parsedTranslations };
return { locale: parsedLocale, translations: parsedTranslations, diagnostics: new diagnostics_1.Diagnostics() };
};

@@ -54,2 +55,2 @@ return SimpleJsonTranslationParser;

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlX2pzb25fdHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy9zaW1wbGVfanNvbl90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFBQTs7Ozs7O09BTUc7SUFDSCw4Q0FBb0Y7SUFDcEYsNkJBQTZCO0lBRzdCOzs7Ozs7Ozs7Ozs7T0FZRztJQUNIO1FBQUE7UUFZQSxDQUFDO1FBWEMsOENBQVEsR0FBUixVQUFTLFFBQWdCLEVBQUUsU0FBaUIsSUFBYSxPQUFPLENBQUMsY0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVsRywyQ0FBSyxHQUFMLFVBQU0sU0FBaUIsRUFBRSxRQUFnQjtZQUNqQyxJQUFBLHlCQUEyRCxFQUExRCx3QkFBb0IsRUFBRSw4QkFBb0MsQ0FBQztZQUNsRSxJQUFNLGtCQUFrQixHQUEyQyxFQUFFLENBQUM7WUFDdEUsS0FBSyxJQUFNLFNBQVMsSUFBSSxZQUFZLEVBQUU7Z0JBQ3BDLElBQU0sYUFBYSxHQUFHLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDOUMsa0JBQWtCLENBQUMsU0FBUyxDQUFDLEdBQUcsNEJBQWlCLENBQUMsYUFBYSxDQUFDLENBQUM7YUFDbEU7WUFDRCxPQUFPLEVBQUMsTUFBTSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUMsQ0FBQztRQUNsRSxDQUFDO1FBQ0gsa0NBQUM7SUFBRCxDQUFDLEFBWkQsSUFZQztJQVpZLGtFQUEyQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVNZXNzYWdlSWQsIMm1UGFyc2VkVHJhbnNsYXRpb24sIMm1cGFyc2VUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtleHRuYW1lfSBmcm9tICdwYXRoJztcbmltcG9ydCB7UGFyc2VkVHJhbnNsYXRpb25CdW5kbGUsIFRyYW5zbGF0aW9uUGFyc2VyfSBmcm9tICcuL3RyYW5zbGF0aW9uX3BhcnNlcic7XG5cbi8qKlxuICogQSB0cmFuc2xhdGlvbiBwYXJzZXIgdGhhdCBjYW4gcGFyc2UgSlNPTiB0aGF0IGhhcyB0aGUgZm9ybTpcbiAqXG4gKiBgYGBcbiAqIHtcbiAqICAgXCJsb2NhbGVcIjogXCIuLi5cIixcbiAqICAgXCJ0cmFuc2xhdGlvbnNcIjoge1xuICogICAgIFwibWVzc2FnZS1pZFwiOiBcIlRhcmdldCBtZXNzYWdlIHN0cmluZ1wiLFxuICogICAgIC4uLlxuICogICB9XG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFNpbXBsZUpzb25UcmFuc2xhdGlvblBhcnNlciBpbXBsZW1lbnRzIFRyYW5zbGF0aW9uUGFyc2VyIHtcbiAgY2FuUGFyc2UoZmlsZVBhdGg6IHN0cmluZywgX2NvbnRlbnRzOiBzdHJpbmcpOiBib29sZWFuIHsgcmV0dXJuIChleHRuYW1lKGZpbGVQYXRoKSA9PT0gJy5qc29uJyk7IH1cblxuICBwYXJzZShfZmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IHN0cmluZyk6IFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgICBjb25zdCB7bG9jYWxlOiBwYXJzZWRMb2NhbGUsIHRyYW5zbGF0aW9uc30gPSBKU09OLnBhcnNlKGNvbnRlbnRzKTtcbiAgICBjb25zdCBwYXJzZWRUcmFuc2xhdGlvbnM6IFJlY29yZDzJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbj4gPSB7fTtcbiAgICBmb3IgKGNvbnN0IG1lc3NhZ2VJZCBpbiB0cmFuc2xhdGlvbnMpIHtcbiAgICAgIGNvbnN0IHRhcmdldE1lc3NhZ2UgPSB0cmFuc2xhdGlvbnNbbWVzc2FnZUlkXTtcbiAgICAgIHBhcnNlZFRyYW5zbGF0aW9uc1ttZXNzYWdlSWRdID0gybVwYXJzZVRyYW5zbGF0aW9uKHRhcmdldE1lc3NhZ2UpO1xuICAgIH1cbiAgICByZXR1cm4ge2xvY2FsZTogcGFyc2VkTG9jYWxlLCB0cmFuc2xhdGlvbnM6IHBhcnNlZFRyYW5zbGF0aW9uc307XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlX2pzb25fdHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy9zaW1wbGVfanNvbl90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFBQTs7Ozs7O09BTUc7SUFDSCw4Q0FBb0Y7SUFDcEYsNkJBQTZCO0lBQzdCLDJFQUFpRDtJQUdqRDs7Ozs7Ozs7Ozs7O09BWUc7SUFDSDtRQUFBO1FBWUEsQ0FBQztRQVhDLDhDQUFRLEdBQVIsVUFBUyxRQUFnQixFQUFFLFNBQWlCLElBQWEsT0FBTyxDQUFDLGNBQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFbEcsMkNBQUssR0FBTCxVQUFNLFNBQWlCLEVBQUUsUUFBZ0I7WUFDakMsSUFBQSx5QkFBMkQsRUFBMUQsd0JBQW9CLEVBQUUsOEJBQW9DLENBQUM7WUFDbEUsSUFBTSxrQkFBa0IsR0FBMkMsRUFBRSxDQUFDO1lBQ3RFLEtBQUssSUFBTSxTQUFTLElBQUksWUFBWSxFQUFFO2dCQUNwQyxJQUFNLGFBQWEsR0FBRyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBQzlDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxHQUFHLDRCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDO2FBQ2xFO1lBQ0QsT0FBTyxFQUFDLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLGtCQUFrQixFQUFFLFdBQVcsRUFBRSxJQUFJLHlCQUFXLEVBQUUsRUFBQyxDQUFDO1FBQ2xHLENBQUM7UUFDSCxrQ0FBQztJQUFELENBQUMsQUFaRCxJQVlDO0lBWlksa0VBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbiwgybVwYXJzZVRyYW5zbGF0aW9ufSBmcm9tICdAYW5ndWxhci9sb2NhbGl6ZSc7XG5pbXBvcnQge2V4dG5hbWV9IGZyb20gJ3BhdGgnO1xuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vLi4vZGlhZ25vc3RpY3MnO1xuaW1wb3J0IHtQYXJzZWRUcmFuc2xhdGlvbkJ1bmRsZSwgVHJhbnNsYXRpb25QYXJzZXJ9IGZyb20gJy4vdHJhbnNsYXRpb25fcGFyc2VyJztcblxuLyoqXG4gKiBBIHRyYW5zbGF0aW9uIHBhcnNlciB0aGF0IGNhbiBwYXJzZSBKU09OIHRoYXQgaGFzIHRoZSBmb3JtOlxuICpcbiAqIGBgYFxuICoge1xuICogICBcImxvY2FsZVwiOiBcIi4uLlwiLFxuICogICBcInRyYW5zbGF0aW9uc1wiOiB7XG4gKiAgICAgXCJtZXNzYWdlLWlkXCI6IFwiVGFyZ2V0IG1lc3NhZ2Ugc3RyaW5nXCIsXG4gKiAgICAgLi4uXG4gKiAgIH1cbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgU2ltcGxlSnNvblRyYW5zbGF0aW9uUGFyc2VyIGltcGxlbWVudHMgVHJhbnNsYXRpb25QYXJzZXIge1xuICBjYW5QYXJzZShmaWxlUGF0aDogc3RyaW5nLCBfY29udGVudHM6IHN0cmluZyk6IGJvb2xlYW4geyByZXR1cm4gKGV4dG5hbWUoZmlsZVBhdGgpID09PSAnLmpzb24nKTsgfVxuXG4gIHBhcnNlKF9maWxlUGF0aDogc3RyaW5nLCBjb250ZW50czogc3RyaW5nKTogUGFyc2VkVHJhbnNsYXRpb25CdW5kbGUge1xuICAgIGNvbnN0IHtsb2NhbGU6IHBhcnNlZExvY2FsZSwgdHJhbnNsYXRpb25zfSA9IEpTT04ucGFyc2UoY29udGVudHMpO1xuICAgIGNvbnN0IHBhcnNlZFRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPiA9IHt9O1xuICAgIGZvciAoY29uc3QgbWVzc2FnZUlkIGluIHRyYW5zbGF0aW9ucykge1xuICAgICAgY29uc3QgdGFyZ2V0TWVzc2FnZSA9IHRyYW5zbGF0aW9uc1ttZXNzYWdlSWRdO1xuICAgICAgcGFyc2VkVHJhbnNsYXRpb25zW21lc3NhZ2VJZF0gPSDJtXBhcnNlVHJhbnNsYXRpb24odGFyZ2V0TWVzc2FnZSk7XG4gICAgfVxuICAgIHJldHVybiB7bG9jYWxlOiBwYXJzZWRMb2NhbGUsIHRyYW5zbGF0aW9uczogcGFyc2VkVHJhbnNsYXRpb25zLCBkaWFnbm9zdGljczogbmV3IERpYWdub3N0aWNzKCl9O1xuICB9XG59XG4iXX0=

@@ -10,2 +10,3 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parser" />

import { ɵMessageId, ɵParsedTranslation } from '@angular/localize/private';
import { Diagnostics } from '../../../diagnostics';
/**

@@ -17,21 +18,58 @@ * An object that holds translations that have been parsed from a translation file.

translations: Record<ɵMessageId, ɵParsedTranslation>;
diagnostics: Diagnostics;
}
/**
* Implement this interface to provide a class that can parse the contents of a translation file.
*
* The `canParse()` method can return a hint that can be used by the `parse()` method to speed up
* parsing. This allows the parser to do significant work to determine if the file can be parsed
* without duplicating the work when it comes to actually parsing the file.
*
* Example usage:
*
* ```
* const parser: TranslationParser = getParser();
* const result = parser.canParse(filePath, content);
* if (result) {
* return parser.parse(filePath, content, result);
* }
* ```
*/
export interface TranslationParser {
export interface TranslationParser<Hint = true> {
/**
* Returns true if this parser can parse the given file.
* Can this parser parse the given file?
*
* @param filePath The absolute path to the translation file.
* @param contents The contents of the translation file.
* @returns A hint, which can be used in doing the actual parsing, if the file can be parsed by
* this parser; false otherwise.
*/
canParse(filePath: string, contents: string): boolean;
canParse(filePath: string, contents: string): Hint | false;
/**
* Parses the given file, extracting the target locale and translations.
*
* Note that this method should not throw an error. Check the `bundle.diagnostics` property for
* potential parsing errors and warnings.
*
* @param filePath The absolute path to the translation file.
* @param contents The contents of the translation file.
* @param hint A value that can be used by the parser to speed up parsing of the file. This will
* have been provided as the return result from calling `canParse()`.
* @returns The translation bundle parsed from the file.
* @throws No errors. If there was a problem with parsing the bundle will contain errors
* in the `diagnostics` property.
*/
parse(filePath: string, contents: string, hint: Hint): ParsedTranslationBundle;
/**
* Parses the given file, extracting the target locale and translations.
*
* @deprecated This overload is kept for backward compatibility. Going forward use the Hint
* returned from `canParse()` so that this method can avoid duplicating effort.
*
* @param filePath The absolute path to the translation file.
* @param contents The contents of the translation file.
* @returns The translation bundle parsed from the file.
* @throws An error if there was a problem parsing this file.
*/
parse(filePath: string, contents: string): ParsedTranslationBundle;
}

@@ -13,2 +13,2 @@ (function (factory) {

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVNZXNzYWdlSWQsIMm1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplL3ByaXZhdGUnO1xuXG4vKipcbiogQW4gb2JqZWN0IHRoYXQgaG9sZHMgdHJhbnNsYXRpb25zIHRoYXQgaGF2ZSBiZWVuIHBhcnNlZCBmcm9tIGEgdHJhbnNsYXRpb24gZmlsZS5cbiovXG5leHBvcnQgaW50ZXJmYWNlIFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgbG9jYWxlOiBzdHJpbmd8dW5kZWZpbmVkO1xuICB0cmFuc2xhdGlvbnM6IFJlY29yZDzJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbj47XG59XG5cbi8qKlxuICogSW1wbGVtZW50IHRoaXMgaW50ZXJmYWNlIHRvIHByb3ZpZGUgYSBjbGFzcyB0aGF0IGNhbiBwYXJzZSB0aGUgY29udGVudHMgb2YgYSB0cmFuc2xhdGlvbiBmaWxlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uUGFyc2VyIHtcbiAgLyoqXG4gICAqIFJldHVybnMgdHJ1ZSBpZiB0aGlzIHBhcnNlciBjYW4gcGFyc2UgdGhlIGdpdmVuIGZpbGUuXG4gICAqXG4gICAqIEBwYXJhbSBmaWxlUGF0aCBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICogQHBhcmFtIGNvbnRlbnRzIFRoZSBjb250ZW50cyBvZiB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICovXG4gIGNhblBhcnNlKGZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBzdHJpbmcpOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBQYXJzZXMgdGhlIGdpdmVuIGZpbGUsIGV4dHJhY3RpbmcgdGhlIHRhcmdldCBsb2NhbGUgYW5kIHRyYW5zbGF0aW9ucy5cbiAgICpcbiAgICogQHBhcmFtIGZpbGVQYXRoIFRoZSBhYnNvbHV0ZSBwYXRoIHRvIHRoZSB0cmFuc2xhdGlvbiBmaWxlLlxuICAgKiBAcGFyYW0gY29udGVudHMgVGhlIGNvbnRlbnRzIG9mIHRoZSB0cmFuc2xhdGlvbiBmaWxlLlxuICAgKi9cbiAgcGFyc2UoZmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IHN0cmluZyk6IFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVNZXNzYWdlSWQsIMm1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplL3ByaXZhdGUnO1xuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vLi4vZGlhZ25vc3RpY3MnO1xuXG4vKipcbiogQW4gb2JqZWN0IHRoYXQgaG9sZHMgdHJhbnNsYXRpb25zIHRoYXQgaGF2ZSBiZWVuIHBhcnNlZCBmcm9tIGEgdHJhbnNsYXRpb24gZmlsZS5cbiovXG5leHBvcnQgaW50ZXJmYWNlIFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgbG9jYWxlOiBzdHJpbmd8dW5kZWZpbmVkO1xuICB0cmFuc2xhdGlvbnM6IFJlY29yZDzJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbj47XG4gIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcztcbn1cblxuLyoqXG4gKiBJbXBsZW1lbnQgdGhpcyBpbnRlcmZhY2UgdG8gcHJvdmlkZSBhIGNsYXNzIHRoYXQgY2FuIHBhcnNlIHRoZSBjb250ZW50cyBvZiBhIHRyYW5zbGF0aW9uIGZpbGUuXG4gKlxuICogVGhlIGBjYW5QYXJzZSgpYCBtZXRob2QgY2FuIHJldHVybiBhIGhpbnQgdGhhdCBjYW4gYmUgdXNlZCBieSB0aGUgYHBhcnNlKClgIG1ldGhvZCB0byBzcGVlZCB1cFxuICogcGFyc2luZy4gVGhpcyBhbGxvd3MgdGhlIHBhcnNlciB0byBkbyBzaWduaWZpY2FudCB3b3JrIHRvIGRldGVybWluZSBpZiB0aGUgZmlsZSBjYW4gYmUgcGFyc2VkXG4gKiB3aXRob3V0IGR1cGxpY2F0aW5nIHRoZSB3b3JrIHdoZW4gaXQgY29tZXMgdG8gYWN0dWFsbHkgcGFyc2luZyB0aGUgZmlsZS5cbiAqXG4gKiBFeGFtcGxlIHVzYWdlOlxuICpcbiAqIGBgYFxuICogY29uc3QgcGFyc2VyOiBUcmFuc2xhdGlvblBhcnNlciA9IGdldFBhcnNlcigpO1xuICogY29uc3QgcmVzdWx0ID0gcGFyc2VyLmNhblBhcnNlKGZpbGVQYXRoLCBjb250ZW50KTtcbiAqIGlmIChyZXN1bHQpIHtcbiAqICAgcmV0dXJuIHBhcnNlci5wYXJzZShmaWxlUGF0aCwgY29udGVudCwgcmVzdWx0KTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uUGFyc2VyPEhpbnQgPSB0cnVlPiB7XG4gIC8qKlxuICAgKiBDYW4gdGhpcyBwYXJzZXIgcGFyc2UgdGhlIGdpdmVuIGZpbGU/XG4gICAqXG4gICAqIEBwYXJhbSBmaWxlUGF0aCBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICogQHBhcmFtIGNvbnRlbnRzIFRoZSBjb250ZW50cyBvZiB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICogQHJldHVybnMgQSBoaW50LCB3aGljaCBjYW4gYmUgdXNlZCBpbiBkb2luZyB0aGUgYWN0dWFsIHBhcnNpbmcsIGlmIHRoZSBmaWxlIGNhbiBiZSBwYXJzZWQgYnlcbiAgICogdGhpcyBwYXJzZXI7IGZhbHNlIG90aGVyd2lzZS5cbiAgICovXG4gIGNhblBhcnNlKGZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBzdHJpbmcpOiBIaW50fGZhbHNlO1xuXG4gIC8qKlxuICAgKiBQYXJzZXMgdGhlIGdpdmVuIGZpbGUsIGV4dHJhY3RpbmcgdGhlIHRhcmdldCBsb2NhbGUgYW5kIHRyYW5zbGF0aW9ucy5cbiAgICpcbiAgICogTm90ZSB0aGF0IHRoaXMgbWV0aG9kIHNob3VsZCBub3QgdGhyb3cgYW4gZXJyb3IuIENoZWNrIHRoZSBgYnVuZGxlLmRpYWdub3N0aWNzYCBwcm9wZXJ0eSBmb3JcbiAgICogcG90ZW50aWFsIHBhcnNpbmcgZXJyb3JzIGFuZCB3YXJuaW5ncy5cbiAgICpcbiAgICogQHBhcmFtIGZpbGVQYXRoIFRoZSBhYnNvbHV0ZSBwYXRoIHRvIHRoZSB0cmFuc2xhdGlvbiBmaWxlLlxuICAgKiBAcGFyYW0gY29udGVudHMgVGhlIGNvbnRlbnRzIG9mIHRoZSB0cmFuc2xhdGlvbiBmaWxlLlxuICAgKiBAcGFyYW0gaGludCBBIHZhbHVlIHRoYXQgY2FuIGJlIHVzZWQgYnkgdGhlIHBhcnNlciB0byBzcGVlZCB1cCBwYXJzaW5nIG9mIHRoZSBmaWxlLiBUaGlzIHdpbGxcbiAgICogaGF2ZSBiZWVuIHByb3ZpZGVkIGFzIHRoZSByZXR1cm4gcmVzdWx0IGZyb20gY2FsbGluZyBgY2FuUGFyc2UoKWAuXG4gICAqIEByZXR1cm5zIFRoZSB0cmFuc2xhdGlvbiBidW5kbGUgcGFyc2VkIGZyb20gdGhlIGZpbGUuXG4gICAqIEB0aHJvd3MgTm8gZXJyb3JzLiBJZiB0aGVyZSB3YXMgYSBwcm9ibGVtIHdpdGggcGFyc2luZyB0aGUgYnVuZGxlIHdpbGwgY29udGFpbiBlcnJvcnNcbiAgICogaW4gdGhlIGBkaWFnbm9zdGljc2AgcHJvcGVydHkuXG4gICAqL1xuICBwYXJzZShmaWxlUGF0aDogc3RyaW5nLCBjb250ZW50czogc3RyaW5nLCBoaW50OiBIaW50KTogUGFyc2VkVHJhbnNsYXRpb25CdW5kbGU7XG4gIC8qKlxuICAgKiBQYXJzZXMgdGhlIGdpdmVuIGZpbGUsIGV4dHJhY3RpbmcgdGhlIHRhcmdldCBsb2NhbGUgYW5kIHRyYW5zbGF0aW9ucy5cbiAgICpcbiAgICogQGRlcHJlY2F0ZWQgVGhpcyBvdmVybG9hZCBpcyBrZXB0IGZvciBiYWNrd2FyZCBjb21wYXRpYmlsaXR5LiBHb2luZyBmb3J3YXJkIHVzZSB0aGUgSGludFxuICAgKiByZXR1cm5lZCBmcm9tIGBjYW5QYXJzZSgpYCBzbyB0aGF0IHRoaXMgbWV0aG9kIGNhbiBhdm9pZCBkdXBsaWNhdGluZyBlZmZvcnQuXG4gICAqXG4gICAqIEBwYXJhbSBmaWxlUGF0aCBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICogQHBhcmFtIGNvbnRlbnRzIFRoZSBjb250ZW50cyBvZiB0aGUgdHJhbnNsYXRpb24gZmlsZS5cbiAgICogQHJldHVybnMgVGhlIHRyYW5zbGF0aW9uIGJ1bmRsZSBwYXJzZWQgZnJvbSB0aGUgZmlsZS5cbiAgICogQHRocm93cyBBbiBlcnJvciBpZiB0aGVyZSB3YXMgYSBwcm9ibGVtIHBhcnNpbmcgdGhpcyBmaWxlLlxuICAgKi9cbiAgcGFyc2UoZmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IHN0cmluZyk6IFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlO1xufVxuIl19

@@ -9,5 +9,52 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils" />

*/
import { Element, Node } from '@angular/compiler';
import { Element, Node, ParseError, ParseErrorLevel, ParseSourceSpan } from '@angular/compiler';
import { Diagnostics } from '../../../diagnostics';
export declare function getAttrOrThrow(element: Element, attrName: string): string;
export declare function getAttribute(element: Element, attrName: string): string | undefined;
/**
* Parse the "contents" of an XML element.
*
* This would be equivalent to parsing the `innerHTML` string of an HTML document.
*
* @param element The element whose inner range we want to parse.
* @returns a collection of XML `Node` objects that were parsed from the element's contents.
*/
export declare function parseInnerRange(element: Element): Node[];
/**
* This "hint" object is used to pass information from `canParse()` to `parse()` for
* `TranslationParser`s that expect XML contents.
*
* This saves the `parse()` method from having to re-parse the XML.
*/
export interface XmlTranslationParserHint {
element: Element;
errors: ParseError[];
}
/**
* Can this XML be parsed for translations, given the expected `rootNodeName` and expected root node
* `attributes` that should appear in the file.
*
* @param filePath The path to the file being checked.
* @param contents The contents of the file being checked.
* @param rootNodeName The expected name of an XML root node that should exist.
* @param attributes The attributes (and their values) that should appear on the root node.
* @returns The `XmlTranslationParserHint` object for use by `TranslationParser.parse()` if the XML
* document has the expected format.
*/
export declare function canParseXml(filePath: string, contents: string, rootNodeName: string, attributes: Record<string, string>): XmlTranslationParserHint | false;
/**
* Create a predicate, which can be used by things like `Array.filter()`, that will match a named
* XML Element from a collection of XML Nodes.
*
* @param name The expected name of the element to match.
*/
export declare function isNamedElement(name: string): (node: Node) => node is Element;
/**
* Add an XML parser related message to the given `diagnostics` object.
*/
export declare function addParseDiagnostic(diagnostics: Diagnostics, sourceSpan: ParseSourceSpan, message: string, level: ParseErrorLevel): void;
/**
* Copy the formatted error message from the given `parseError` object into the given `diagnostics`
* object.
*/
export declare function addParseError(diagnostics: Diagnostics, parseError: ParseError): void;

@@ -7,3 +7,3 @@ (function (factory) {

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils", ["require", "exports", "@angular/compiler", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error"], factory);
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils", ["require", "exports", "tslib", "@angular/compiler", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error"], factory);
}

@@ -13,2 +13,3 @@ })(function (require, exports) {

Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
/**

@@ -36,2 +37,10 @@ * @license

exports.getAttribute = getAttribute;
/**
* Parse the "contents" of an XML element.
*
* This would be equivalent to parsing the `innerHTML` string of an HTML document.
*
* @param element The element whose inner range we want to parse.
* @returns a collection of XML `Node` objects that were parsed from the element's contents.
*/
function parseInnerRange(element) {

@@ -46,2 +55,6 @@ var xmlParser = new compiler_1.XmlParser();

exports.parseInnerRange = parseInnerRange;
/**
* Compute a `LexerRange` that contains all the children of the given `element`.
* @param element The element whose inner range we want to compute.
*/
function getInnerRange(element) {

@@ -57,3 +70,87 @@ var start = element.startSourceSpan.end;

}
/**
* Can this XML be parsed for translations, given the expected `rootNodeName` and expected root node
* `attributes` that should appear in the file.
*
* @param filePath The path to the file being checked.
* @param contents The contents of the file being checked.
* @param rootNodeName The expected name of an XML root node that should exist.
* @param attributes The attributes (and their values) that should appear on the root node.
* @returns The `XmlTranslationParserHint` object for use by `TranslationParser.parse()` if the XML
* document has the expected format.
*/
function canParseXml(filePath, contents, rootNodeName, attributes) {
var e_1, _a;
var xmlParser = new compiler_1.XmlParser();
var xml = xmlParser.parse(contents, filePath);
if (xml.rootNodes.length === 0 ||
xml.errors.some(function (error) { return error.level === compiler_1.ParseErrorLevel.ERROR; })) {
return false;
}
var rootElements = xml.rootNodes.filter(isNamedElement(rootNodeName));
var rootElement = rootElements[0];
if (rootElement === undefined) {
return false;
}
var _loop_1 = function (attrKey) {
var attr = rootElement.attrs.find(function (attr) { return attr.name === attrKey; });
if (attr === undefined || attr.value !== attributes[attrKey]) {
return { value: false };
}
};
try {
for (var _b = tslib_1.__values(Object.keys(attributes)), _c = _b.next(); !_c.done; _c = _b.next()) {
var attrKey = _c.value;
var state_1 = _loop_1(attrKey);
if (typeof state_1 === "object")
return state_1.value;
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
if (rootElements.length > 1) {
xml.errors.push(new compiler_1.ParseError(xml.rootNodes[1].sourceSpan, 'Unexpected root node. XLIFF 1.2 files should only have a single <xliff> root node.', compiler_1.ParseErrorLevel.WARNING));
}
return { element: rootElement, errors: xml.errors };
}
exports.canParseXml = canParseXml;
/**
* Create a predicate, which can be used by things like `Array.filter()`, that will match a named
* XML Element from a collection of XML Nodes.
*
* @param name The expected name of the element to match.
*/
function isNamedElement(name) {
function predicate(node) {
return node instanceof compiler_1.Element && node.name === name;
}
return predicate;
}
exports.isNamedElement = isNamedElement;
/**
* Add an XML parser related message to the given `diagnostics` object.
*/
function addParseDiagnostic(diagnostics, sourceSpan, message, level) {
addParseError(diagnostics, new compiler_1.ParseError(sourceSpan, message, level));
}
exports.addParseDiagnostic = addParseDiagnostic;
/**
* Copy the formatted error message from the given `parseError` object into the given `diagnostics`
* object.
*/
function addParseError(diagnostics, parseError) {
if (parseError.level === compiler_1.ParseErrorLevel.ERROR) {
diagnostics.error(parseError.toString());
}
else {
diagnostics.warn(parseError.toString());
}
}
exports.addParseError = addParseError;
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb25fdXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS90cmFuc2xhdGlvbl9maWxlcy90cmFuc2xhdGlvbl9wYXJzZXJzL3RyYW5zbGF0aW9uX3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBQUE7Ozs7OztPQU1HO0lBQ0gsOENBQXVFO0lBQ3ZFLG1KQUFnRTtJQUVoRSxTQUFnQixjQUFjLENBQUMsT0FBZ0IsRUFBRSxRQUFnQjtRQUMvRCxJQUFNLFNBQVMsR0FBRyxZQUFZLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ2xELElBQUksU0FBUyxLQUFLLFNBQVMsRUFBRTtZQUMzQixNQUFNLElBQUksK0NBQXFCLENBQzNCLE9BQU8sQ0FBQyxVQUFVLEVBQUUsd0JBQXFCLFFBQVEsa0JBQWMsQ0FBQyxDQUFDO1NBQ3RFO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQVBELHdDQU9DO0lBRUQsU0FBZ0IsWUFBWSxDQUFDLE9BQWdCLEVBQUUsUUFBZ0I7UUFDN0QsSUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBQSxDQUFDLElBQUksT0FBQSxDQUFDLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBbkIsQ0FBbUIsQ0FBQyxDQUFDO1FBQzFELE9BQU8sSUFBSSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQ3JELENBQUM7SUFIRCxvQ0FHQztJQUVELFNBQWdCLGVBQWUsQ0FBQyxPQUFnQjtRQUM5QyxJQUFNLFNBQVMsR0FBRyxJQUFJLG9CQUFTLEVBQUUsQ0FBQztRQUNsQyxJQUFNLEdBQUcsR0FBRyxTQUFTLENBQUMsS0FBSyxDQUN2QixPQUFPLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQ3hFLEVBQUMsc0JBQXNCLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxhQUFhLENBQUMsT0FBTyxDQUFDLEVBQUMsQ0FBQyxDQUFDO1FBQ25FLElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUU7WUFDckIsTUFBTSxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLElBQUksK0NBQXFCLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQW5ELENBQW1ELENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDM0Y7UUFDRCxPQUFPLEdBQUcsQ0FBQyxTQUFTLENBQUM7SUFDdkIsQ0FBQztJQVRELDBDQVNDO0lBRUQsU0FBUyxhQUFhLENBQUMsT0FBZ0I7UUFDckMsSUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLGVBQWlCLENBQUMsR0FBRyxDQUFDO1FBQzVDLElBQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxhQUFlLENBQUMsS0FBSyxDQUFDO1FBQzFDLE9BQU87WUFDTCxRQUFRLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDdEIsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ3JCLFFBQVEsRUFBRSxLQUFLLENBQUMsR0FBRztZQUNuQixNQUFNLEVBQUUsR0FBRyxDQUFDLE1BQU07U0FDbkIsQ0FBQztJQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0VsZW1lbnQsIExleGVyUmFuZ2UsIE5vZGUsIFhtbFBhcnNlcn0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXInO1xuaW1wb3J0IHtUcmFuc2xhdGlvblBhcnNlRXJyb3J9IGZyb20gJy4vdHJhbnNsYXRpb25fcGFyc2VfZXJyb3InO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXR0ck9yVGhyb3coZWxlbWVudDogRWxlbWVudCwgYXR0ck5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGF0dHJWYWx1ZSA9IGdldEF0dHJpYnV0ZShlbGVtZW50LCBhdHRyTmFtZSk7XG4gIGlmIChhdHRyVmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgIHRocm93IG5ldyBUcmFuc2xhdGlvblBhcnNlRXJyb3IoXG4gICAgICAgIGVsZW1lbnQuc291cmNlU3BhbiwgYE1pc3NpbmcgcmVxdWlyZWQgXCIke2F0dHJOYW1lfVwiIGF0dHJpYnV0ZTpgKTtcbiAgfVxuICByZXR1cm4gYXR0clZhbHVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXR0cmlidXRlKGVsZW1lbnQ6IEVsZW1lbnQsIGF0dHJOYW1lOiBzdHJpbmcpOiBzdHJpbmd8dW5kZWZpbmVkIHtcbiAgY29uc3QgYXR0ciA9IGVsZW1lbnQuYXR0cnMuZmluZChhID0+IGEubmFtZSA9PT0gYXR0ck5hbWUpO1xuICByZXR1cm4gYXR0ciAhPT0gdW5kZWZpbmVkID8gYXR0ci52YWx1ZSA6IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHBhcnNlSW5uZXJSYW5nZShlbGVtZW50OiBFbGVtZW50KTogTm9kZVtdIHtcbiAgY29uc3QgeG1sUGFyc2VyID0gbmV3IFhtbFBhcnNlcigpO1xuICBjb25zdCB4bWwgPSB4bWxQYXJzZXIucGFyc2UoXG4gICAgICBlbGVtZW50LnNvdXJjZVNwYW4uc3RhcnQuZmlsZS5jb250ZW50LCBlbGVtZW50LnNvdXJjZVNwYW4uc3RhcnQuZmlsZS51cmwsXG4gICAgICB7dG9rZW5pemVFeHBhbnNpb25Gb3JtczogdHJ1ZSwgcmFuZ2U6IGdldElubmVyUmFuZ2UoZWxlbWVudCl9KTtcbiAgaWYgKHhtbC5lcnJvcnMubGVuZ3RoKSB7XG4gICAgdGhyb3cgeG1sLmVycm9ycy5tYXAoZSA9PiBuZXcgVHJhbnNsYXRpb25QYXJzZUVycm9yKGUuc3BhbiwgZS5tc2cpLnRvU3RyaW5nKCkpLmpvaW4oJ1xcbicpO1xuICB9XG4gIHJldHVybiB4bWwucm9vdE5vZGVzO1xufVxuXG5mdW5jdGlvbiBnZXRJbm5lclJhbmdlKGVsZW1lbnQ6IEVsZW1lbnQpOiBMZXhlclJhbmdlIHtcbiAgY29uc3Qgc3RhcnQgPSBlbGVtZW50LnN0YXJ0U291cmNlU3BhbiAhLmVuZDtcbiAgY29uc3QgZW5kID0gZWxlbWVudC5lbmRTb3VyY2VTcGFuICEuc3RhcnQ7XG4gIHJldHVybiB7XG4gICAgc3RhcnRQb3M6IHN0YXJ0Lm9mZnNldCxcbiAgICBzdGFydExpbmU6IHN0YXJ0LmxpbmUsXG4gICAgc3RhcnRDb2w6IHN0YXJ0LmNvbCxcbiAgICBlbmRQb3M6IGVuZC5vZmZzZXQsXG4gIH07XG59Il19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation_utils.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, LexerRange, Node, ParseError, ParseErrorLevel, ParseSourceSpan, XmlParser} from '@angular/compiler';\nimport {Diagnostics} from '../../../diagnostics';\nimport {TranslationParseError} from './translation_parse_error';\n\nexport function getAttrOrThrow(element: Element, attrName: string): string {\n  const attrValue = getAttribute(element, attrName);\n  if (attrValue === undefined) {\n    throw new TranslationParseError(\n        element.sourceSpan, `Missing required \"${attrName}\" attribute:`);\n  }\n  return attrValue;\n}\n\nexport function getAttribute(element: Element, attrName: string): string|undefined {\n  const attr = element.attrs.find(a => a.name === attrName);\n  return attr !== undefined ? attr.value : undefined;\n}\n\n/**\n * Parse the \"contents\" of an XML element.\n *\n * This would be equivalent to parsing the `innerHTML` string of an HTML document.\n *\n * @param element The element whose inner range we want to parse.\n * @returns a collection of XML `Node` objects that were parsed from the element's contents.\n */\nexport function parseInnerRange(element: Element): Node[] {\n  const xmlParser = new XmlParser();\n  const xml = xmlParser.parse(\n      element.sourceSpan.start.file.content, element.sourceSpan.start.file.url,\n      {tokenizeExpansionForms: true, range: getInnerRange(element)});\n  if (xml.errors.length) {\n    throw xml.errors.map(e => new TranslationParseError(e.span, e.msg).toString()).join('\\n');\n  }\n  return xml.rootNodes;\n}\n\n/**\n * Compute a `LexerRange` that contains all the children of the given `element`.\n * @param element The element whose inner range we want to compute.\n */\nfunction getInnerRange(element: Element): LexerRange {\n  const start = element.startSourceSpan !.end;\n  const end = element.endSourceSpan !.start;\n  return {\n    startPos: start.offset,\n    startLine: start.line,\n    startCol: start.col,\n    endPos: end.offset,\n  };\n}\n\n/**\n * This \"hint\" object is used to pass information from `canParse()` to `parse()` for\n * `TranslationParser`s that expect XML contents.\n *\n * This saves the `parse()` method from having to re-parse the XML.\n */\nexport interface XmlTranslationParserHint {\n  element: Element;\n  errors: ParseError[];\n}\n\n/**\n * Can this XML be parsed for translations, given the expected `rootNodeName` and expected root node\n * `attributes` that should appear in the file.\n *\n * @param filePath The path to the file being checked.\n * @param contents The contents of the file being checked.\n * @param rootNodeName The expected name of an XML root node that should exist.\n * @param attributes The attributes (and their values) that should appear on the root node.\n * @returns The `XmlTranslationParserHint` object for use by `TranslationParser.parse()` if the XML\n * document has the expected format.\n */\nexport function canParseXml(\n    filePath: string, contents: string, rootNodeName: string,\n    attributes: Record<string, string>): XmlTranslationParserHint|false {\n  const xmlParser = new XmlParser();\n  const xml = xmlParser.parse(contents, filePath);\n\n  if (xml.rootNodes.length === 0 ||\n      xml.errors.some(error => error.level === ParseErrorLevel.ERROR)) {\n    return false;\n  }\n\n  const rootElements = xml.rootNodes.filter(isNamedElement(rootNodeName));\n  const rootElement = rootElements[0];\n  if (rootElement === undefined) {\n    return false;\n  }\n\n  for (const attrKey of Object.keys(attributes)) {\n    const attr = rootElement.attrs.find(attr => attr.name === attrKey);\n    if (attr === undefined || attr.value !== attributes[attrKey]) {\n      return false;\n    }\n  }\n\n  if (rootElements.length > 1) {\n    xml.errors.push(new ParseError(\n        xml.rootNodes[1].sourceSpan,\n        'Unexpected root node. XLIFF 1.2 files should only have a single <xliff> root node.',\n        ParseErrorLevel.WARNING));\n  }\n\n  return {element: rootElement, errors: xml.errors};\n}\n\n/**\n * Create a predicate, which can be used by things like `Array.filter()`, that will match a named\n * XML Element from a collection of XML Nodes.\n *\n * @param name The expected name of the element to match.\n */\nexport function isNamedElement(name: string): (node: Node) => node is Element {\n  function predicate(node: Node): node is Element {\n    return node instanceof Element && node.name === name;\n  }\n  return predicate;\n}\n\n/**\n * Add an XML parser related message to the given `diagnostics` object.\n */\nexport function addParseDiagnostic(\n    diagnostics: Diagnostics, sourceSpan: ParseSourceSpan, message: string,\n    level: ParseErrorLevel): void {\n  addParseError(diagnostics, new ParseError(sourceSpan, message, level));\n}\n\n/**\n * Copy the formatted error message from the given `parseError` object into the given `diagnostics`\n * object.\n */\nexport function addParseError(diagnostics: Diagnostics, parseError: ParseError): void {\n  if (parseError.level === ParseErrorLevel.ERROR) {\n    diagnostics.error(parseError.toString());\n  } else {\n    diagnostics.warn(parseError.toString());\n  }\n}\n"]}
/// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser" />
import { ParsedTranslationBundle, TranslationParser } from './translation_parser';
import { XmlTranslationParserHint } from './translation_utils';
/**

@@ -10,5 +11,7 @@ * A translation parser that can load XLIFF 1.2 files.

*/
export declare class Xliff1TranslationParser implements TranslationParser {
canParse(filePath: string, contents: string): boolean;
parse(filePath: string, contents: string): ParsedTranslationBundle;
export declare class Xliff1TranslationParser implements TranslationParser<XmlTranslationParserHint> {
canParse(filePath: string, contents: string): XmlTranslationParserHint | false;
parse(filePath: string, contents: string, hint?: XmlTranslationParserHint): ParsedTranslationBundle;
private extractBundle;
private extractBundleDeprecated;
}

@@ -7,3 +7,3 @@ (function (factory) {

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "path", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "@angular/localize/src/tools/src/diagnostics", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
}

@@ -22,9 +22,7 @@ })(function (require, exports) {

var compiler_1 = require("@angular/compiler");
var path_1 = require("path");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
var base_visitor_1 = require("@angular/localize/src/tools/src/translate/translation_files/base_visitor");
var message_serializer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer");
var target_message_renderer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer");
var translation_parse_error_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error");
var translation_utils_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils");
var XLIFF_1_2_NS_REGEX = /xmlns="urn:oasis:names:tc:xliff:document:1.2"/;
/**

@@ -41,11 +39,64 @@ * A translation parser that can load XLIFF 1.2 files.

Xliff1TranslationParser.prototype.canParse = function (filePath, contents) {
return (path_1.extname(filePath) === '.xlf') && XLIFF_1_2_NS_REGEX.test(contents);
return translation_utils_1.canParseXml(filePath, contents, 'xliff', { version: '1.2' });
};
Xliff1TranslationParser.prototype.parse = function (filePath, contents) {
var xmlParser = new compiler_1.XmlParser();
var xml = xmlParser.parse(contents, filePath);
var bundle = XliffFileElementVisitor.extractBundle(xml.rootNodes);
if (bundle === undefined) {
Xliff1TranslationParser.prototype.parse = function (filePath, contents, hint) {
if (hint) {
return this.extractBundle(hint);
}
else {
return this.extractBundleDeprecated(filePath, contents);
}
};
Xliff1TranslationParser.prototype.extractBundle = function (_a) {
var e_1, _b;
var element = _a.element, errors = _a.errors;
var diagnostics = new diagnostics_1.Diagnostics();
errors.forEach(function (e) { return translation_utils_1.addParseError(diagnostics, e); });
if (element.children.length === 0) {
translation_utils_1.addParseDiagnostic(diagnostics, element.sourceSpan, 'Missing expected <file> element', compiler_1.ParseErrorLevel.WARNING);
return { locale: undefined, translations: {}, diagnostics: diagnostics };
}
var files = element.children.filter(translation_utils_1.isNamedElement('file'));
if (files.length === 0) {
translation_utils_1.addParseDiagnostic(diagnostics, element.sourceSpan, 'No <file> elements found in <xliff>', compiler_1.ParseErrorLevel.WARNING);
}
else if (files.length > 1) {
translation_utils_1.addParseDiagnostic(diagnostics, files[1].sourceSpan, 'More than one <file> element found in <xliff>', compiler_1.ParseErrorLevel.WARNING);
}
var bundle = { locale: undefined, translations: {}, diagnostics: diagnostics };
var translationVisitor = new XliffTranslationVisitor();
var localesFound = new Set();
try {
for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) {
var file = files_1_1.value;
var locale = translation_utils_1.getAttribute(file, 'target-language');
if (locale !== undefined) {
localesFound.add(locale);
bundle.locale = locale;
}
compiler_1.visitAll(translationVisitor, file.children, bundle);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (files_1_1 && !files_1_1.done && (_b = files_1.return)) _b.call(files_1);
}
finally { if (e_1) throw e_1.error; }
}
if (localesFound.size > 1) {
translation_utils_1.addParseDiagnostic(diagnostics, element.sourceSpan, "More than one locale found in translation file: " + JSON.stringify(Array.from(localesFound)) + ". Using \"" + bundle.locale + "\"", compiler_1.ParseErrorLevel.WARNING);
}
return bundle;
};
Xliff1TranslationParser.prototype.extractBundleDeprecated = function (filePath, contents) {
var hint = this.canParse(filePath, contents);
if (!hint) {
throw new Error("Unable to parse \"" + filePath + "\" as XLIFF 1.2 format.");
}
var bundle = this.extractBundle(hint);
if (bundle.diagnostics.hasErrors) {
var message = bundle.diagnostics.formatDiagnostics("Failed to parse \"" + filePath + "\" as XLIFF 1.2 format");
throw new Error(message);
}
return bundle;

@@ -61,17 +112,6 @@ };

}
XliffFileElementVisitor.extractBundle = function (xliff) {
var visitor = new this();
compiler_1.visitAll(visitor, xliff);
return visitor.bundle;
};
XliffFileElementVisitor.prototype.visitElement = function (element) {
if (element.name === 'file') {
this.bundle = {
locale: translation_utils_1.getAttribute(element, 'target-language'),
translations: XliffTranslationVisitor.extractTranslations(element)
};
XliffFileElementVisitor.prototype.visitElement = function (fileElement) {
if (fileElement.name === 'file') {
return { fileElement: fileElement, locale: translation_utils_1.getAttribute(fileElement, 'target-language') };
}
else {
return compiler_1.visitAll(this, element.children);
}
};

@@ -83,27 +123,43 @@ return XliffFileElementVisitor;

function XliffTranslationVisitor() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.translations = {};
return _this;
return _super !== null && _super.apply(this, arguments) || this;
}
XliffTranslationVisitor.extractTranslations = function (file) {
var visitor = new this();
compiler_1.visitAll(visitor, file.children);
return visitor.translations;
};
XliffTranslationVisitor.prototype.visitElement = function (element) {
XliffTranslationVisitor.prototype.visitElement = function (element, bundle) {
if (element.name === 'trans-unit') {
var id = translation_utils_1.getAttrOrThrow(element, 'id');
if (this.translations[id] !== undefined) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, "Duplicated translations for message \"" + id + "\"");
}
var targetMessage = element.children.find(isTargetElement);
if (targetMessage === undefined) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, 'Missing required <target> element');
}
this.translations[id] = serializeTargetMessage(targetMessage);
this.visitTransUnitElement(element, bundle);
}
else {
return compiler_1.visitAll(this, element.children);
compiler_1.visitAll(this, element.children, bundle);
}
};
XliffTranslationVisitor.prototype.visitTransUnitElement = function (element, bundle) {
// Error if no `id` attribute
var id = translation_utils_1.getAttribute(element, 'id');
if (id === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Missing required \"id\" attribute on <trans-unit> element.", compiler_1.ParseErrorLevel.ERROR);
return;
}
// Error if there is already a translation with the same id
if (bundle.translations[id] !== undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Duplicated translations for message \"" + id + "\"", compiler_1.ParseErrorLevel.ERROR);
return;
}
// Error if there is no `<target>` child element
var targetMessage = element.children.find(translation_utils_1.isNamedElement('target'));
if (targetMessage === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, 'Missing required <target> element', compiler_1.ParseErrorLevel.ERROR);
return;
}
try {
bundle.translations[id] = serializeTargetMessage(targetMessage);
}
catch (e) {
// Capture any errors from serialize the target message
if (e.span && e.msg && e.level) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, e.span, e.msg, e.level);
}
else {
throw e;
}
}
};
return XliffTranslationVisitor;

@@ -118,6 +174,3 @@ }(base_visitor_1.BaseVisitor));

}
function isTargetElement(node) {
return node instanceof compiler_1.Element && node.name === 'target';
}
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xliff1_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, Node, XmlParser, visitAll} from '@angular/compiler';\nimport {ɵMessageId, ɵParsedTranslation} from '@angular/localize';\nimport {extname} from 'path';\n\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {TranslationParseError} from './translation_parse_error';\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {getAttrOrThrow, getAttribute, parseInnerRange} from './translation_utils';\n\nconst XLIFF_1_2_NS_REGEX = /xmlns=\"urn:oasis:names:tc:xliff:document:1.2\"/;\n\n/**\n * A translation parser that can load XLIFF 1.2 files.\n *\n * http://docs.oasis-open.org/xliff/v1.2/os/xliff-core.html\n * http://docs.oasis-open.org/xliff/v1.2/xliff-profile-html/xliff-profile-html-1.2.html\n *\n */\nexport class Xliff1TranslationParser implements TranslationParser {\n  canParse(filePath: string, contents: string): boolean {\n    return (extname(filePath) === '.xlf') && XLIFF_1_2_NS_REGEX.test(contents);\n  }\n\n  parse(filePath: string, contents: string): ParsedTranslationBundle {\n    const xmlParser = new XmlParser();\n    const xml = xmlParser.parse(contents, filePath);\n    const bundle = XliffFileElementVisitor.extractBundle(xml.rootNodes);\n    if (bundle === undefined) {\n      throw new Error(`Unable to parse \"${filePath}\" as XLIFF 1.2 format.`);\n    }\n    return bundle;\n  }\n}\n\nclass XliffFileElementVisitor extends BaseVisitor {\n  private bundle: ParsedTranslationBundle|undefined;\n\n  static extractBundle(xliff: Node[]): ParsedTranslationBundle|undefined {\n    const visitor = new this();\n    visitAll(visitor, xliff);\n    return visitor.bundle;\n  }\n\n  visitElement(element: Element): any {\n    if (element.name === 'file') {\n      this.bundle = {\n        locale: getAttribute(element, 'target-language'),\n        translations: XliffTranslationVisitor.extractTranslations(element)\n      };\n    } else {\n      return visitAll(this, element.children);\n    }\n  }\n}\n\nclass XliffTranslationVisitor extends BaseVisitor {\n  private translations: Record<ɵMessageId, ɵParsedTranslation> = {};\n\n  static extractTranslations(file: Element): Record<string, ɵParsedTranslation> {\n    const visitor = new this();\n    visitAll(visitor, file.children);\n    return visitor.translations;\n  }\n\n  visitElement(element: Element): any {\n    if (element.name === 'trans-unit') {\n      const id = getAttrOrThrow(element, 'id');\n      if (this.translations[id] !== undefined) {\n        throw new TranslationParseError(\n            element.sourceSpan, `Duplicated translations for message \"${id}\"`);\n      }\n\n      const targetMessage = element.children.find(isTargetElement);\n      if (targetMessage === undefined) {\n        throw new TranslationParseError(element.sourceSpan, 'Missing required <target> element');\n      }\n      this.translations[id] = serializeTargetMessage(targetMessage);\n    } else {\n      return visitAll(this, element.children);\n    }\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(new TargetMessageRenderer(), {\n    inlineElements: ['g', 'bx', 'ex', 'bpt', 'ept', 'ph', 'it', 'mrk'],\n    placeholder: {elementName: 'x', nameAttribute: 'id'}\n  });\n  return serializer.serialize(parseInnerRange(source));\n}\n\nfunction isTargetElement(node: Node): node is Element {\n  return node instanceof Element && node.name === 'target';\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xliff1_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, ParseErrorLevel, visitAll} from '@angular/compiler';\nimport {ɵParsedTranslation} from '@angular/localize';\n\nimport {Diagnostics} from '../../../diagnostics';\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {XmlTranslationParserHint, addParseDiagnostic, addParseError, canParseXml, getAttribute, isNamedElement, parseInnerRange} from './translation_utils';\n\n/**\n * A translation parser that can load XLIFF 1.2 files.\n *\n * http://docs.oasis-open.org/xliff/v1.2/os/xliff-core.html\n * http://docs.oasis-open.org/xliff/v1.2/xliff-profile-html/xliff-profile-html-1.2.html\n *\n */\nexport class Xliff1TranslationParser implements TranslationParser<XmlTranslationParserHint> {\n  canParse(filePath: string, contents: string): XmlTranslationParserHint|false {\n    return canParseXml(filePath, contents, 'xliff', {version: '1.2'});\n  }\n\n  parse(filePath: string, contents: string, hint?: XmlTranslationParserHint):\n      ParsedTranslationBundle {\n    if (hint) {\n      return this.extractBundle(hint);\n    } else {\n      return this.extractBundleDeprecated(filePath, contents);\n    }\n  }\n\n  private extractBundle({element, errors}: XmlTranslationParserHint): ParsedTranslationBundle {\n    const diagnostics = new Diagnostics();\n    errors.forEach(e => addParseError(diagnostics, e));\n\n    if (element.children.length === 0) {\n      addParseDiagnostic(\n          diagnostics, element.sourceSpan, 'Missing expected <file> element',\n          ParseErrorLevel.WARNING);\n      return {locale: undefined, translations: {}, diagnostics};\n    }\n\n    const files = element.children.filter(isNamedElement('file'));\n    if (files.length === 0) {\n      addParseDiagnostic(\n          diagnostics, element.sourceSpan, 'No <file> elements found in <xliff>',\n          ParseErrorLevel.WARNING);\n    } else if (files.length > 1) {\n      addParseDiagnostic(\n          diagnostics, files[1].sourceSpan, 'More than one <file> element found in <xliff>',\n          ParseErrorLevel.WARNING);\n    }\n\n    const bundle: ParsedTranslationBundle = {locale: undefined, translations: {}, diagnostics};\n    const translationVisitor = new XliffTranslationVisitor();\n    const localesFound = new Set<string>();\n    for (const file of files) {\n      const locale = getAttribute(file, 'target-language');\n      if (locale !== undefined) {\n        localesFound.add(locale);\n        bundle.locale = locale;\n      }\n      visitAll(translationVisitor, file.children, bundle);\n    }\n\n    if (localesFound.size > 1) {\n      addParseDiagnostic(\n          diagnostics, element.sourceSpan,\n          `More than one locale found in translation file: ${JSON.stringify(Array.from(localesFound))}. Using \"${bundle.locale}\"`,\n          ParseErrorLevel.WARNING);\n    }\n\n    return bundle;\n  }\n\n  private extractBundleDeprecated(filePath: string, contents: string) {\n    const hint = this.canParse(filePath, contents);\n    if (!hint) {\n      throw new Error(`Unable to parse \"${filePath}\" as XLIFF 1.2 format.`);\n    }\n    const bundle = this.extractBundle(hint);\n    if (bundle.diagnostics.hasErrors) {\n      const message =\n          bundle.diagnostics.formatDiagnostics(`Failed to parse \"${filePath}\" as XLIFF 1.2 format`);\n      throw new Error(message);\n    }\n    return bundle;\n  }\n}\n\nclass XliffFileElementVisitor extends BaseVisitor {\n  visitElement(fileElement: Element): any {\n    if (fileElement.name === 'file') {\n      return {fileElement, locale: getAttribute(fileElement, 'target-language')};\n    }\n  }\n}\n\nclass XliffTranslationVisitor extends BaseVisitor {\n  visitElement(element: Element, bundle: ParsedTranslationBundle): void {\n    if (element.name === 'trans-unit') {\n      this.visitTransUnitElement(element, bundle);\n    } else {\n      visitAll(this, element.children, bundle);\n    }\n  }\n\n  private visitTransUnitElement(element: Element, bundle: ParsedTranslationBundle): void {\n    // Error if no `id` attribute\n    const id = getAttribute(element, 'id');\n    if (id === undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan,\n          `Missing required \"id\" attribute on <trans-unit> element.`, ParseErrorLevel.ERROR);\n      return;\n    }\n\n    // Error if there is already a translation with the same id\n    if (bundle.translations[id] !== undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan, `Duplicated translations for message \"${id}\"`,\n          ParseErrorLevel.ERROR);\n      return;\n    }\n\n    // Error if there is no `<target>` child element\n    const targetMessage = element.children.find(isNamedElement('target'));\n    if (targetMessage === undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan, 'Missing required <target> element',\n          ParseErrorLevel.ERROR);\n      return;\n    }\n\n    try {\n      bundle.translations[id] = serializeTargetMessage(targetMessage);\n    } catch (e) {\n      // Capture any errors from serialize the target message\n      if (e.span && e.msg && e.level) {\n        addParseDiagnostic(bundle.diagnostics, e.span, e.msg, e.level);\n      } else {\n        throw e;\n      }\n    }\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(new TargetMessageRenderer(), {\n    inlineElements: ['g', 'bx', 'ex', 'bpt', 'ept', 'ph', 'it', 'mrk'],\n    placeholder: {elementName: 'x', nameAttribute: 'id'}\n  });\n  return serializer.serialize(parseInnerRange(source));\n}\n"]}
/// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser" />
import { ParsedTranslationBundle, TranslationParser } from './translation_parser';
import { XmlTranslationParserHint } from './translation_utils';
/**

@@ -9,5 +10,7 @@ * A translation parser that can load translations from XLIFF 2 files.

*/
export declare class Xliff2TranslationParser implements TranslationParser {
canParse(filePath: string, contents: string): boolean;
parse(filePath: string, contents: string): ParsedTranslationBundle;
export declare class Xliff2TranslationParser implements TranslationParser<XmlTranslationParserHint> {
canParse(filePath: string, contents: string): XmlTranslationParserHint | false;
parse(filePath: string, contents: string, hint?: XmlTranslationParserHint): ParsedTranslationBundle;
private extractBundle;
private extractBundleDeprecated;
}

@@ -7,3 +7,3 @@ (function (factory) {

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "path", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "@angular/localize/src/tools/src/diagnostics", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
}

@@ -22,9 +22,7 @@ })(function (require, exports) {

var compiler_1 = require("@angular/compiler");
var path_1 = require("path");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
var base_visitor_1 = require("@angular/localize/src/tools/src/translate/translation_files/base_visitor");
var message_serializer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer");
var target_message_renderer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer");
var translation_parse_error_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error");
var translation_utils_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils");
var XLIFF_2_0_NS_REGEX = /xmlns="urn:oasis:names:tc:xliff:document:2.0"/;
/**

@@ -40,11 +38,52 @@ * A translation parser that can load translations from XLIFF 2 files.

Xliff2TranslationParser.prototype.canParse = function (filePath, contents) {
return (path_1.extname(filePath) === '.xlf') && XLIFF_2_0_NS_REGEX.test(contents);
return translation_utils_1.canParseXml(filePath, contents, 'xliff', { version: '2.0' });
};
Xliff2TranslationParser.prototype.parse = function (filePath, contents) {
var xmlParser = new compiler_1.XmlParser();
var xml = xmlParser.parse(contents, filePath);
var bundle = Xliff2TranslationBundleVisitor.extractBundle(xml.rootNodes);
if (bundle === undefined) {
Xliff2TranslationParser.prototype.parse = function (filePath, contents, hint) {
if (hint) {
return this.extractBundle(hint);
}
else {
return this.extractBundleDeprecated(filePath, contents);
}
};
Xliff2TranslationParser.prototype.extractBundle = function (_a) {
var e_1, _b;
var element = _a.element, errors = _a.errors;
var diagnostics = new diagnostics_1.Diagnostics();
errors.forEach(function (e) { return translation_utils_1.addParseError(diagnostics, e); });
var locale = translation_utils_1.getAttribute(element, 'trgLang');
var files = element.children.filter(isFileElement);
if (files.length === 0) {
translation_utils_1.addParseDiagnostic(diagnostics, element.sourceSpan, 'No <file> elements found in <xliff>', compiler_1.ParseErrorLevel.WARNING);
}
else if (files.length > 1) {
translation_utils_1.addParseDiagnostic(diagnostics, files[1].sourceSpan, 'More than one <file> element found in <xliff>', compiler_1.ParseErrorLevel.WARNING);
}
var bundle = { locale: locale, translations: {}, diagnostics: diagnostics };
var translationVisitor = new Xliff2TranslationVisitor();
try {
for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) {
var file = files_1_1.value;
compiler_1.visitAll(translationVisitor, file.children, { bundle: bundle });
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (files_1_1 && !files_1_1.done && (_b = files_1.return)) _b.call(files_1);
}
finally { if (e_1) throw e_1.error; }
}
return bundle;
};
Xliff2TranslationParser.prototype.extractBundleDeprecated = function (filePath, contents) {
var hint = this.canParse(filePath, contents);
if (!hint) {
throw new Error("Unable to parse \"" + filePath + "\" as XLIFF 2.0 format.");
}
var bundle = this.extractBundle(hint);
if (bundle.diagnostics.hasErrors) {
var message = bundle.diagnostics.formatDiagnostics("Failed to parse \"" + filePath + "\" as XLIFF 2.0 format");
throw new Error(message);
}
return bundle;

@@ -55,69 +94,59 @@ };

exports.Xliff2TranslationParser = Xliff2TranslationParser;
var Xliff2TranslationBundleVisitor = /** @class */ (function (_super) {
tslib_1.__extends(Xliff2TranslationBundleVisitor, _super);
function Xliff2TranslationBundleVisitor() {
var Xliff2TranslationVisitor = /** @class */ (function (_super) {
tslib_1.__extends(Xliff2TranslationVisitor, _super);
function Xliff2TranslationVisitor() {
return _super !== null && _super.apply(this, arguments) || this;
}
Xliff2TranslationBundleVisitor.extractBundle = function (xliff) {
var visitor = new this();
compiler_1.visitAll(visitor, xliff, {});
return visitor.bundle;
};
Xliff2TranslationBundleVisitor.prototype.visitElement = function (element, _a) {
var parsedLocale = _a.parsedLocale;
if (element.name === 'xliff') {
parsedLocale = translation_utils_1.getAttribute(element, 'trgLang');
return compiler_1.visitAll(this, element.children, { parsedLocale: parsedLocale });
Xliff2TranslationVisitor.prototype.visitElement = function (element, _a) {
var bundle = _a.bundle, unit = _a.unit;
if (element.name === 'unit') {
this.visitUnitElement(element, bundle);
}
else if (element.name === 'file') {
this.bundle = {
locale: parsedLocale,
translations: Xliff2TranslationVisitor.extractTranslations(element)
};
else if (element.name === 'segment') {
this.visitSegmentElement(element, bundle, unit);
}
else {
return compiler_1.visitAll(this, element.children, { parsedLocale: parsedLocale });
compiler_1.visitAll(this, element.children, { bundle: bundle, unit: unit });
}
};
return Xliff2TranslationBundleVisitor;
}(base_visitor_1.BaseVisitor));
var Xliff2TranslationVisitor = /** @class */ (function (_super) {
tslib_1.__extends(Xliff2TranslationVisitor, _super);
function Xliff2TranslationVisitor() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.translations = {};
return _this;
}
Xliff2TranslationVisitor.extractTranslations = function (file) {
var visitor = new this();
compiler_1.visitAll(visitor, file.children);
return visitor.translations;
Xliff2TranslationVisitor.prototype.visitUnitElement = function (element, bundle) {
// Error if no `id` attribute
var externalId = translation_utils_1.getAttribute(element, 'id');
if (externalId === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Missing required \"id\" attribute on <trans-unit> element.", compiler_1.ParseErrorLevel.ERROR);
return;
}
// Error if there is already a translation with the same id
if (bundle.translations[externalId] !== undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Duplicated translations for message \"" + externalId + "\"", compiler_1.ParseErrorLevel.ERROR);
return;
}
compiler_1.visitAll(this, element.children, { bundle: bundle, unit: externalId });
};
Xliff2TranslationVisitor.prototype.visitElement = function (element, context) {
if (element.name === 'unit') {
var externalId = translation_utils_1.getAttrOrThrow(element, 'id');
if (this.translations[externalId] !== undefined) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, "Duplicated translations for message \"" + externalId + "\"");
}
compiler_1.visitAll(this, element.children, { unit: externalId });
Xliff2TranslationVisitor.prototype.visitSegmentElement = function (element, bundle, unit) {
// A `<segment>` element must be below a `<unit>` element
if (unit === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, 'Invalid <segment> element: should be a child of a <unit> element.', compiler_1.ParseErrorLevel.ERROR);
return;
}
else if (element.name === 'segment') {
assertTranslationUnit(element, context);
var targetMessage = element.children.find(isTargetElement);
if (targetMessage === undefined) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, 'Missing required <target> element');
var targetMessage = element.children.find(translation_utils_1.isNamedElement('target'));
if (targetMessage === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, 'Missing required <target> element', compiler_1.ParseErrorLevel.ERROR);
return;
}
try {
bundle.translations[unit] = serializeTargetMessage(targetMessage);
}
catch (e) {
// Capture any errors from serialize the target message
if (e.span && e.msg && e.level) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, e.span, e.msg, e.level);
}
this.translations[context.unit] = serializeTargetMessage(targetMessage);
else {
throw e;
}
}
else {
return compiler_1.visitAll(this, element.children);
}
};
return Xliff2TranslationVisitor;
}(base_visitor_1.BaseVisitor));
function assertTranslationUnit(segment, context) {
if (context === undefined || context.unit === undefined) {
throw new translation_parse_error_1.TranslationParseError(segment.sourceSpan, 'Invalid <segment> element: should be a child of a <unit> element.');
}
}
function serializeTargetMessage(source) {

@@ -131,6 +160,6 @@ var serializer = new message_serializer_1.MessageSerializer(new target_message_renderer_1.TargetMessageRenderer(), {

}
function isTargetElement(node) {
return node instanceof compiler_1.Element && node.name === 'target';
function isFileElement(node) {
return node instanceof compiler_1.Element && node.name === 'file';
}
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xliff2_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, Node, XmlParser, visitAll} from '@angular/compiler';\nimport {ɵMessageId, ɵParsedTranslation} from '@angular/localize';\nimport {extname} from 'path';\n\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {TranslationParseError} from './translation_parse_error';\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {getAttrOrThrow, getAttribute, parseInnerRange} from './translation_utils';\n\nconst XLIFF_2_0_NS_REGEX = /xmlns=\"urn:oasis:names:tc:xliff:document:2.0\"/;\n\n/**\n * A translation parser that can load translations from XLIFF 2 files.\n *\n * http://docs.oasis-open.org/xliff/xliff-core/v2.0/os/xliff-core-v2.0-os.html\n *\n */\nexport class Xliff2TranslationParser implements TranslationParser {\n  canParse(filePath: string, contents: string): boolean {\n    return (extname(filePath) === '.xlf') && XLIFF_2_0_NS_REGEX.test(contents);\n  }\n\n  parse(filePath: string, contents: string): ParsedTranslationBundle {\n    const xmlParser = new XmlParser();\n    const xml = xmlParser.parse(contents, filePath);\n    const bundle = Xliff2TranslationBundleVisitor.extractBundle(xml.rootNodes);\n    if (bundle === undefined) {\n      throw new Error(`Unable to parse \"${filePath}\" as XLIFF 2.0 format.`);\n    }\n    return bundle;\n  }\n}\n\ninterface BundleVisitorContext {\n  parsedLocale?: string;\n}\n\nclass Xliff2TranslationBundleVisitor extends BaseVisitor {\n  private bundle: ParsedTranslationBundle|undefined;\n\n  static extractBundle(xliff: Node[]): ParsedTranslationBundle|undefined {\n    const visitor = new this();\n    visitAll(visitor, xliff, {});\n    return visitor.bundle;\n  }\n\n  visitElement(element: Element, {parsedLocale}: BundleVisitorContext): any {\n    if (element.name === 'xliff') {\n      parsedLocale = getAttribute(element, 'trgLang');\n      return visitAll(this, element.children, {parsedLocale});\n    } else if (element.name === 'file') {\n      this.bundle = {\n        locale: parsedLocale,\n        translations: Xliff2TranslationVisitor.extractTranslations(element)\n      };\n    } else {\n      return visitAll(this, element.children, {parsedLocale});\n    }\n  }\n}\n\nclass Xliff2TranslationVisitor extends BaseVisitor {\n  private translations: Record<ɵMessageId, ɵParsedTranslation> = {};\n\n  static extractTranslations(file: Element): Record<string, ɵParsedTranslation> {\n    const visitor = new this();\n    visitAll(visitor, file.children);\n    return visitor.translations;\n  }\n\n  visitElement(element: Element, context: any): any {\n    if (element.name === 'unit') {\n      const externalId = getAttrOrThrow(element, 'id');\n      if (this.translations[externalId] !== undefined) {\n        throw new TranslationParseError(\n            element.sourceSpan, `Duplicated translations for message \"${externalId}\"`);\n      }\n      visitAll(this, element.children, {unit: externalId});\n    } else if (element.name === 'segment') {\n      assertTranslationUnit(element, context);\n      const targetMessage = element.children.find(isTargetElement);\n      if (targetMessage === undefined) {\n        throw new TranslationParseError(element.sourceSpan, 'Missing required <target> element');\n      }\n      this.translations[context.unit] = serializeTargetMessage(targetMessage);\n    } else {\n      return visitAll(this, element.children);\n    }\n  }\n}\n\nfunction assertTranslationUnit(segment: Element, context: any) {\n  if (context === undefined || context.unit === undefined) {\n    throw new TranslationParseError(\n        segment.sourceSpan, 'Invalid <segment> element: should be a child of a <unit> element.');\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(new TargetMessageRenderer(), {\n    inlineElements: ['cp', 'sc', 'ec', 'mrk', 'sm', 'em'],\n    placeholder: {elementName: 'ph', nameAttribute: 'equiv', bodyAttribute: 'disp'},\n    placeholderContainer:\n        {elementName: 'pc', startAttribute: 'equivStart', endAttribute: 'equivEnd'}\n  });\n  return serializer.serialize(parseInnerRange(source));\n}\n\nfunction isTargetElement(node: Node): node is Element {\n  return node instanceof Element && node.name === 'target';\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xliff2_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, Node, ParseErrorLevel, visitAll} from '@angular/compiler';\nimport {ɵParsedTranslation} from '@angular/localize';\n\nimport {Diagnostics} from '../../../diagnostics';\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {XmlTranslationParserHint, addParseDiagnostic, addParseError, canParseXml, getAttribute, isNamedElement, parseInnerRange} from './translation_utils';\n\n/**\n * A translation parser that can load translations from XLIFF 2 files.\n *\n * http://docs.oasis-open.org/xliff/xliff-core/v2.0/os/xliff-core-v2.0-os.html\n *\n */\nexport class Xliff2TranslationParser implements TranslationParser<XmlTranslationParserHint> {\n  canParse(filePath: string, contents: string): XmlTranslationParserHint|false {\n    return canParseXml(filePath, contents, 'xliff', {version: '2.0'});\n  }\n\n  parse(filePath: string, contents: string, hint?: XmlTranslationParserHint):\n      ParsedTranslationBundle {\n    if (hint) {\n      return this.extractBundle(hint);\n    } else {\n      return this.extractBundleDeprecated(filePath, contents);\n    }\n  }\n\n  private extractBundle({element, errors}: XmlTranslationParserHint): ParsedTranslationBundle {\n    const diagnostics = new Diagnostics();\n    errors.forEach(e => addParseError(diagnostics, e));\n\n    const locale = getAttribute(element, 'trgLang');\n    const files = element.children.filter(isFileElement);\n    if (files.length === 0) {\n      addParseDiagnostic(\n          diagnostics, element.sourceSpan, 'No <file> elements found in <xliff>',\n          ParseErrorLevel.WARNING);\n    } else if (files.length > 1) {\n      addParseDiagnostic(\n          diagnostics, files[1].sourceSpan, 'More than one <file> element found in <xliff>',\n          ParseErrorLevel.WARNING);\n    }\n\n    const bundle = {locale, translations: {}, diagnostics};\n    const translationVisitor = new Xliff2TranslationVisitor();\n    for (const file of files) {\n      visitAll(translationVisitor, file.children, {bundle});\n    }\n    return bundle;\n  }\n\n  private extractBundleDeprecated(filePath: string, contents: string) {\n    const hint = this.canParse(filePath, contents);\n    if (!hint) {\n      throw new Error(`Unable to parse \"${filePath}\" as XLIFF 2.0 format.`);\n    }\n    const bundle = this.extractBundle(hint);\n    if (bundle.diagnostics.hasErrors) {\n      const message =\n          bundle.diagnostics.formatDiagnostics(`Failed to parse \"${filePath}\" as XLIFF 2.0 format`);\n      throw new Error(message);\n    }\n    return bundle;\n  }\n}\n\n\ninterface TranslationVisitorContext {\n  unit?: string;\n  bundle: ParsedTranslationBundle;\n}\n\nclass Xliff2TranslationVisitor extends BaseVisitor {\n  visitElement(element: Element, {bundle, unit}: TranslationVisitorContext): any {\n    if (element.name === 'unit') {\n      this.visitUnitElement(element, bundle);\n    } else if (element.name === 'segment') {\n      this.visitSegmentElement(element, bundle, unit);\n    } else {\n      visitAll(this, element.children, {bundle, unit});\n    }\n  }\n\n  private visitUnitElement(element: Element, bundle: ParsedTranslationBundle): void {\n    // Error if no `id` attribute\n    const externalId = getAttribute(element, 'id');\n    if (externalId === undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan,\n          `Missing required \"id\" attribute on <trans-unit> element.`, ParseErrorLevel.ERROR);\n      return;\n    }\n\n    // Error if there is already a translation with the same id\n    if (bundle.translations[externalId] !== undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan,\n          `Duplicated translations for message \"${externalId}\"`, ParseErrorLevel.ERROR);\n      return;\n    }\n\n    visitAll(this, element.children, {bundle, unit: externalId});\n  }\n\n  private visitSegmentElement(\n      element: Element, bundle: ParsedTranslationBundle, unit: string|undefined): void {\n    // A `<segment>` element must be below a `<unit>` element\n    if (unit === undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan,\n          'Invalid <segment> element: should be a child of a <unit> element.',\n          ParseErrorLevel.ERROR);\n      return;\n    }\n\n    const targetMessage = element.children.find(isNamedElement('target'));\n    if (targetMessage === undefined) {\n      addParseDiagnostic(\n          bundle.diagnostics, element.sourceSpan, 'Missing required <target> element',\n          ParseErrorLevel.ERROR);\n      return;\n    }\n\n    try {\n      bundle.translations[unit] = serializeTargetMessage(targetMessage);\n    } catch (e) {\n      // Capture any errors from serialize the target message\n      if (e.span && e.msg && e.level) {\n        addParseDiagnostic(bundle.diagnostics, e.span, e.msg, e.level);\n      } else {\n        throw e;\n      }\n    }\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(new TargetMessageRenderer(), {\n    inlineElements: ['cp', 'sc', 'ec', 'mrk', 'sm', 'em'],\n    placeholder: {elementName: 'ph', nameAttribute: 'equiv', bodyAttribute: 'disp'},\n    placeholderContainer:\n        {elementName: 'pc', startAttribute: 'equivStart', endAttribute: 'equivEnd'}\n  });\n  return serializer.serialize(parseInnerRange(source));\n}\n\nfunction isFileElement(node: Node): node is Element {\n  return node instanceof Element && node.name === 'file';\n}\n"]}
/// <amd-module name="@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser" />
import { Diagnostics } from '../../../diagnostics';
import { ParsedTranslationBundle, TranslationParser } from './translation_parser';
import { XmlTranslationParserHint } from './translation_utils';
/**
* A translation parser that can load XB files.
*/
export declare class XtbTranslationParser implements TranslationParser {
private diagnostics;
constructor(diagnostics: Diagnostics);
canParse(filePath: string, contents: string): boolean;
parse(filePath: string, contents: string): ParsedTranslationBundle;
export declare class XtbTranslationParser implements TranslationParser<XmlTranslationParserHint> {
canParse(filePath: string, contents: string): XmlTranslationParserHint | false;
parse(filePath: string, contents: string, hint?: XmlTranslationParserHint): ParsedTranslationBundle;
private extractBundle;
private extractBundleDeprecated;
}

@@ -7,3 +7,3 @@ (function (factory) {

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "path", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
define("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser", ["require", "exports", "tslib", "@angular/compiler", "path", "@angular/localize/src/tools/src/diagnostics", "@angular/localize/src/tools/src/translate/translation_files/base_visitor", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer", "@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils"], factory);
}

@@ -23,6 +23,6 @@ })(function (require, exports) {

var path_1 = require("path");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
var base_visitor_1 = require("@angular/localize/src/tools/src/translate/translation_files/base_visitor");
var message_serializer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/message_serializer");
var target_message_renderer_1 = require("@angular/localize/src/tools/src/translate/translation_files/message_serialization/target_message_renderer");
var translation_parse_error_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_parse_error");
var translation_utils_1 = require("@angular/localize/src/tools/src/translate/translation_files/translation_parsers/translation_utils");

@@ -33,19 +33,44 @@ /**

var XtbTranslationParser = /** @class */ (function () {
function XtbTranslationParser(diagnostics) {
this.diagnostics = diagnostics;
function XtbTranslationParser() {
}
XtbTranslationParser.prototype.canParse = function (filePath, contents) {
var extension = path_1.extname(filePath);
return (extension === '.xtb' || extension === '.xmb') &&
contents.includes('<translationbundle');
if (extension !== '.xtb' && extension !== '.xmb') {
return false;
}
return translation_utils_1.canParseXml(filePath, contents, 'translationbundle', {});
};
XtbTranslationParser.prototype.parse = function (filePath, contents) {
var xmlParser = new compiler_1.XmlParser();
var xml = xmlParser.parse(contents, filePath);
var bundle = XtbVisitor.extractBundle(this.diagnostics, xml.rootNodes);
if (bundle === undefined) {
throw new Error("Unable to parse \"" + filePath + "\" as XTB/XMB format.");
XtbTranslationParser.prototype.parse = function (filePath, contents, hint) {
if (hint) {
return this.extractBundle(hint);
}
else {
return this.extractBundleDeprecated(filePath, contents);
}
};
XtbTranslationParser.prototype.extractBundle = function (_a) {
var element = _a.element, errors = _a.errors;
var langAttr = element.attrs.find(function (attr) { return attr.name === 'lang'; });
var bundle = {
locale: langAttr && langAttr.value,
translations: {},
diagnostics: new diagnostics_1.Diagnostics()
};
errors.forEach(function (e) { return translation_utils_1.addParseError(bundle.diagnostics, e); });
var bundleVisitor = new XtbVisitor();
compiler_1.visitAll(bundleVisitor, element.children, bundle);
return bundle;
};
XtbTranslationParser.prototype.extractBundleDeprecated = function (filePath, contents) {
var hint = this.canParse(filePath, contents);
if (!hint) {
throw new Error("Unable to parse \"" + filePath + "\" as XMB/XTB format.");
}
var bundle = this.extractBundle(hint);
if (bundle.diagnostics.hasErrors) {
var message = bundle.diagnostics.formatDiagnostics("Failed to parse \"" + filePath + "\" as XMB/XTB format");
throw new Error(message);
}
return bundle;
};
return XtbTranslationParser;

@@ -56,47 +81,37 @@ }());

tslib_1.__extends(XtbVisitor, _super);
function XtbVisitor(diagnostics) {
var _this = _super.call(this) || this;
_this.diagnostics = diagnostics;
return _this;
function XtbVisitor() {
return _super !== null && _super.apply(this, arguments) || this;
}
XtbVisitor.extractBundle = function (diagnostics, messageBundles) {
var visitor = new this(diagnostics);
var bundles = compiler_1.visitAll(visitor, messageBundles, undefined);
return bundles[0];
};
XtbVisitor.prototype.visitElement = function (element, bundle) {
switch (element.name) {
case 'translationbundle':
if (bundle) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, '<translationbundle> elements can not be nested');
}
var langAttr = element.attrs.find(function (attr) { return attr.name === 'lang'; });
bundle = { locale: langAttr && langAttr.value, translations: {} };
compiler_1.visitAll(this, element.children, bundle);
return bundle;
case 'translation':
if (!bundle) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, '<translation> must be inside a <translationbundle>');
// Error if no `id` attribute
var id = translation_utils_1.getAttribute(element, 'id');
if (id === undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Missing required \"id\" attribute on <trans-unit> element.", compiler_1.ParseErrorLevel.ERROR);
return;
}
var id = translation_utils_1.getAttrOrThrow(element, 'id');
if (bundle.translations.hasOwnProperty(id)) {
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, "Duplicated translations for message \"" + id + "\"");
// Error if there is already a translation with the same id
if (bundle.translations[id] !== undefined) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Duplicated translations for message \"" + id + "\"", compiler_1.ParseErrorLevel.ERROR);
return;
}
else {
try {
bundle.translations[id] = serializeTargetMessage(element);
try {
bundle.translations[id] = serializeTargetMessage(element);
}
catch (error) {
if (typeof error === 'string') {
bundle.diagnostics.warn("Could not parse message with id \"" + id + "\" - perhaps it has an unrecognised ICU format?\n" +
error);
}
catch (error) {
if (typeof error === 'string') {
this.diagnostics.warn("Could not parse message with id \"" + id + "\" - perhaps it has an unrecognised ICU format?\n" +
error);
}
else {
throw error;
}
else if (error.span && error.msg && error.level) {
translation_utils_1.addParseDiagnostic(bundle.diagnostics, error.span, error.msg, error.level);
}
else {
throw error;
}
}
break;
default:
throw new translation_parse_error_1.TranslationParseError(element.sourceSpan, 'Unexpected tag');
translation_utils_1.addParseDiagnostic(bundle.diagnostics, element.sourceSpan, "Unexpected <" + element.name + "> tag.", compiler_1.ParseErrorLevel.ERROR);
}

@@ -111,2 +126,2 @@ };

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xtb_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, Node, XmlParser, visitAll} from '@angular/compiler';\nimport {ɵParsedTranslation} from '@angular/localize';\nimport {extname} from 'path';\n\nimport {Diagnostics} from '../../../diagnostics';\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {TranslationParseError} from './translation_parse_error';\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {getAttrOrThrow, parseInnerRange} from './translation_utils';\n\n\n\n/**\n * A translation parser that can load XB files.\n */\nexport class XtbTranslationParser implements TranslationParser {\n  constructor(private diagnostics: Diagnostics) {}\n\n  canParse(filePath: string, contents: string): boolean {\n    const extension = extname(filePath);\n    return (extension === '.xtb' || extension === '.xmb') &&\n        contents.includes('<translationbundle');\n  }\n\n  parse(filePath: string, contents: string): ParsedTranslationBundle {\n    const xmlParser = new XmlParser();\n    const xml = xmlParser.parse(contents, filePath);\n    const bundle = XtbVisitor.extractBundle(this.diagnostics, xml.rootNodes);\n    if (bundle === undefined) {\n      throw new Error(`Unable to parse \"${filePath}\" as XTB/XMB format.`);\n    }\n    return bundle;\n  }\n}\n\nclass XtbVisitor extends BaseVisitor {\n  static extractBundle(diagnostics: Diagnostics, messageBundles: Node[]): ParsedTranslationBundle\n      |undefined {\n    const visitor = new this(diagnostics);\n    const bundles: ParsedTranslationBundle[] = visitAll(visitor, messageBundles, undefined);\n    return bundles[0];\n  }\n\n  constructor(private diagnostics: Diagnostics) { super(); }\n\n  visitElement(element: Element, bundle: ParsedTranslationBundle|undefined): any {\n    switch (element.name) {\n      case 'translationbundle':\n        if (bundle) {\n          throw new TranslationParseError(\n              element.sourceSpan, '<translationbundle> elements can not be nested');\n        }\n        const langAttr = element.attrs.find((attr) => attr.name === 'lang');\n        bundle = {locale: langAttr && langAttr.value, translations: {}};\n        visitAll(this, element.children, bundle);\n        return bundle;\n\n      case 'translation':\n        if (!bundle) {\n          throw new TranslationParseError(\n              element.sourceSpan, '<translation> must be inside a <translationbundle>');\n        }\n        const id = getAttrOrThrow(element, 'id');\n        if (bundle.translations.hasOwnProperty(id)) {\n          throw new TranslationParseError(\n              element.sourceSpan, `Duplicated translations for message \"${id}\"`);\n        } else {\n          try {\n            bundle.translations[id] = serializeTargetMessage(element);\n          } catch (error) {\n            if (typeof error === 'string') {\n              this.diagnostics.warn(\n                  `Could not parse message with id \"${id}\" - perhaps it has an unrecognised ICU format?\\n` +\n                  error);\n            } else {\n              throw error;\n            }\n          }\n        }\n        break;\n\n      default:\n        throw new TranslationParseError(element.sourceSpan, 'Unexpected tag');\n    }\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(\n      new TargetMessageRenderer(),\n      {inlineElements: [], placeholder: {elementName: 'ph', nameAttribute: 'name'}});\n  return serializer.serialize(parseInnerRange(source));\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xtb_translation_parser.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Element, ParseErrorLevel, visitAll} from '@angular/compiler';\nimport {ɵParsedTranslation} from '@angular/localize';\nimport {extname} from 'path';\n\nimport {Diagnostics} from '../../../diagnostics';\nimport {BaseVisitor} from '../base_visitor';\nimport {MessageSerializer} from '../message_serialization/message_serializer';\nimport {TargetMessageRenderer} from '../message_serialization/target_message_renderer';\n\nimport {ParsedTranslationBundle, TranslationParser} from './translation_parser';\nimport {XmlTranslationParserHint, addParseDiagnostic, addParseError, canParseXml, getAttribute, parseInnerRange} from './translation_utils';\n\n\n/**\n * A translation parser that can load XB files.\n */\nexport class XtbTranslationParser implements TranslationParser<XmlTranslationParserHint> {\n  canParse(filePath: string, contents: string): XmlTranslationParserHint|false {\n    const extension = extname(filePath);\n    if (extension !== '.xtb' && extension !== '.xmb') {\n      return false;\n    }\n    return canParseXml(filePath, contents, 'translationbundle', {});\n  }\n\n  parse(filePath: string, contents: string, hint?: XmlTranslationParserHint):\n      ParsedTranslationBundle {\n    if (hint) {\n      return this.extractBundle(hint);\n    } else {\n      return this.extractBundleDeprecated(filePath, contents);\n    }\n  }\n\n  private extractBundle({element, errors}: XmlTranslationParserHint): ParsedTranslationBundle {\n    const langAttr = element.attrs.find((attr) => attr.name === 'lang');\n    const bundle: ParsedTranslationBundle = {\n      locale: langAttr && langAttr.value,\n      translations: {},\n      diagnostics: new Diagnostics()\n    };\n    errors.forEach(e => addParseError(bundle.diagnostics, e));\n\n    const bundleVisitor = new XtbVisitor();\n    visitAll(bundleVisitor, element.children, bundle);\n    return bundle;\n  }\n\n  private extractBundleDeprecated(filePath: string, contents: string) {\n    const hint = this.canParse(filePath, contents);\n    if (!hint) {\n      throw new Error(`Unable to parse \"${filePath}\" as XMB/XTB format.`);\n    }\n    const bundle = this.extractBundle(hint);\n    if (bundle.diagnostics.hasErrors) {\n      const message =\n          bundle.diagnostics.formatDiagnostics(`Failed to parse \"${filePath}\" as XMB/XTB format`);\n      throw new Error(message);\n    }\n    return bundle;\n  }\n}\n\nclass XtbVisitor extends BaseVisitor {\n  visitElement(element: Element, bundle: ParsedTranslationBundle): any {\n    switch (element.name) {\n      case 'translation':\n        // Error if no `id` attribute\n        const id = getAttribute(element, 'id');\n        if (id === undefined) {\n          addParseDiagnostic(\n              bundle.diagnostics, element.sourceSpan,\n              `Missing required \"id\" attribute on <trans-unit> element.`, ParseErrorLevel.ERROR);\n          return;\n        }\n\n        // Error if there is already a translation with the same id\n        if (bundle.translations[id] !== undefined) {\n          addParseDiagnostic(\n              bundle.diagnostics, element.sourceSpan, `Duplicated translations for message \"${id}\"`,\n              ParseErrorLevel.ERROR);\n          return;\n        }\n\n        try {\n          bundle.translations[id] = serializeTargetMessage(element);\n        } catch (error) {\n          if (typeof error === 'string') {\n            bundle.diagnostics.warn(\n                `Could not parse message with id \"${id}\" - perhaps it has an unrecognised ICU format?\\n` +\n                error);\n          } else if (error.span && error.msg && error.level) {\n            addParseDiagnostic(bundle.diagnostics, error.span, error.msg, error.level);\n          } else {\n            throw error;\n          }\n        }\n        break;\n\n      default:\n        addParseDiagnostic(\n            bundle.diagnostics, element.sourceSpan, `Unexpected <${element.name}> tag.`,\n            ParseErrorLevel.ERROR);\n    }\n  }\n}\n\nfunction serializeTargetMessage(source: Element): ɵParsedTranslation {\n  const serializer = new MessageSerializer(\n      new TargetMessageRenderer(),\n      {inlineElements: [], placeholder: {elementName: 'ph', nameAttribute: 'name'}});\n  return serializer.serialize(parseInnerRange(source));\n}\n"]}

@@ -18,2 +18,3 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/translator" />

translations: Record<ɵMessageId, ɵParsedTranslation>;
diagnostics?: Diagnostics;
}

@@ -20,0 +21,0 @@ /**

@@ -52,2 +52,2 @@ (function (factory) {

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEsNkJBQThCO0lBRzlCLHlFQUF3QztJQWdEeEM7OztPQUdHO0lBQ0g7UUFDRSxvQkFBb0IsZ0JBQXNDLEVBQVUsV0FBd0I7WUFBeEUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFzQjtZQUFVLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQUcsQ0FBQztRQUVoRyxtQ0FBYyxHQUFkLFVBQ0ksVUFBb0IsRUFBRSxRQUFnQixFQUFFLFlBQTBCLEVBQ2xFLFlBQWlDLEVBQUUsWUFBcUI7WUFGNUQsaUJBZUM7WUFaQyxVQUFVLENBQUMsT0FBTyxDQUFDLFVBQUEsU0FBUzs7Z0JBQzFCLElBQU0sUUFBUSxHQUFHLHNCQUFTLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUNyRCxJQUFNLFlBQVksR0FBRyxlQUFRLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDOztvQkFDbkQsS0FBOEIsSUFBQSxLQUFBLGlCQUFBLEtBQUksQ0FBQyxnQkFBZ0IsQ0FBQSxnQkFBQSw0QkFBRTt3QkFBaEQsSUFBTSxlQUFlLFdBQUE7d0JBQ3hCLElBQUksZUFBZSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsUUFBUSxDQUFDLEVBQUU7NEJBQ3hELE9BQU8sZUFBZSxDQUFDLFNBQVMsQ0FDNUIsS0FBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUM5RSxZQUFZLENBQUMsQ0FBQzt5QkFDbkI7cUJBQ0Y7Ozs7Ozs7OztnQkFDRCxLQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxxQ0FBbUMsU0FBVyxDQUFDLENBQUM7WUFDekUsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0gsaUJBQUM7SUFBRCxDQUFDLEFBbkJELElBbUJDO0lBbkJZLGdDQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtyZWxhdGl2ZX0gZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7RmlsZVV0aWxzfSBmcm9tICcuLi9maWxlX3V0aWxzJztcblxuaW1wb3J0IHtPdXRwdXRQYXRoRm59IGZyb20gJy4vb3V0cHV0X3BhdGgnO1xuXG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGhvbGRzIGluZm9ybWF0aW9uIHRvIGJlIHVzZWQgdG8gdHJhbnNsYXRlIGZpbGVzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgbG9jYWxlOiBzdHJpbmc7XG4gIHRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPjtcbn1cblxuLyoqXG4gKiBJbXBsZW1lbnQgdGhpcyBpbnRlcmZhY2UgdG8gcHJvdmlkZSBhIGNsYXNzIHRoYXQgY2FuIGhhbmRsZSB0cmFuc2xhdGlvbiBmb3IgdGhlIGdpdmVuIHJlc291cmNlIGluXG4gKiBhbiBhcHByb3ByaWF0ZSBtYW5uZXIuXG4gKlxuICogRm9yIGV4YW1wbGUsIHNvdXJjZSBjb2RlIGZpbGVzIHdpbGwgbmVlZCB0byBiZSB0cmFuc2Zvcm1lZCBpZiB0aGV5IGNvbnRhaW4gYCRsb2NhbGl6ZWAgdGFnZ2VkXG4gKiB0ZW1wbGF0ZSBzdHJpbmdzLCB3aGlsZSBtb3N0IHN0YXRpYyBhc3NldHMgd2lsbCBqdXN0IG5lZWQgdG8gYmUgY29waWVkLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uSGFuZGxlciB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRydWUgaWYgdGhlIGdpdmVuIGZpbGUgY2FuIGJlIHRyYW5zbGF0ZWQgYnkgdGhpcyBoYW5kbGVyLlxuICAgKlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgcmVzb3VyY2UgZmlsZSB0byBoYW5kbGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gaGFuZGxlLlxuICAgKi9cbiAgY2FuVHJhbnNsYXRlKHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRyYW5zbGF0ZSB0aGUgZmlsZSBhdCBgcmVsYXRpdmVGaWxlUGF0aGAgY29udGFpbmluZyBgY29udGVudHNgLCB1c2luZyB0aGUgZ2l2ZW4gYHRyYW5zbGF0aW9uc2AsXG4gICAqIGFuZCB3cml0ZSB0aGUgdHJhbnNsYXRlZCBjb250ZW50IHRvIHRoZSBwYXRoIGNvbXB1dGVkIGJ5IGNhbGxpbmcgYG91dHB1dFBhdGhGbigpYC5cbiAgICpcbiAgICogQHBhcmFtIGRpYWdub3N0aWNzIEFuIG9iamVjdCBmb3IgY29sbGVjdGluZyB0cmFuc2xhdGlvbiBkaWFnbm9zdGljIG1lc3NhZ2VzLlxuICAgKiBAcGFyYW0gc291cmNlUm9vdCBBbiBhYnNvbHV0ZSBwYXRoIHRvIHRoZSByb290IG9mIHRoZSBmaWxlcyBiZWluZyB0cmFuc2xhdGVkLlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgZmlsZSB0byB0cmFuc2xhdGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gdHJhbnNsYXRlLlxuICAgKiBAcGFyYW0gb3V0cHV0UGF0aEZuIEEgZnVuY3Rpb24gdGhhdCByZXR1cm5zIGFuIGFic29sdXRlIHBhdGggd2hlcmUgdGhlIG91dHB1dCBmaWxlIHNob3VsZCBiZVxuICAgKiB3cml0dGVuLlxuICAgKiBAcGFyYW0gdHJhbnNsYXRpb25zIEEgY29sbGVjdGlvbiBvZiB0cmFuc2xhdGlvbnMgdG8gYXBwbHkgdG8gdGhpcyBmaWxlLlxuICAgKiBAcGFyYW0gc291cmNlTG9jYWxlIFRoZSBsb2NhbGUgb2YgdGhlIG9yaWdpbmFsIGFwcGxpY2F0aW9uIHNvdXJjZS4gSWYgcHJvdmlkZWQgdGhlbiBhblxuICAgKiBhZGRpdGlvbmFsIGNvcHkgb2YgdGhlIGFwcGxpY2F0aW9uIGlzIGNyZWF0ZWQgdW5kZXIgdGhpcyBsb2NhbGUganVzdCB3aXRoIHRoZSBgJGxvY2FsaXplYCBjYWxsc1xuICAgKiBzdHJpcHBlZCBvdXQuXG4gICAqL1xuICB0cmFuc2xhdGUoXG4gICAgICBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MsIHNvdXJjZVJvb3Q6IHN0cmluZywgcmVsYXRpdmVGaWxlUGF0aDogc3RyaW5nLCBjb250ZW50czogQnVmZmVyLFxuICAgICAgb3V0cHV0UGF0aEZuOiBPdXRwdXRQYXRoRm4sIHRyYW5zbGF0aW9uczogVHJhbnNsYXRpb25CdW5kbGVbXSwgc291cmNlTG9jYWxlPzogc3RyaW5nKTogdm9pZDtcbn1cblxuLyoqXG4gKiBUcmFuc2xhdGUgZWFjaCBmaWxlIChlLmcuIHNvdXJjZSBmaWxlIG9yIHN0YXRpYyBhc3NldCkgdXNpbmcgdGhlIGdpdmVuIGBUcmFuc2xhdGlvbkhhbmRsZXJgcy5cbiAqIFRoZSBmaWxlIHdpbGwgYmUgdHJhbnNsYXRlZCBieSB0aGUgZmlyc3QgaGFuZGxlciB0aGF0IHJldHVybnMgdHJ1ZSBmb3IgYGNhblRyYW5zbGF0ZSgpYC5cbiAqL1xuZXhwb3J0IGNsYXNzIFRyYW5zbGF0b3Ige1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlc291cmNlSGFuZGxlcnM6IFRyYW5zbGF0aW9uSGFuZGxlcltdLCBwcml2YXRlIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcykge31cblxuICB0cmFuc2xhdGVGaWxlcyhcbiAgICAgIGlucHV0UGF0aHM6IHN0cmluZ1tdLCByb290UGF0aDogc3RyaW5nLCBvdXRwdXRQYXRoRm46IE91dHB1dFBhdGhGbixcbiAgICAgIHRyYW5zbGF0aW9uczogVHJhbnNsYXRpb25CdW5kbGVbXSwgc291cmNlTG9jYWxlPzogc3RyaW5nKTogdm9pZCB7XG4gICAgaW5wdXRQYXRocy5mb3JFYWNoKGlucHV0UGF0aCA9PiB7XG4gICAgICBjb25zdCBjb250ZW50cyA9IEZpbGVVdGlscy5yZWFkRmlsZUJ1ZmZlcihpbnB1dFBhdGgpO1xuICAgICAgY29uc3QgcmVsYXRpdmVQYXRoID0gcmVsYXRpdmUocm9vdFBhdGgsIGlucHV0UGF0aCk7XG4gICAgICBmb3IgKGNvbnN0IHJlc291cmNlSGFuZGxlciBvZiB0aGlzLnJlc291cmNlSGFuZGxlcnMpIHtcbiAgICAgICAgaWYgKHJlc291cmNlSGFuZGxlci5jYW5UcmFuc2xhdGUocmVsYXRpdmVQYXRoLCBjb250ZW50cykpIHtcbiAgICAgICAgICByZXR1cm4gcmVzb3VyY2VIYW5kbGVyLnRyYW5zbGF0ZShcbiAgICAgICAgICAgICAgdGhpcy5kaWFnbm9zdGljcywgcm9vdFBhdGgsIHJlbGF0aXZlUGF0aCwgY29udGVudHMsIG91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zLFxuICAgICAgICAgICAgICBzb3VyY2VMb2NhbGUpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICB0aGlzLmRpYWdub3N0aWNzLmVycm9yKGBVbmFibGUgdG8gaGFuZGxlIHJlc291cmNlIGZpbGU6ICR7aW5wdXRQYXRofWApO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEsNkJBQThCO0lBRzlCLHlFQUF3QztJQWlEeEM7OztPQUdHO0lBQ0g7UUFDRSxvQkFBb0IsZ0JBQXNDLEVBQVUsV0FBd0I7WUFBeEUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFzQjtZQUFVLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQUcsQ0FBQztRQUVoRyxtQ0FBYyxHQUFkLFVBQ0ksVUFBb0IsRUFBRSxRQUFnQixFQUFFLFlBQTBCLEVBQ2xFLFlBQWlDLEVBQUUsWUFBcUI7WUFGNUQsaUJBZUM7WUFaQyxVQUFVLENBQUMsT0FBTyxDQUFDLFVBQUEsU0FBUzs7Z0JBQzFCLElBQU0sUUFBUSxHQUFHLHNCQUFTLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUNyRCxJQUFNLFlBQVksR0FBRyxlQUFRLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDOztvQkFDbkQsS0FBOEIsSUFBQSxLQUFBLGlCQUFBLEtBQUksQ0FBQyxnQkFBZ0IsQ0FBQSxnQkFBQSw0QkFBRTt3QkFBaEQsSUFBTSxlQUFlLFdBQUE7d0JBQ3hCLElBQUksZUFBZSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsUUFBUSxDQUFDLEVBQUU7NEJBQ3hELE9BQU8sZUFBZSxDQUFDLFNBQVMsQ0FDNUIsS0FBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUM5RSxZQUFZLENBQUMsQ0FBQzt5QkFDbkI7cUJBQ0Y7Ozs7Ozs7OztnQkFDRCxLQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxxQ0FBbUMsU0FBVyxDQUFDLENBQUM7WUFDekUsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0gsaUJBQUM7SUFBRCxDQUFDLEFBbkJELElBbUJDO0lBbkJZLGdDQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtyZWxhdGl2ZX0gZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7RmlsZVV0aWxzfSBmcm9tICcuLi9maWxlX3V0aWxzJztcblxuaW1wb3J0IHtPdXRwdXRQYXRoRm59IGZyb20gJy4vb3V0cHV0X3BhdGgnO1xuXG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGhvbGRzIGluZm9ybWF0aW9uIHRvIGJlIHVzZWQgdG8gdHJhbnNsYXRlIGZpbGVzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgbG9jYWxlOiBzdHJpbmc7XG4gIHRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPjtcbiAgZGlhZ25vc3RpY3M/OiBEaWFnbm9zdGljcztcbn1cblxuLyoqXG4gKiBJbXBsZW1lbnQgdGhpcyBpbnRlcmZhY2UgdG8gcHJvdmlkZSBhIGNsYXNzIHRoYXQgY2FuIGhhbmRsZSB0cmFuc2xhdGlvbiBmb3IgdGhlIGdpdmVuIHJlc291cmNlIGluXG4gKiBhbiBhcHByb3ByaWF0ZSBtYW5uZXIuXG4gKlxuICogRm9yIGV4YW1wbGUsIHNvdXJjZSBjb2RlIGZpbGVzIHdpbGwgbmVlZCB0byBiZSB0cmFuc2Zvcm1lZCBpZiB0aGV5IGNvbnRhaW4gYCRsb2NhbGl6ZWAgdGFnZ2VkXG4gKiB0ZW1wbGF0ZSBzdHJpbmdzLCB3aGlsZSBtb3N0IHN0YXRpYyBhc3NldHMgd2lsbCBqdXN0IG5lZWQgdG8gYmUgY29waWVkLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uSGFuZGxlciB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRydWUgaWYgdGhlIGdpdmVuIGZpbGUgY2FuIGJlIHRyYW5zbGF0ZWQgYnkgdGhpcyBoYW5kbGVyLlxuICAgKlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgcmVzb3VyY2UgZmlsZSB0byBoYW5kbGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gaGFuZGxlLlxuICAgKi9cbiAgY2FuVHJhbnNsYXRlKHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRyYW5zbGF0ZSB0aGUgZmlsZSBhdCBgcmVsYXRpdmVGaWxlUGF0aGAgY29udGFpbmluZyBgY29udGVudHNgLCB1c2luZyB0aGUgZ2l2ZW4gYHRyYW5zbGF0aW9uc2AsXG4gICAqIGFuZCB3cml0ZSB0aGUgdHJhbnNsYXRlZCBjb250ZW50IHRvIHRoZSBwYXRoIGNvbXB1dGVkIGJ5IGNhbGxpbmcgYG91dHB1dFBhdGhGbigpYC5cbiAgICpcbiAgICogQHBhcmFtIGRpYWdub3N0aWNzIEFuIG9iamVjdCBmb3IgY29sbGVjdGluZyB0cmFuc2xhdGlvbiBkaWFnbm9zdGljIG1lc3NhZ2VzLlxuICAgKiBAcGFyYW0gc291cmNlUm9vdCBBbiBhYnNvbHV0ZSBwYXRoIHRvIHRoZSByb290IG9mIHRoZSBmaWxlcyBiZWluZyB0cmFuc2xhdGVkLlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgZmlsZSB0byB0cmFuc2xhdGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gdHJhbnNsYXRlLlxuICAgKiBAcGFyYW0gb3V0cHV0UGF0aEZuIEEgZnVuY3Rpb24gdGhhdCByZXR1cm5zIGFuIGFic29sdXRlIHBhdGggd2hlcmUgdGhlIG91dHB1dCBmaWxlIHNob3VsZCBiZVxuICAgKiB3cml0dGVuLlxuICAgKiBAcGFyYW0gdHJhbnNsYXRpb25zIEEgY29sbGVjdGlvbiBvZiB0cmFuc2xhdGlvbnMgdG8gYXBwbHkgdG8gdGhpcyBmaWxlLlxuICAgKiBAcGFyYW0gc291cmNlTG9jYWxlIFRoZSBsb2NhbGUgb2YgdGhlIG9yaWdpbmFsIGFwcGxpY2F0aW9uIHNvdXJjZS4gSWYgcHJvdmlkZWQgdGhlbiBhblxuICAgKiBhZGRpdGlvbmFsIGNvcHkgb2YgdGhlIGFwcGxpY2F0aW9uIGlzIGNyZWF0ZWQgdW5kZXIgdGhpcyBsb2NhbGUganVzdCB3aXRoIHRoZSBgJGxvY2FsaXplYCBjYWxsc1xuICAgKiBzdHJpcHBlZCBvdXQuXG4gICAqL1xuICB0cmFuc2xhdGUoXG4gICAgICBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MsIHNvdXJjZVJvb3Q6IHN0cmluZywgcmVsYXRpdmVGaWxlUGF0aDogc3RyaW5nLCBjb250ZW50czogQnVmZmVyLFxuICAgICAgb3V0cHV0UGF0aEZuOiBPdXRwdXRQYXRoRm4sIHRyYW5zbGF0aW9uczogVHJhbnNsYXRpb25CdW5kbGVbXSwgc291cmNlTG9jYWxlPzogc3RyaW5nKTogdm9pZDtcbn1cblxuLyoqXG4gKiBUcmFuc2xhdGUgZWFjaCBmaWxlIChlLmcuIHNvdXJjZSBmaWxlIG9yIHN0YXRpYyBhc3NldCkgdXNpbmcgdGhlIGdpdmVuIGBUcmFuc2xhdGlvbkhhbmRsZXJgcy5cbiAqIFRoZSBmaWxlIHdpbGwgYmUgdHJhbnNsYXRlZCBieSB0aGUgZmlyc3QgaGFuZGxlciB0aGF0IHJldHVybnMgdHJ1ZSBmb3IgYGNhblRyYW5zbGF0ZSgpYC5cbiAqL1xuZXhwb3J0IGNsYXNzIFRyYW5zbGF0b3Ige1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlc291cmNlSGFuZGxlcnM6IFRyYW5zbGF0aW9uSGFuZGxlcltdLCBwcml2YXRlIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcykge31cblxuICB0cmFuc2xhdGVGaWxlcyhcbiAgICAgIGlucHV0UGF0aHM6IHN0cmluZ1tdLCByb290UGF0aDogc3RyaW5nLCBvdXRwdXRQYXRoRm46IE91dHB1dFBhdGhGbixcbiAgICAgIHRyYW5zbGF0aW9uczogVHJhbnNsYXRpb25CdW5kbGVbXSwgc291cmNlTG9jYWxlPzogc3RyaW5nKTogdm9pZCB7XG4gICAgaW5wdXRQYXRocy5mb3JFYWNoKGlucHV0UGF0aCA9PiB7XG4gICAgICBjb25zdCBjb250ZW50cyA9IEZpbGVVdGlscy5yZWFkRmlsZUJ1ZmZlcihpbnB1dFBhdGgpO1xuICAgICAgY29uc3QgcmVsYXRpdmVQYXRoID0gcmVsYXRpdmUocm9vdFBhdGgsIGlucHV0UGF0aCk7XG4gICAgICBmb3IgKGNvbnN0IHJlc291cmNlSGFuZGxlciBvZiB0aGlzLnJlc291cmNlSGFuZGxlcnMpIHtcbiAgICAgICAgaWYgKHJlc291cmNlSGFuZGxlci5jYW5UcmFuc2xhdGUocmVsYXRpdmVQYXRoLCBjb250ZW50cykpIHtcbiAgICAgICAgICByZXR1cm4gcmVzb3VyY2VIYW5kbGVyLnRyYW5zbGF0ZShcbiAgICAgICAgICAgICAgdGhpcy5kaWFnbm9zdGljcywgcm9vdFBhdGgsIHJlbGF0aXZlUGF0aCwgY29udGVudHMsIG91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zLFxuICAgICAgICAgICAgICBzb3VyY2VMb2NhbGUpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICB0aGlzLmRpYWdub3N0aWNzLmVycm9yKGBVbmFibGUgdG8gaGFuZGxlIHJlc291cmNlIGZpbGU6ICR7aW5wdXRQYXRofWApO1xuICAgIH0pO1xuICB9XG59XG4iXX0=

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc