Socket
Socket
Sign inDemoInstall

@angular/localize

Package Overview
Dependencies
Maintainers
2
Versions
531
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@angular/localize - npm Package Compare versions

Comparing version 10.0.0-next.3 to 10.0.0-next.4

src/tools/src/source_file_utils.d.ts

2

bundles/localize-init.umd.js
/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

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

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

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

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -290,3 +290,3 @@ * License: MIT

*/
function parseMessage(messageParts, expressions) {
function parseMessage(messageParts, expressions, location) {
var substitutions = {};

@@ -307,8 +307,8 @@ var metadata = parseMetadata(messageParts[0], messageParts.raw[0]);

var messageId = metadata.id || compiler.computeMsgId(messageString, metadata.meaning || '');
var legacyIds = metadata.legacyIds.filter(function (id) { return id !== messageId; });
var legacyIds = metadata.legacyIds && metadata.legacyIds.filter(function (id) { return id !== messageId; });
return {
messageId: messageId,
id: messageId,
legacyIds: legacyIds,
substitutions: substitutions,
messageString: messageString,
text: messageString,
meaning: metadata.meaning || '',

@@ -318,2 +318,3 @@ description: metadata.description || '',

placeholderNames: placeholderNames,
location: location,
};

@@ -348,5 +349,5 @@ }

function parseMetadata(cooked, raw) {
var _a = splitBlock(cooked, raw), text = _a.text, block = _a.block;
var _a = splitBlock(cooked, raw), messageString = _a.text, block = _a.block;
if (block === undefined) {
return { text: text, meaning: undefined, description: undefined, id: undefined, legacyIds: [] };
return { text: messageString };
}

@@ -364,3 +365,3 @@ else {

}
return { text: text, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
return { text: messageString, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
}

@@ -460,6 +461,8 @@ }

// Look up the translation using the messageId, and then the legacyId if available.
var translation = translations[message.messageId];
var translation = translations[message.id];
// If the messageId did not match a translation, try matching the legacy ids instead
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
if (message.legacyIds !== undefined) {
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
}
}

@@ -489,4 +492,4 @@ if (translation === undefined) {

*/
function parseTranslation(message) {
var parts = message.split(/{\$([^}]*)}/);
function parseTranslation(messageString) {
var parts = messageString.split(/{\$([^}]*)}/);
var messageParts = [parts[0]];

@@ -499,3 +502,7 @@ var placeholderNames = [];

var rawMessageParts = messageParts.map(function (part) { return part.charAt(0) === BLOCK_MARKER ? '\\' + part : part; });
return { messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames: placeholderNames };
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, rawMessageParts),
placeholderNames: placeholderNames,
};
}

@@ -510,3 +517,11 @@ /**

if (placeholderNames === void 0) { placeholderNames = []; }
return { messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames: placeholderNames };
var messageString = messageParts[0];
for (var i = 0; i < placeholderNames.length - 1; i++) {
messageString += "{$" + placeholderNames[i] + "}" + messageParts[i + 1];
}
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, messageParts),
placeholderNames: placeholderNames
};
}

@@ -525,3 +540,6 @@ /**

var meaningString = message.meaning && " - \"" + message.meaning + "\"";
return "\"" + message.messageId + "\" (\"" + message.messageString + "\"" + meaningString + ")";
var legacy = message.legacyIds && message.legacyIds.length > 0 ?
" [" + message.legacyIds.map(function (l) { return "\"" + l + "\""; }).join(', ') + "]" :
'';
return "\"" + message.id + "\"" + legacy + " (\"" + message.text + "\"" + meaningString + ")";
}

@@ -528,0 +546,0 @@

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -13,3 +13,3 @@ * License: MIT

* found in the LICENSE file at https://angular.io/license
*/var r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])})(e,t)};function n(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,a=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}function o(e,r){for(var n,o={},s=a(e[0],e.raw[0]),l=[s.text],c=[],u=s.text,f=1;f<e.length;f++){var d=i(e[f],e.raw[f]),p=d.text,g=d.block,m=void 0===g?1===(n=f)?"PH":"PH_"+(n-1):g;u+="{$"+m+"}"+p,void 0!==r&&(o[m]=r[f-1]),c.push(m),l.push(p)}var h=s.id||t.computeMsgId(u,s.meaning||""),v=s.legacyIds.filter((function(e){return e!==h}));return{messageId:h,legacyIds:v,substitutions:o,messageString:u,meaning:s.meaning||"",description:s.description||"",messageParts:l,placeholderNames:c}}function a(e,t){var r=i(e,t),o=r.text,a=r.block;if(void 0===a)return{text:o,meaning:void 0,description:void 0,id:void 0,legacyIds:[]};var s=n(a.split("␟")),l=s[0],c=s.slice(1),u=n(l.split("@@",2),2),f=u[1],d=n(u[0].split("|",2),2),p=d[0],g=d[1];return void 0===g&&(g=p,p=void 0),""===g&&(g=void 0),{text:o,meaning:p,description:g,id:f,legacyIds:c}}function i(e,t){if(":"!==t.charAt(0))return{text:e};var r=s(e,t);return{block:e.substring(1,r),text:e.substring(r+1)}}function s(e,t){for(var r=1,n=1;r<e.length;r++,n++)if("\\"===t[n])n++;else if(":"===e[r])return r;throw new Error('Unterminated $localize metadata block in "'+t+'".')}var l=function(e){function t(t){var r=e.call(this,"No translation found for "+d(t)+".")||this;return r.parsedMessage=t,r.type="MissingTranslationError",r}return function n(e,t){function n(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}(t,e),t}(Error);function c(e,t,r){for(var n=o(t,r),a=e[n.messageId],i=0;i<n.legacyIds.length&&void 0===a;i++)a=e[n.legacyIds[i]];if(void 0===a)throw new l(n);return[a.messageParts,a.placeholderNames.map((function(e){if(n.substitutions.hasOwnProperty(e))return n.substitutions[e];throw new Error("There is a placeholder name mismatch with the translation provided for the message "+d(n)+".\nThe translation contains a placeholder with name "+e+", which does not exist in the message.")}))]}function u(e){for(var t=e.split(/{\$([^}]*)}/),r=[t[0]],n=[],o=1;o<t.length-1;o+=2)n.push(t[o]),r.push(""+t[o+1]);var a=r.map((function(e){return":"===e.charAt(0)?"\\"+e:e}));return{messageParts:f(r,a),placeholderNames:n}}function f(e,t){return Object.defineProperty(e,"raw",{value:t}),e}function d(e){return'"'+e.messageId+'" ("'+e.messageString+'"'+(e.meaning&&' - "'+e.meaning+'"')+")"}
*/var r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])})(e,t)};function n(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,a=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}function o(e,r,n){for(var o,s={},l=a(e[0],e.raw[0]),c=[l.text],u=[],f=l.text,d=1;d<e.length;d++){var p=i(e[d],e.raw[d]),g=p.text,h=p.block,m=void 0===h?1===(o=d)?"PH":"PH_"+(o-1):h;f+="{$"+m+"}"+g,void 0!==r&&(s[m]=r[d-1]),u.push(m),c.push(g)}var v=l.id||t.computeMsgId(f,l.meaning||""),y=l.legacyIds&&l.legacyIds.filter((function(e){return e!==v}));return{id:v,legacyIds:y,substitutions:s,text:f,meaning:l.meaning||"",description:l.description||"",messageParts:c,placeholderNames:u,location:n}}function a(e,t){var r=i(e,t),o=r.text,a=r.block;if(void 0===a)return{text:o};var s=n(a.split("␟")),l=s[0],c=s.slice(1),u=n(l.split("@@",2),2),f=u[1],d=n(u[0].split("|",2),2),p=d[0],g=d[1];return void 0===g&&(g=p,p=void 0),""===g&&(g=void 0),{text:o,meaning:p,description:g,id:f,legacyIds:c}}function i(e,t){if(":"!==t.charAt(0))return{text:e};var r=s(e,t);return{block:e.substring(1,r),text:e.substring(r+1)}}function s(e,t){for(var r=1,n=1;r<e.length;r++,n++)if("\\"===t[n])n++;else if(":"===e[r])return r;throw new Error('Unterminated $localize metadata block in "'+t+'".')}var l=function(e){function t(t){var r=e.call(this,"No translation found for "+d(t)+".")||this;return r.parsedMessage=t,r.type="MissingTranslationError",r}return function n(e,t){function n(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}(t,e),t}(Error);function c(e,t,r){var n=o(t,r),a=e[n.id];if(void 0!==n.legacyIds)for(var i=0;i<n.legacyIds.length&&void 0===a;i++)a=e[n.legacyIds[i]];if(void 0===a)throw new l(n);return[a.messageParts,a.placeholderNames.map((function(e){if(n.substitutions.hasOwnProperty(e))return n.substitutions[e];throw new Error("There is a placeholder name mismatch with the translation provided for the message "+d(n)+".\nThe translation contains a placeholder with name "+e+", which does not exist in the message.")}))]}function u(e){for(var t=e.split(/{\$([^}]*)}/),r=[t[0]],n=[],o=1;o<t.length-1;o+=2)n.push(t[o]),r.push(""+t[o+1]);var a=r.map((function(e){return":"===e.charAt(0)?"\\"+e:e}));return{text:e,messageParts:f(r,a),placeholderNames:n}}function f(e,t){return Object.defineProperty(e,"raw",{value:t}),e}function d(e){var t=e.meaning&&' - "'+e.meaning+'"',r=e.legacyIds&&e.legacyIds.length>0?" ["+e.legacyIds.map((function(e){return'"'+e+'"'})).join(", ")+"]":"";return'"'+e.id+'"'+r+' ("'+e.text+'"'+t+")"}
/**

@@ -42,2 +42,2 @@ * @license

* found in the LICENSE file at https://angular.io/license
*/Object.defineProperty(e,"ɵcomputeMsgId",{enumerable:!0,get:function(){return t.computeMsgId}}),e.clearTranslations=function g(){$localize.translate=void 0,$localize.TRANSLATIONS={}},e.loadTranslations=function m(e){$localize.translate||($localize.translate=p),$localize.TRANSLATIONS||($localize.TRANSLATIONS={}),Object.keys(e).forEach((function(t){$localize.TRANSLATIONS[t]=u(e[t])}))},e.ɵMissingTranslationError=l,e.ɵfindEndOfBlock=s,e.ɵisMissingTranslationError=function h(e){return"MissingTranslationError"===e.type},e.ɵmakeParsedTranslation=function v(e,t){return void 0===t&&(t=[]),{messageParts:f(e,e),placeholderNames:t}},e.ɵmakeTemplateObject=f,e.ɵparseMessage=o,e.ɵparseMetadata=a,e.ɵparseTranslation=u,e.ɵsplitBlock=i,e.ɵtranslate=c,Object.defineProperty(e,"__esModule",{value:!0})}));
*/Object.defineProperty(e,"ɵcomputeMsgId",{enumerable:!0,get:function(){return t.computeMsgId}}),e.clearTranslations=function g(){$localize.translate=void 0,$localize.TRANSLATIONS={}},e.loadTranslations=function h(e){$localize.translate||($localize.translate=p),$localize.TRANSLATIONS||($localize.TRANSLATIONS={}),Object.keys(e).forEach((function(t){$localize.TRANSLATIONS[t]=u(e[t])}))},e.ɵMissingTranslationError=l,e.ɵfindEndOfBlock=s,e.ɵisMissingTranslationError=function m(e){return"MissingTranslationError"===e.type},e.ɵmakeParsedTranslation=function v(e,t){void 0===t&&(t=[]);for(var r=e[0],n=0;n<t.length-1;n++)r+="{$"+t[n]+"}"+e[n+1];return{text:r,messageParts:f(e,e),placeholderNames:t}},e.ɵmakeTemplateObject=f,e.ɵparseMessage=o,e.ɵparseMetadata=a,e.ɵparseTranslation=u,e.ɵsplitBlock=i,e.ɵtranslate=c,Object.defineProperty(e,"__esModule",{value:!0})}));

@@ -11,2 +11,2 @@ /**

export { computeMsgId as ɵcomputeMsgId, findEndOfBlock as ɵfindEndOfBlock, isMissingTranslationError as ɵisMissingTranslationError, makeParsedTranslation as ɵmakeParsedTranslation, makeTemplateObject as ɵmakeTemplateObject, MissingTranslationError as ɵMissingTranslationError, parseMessage as ɵparseMessage, parseMetadata as ɵparseMetadata, parseTranslation as ɵparseTranslation, splitBlock as ɵsplitBlock, translate as ɵtranslate } from './src/utils';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3ByaXZhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsa0dBQWtHO0FBQ2xHLHdCQUF3QjtBQUN4QixPQUFPLEVBQUMsWUFBWSxJQUFJLGFBQWEsRUFBRSxjQUFjLElBQUksZUFBZSxFQUFFLHlCQUF5QixJQUFJLDBCQUEwQixFQUFFLHFCQUFxQixJQUFJLHNCQUFzQixFQUFFLGtCQUFrQixJQUFJLG1CQUFtQixFQUEyQix1QkFBdUIsSUFBSSx3QkFBd0IsRUFBdUgsWUFBWSxJQUFJLGFBQWEsRUFBRSxhQUFhLElBQUksY0FBYyxFQUFFLGdCQUFnQixJQUFJLGlCQUFpQixFQUFtQyxVQUFVLElBQUksV0FBVyxFQUFtQyxTQUFTLElBQUksVUFBVSxFQUFDLE1BQU0sYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vLyBUaGlzIGZpbGUgZXhwb3J0cyBhbGwgdGhlIGB1dGlsc2AgYXMgcHJpdmF0ZSBleHBvcnRzIHNvIHRoYXQgb3RoZXIgcGFydHMgb2YgYEBhbmd1bGFyL2xvY2FsaXplYFxuLy8gY2FuIG1ha2UgdXNlIG9mIHRoZW0uXG5leHBvcnQge2NvbXB1dGVNc2dJZCBhcyDJtWNvbXB1dGVNc2dJZCwgZmluZEVuZE9mQmxvY2sgYXMgybVmaW5kRW5kT2ZCbG9jaywgaXNNaXNzaW5nVHJhbnNsYXRpb25FcnJvciBhcyDJtWlzTWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIG1ha2VQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtW1ha2VQYXJzZWRUcmFuc2xhdGlvbiwgbWFrZVRlbXBsYXRlT2JqZWN0IGFzIMm1bWFrZVRlbXBsYXRlT2JqZWN0LCBNZXNzYWdlSWQgYXMgybVNZXNzYWdlSWQsIE1pc3NpbmdUcmFuc2xhdGlvbkVycm9yIGFzIMm1TWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIFBhcnNlZE1lc3NhZ2UgYXMgybVQYXJzZWRNZXNzYWdlLCBQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtVBhcnNlZFRyYW5zbGF0aW9uLCBQYXJzZWRUcmFuc2xhdGlvbnMgYXMgybVQYXJzZWRUcmFuc2xhdGlvbnMsIHBhcnNlTWVzc2FnZSBhcyDJtXBhcnNlTWVzc2FnZSwgcGFyc2VNZXRhZGF0YSBhcyDJtXBhcnNlTWV0YWRhdGEsIHBhcnNlVHJhbnNsYXRpb24gYXMgybVwYXJzZVRyYW5zbGF0aW9uLCBTb3VyY2VNZXNzYWdlIGFzIMm1U291cmNlTWVzc2FnZSwgc3BsaXRCbG9jayBhcyDJtXNwbGl0QmxvY2ssIFRhcmdldE1lc3NhZ2UgYXMgybVUYXJnZXRNZXNzYWdlLCB0cmFuc2xhdGUgYXMgybV0cmFuc2xhdGV9IGZyb20gJy4vc3JjL3V0aWxzJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3ByaXZhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsa0dBQWtHO0FBQ2xHLHdCQUF3QjtBQUN4QixPQUFPLEVBQUMsWUFBWSxJQUFJLGFBQWEsRUFBRSxjQUFjLElBQUksZUFBZSxFQUFFLHlCQUF5QixJQUFJLDBCQUEwQixFQUFFLHFCQUFxQixJQUFJLHNCQUFzQixFQUFFLGtCQUFrQixJQUFJLG1CQUFtQixFQUEyQix1QkFBdUIsSUFBSSx3QkFBd0IsRUFBdUgsWUFBWSxJQUFJLGFBQWEsRUFBRSxhQUFhLElBQUksY0FBYyxFQUFFLGdCQUFnQixJQUFJLGlCQUFpQixFQUFzRSxVQUFVLElBQUksV0FBVyxFQUFtQyxTQUFTLElBQUksVUFBVSxFQUFDLE1BQU0sYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vLyBUaGlzIGZpbGUgZXhwb3J0cyBhbGwgdGhlIGB1dGlsc2AgYXMgcHJpdmF0ZSBleHBvcnRzIHNvIHRoYXQgb3RoZXIgcGFydHMgb2YgYEBhbmd1bGFyL2xvY2FsaXplYFxuLy8gY2FuIG1ha2UgdXNlIG9mIHRoZW0uXG5leHBvcnQge2NvbXB1dGVNc2dJZCBhcyDJtWNvbXB1dGVNc2dJZCwgZmluZEVuZE9mQmxvY2sgYXMgybVmaW5kRW5kT2ZCbG9jaywgaXNNaXNzaW5nVHJhbnNsYXRpb25FcnJvciBhcyDJtWlzTWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIG1ha2VQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtW1ha2VQYXJzZWRUcmFuc2xhdGlvbiwgbWFrZVRlbXBsYXRlT2JqZWN0IGFzIMm1bWFrZVRlbXBsYXRlT2JqZWN0LCBNZXNzYWdlSWQgYXMgybVNZXNzYWdlSWQsIE1pc3NpbmdUcmFuc2xhdGlvbkVycm9yIGFzIMm1TWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIFBhcnNlZE1lc3NhZ2UgYXMgybVQYXJzZWRNZXNzYWdlLCBQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtVBhcnNlZFRyYW5zbGF0aW9uLCBQYXJzZWRUcmFuc2xhdGlvbnMgYXMgybVQYXJzZWRUcmFuc2xhdGlvbnMsIHBhcnNlTWVzc2FnZSBhcyDJtXBhcnNlTWVzc2FnZSwgcGFyc2VNZXRhZGF0YSBhcyDJtXBhcnNlTWV0YWRhdGEsIHBhcnNlVHJhbnNsYXRpb24gYXMgybVwYXJzZVRyYW5zbGF0aW9uLCBTb3VyY2VMb2NhdGlvbiBhcyDJtVNvdXJjZUxvY2F0aW9uLCBTb3VyY2VNZXNzYWdlIGFzIMm1U291cmNlTWVzc2FnZSwgc3BsaXRCbG9jayBhcyDJtXNwbGl0QmxvY2ssIFRhcmdldE1lc3NhZ2UgYXMgybVUYXJnZXRNZXNzYWdlLCB0cmFuc2xhdGUgYXMgybV0cmFuc2xhdGV9IGZyb20gJy4vc3JjL3V0aWxzJztcbiJdfQ==

@@ -20,3 +20,3 @@ /**

*/
export function parseMessage(messageParts, expressions) {
export function parseMessage(messageParts, expressions, location) {
const substitutions = {};

@@ -37,8 +37,8 @@ const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);

const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');
const legacyIds = metadata.legacyIds.filter(id => id !== messageId);
const legacyIds = metadata.legacyIds && metadata.legacyIds.filter(id => id !== messageId);
return {
messageId,
id: messageId,
legacyIds,
substitutions,
messageString,
text: messageString,
meaning: metadata.meaning || '',

@@ -48,2 +48,3 @@ description: metadata.description || '',

placeholderNames,
location,
};

@@ -78,5 +79,5 @@ }

export function parseMetadata(cooked, raw) {
const { text, block } = splitBlock(cooked, raw);
const { text: messageString, block } = splitBlock(cooked, raw);
if (block === undefined) {
return { text, meaning: undefined, description: undefined, id: undefined, legacyIds: [] };
return { text: messageString };
}

@@ -94,3 +95,3 @@ else {

}
return { text, meaning, description, id, legacyIds };
return { text: messageString, meaning, description, id, legacyIds };
}

@@ -157,2 +158,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/utils/src/messages.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 {computeMsgId} from '@angular/compiler';\n\nimport {BLOCK_MARKER, ID_SEPARATOR, LEGACY_ID_INDICATOR, MEANING_SEPARATOR} from './constants';\n\n/**\n * Re-export this helper function so that users of `@angular/localize` don't need to actively import\n * from `@angular/compiler`.\n */\nexport {computeMsgId} from '@angular/compiler';\n\n/**\n * A string containing a translation source message.\n *\n * I.E. the message that indicates what will be translated from.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type SourceMessage = string;\n\n/**\n * A string containing a translation target message.\n *\n * I.E. the message that indicates what will be translated to.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type TargetMessage = string;\n\n/**\n * A string that uniquely identifies a message, to be used for matching translations.\n */\nexport type MessageId = string;\n\n/**\n * Information parsed from a `$localize` tagged string that is used to translate it.\n *\n * For example:\n *\n * ```\n * const name = 'Jo Bloggs';\n * $localize`Hello ${name}:title!`;\n * ```\n *\n * May be parsed into:\n *\n * ```\n * {\n *   messageId: '6998194507597730591',\n *   substitutions: { title: 'Jo Bloggs' },\n *   messageString: 'Hello {$title}!',\n * }\n * ```\n */\nexport interface ParsedMessage {\n  /**\n   * The key used to look up the appropriate translation target.\n   */\n  messageId: MessageId;\n  /**\n   * Legacy message ids, if provided.\n   *\n   * In legacy message formats the message id can only be computed directly from the original\n   * template source.\n   *\n   * Since this information is not available in `$localize` calls, the legacy message ids may be\n   * attached by the compiler to the `$localize` metablock so it can be used if needed at the point\n   * of translation if the translations are encoded using the legacy message id.\n   */\n  legacyIds: MessageId[];\n  /**\n   * A mapping of placeholder names to substitution values.\n   */\n  substitutions: Record<string, any>;\n  /**\n   * A human readable rendering of the message\n   */\n  messageString: string;\n  /**\n   * The meaning of the `message`, used to distinguish identical `messageString`s.\n   */\n  meaning: string;\n  /**\n   * The description of the `message`, used to aid translation.\n   */\n  description: string;\n  /**\n   * The static parts of the message.\n   */\n  messageParts: string[];\n  /**\n   * The names of the placeholders that will be replaced with substitutions.\n   */\n  placeholderNames: string[];\n}\n\n/**\n * Parse a `$localize` tagged string into a structure that can be used for translation.\n *\n * See `ParsedMessage` for an example.\n */\nexport function parseMessage(\n    messageParts: TemplateStringsArray, expressions?: readonly any[]): ParsedMessage {\n  const substitutions: {[placeholderName: string]: any} = {};\n  const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);\n  const cleanedMessageParts: string[] = [metadata.text];\n  const placeholderNames: string[] = [];\n  let messageString = metadata.text;\n  for (let i = 1; i < messageParts.length; i++) {\n    const {text: messagePart, block: placeholderName = computePlaceholderName(i)} =\n        splitBlock(messageParts[i], messageParts.raw[i]);\n    messageString += `{$${placeholderName}}${messagePart}`;\n    if (expressions !== undefined) {\n      substitutions[placeholderName] = expressions[i - 1];\n    }\n    placeholderNames.push(placeholderName);\n    cleanedMessageParts.push(messagePart);\n  }\n  const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');\n  const legacyIds = metadata.legacyIds.filter(id => id !== messageId);\n  return {\n    messageId,\n    legacyIds,\n    substitutions,\n    messageString,\n    meaning: metadata.meaning || '',\n    description: metadata.description || '',\n    messageParts: cleanedMessageParts,\n    placeholderNames,\n  };\n}\n\nexport interface MessageMetadata {\n  text: string;\n  meaning: string|undefined;\n  description: string|undefined;\n  id: string|undefined;\n  legacyIds: string[];\n}\n\n/**\n * Parse the given message part (`cooked` + `raw`) to extract the message metadata from the text.\n *\n * If the message part has a metadata block this function will extract the `meaning`,\n * `description`, `customId` and `legacyId` (if provided) from the block. These metadata properties\n * are serialized in the string delimited by `|`, `@@` and `␟` respectively.\n *\n * (Note that `␟` is the `LEGACY_ID_INDICATOR` - see `constants.ts`.)\n *\n * For example:\n *\n * ```ts\n * `:meaning|description@@custom-id`\n * `:meaning|@@custom-id`\n * `:meaning|description`\n * `description@@custom-id`\n * `meaning|`\n * `description`\n * `@@custom-id`\n * `:meaning|description@@custom-id␟legacy-id-1␟legacy-id-2`\n * ```\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns A object containing any metadata that was parsed from the message part.\n */\nexport function parseMetadata(cooked: string, raw: string): MessageMetadata {\n  const {text, block} = splitBlock(cooked, raw);\n  if (block === undefined) {\n    return {text, meaning: undefined, description: undefined, id: undefined, legacyIds: []};\n  } else {\n    const [meaningDescAndId, ...legacyIds] = block.split(LEGACY_ID_INDICATOR);\n    const [meaningAndDesc, id] = meaningDescAndId.split(ID_SEPARATOR, 2);\n    let [meaning, description]: (string|undefined)[] = meaningAndDesc.split(MEANING_SEPARATOR, 2);\n    if (description === undefined) {\n      description = meaning;\n      meaning = undefined;\n    }\n    if (description === '') {\n      description = undefined;\n    }\n    return {text, meaning, description, id, legacyIds};\n  }\n}\n\n/**\n * Split a message part (`cooked` + `raw`) into an optional delimited \"block\" off the front and the\n * rest of the text of the message part.\n *\n * Blocks appear at the start of message parts. They are delimited by a colon `:` character at the\n * start and end of the block.\n *\n * If the block is in the first message part then it will be metadata about the whole message:\n * meaning, description, id.  Otherwise it will be metadata about the immediately preceding\n * substitution: placeholder name.\n *\n * Since blocks are optional, it is possible that the content of a message block actually starts\n * with a block marker. In this case the marker must be escaped `\\:`.\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns An object containing the `text` of the message part and the text of the `block`, if it\n * exists.\n * @throws an error if the `block` is unterminated\n */\nexport function splitBlock(cooked: string, raw: string): {text: string, block?: string} {\n  if (raw.charAt(0) !== BLOCK_MARKER) {\n    return {text: cooked};\n  } else {\n    const endOfBlock = findEndOfBlock(cooked, raw);\n    return {\n      block: cooked.substring(1, endOfBlock),\n      text: cooked.substring(endOfBlock + 1),\n    };\n  }\n}\n\n\nfunction computePlaceholderName(index: number) {\n  return index === 1 ? 'PH' : `PH_${index - 1}`;\n}\n\n/**\n * Find the end of a \"marked block\" indicated by the first non-escaped colon.\n *\n * @param cooked The cooked string (where escaped chars have been processed)\n * @param raw The raw string (where escape sequences are still in place)\n *\n * @returns the index of the end of block marker\n * @throws an error if the block is unterminated\n */\nexport function findEndOfBlock(cooked: string, raw: string): number {\n  /************************************************************************************************\n   * This function is repeated in `src/localize/src/localize.ts` and the two should be kept in sync.\n   * (See that file for more explanation of why.)\n   ************************************************************************************************/\n  for (let cookedIndex = 1, rawIndex = 1; cookedIndex < cooked.length; cookedIndex++, rawIndex++) {\n    if (raw[rawIndex] === '\\\\') {\n      rawIndex++;\n    } else if (cooked[cookedIndex] === BLOCK_MARKER) {\n      return cookedIndex;\n    }\n  }\n  throw new Error(`Unterminated $localize metadata block in \"${raw}\".`);\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/utils/src/messages.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 {computeMsgId} from '@angular/compiler';\n\nimport {BLOCK_MARKER, ID_SEPARATOR, LEGACY_ID_INDICATOR, MEANING_SEPARATOR} from './constants';\n\n/**\n * Re-export this helper function so that users of `@angular/localize` don't need to actively import\n * from `@angular/compiler`.\n */\nexport {computeMsgId} from '@angular/compiler';\n\n/**\n * A string containing a translation source message.\n *\n * I.E. the message that indicates what will be translated from.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type SourceMessage = string;\n\n/**\n * A string containing a translation target message.\n *\n * I.E. the message that indicates what will be translated to.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type TargetMessage = string;\n\n/**\n * A string that uniquely identifies a message, to be used for matching translations.\n */\nexport type MessageId = string;\n\n/**\n * The location of the message\n */\nexport interface SourceLocation {\n  start: {line: number, column: number};\n  end: {line: number, column: number};\n  file: string;\n}\n\n/**\n * Additional information that can be associated with a message.\n */\nexport interface MessageMetadata {\n  /**\n   * A human readable rendering of the message\n   */\n  text: string;\n  /**\n   * A unique identifier for this message.\n   */\n  id?: MessageId;\n  /**\n   * Legacy message ids, if provided.\n   *\n   * In legacy message formats the message id can only be computed directly from the original\n   * template source.\n   *\n   * Since this information is not available in `$localize` calls, the legacy message ids may be\n   * attached by the compiler to the `$localize` metablock so it can be used if needed at the point\n   * of translation if the translations are encoded using the legacy message id.\n   */\n  legacyIds?: string[];\n  /**\n   * The meaning of the `message`, used to distinguish identical `messageString`s.\n   */\n  meaning?: string;\n  /**\n   * The description of the `message`, used to aid translation.\n   */\n  description?: string;\n  /**\n   * The location of the message in the source.\n   */\n  location?: SourceLocation;\n}\n\n/**\n * Information parsed from a `$localize` tagged string that is used to translate it.\n *\n * For example:\n *\n * ```\n * const name = 'Jo Bloggs';\n * $localize`Hello ${name}:title!`;\n * ```\n *\n * May be parsed into:\n *\n * ```\n * {\n *   id: '6998194507597730591',\n *   substitutions: { title: 'Jo Bloggs' },\n *   messageString: 'Hello {$title}!',\n * }\n * ```\n */\nexport interface ParsedMessage extends MessageMetadata {\n  /**\n   * The key used to look up the appropriate translation target.\n   *\n   * In `ParsedMessage` this is a required field, whereas it is optional in `MessageMetadata`.\n   */\n  id: MessageId;\n  /**\n   * A mapping of placeholder names to substitution values.\n   */\n  substitutions: Record<string, any>;\n  /**\n   * The static parts of the message.\n   */\n  messageParts: string[];\n  /**\n   * The names of the placeholders that will be replaced with substitutions.\n   */\n  placeholderNames: string[];\n}\n\n/**\n * Parse a `$localize` tagged string into a structure that can be used for translation.\n *\n * See `ParsedMessage` for an example.\n */\nexport function parseMessage(\n    messageParts: TemplateStringsArray, expressions?: readonly any[],\n    location?: SourceLocation): ParsedMessage {\n  const substitutions: {[placeholderName: string]: any} = {};\n  const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);\n  const cleanedMessageParts: string[] = [metadata.text];\n  const placeholderNames: string[] = [];\n  let messageString = metadata.text;\n  for (let i = 1; i < messageParts.length; i++) {\n    const {text: messagePart, block: placeholderName = computePlaceholderName(i)} =\n        splitBlock(messageParts[i], messageParts.raw[i]);\n    messageString += `{$${placeholderName}}${messagePart}`;\n    if (expressions !== undefined) {\n      substitutions[placeholderName] = expressions[i - 1];\n    }\n    placeholderNames.push(placeholderName);\n    cleanedMessageParts.push(messagePart);\n  }\n  const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');\n  const legacyIds = metadata.legacyIds && metadata.legacyIds.filter(id => id !== messageId);\n  return {\n    id: messageId,\n    legacyIds,\n    substitutions,\n    text: messageString,\n    meaning: metadata.meaning || '',\n    description: metadata.description || '',\n    messageParts: cleanedMessageParts,\n    placeholderNames,\n    location,\n  };\n}\n\n/**\n * Parse the given message part (`cooked` + `raw`) to extract the message metadata from the text.\n *\n * If the message part has a metadata block this function will extract the `meaning`,\n * `description`, `customId` and `legacyId` (if provided) from the block. These metadata properties\n * are serialized in the string delimited by `|`, `@@` and `␟` respectively.\n *\n * (Note that `␟` is the `LEGACY_ID_INDICATOR` - see `constants.ts`.)\n *\n * For example:\n *\n * ```ts\n * `:meaning|description@@custom-id`\n * `:meaning|@@custom-id`\n * `:meaning|description`\n * `description@@custom-id`\n * `meaning|`\n * `description`\n * `@@custom-id`\n * `:meaning|description@@custom-id␟legacy-id-1␟legacy-id-2`\n * ```\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns A object containing any metadata that was parsed from the message part.\n */\nexport function parseMetadata(cooked: string, raw: string): MessageMetadata {\n  const {text: messageString, block} = splitBlock(cooked, raw);\n  if (block === undefined) {\n    return {text: messageString};\n  } else {\n    const [meaningDescAndId, ...legacyIds] = block.split(LEGACY_ID_INDICATOR);\n    const [meaningAndDesc, id] = meaningDescAndId.split(ID_SEPARATOR, 2);\n    let [meaning, description]: (string|undefined)[] = meaningAndDesc.split(MEANING_SEPARATOR, 2);\n    if (description === undefined) {\n      description = meaning;\n      meaning = undefined;\n    }\n    if (description === '') {\n      description = undefined;\n    }\n    return {text: messageString, meaning, description, id, legacyIds};\n  }\n}\n\n/**\n * Split a message part (`cooked` + `raw`) into an optional delimited \"block\" off the front and the\n * rest of the text of the message part.\n *\n * Blocks appear at the start of message parts. They are delimited by a colon `:` character at the\n * start and end of the block.\n *\n * If the block is in the first message part then it will be metadata about the whole message:\n * meaning, description, id.  Otherwise it will be metadata about the immediately preceding\n * substitution: placeholder name.\n *\n * Since blocks are optional, it is possible that the content of a message block actually starts\n * with a block marker. In this case the marker must be escaped `\\:`.\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns An object containing the `text` of the message part and the text of the `block`, if it\n * exists.\n * @throws an error if the `block` is unterminated\n */\nexport function splitBlock(cooked: string, raw: string): {text: string, block?: string} {\n  if (raw.charAt(0) !== BLOCK_MARKER) {\n    return {text: cooked};\n  } else {\n    const endOfBlock = findEndOfBlock(cooked, raw);\n    return {\n      block: cooked.substring(1, endOfBlock),\n      text: cooked.substring(endOfBlock + 1),\n    };\n  }\n}\n\n\nfunction computePlaceholderName(index: number) {\n  return index === 1 ? 'PH' : `PH_${index - 1}`;\n}\n\n/**\n * Find the end of a \"marked block\" indicated by the first non-escaped colon.\n *\n * @param cooked The cooked string (where escaped chars have been processed)\n * @param raw The raw string (where escape sequences are still in place)\n *\n * @returns the index of the end of block marker\n * @throws an error if the block is unterminated\n */\nexport function findEndOfBlock(cooked: string, raw: string): number {\n  /************************************************************************************************\n   * This function is repeated in `src/localize/src/localize.ts` and the two should be kept in sync.\n   * (See that file for more explanation of why.)\n   ************************************************************************************************/\n  for (let cookedIndex = 1, rawIndex = 1; cookedIndex < cooked.length; cookedIndex++, rawIndex++) {\n    if (raw[rawIndex] === '\\\\') {\n      rawIndex++;\n    } else if (cooked[cookedIndex] === BLOCK_MARKER) {\n      return cookedIndex;\n    }\n  }\n  throw new Error(`Unterminated $localize metadata block in \"${raw}\".`);\n}"]}

@@ -39,6 +39,8 @@ /**

// Look up the translation using the messageId, and then the legacyId if available.
let translation = translations[message.messageId];
let translation = translations[message.id];
// If the messageId did not match a translation, try matching the legacy ids instead
for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
if (message.legacyIds !== undefined) {
for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
}
}

@@ -68,4 +70,4 @@ if (translation === undefined) {

*/
export function parseTranslation(message) {
const parts = message.split(/{\$([^}]*)}/);
export function parseTranslation(messageString) {
const parts = messageString.split(/{\$([^}]*)}/);
const messageParts = [parts[0]];

@@ -78,3 +80,7 @@ const placeholderNames = [];

const rawMessageParts = messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\' + part : part);
return { messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames };
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, rawMessageParts),
placeholderNames,
};
}

@@ -88,3 +94,11 @@ /**

export function makeParsedTranslation(messageParts, placeholderNames = []) {
return { messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames };
let messageString = messageParts[0];
for (let i = 0; i < placeholderNames.length - 1; i++) {
messageString += `{$${placeholderNames[i]}}${messageParts[i + 1]}`;
}
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, messageParts),
placeholderNames
};
}

@@ -103,4 +117,7 @@ /**

const meaningString = message.meaning && ` - "${message.meaning}"`;
return `"${message.messageId}" ("${message.messageString}"${meaningString})`;
const legacy = message.legacyIds && message.legacyIds.length > 0 ?
` [${message.legacyIds.map(l => `"${l}"`).join(', ')}]` :
'';
return `"${message.id}"${legacy} ("${message.text}"${meaningString})`;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translations.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/utils/src/translations.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 {BLOCK_MARKER} from './constants';\nimport {MessageId, ParsedMessage, parseMessage, TargetMessage} from './messages';\n\n\n/**\n * A translation message that has been processed to extract the message parts and placeholders.\n */\nexport interface ParsedTranslation {\n  messageParts: TemplateStringsArray;\n  placeholderNames: string[];\n}\n\n/**\n * The internal structure used by the runtime localization to translate messages.\n */\nexport type ParsedTranslations = Record<MessageId, ParsedTranslation>;\n\nexport class MissingTranslationError extends Error {\n  private readonly type = 'MissingTranslationError';\n  constructor(readonly parsedMessage: ParsedMessage) {\n    super(`No translation found for ${describeMessage(parsedMessage)}.`);\n  }\n}\n\nexport function isMissingTranslationError(e: any): e is MissingTranslationError {\n  return e.type === 'MissingTranslationError';\n}\n\n/**\n * Translate the text of the `$localize` tagged-string (i.e. `messageParts` and\n * `substitutions`) using the given `translations`.\n *\n * The tagged-string is parsed to extract its `messageId` which is used to find an appropriate\n * `ParsedTranslation`. If this doesn't match and there are legacy ids then try matching a\n * translation using those.\n *\n * If one is found then it is used to translate the message into a new set of `messageParts` and\n * `substitutions`.\n * The translation may reorder (or remove) substitutions as appropriate.\n *\n * If there is no translation with a matching message id then an error is thrown.\n * If a translation contains a placeholder that is not found in the message being translated then an\n * error is thrown.\n */\nexport function translate(\n    translations: Record<string, ParsedTranslation>, messageParts: TemplateStringsArray,\n    substitutions: readonly any[]): [TemplateStringsArray, readonly any[]] {\n  const message = parseMessage(messageParts, substitutions);\n  // Look up the translation using the messageId, and then the legacyId if available.\n  let translation = translations[message.messageId];\n  // If the messageId did not match a translation, try matching the legacy ids instead\n  for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {\n    translation = translations[message.legacyIds[i]];\n  }\n  if (translation === undefined) {\n    throw new MissingTranslationError(message);\n  }\n  return [\n    translation.messageParts, translation.placeholderNames.map(placeholder => {\n      if (message.substitutions.hasOwnProperty(placeholder)) {\n        return message.substitutions[placeholder];\n      } else {\n        throw new Error(\n            `There is a placeholder name mismatch with the translation provided for the message ${\n                describeMessage(message)}.\\n` +\n            `The translation contains a placeholder with name ${\n                placeholder}, which does not exist in the message.`);\n      }\n    })\n  ];\n}\n\n/**\n * Parse the `messageParts` and `placeholderNames` out of a target `message`.\n *\n * Used by `loadTranslations()` to convert target message strings into a structure that is more\n * appropriate for doing translation.\n *\n * @param message the message to be parsed.\n */\nexport function parseTranslation(message: TargetMessage): ParsedTranslation {\n  const parts = message.split(/{\\$([^}]*)}/);\n  const messageParts = [parts[0]];\n  const placeholderNames: string[] = [];\n  for (let i = 1; i < parts.length - 1; i += 2) {\n    placeholderNames.push(parts[i]);\n    messageParts.push(`${parts[i + 1]}`);\n  }\n  const rawMessageParts =\n      messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\\\' + part : part);\n  return {messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames};\n}\n\n/**\n * Create a `ParsedTranslation` from a set of `messageParts` and `placeholderNames`.\n *\n * @param messageParts The message parts to appear in the ParsedTranslation.\n * @param placeholderNames The names of the placeholders to intersperse between the `messageParts`.\n */\nexport function makeParsedTranslation(\n    messageParts: string[], placeholderNames: string[] = []): ParsedTranslation {\n  return {messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames};\n}\n\n/**\n * Create the specialized array that is passed to tagged-string tag functions.\n *\n * @param cooked The message parts with their escape codes processed.\n * @param raw The message parts with their escaped codes as-is.\n */\nexport function makeTemplateObject(cooked: string[], raw: string[]): TemplateStringsArray {\n  Object.defineProperty(cooked, 'raw', {value: raw});\n  return cooked as any;\n}\n\n\nfunction describeMessage(message: ParsedMessage): string {\n  const meaningString = message.meaning && ` - \"${message.meaning}\"`;\n  return `\"${message.messageId}\" (\"${message.messageString}\"${meaningString})`;\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translations.js","sourceRoot":"","sources":["../../../../../../../../packages/localize/src/utils/src/translations.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 {BLOCK_MARKER} from './constants';\nimport {MessageId, MessageMetadata, ParsedMessage, parseMessage, TargetMessage} from './messages';\n\n\n/**\n * A translation message that has been processed to extract the message parts and placeholders.\n */\nexport interface ParsedTranslation extends MessageMetadata {\n  messageParts: TemplateStringsArray;\n  placeholderNames: string[];\n}\n\n/**\n * The internal structure used by the runtime localization to translate messages.\n */\nexport type ParsedTranslations = Record<MessageId, ParsedTranslation>;\n\nexport class MissingTranslationError extends Error {\n  private readonly type = 'MissingTranslationError';\n  constructor(readonly parsedMessage: ParsedMessage) {\n    super(`No translation found for ${describeMessage(parsedMessage)}.`);\n  }\n}\n\nexport function isMissingTranslationError(e: any): e is MissingTranslationError {\n  return e.type === 'MissingTranslationError';\n}\n\n/**\n * Translate the text of the `$localize` tagged-string (i.e. `messageParts` and\n * `substitutions`) using the given `translations`.\n *\n * The tagged-string is parsed to extract its `messageId` which is used to find an appropriate\n * `ParsedTranslation`. If this doesn't match and there are legacy ids then try matching a\n * translation using those.\n *\n * If one is found then it is used to translate the message into a new set of `messageParts` and\n * `substitutions`.\n * The translation may reorder (or remove) substitutions as appropriate.\n *\n * If there is no translation with a matching message id then an error is thrown.\n * If a translation contains a placeholder that is not found in the message being translated then an\n * error is thrown.\n */\nexport function translate(\n    translations: Record<string, ParsedTranslation>, messageParts: TemplateStringsArray,\n    substitutions: readonly any[]): [TemplateStringsArray, readonly any[]] {\n  const message = parseMessage(messageParts, substitutions);\n  // Look up the translation using the messageId, and then the legacyId if available.\n  let translation = translations[message.id];\n  // If the messageId did not match a translation, try matching the legacy ids instead\n  if (message.legacyIds !== undefined) {\n    for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {\n      translation = translations[message.legacyIds[i]];\n    }\n  }\n  if (translation === undefined) {\n    throw new MissingTranslationError(message);\n  }\n  return [\n    translation.messageParts, translation.placeholderNames.map(placeholder => {\n      if (message.substitutions.hasOwnProperty(placeholder)) {\n        return message.substitutions[placeholder];\n      } else {\n        throw new Error(\n            `There is a placeholder name mismatch with the translation provided for the message ${\n                describeMessage(message)}.\\n` +\n            `The translation contains a placeholder with name ${\n                placeholder}, which does not exist in the message.`);\n      }\n    })\n  ];\n}\n\n/**\n * Parse the `messageParts` and `placeholderNames` out of a target `message`.\n *\n * Used by `loadTranslations()` to convert target message strings into a structure that is more\n * appropriate for doing translation.\n *\n * @param message the message to be parsed.\n */\nexport function parseTranslation(messageString: TargetMessage): ParsedTranslation {\n  const parts = messageString.split(/{\\$([^}]*)}/);\n  const messageParts = [parts[0]];\n  const placeholderNames: string[] = [];\n  for (let i = 1; i < parts.length - 1; i += 2) {\n    placeholderNames.push(parts[i]);\n    messageParts.push(`${parts[i + 1]}`);\n  }\n  const rawMessageParts =\n      messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\\\' + part : part);\n  return {\n    text: messageString,\n    messageParts: makeTemplateObject(messageParts, rawMessageParts),\n    placeholderNames,\n  };\n}\n\n/**\n * Create a `ParsedTranslation` from a set of `messageParts` and `placeholderNames`.\n *\n * @param messageParts The message parts to appear in the ParsedTranslation.\n * @param placeholderNames The names of the placeholders to intersperse between the `messageParts`.\n */\nexport function makeParsedTranslation(\n    messageParts: string[], placeholderNames: string[] = []): ParsedTranslation {\n  let messageString = messageParts[0];\n  for (let i = 0; i < placeholderNames.length - 1; i++) {\n    messageString += `{$${placeholderNames[i]}}${messageParts[i + 1]}`;\n  }\n  return {\n    text: messageString,\n    messageParts: makeTemplateObject(messageParts, messageParts),\n    placeholderNames\n  };\n}\n\n/**\n * Create the specialized array that is passed to tagged-string tag functions.\n *\n * @param cooked The message parts with their escape codes processed.\n * @param raw The message parts with their escaped codes as-is.\n */\nexport function makeTemplateObject(cooked: string[], raw: string[]): TemplateStringsArray {\n  Object.defineProperty(cooked, 'raw', {value: raw});\n  return cooked as any;\n}\n\n\nfunction describeMessage(message: ParsedMessage): string {\n  const meaningString = message.meaning && ` - \"${message.meaning}\"`;\n  const legacy = message.legacyIds && message.legacyIds.length > 0 ?\n      ` [${message.legacyIds.map(l => `\"${l}\"`).join(', ')}]` :\n      '';\n  return `\"${message.id}\"${legacy} (\"${message.text}\"${meaningString})`;\n}"]}

@@ -11,2 +11,2 @@ /**

export { computeMsgId as ɵcomputeMsgId, findEndOfBlock as ɵfindEndOfBlock, isMissingTranslationError as ɵisMissingTranslationError, makeParsedTranslation as ɵmakeParsedTranslation, makeTemplateObject as ɵmakeTemplateObject, MissingTranslationError as ɵMissingTranslationError, parseMessage as ɵparseMessage, parseMetadata as ɵparseMetadata, parseTranslation as ɵparseTranslation, splitBlock as ɵsplitBlock, translate as ɵtranslate } from './src/utils';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3ByaXZhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsa0dBQWtHO0FBQ2xHLHdCQUF3QjtBQUN4QixPQUFPLEVBQUMsWUFBWSxJQUFJLGFBQWEsRUFBRSxjQUFjLElBQUksZUFBZSxFQUFFLHlCQUF5QixJQUFJLDBCQUEwQixFQUFFLHFCQUFxQixJQUFJLHNCQUFzQixFQUFFLGtCQUFrQixJQUFJLG1CQUFtQixFQUEyQix1QkFBdUIsSUFBSSx3QkFBd0IsRUFBdUgsWUFBWSxJQUFJLGFBQWEsRUFBRSxhQUFhLElBQUksY0FBYyxFQUFFLGdCQUFnQixJQUFJLGlCQUFpQixFQUFtQyxVQUFVLElBQUksV0FBVyxFQUFtQyxTQUFTLElBQUksVUFBVSxFQUFDLE1BQU0sYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vLyBUaGlzIGZpbGUgZXhwb3J0cyBhbGwgdGhlIGB1dGlsc2AgYXMgcHJpdmF0ZSBleHBvcnRzIHNvIHRoYXQgb3RoZXIgcGFydHMgb2YgYEBhbmd1bGFyL2xvY2FsaXplYFxuLy8gY2FuIG1ha2UgdXNlIG9mIHRoZW0uXG5leHBvcnQge2NvbXB1dGVNc2dJZCBhcyDJtWNvbXB1dGVNc2dJZCwgZmluZEVuZE9mQmxvY2sgYXMgybVmaW5kRW5kT2ZCbG9jaywgaXNNaXNzaW5nVHJhbnNsYXRpb25FcnJvciBhcyDJtWlzTWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIG1ha2VQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtW1ha2VQYXJzZWRUcmFuc2xhdGlvbiwgbWFrZVRlbXBsYXRlT2JqZWN0IGFzIMm1bWFrZVRlbXBsYXRlT2JqZWN0LCBNZXNzYWdlSWQgYXMgybVNZXNzYWdlSWQsIE1pc3NpbmdUcmFuc2xhdGlvbkVycm9yIGFzIMm1TWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIFBhcnNlZE1lc3NhZ2UgYXMgybVQYXJzZWRNZXNzYWdlLCBQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtVBhcnNlZFRyYW5zbGF0aW9uLCBQYXJzZWRUcmFuc2xhdGlvbnMgYXMgybVQYXJzZWRUcmFuc2xhdGlvbnMsIHBhcnNlTWVzc2FnZSBhcyDJtXBhcnNlTWVzc2FnZSwgcGFyc2VNZXRhZGF0YSBhcyDJtXBhcnNlTWV0YWRhdGEsIHBhcnNlVHJhbnNsYXRpb24gYXMgybVwYXJzZVRyYW5zbGF0aW9uLCBTb3VyY2VNZXNzYWdlIGFzIMm1U291cmNlTWVzc2FnZSwgc3BsaXRCbG9jayBhcyDJtXNwbGl0QmxvY2ssIFRhcmdldE1lc3NhZ2UgYXMgybVUYXJnZXRNZXNzYWdlLCB0cmFuc2xhdGUgYXMgybV0cmFuc2xhdGV9IGZyb20gJy4vc3JjL3V0aWxzJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3ByaXZhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsa0dBQWtHO0FBQ2xHLHdCQUF3QjtBQUN4QixPQUFPLEVBQUMsWUFBWSxJQUFJLGFBQWEsRUFBRSxjQUFjLElBQUksZUFBZSxFQUFFLHlCQUF5QixJQUFJLDBCQUEwQixFQUFFLHFCQUFxQixJQUFJLHNCQUFzQixFQUFFLGtCQUFrQixJQUFJLG1CQUFtQixFQUEyQix1QkFBdUIsSUFBSSx3QkFBd0IsRUFBdUgsWUFBWSxJQUFJLGFBQWEsRUFBRSxhQUFhLElBQUksY0FBYyxFQUFFLGdCQUFnQixJQUFJLGlCQUFpQixFQUFzRSxVQUFVLElBQUksV0FBVyxFQUFtQyxTQUFTLElBQUksVUFBVSxFQUFDLE1BQU0sYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG4vLyBUaGlzIGZpbGUgZXhwb3J0cyBhbGwgdGhlIGB1dGlsc2AgYXMgcHJpdmF0ZSBleHBvcnRzIHNvIHRoYXQgb3RoZXIgcGFydHMgb2YgYEBhbmd1bGFyL2xvY2FsaXplYFxuLy8gY2FuIG1ha2UgdXNlIG9mIHRoZW0uXG5leHBvcnQge2NvbXB1dGVNc2dJZCBhcyDJtWNvbXB1dGVNc2dJZCwgZmluZEVuZE9mQmxvY2sgYXMgybVmaW5kRW5kT2ZCbG9jaywgaXNNaXNzaW5nVHJhbnNsYXRpb25FcnJvciBhcyDJtWlzTWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIG1ha2VQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtW1ha2VQYXJzZWRUcmFuc2xhdGlvbiwgbWFrZVRlbXBsYXRlT2JqZWN0IGFzIMm1bWFrZVRlbXBsYXRlT2JqZWN0LCBNZXNzYWdlSWQgYXMgybVNZXNzYWdlSWQsIE1pc3NpbmdUcmFuc2xhdGlvbkVycm9yIGFzIMm1TWlzc2luZ1RyYW5zbGF0aW9uRXJyb3IsIFBhcnNlZE1lc3NhZ2UgYXMgybVQYXJzZWRNZXNzYWdlLCBQYXJzZWRUcmFuc2xhdGlvbiBhcyDJtVBhcnNlZFRyYW5zbGF0aW9uLCBQYXJzZWRUcmFuc2xhdGlvbnMgYXMgybVQYXJzZWRUcmFuc2xhdGlvbnMsIHBhcnNlTWVzc2FnZSBhcyDJtXBhcnNlTWVzc2FnZSwgcGFyc2VNZXRhZGF0YSBhcyDJtXBhcnNlTWV0YWRhdGEsIHBhcnNlVHJhbnNsYXRpb24gYXMgybVwYXJzZVRyYW5zbGF0aW9uLCBTb3VyY2VMb2NhdGlvbiBhcyDJtVNvdXJjZUxvY2F0aW9uLCBTb3VyY2VNZXNzYWdlIGFzIMm1U291cmNlTWVzc2FnZSwgc3BsaXRCbG9jayBhcyDJtXNwbGl0QmxvY2ssIFRhcmdldE1lc3NhZ2UgYXMgybVUYXJnZXRNZXNzYWdlLCB0cmFuc2xhdGUgYXMgybV0cmFuc2xhdGV9IGZyb20gJy4vc3JjL3V0aWxzJztcbiJdfQ==

@@ -21,3 +21,3 @@ import { __read } from "tslib";

*/
export function parseMessage(messageParts, expressions) {
export function parseMessage(messageParts, expressions, location) {
var substitutions = {};

@@ -38,8 +38,8 @@ var metadata = parseMetadata(messageParts[0], messageParts.raw[0]);

var messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');
var legacyIds = metadata.legacyIds.filter(function (id) { return id !== messageId; });
var legacyIds = metadata.legacyIds && metadata.legacyIds.filter(function (id) { return id !== messageId; });
return {
messageId: messageId,
id: messageId,
legacyIds: legacyIds,
substitutions: substitutions,
messageString: messageString,
text: messageString,
meaning: metadata.meaning || '',

@@ -49,2 +49,3 @@ description: metadata.description || '',

placeholderNames: placeholderNames,
location: location,
};

@@ -79,5 +80,5 @@ }

export function parseMetadata(cooked, raw) {
var _a = splitBlock(cooked, raw), text = _a.text, block = _a.block;
var _a = splitBlock(cooked, raw), messageString = _a.text, block = _a.block;
if (block === undefined) {
return { text: text, meaning: undefined, description: undefined, id: undefined, legacyIds: [] };
return { text: messageString };
}

@@ -95,3 +96,3 @@ else {

}
return { text: text, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
return { text: messageString, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
}

@@ -158,2 +159,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../../../../../../../../../../packages/localize/src/utils/src/messages.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 {computeMsgId} from '@angular/compiler';\n\nimport {BLOCK_MARKER, ID_SEPARATOR, LEGACY_ID_INDICATOR, MEANING_SEPARATOR} from './constants';\n\n/**\n * Re-export this helper function so that users of `@angular/localize` don't need to actively import\n * from `@angular/compiler`.\n */\nexport {computeMsgId} from '@angular/compiler';\n\n/**\n * A string containing a translation source message.\n *\n * I.E. the message that indicates what will be translated from.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type SourceMessage = string;\n\n/**\n * A string containing a translation target message.\n *\n * I.E. the message that indicates what will be translated to.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type TargetMessage = string;\n\n/**\n * A string that uniquely identifies a message, to be used for matching translations.\n */\nexport type MessageId = string;\n\n/**\n * Information parsed from a `$localize` tagged string that is used to translate it.\n *\n * For example:\n *\n * ```\n * const name = 'Jo Bloggs';\n * $localize`Hello ${name}:title!`;\n * ```\n *\n * May be parsed into:\n *\n * ```\n * {\n *   messageId: '6998194507597730591',\n *   substitutions: { title: 'Jo Bloggs' },\n *   messageString: 'Hello {$title}!',\n * }\n * ```\n */\nexport interface ParsedMessage {\n  /**\n   * The key used to look up the appropriate translation target.\n   */\n  messageId: MessageId;\n  /**\n   * Legacy message ids, if provided.\n   *\n   * In legacy message formats the message id can only be computed directly from the original\n   * template source.\n   *\n   * Since this information is not available in `$localize` calls, the legacy message ids may be\n   * attached by the compiler to the `$localize` metablock so it can be used if needed at the point\n   * of translation if the translations are encoded using the legacy message id.\n   */\n  legacyIds: MessageId[];\n  /**\n   * A mapping of placeholder names to substitution values.\n   */\n  substitutions: Record<string, any>;\n  /**\n   * A human readable rendering of the message\n   */\n  messageString: string;\n  /**\n   * The meaning of the `message`, used to distinguish identical `messageString`s.\n   */\n  meaning: string;\n  /**\n   * The description of the `message`, used to aid translation.\n   */\n  description: string;\n  /**\n   * The static parts of the message.\n   */\n  messageParts: string[];\n  /**\n   * The names of the placeholders that will be replaced with substitutions.\n   */\n  placeholderNames: string[];\n}\n\n/**\n * Parse a `$localize` tagged string into a structure that can be used for translation.\n *\n * See `ParsedMessage` for an example.\n */\nexport function parseMessage(\n    messageParts: TemplateStringsArray, expressions?: readonly any[]): ParsedMessage {\n  const substitutions: {[placeholderName: string]: any} = {};\n  const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);\n  const cleanedMessageParts: string[] = [metadata.text];\n  const placeholderNames: string[] = [];\n  let messageString = metadata.text;\n  for (let i = 1; i < messageParts.length; i++) {\n    const {text: messagePart, block: placeholderName = computePlaceholderName(i)} =\n        splitBlock(messageParts[i], messageParts.raw[i]);\n    messageString += `{$${placeholderName}}${messagePart}`;\n    if (expressions !== undefined) {\n      substitutions[placeholderName] = expressions[i - 1];\n    }\n    placeholderNames.push(placeholderName);\n    cleanedMessageParts.push(messagePart);\n  }\n  const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');\n  const legacyIds = metadata.legacyIds.filter(id => id !== messageId);\n  return {\n    messageId,\n    legacyIds,\n    substitutions,\n    messageString,\n    meaning: metadata.meaning || '',\n    description: metadata.description || '',\n    messageParts: cleanedMessageParts,\n    placeholderNames,\n  };\n}\n\nexport interface MessageMetadata {\n  text: string;\n  meaning: string|undefined;\n  description: string|undefined;\n  id: string|undefined;\n  legacyIds: string[];\n}\n\n/**\n * Parse the given message part (`cooked` + `raw`) to extract the message metadata from the text.\n *\n * If the message part has a metadata block this function will extract the `meaning`,\n * `description`, `customId` and `legacyId` (if provided) from the block. These metadata properties\n * are serialized in the string delimited by `|`, `@@` and `␟` respectively.\n *\n * (Note that `␟` is the `LEGACY_ID_INDICATOR` - see `constants.ts`.)\n *\n * For example:\n *\n * ```ts\n * `:meaning|description@@custom-id`\n * `:meaning|@@custom-id`\n * `:meaning|description`\n * `description@@custom-id`\n * `meaning|`\n * `description`\n * `@@custom-id`\n * `:meaning|description@@custom-id␟legacy-id-1␟legacy-id-2`\n * ```\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns A object containing any metadata that was parsed from the message part.\n */\nexport function parseMetadata(cooked: string, raw: string): MessageMetadata {\n  const {text, block} = splitBlock(cooked, raw);\n  if (block === undefined) {\n    return {text, meaning: undefined, description: undefined, id: undefined, legacyIds: []};\n  } else {\n    const [meaningDescAndId, ...legacyIds] = block.split(LEGACY_ID_INDICATOR);\n    const [meaningAndDesc, id] = meaningDescAndId.split(ID_SEPARATOR, 2);\n    let [meaning, description]: (string|undefined)[] = meaningAndDesc.split(MEANING_SEPARATOR, 2);\n    if (description === undefined) {\n      description = meaning;\n      meaning = undefined;\n    }\n    if (description === '') {\n      description = undefined;\n    }\n    return {text, meaning, description, id, legacyIds};\n  }\n}\n\n/**\n * Split a message part (`cooked` + `raw`) into an optional delimited \"block\" off the front and the\n * rest of the text of the message part.\n *\n * Blocks appear at the start of message parts. They are delimited by a colon `:` character at the\n * start and end of the block.\n *\n * If the block is in the first message part then it will be metadata about the whole message:\n * meaning, description, id.  Otherwise it will be metadata about the immediately preceding\n * substitution: placeholder name.\n *\n * Since blocks are optional, it is possible that the content of a message block actually starts\n * with a block marker. In this case the marker must be escaped `\\:`.\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns An object containing the `text` of the message part and the text of the `block`, if it\n * exists.\n * @throws an error if the `block` is unterminated\n */\nexport function splitBlock(cooked: string, raw: string): {text: string, block?: string} {\n  if (raw.charAt(0) !== BLOCK_MARKER) {\n    return {text: cooked};\n  } else {\n    const endOfBlock = findEndOfBlock(cooked, raw);\n    return {\n      block: cooked.substring(1, endOfBlock),\n      text: cooked.substring(endOfBlock + 1),\n    };\n  }\n}\n\n\nfunction computePlaceholderName(index: number) {\n  return index === 1 ? 'PH' : `PH_${index - 1}`;\n}\n\n/**\n * Find the end of a \"marked block\" indicated by the first non-escaped colon.\n *\n * @param cooked The cooked string (where escaped chars have been processed)\n * @param raw The raw string (where escape sequences are still in place)\n *\n * @returns the index of the end of block marker\n * @throws an error if the block is unterminated\n */\nexport function findEndOfBlock(cooked: string, raw: string): number {\n  /************************************************************************************************\n   * This function is repeated in `src/localize/src/localize.ts` and the two should be kept in sync.\n   * (See that file for more explanation of why.)\n   ************************************************************************************************/\n  for (let cookedIndex = 1, rawIndex = 1; cookedIndex < cooked.length; cookedIndex++, rawIndex++) {\n    if (raw[rawIndex] === '\\\\') {\n      rawIndex++;\n    } else if (cooked[cookedIndex] === BLOCK_MARKER) {\n      return cookedIndex;\n    }\n  }\n  throw new Error(`Unterminated $localize metadata block in \"${raw}\".`);\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../../../../../../../../../../packages/localize/src/utils/src/messages.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 {computeMsgId} from '@angular/compiler';\n\nimport {BLOCK_MARKER, ID_SEPARATOR, LEGACY_ID_INDICATOR, MEANING_SEPARATOR} from './constants';\n\n/**\n * Re-export this helper function so that users of `@angular/localize` don't need to actively import\n * from `@angular/compiler`.\n */\nexport {computeMsgId} from '@angular/compiler';\n\n/**\n * A string containing a translation source message.\n *\n * I.E. the message that indicates what will be translated from.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type SourceMessage = string;\n\n/**\n * A string containing a translation target message.\n *\n * I.E. the message that indicates what will be translated to.\n *\n * Uses `{$placeholder-name}` to indicate a placeholder.\n */\nexport type TargetMessage = string;\n\n/**\n * A string that uniquely identifies a message, to be used for matching translations.\n */\nexport type MessageId = string;\n\n/**\n * The location of the message\n */\nexport interface SourceLocation {\n  start: {line: number, column: number};\n  end: {line: number, column: number};\n  file: string;\n}\n\n/**\n * Additional information that can be associated with a message.\n */\nexport interface MessageMetadata {\n  /**\n   * A human readable rendering of the message\n   */\n  text: string;\n  /**\n   * A unique identifier for this message.\n   */\n  id?: MessageId;\n  /**\n   * Legacy message ids, if provided.\n   *\n   * In legacy message formats the message id can only be computed directly from the original\n   * template source.\n   *\n   * Since this information is not available in `$localize` calls, the legacy message ids may be\n   * attached by the compiler to the `$localize` metablock so it can be used if needed at the point\n   * of translation if the translations are encoded using the legacy message id.\n   */\n  legacyIds?: string[];\n  /**\n   * The meaning of the `message`, used to distinguish identical `messageString`s.\n   */\n  meaning?: string;\n  /**\n   * The description of the `message`, used to aid translation.\n   */\n  description?: string;\n  /**\n   * The location of the message in the source.\n   */\n  location?: SourceLocation;\n}\n\n/**\n * Information parsed from a `$localize` tagged string that is used to translate it.\n *\n * For example:\n *\n * ```\n * const name = 'Jo Bloggs';\n * $localize`Hello ${name}:title!`;\n * ```\n *\n * May be parsed into:\n *\n * ```\n * {\n *   id: '6998194507597730591',\n *   substitutions: { title: 'Jo Bloggs' },\n *   messageString: 'Hello {$title}!',\n * }\n * ```\n */\nexport interface ParsedMessage extends MessageMetadata {\n  /**\n   * The key used to look up the appropriate translation target.\n   *\n   * In `ParsedMessage` this is a required field, whereas it is optional in `MessageMetadata`.\n   */\n  id: MessageId;\n  /**\n   * A mapping of placeholder names to substitution values.\n   */\n  substitutions: Record<string, any>;\n  /**\n   * The static parts of the message.\n   */\n  messageParts: string[];\n  /**\n   * The names of the placeholders that will be replaced with substitutions.\n   */\n  placeholderNames: string[];\n}\n\n/**\n * Parse a `$localize` tagged string into a structure that can be used for translation.\n *\n * See `ParsedMessage` for an example.\n */\nexport function parseMessage(\n    messageParts: TemplateStringsArray, expressions?: readonly any[],\n    location?: SourceLocation): ParsedMessage {\n  const substitutions: {[placeholderName: string]: any} = {};\n  const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);\n  const cleanedMessageParts: string[] = [metadata.text];\n  const placeholderNames: string[] = [];\n  let messageString = metadata.text;\n  for (let i = 1; i < messageParts.length; i++) {\n    const {text: messagePart, block: placeholderName = computePlaceholderName(i)} =\n        splitBlock(messageParts[i], messageParts.raw[i]);\n    messageString += `{$${placeholderName}}${messagePart}`;\n    if (expressions !== undefined) {\n      substitutions[placeholderName] = expressions[i - 1];\n    }\n    placeholderNames.push(placeholderName);\n    cleanedMessageParts.push(messagePart);\n  }\n  const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');\n  const legacyIds = metadata.legacyIds && metadata.legacyIds.filter(id => id !== messageId);\n  return {\n    id: messageId,\n    legacyIds,\n    substitutions,\n    text: messageString,\n    meaning: metadata.meaning || '',\n    description: metadata.description || '',\n    messageParts: cleanedMessageParts,\n    placeholderNames,\n    location,\n  };\n}\n\n/**\n * Parse the given message part (`cooked` + `raw`) to extract the message metadata from the text.\n *\n * If the message part has a metadata block this function will extract the `meaning`,\n * `description`, `customId` and `legacyId` (if provided) from the block. These metadata properties\n * are serialized in the string delimited by `|`, `@@` and `␟` respectively.\n *\n * (Note that `␟` is the `LEGACY_ID_INDICATOR` - see `constants.ts`.)\n *\n * For example:\n *\n * ```ts\n * `:meaning|description@@custom-id`\n * `:meaning|@@custom-id`\n * `:meaning|description`\n * `description@@custom-id`\n * `meaning|`\n * `description`\n * `@@custom-id`\n * `:meaning|description@@custom-id␟legacy-id-1␟legacy-id-2`\n * ```\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns A object containing any metadata that was parsed from the message part.\n */\nexport function parseMetadata(cooked: string, raw: string): MessageMetadata {\n  const {text: messageString, block} = splitBlock(cooked, raw);\n  if (block === undefined) {\n    return {text: messageString};\n  } else {\n    const [meaningDescAndId, ...legacyIds] = block.split(LEGACY_ID_INDICATOR);\n    const [meaningAndDesc, id] = meaningDescAndId.split(ID_SEPARATOR, 2);\n    let [meaning, description]: (string|undefined)[] = meaningAndDesc.split(MEANING_SEPARATOR, 2);\n    if (description === undefined) {\n      description = meaning;\n      meaning = undefined;\n    }\n    if (description === '') {\n      description = undefined;\n    }\n    return {text: messageString, meaning, description, id, legacyIds};\n  }\n}\n\n/**\n * Split a message part (`cooked` + `raw`) into an optional delimited \"block\" off the front and the\n * rest of the text of the message part.\n *\n * Blocks appear at the start of message parts. They are delimited by a colon `:` character at the\n * start and end of the block.\n *\n * If the block is in the first message part then it will be metadata about the whole message:\n * meaning, description, id.  Otherwise it will be metadata about the immediately preceding\n * substitution: placeholder name.\n *\n * Since blocks are optional, it is possible that the content of a message block actually starts\n * with a block marker. In this case the marker must be escaped `\\:`.\n *\n * @param cooked The cooked version of the message part to parse.\n * @param raw The raw version of the message part to parse.\n * @returns An object containing the `text` of the message part and the text of the `block`, if it\n * exists.\n * @throws an error if the `block` is unterminated\n */\nexport function splitBlock(cooked: string, raw: string): {text: string, block?: string} {\n  if (raw.charAt(0) !== BLOCK_MARKER) {\n    return {text: cooked};\n  } else {\n    const endOfBlock = findEndOfBlock(cooked, raw);\n    return {\n      block: cooked.substring(1, endOfBlock),\n      text: cooked.substring(endOfBlock + 1),\n    };\n  }\n}\n\n\nfunction computePlaceholderName(index: number) {\n  return index === 1 ? 'PH' : `PH_${index - 1}`;\n}\n\n/**\n * Find the end of a \"marked block\" indicated by the first non-escaped colon.\n *\n * @param cooked The cooked string (where escaped chars have been processed)\n * @param raw The raw string (where escape sequences are still in place)\n *\n * @returns the index of the end of block marker\n * @throws an error if the block is unterminated\n */\nexport function findEndOfBlock(cooked: string, raw: string): number {\n  /************************************************************************************************\n   * This function is repeated in `src/localize/src/localize.ts` and the two should be kept in sync.\n   * (See that file for more explanation of why.)\n   ************************************************************************************************/\n  for (let cookedIndex = 1, rawIndex = 1; cookedIndex < cooked.length; cookedIndex++, rawIndex++) {\n    if (raw[rawIndex] === '\\\\') {\n      rawIndex++;\n    } else if (cooked[cookedIndex] === BLOCK_MARKER) {\n      return cookedIndex;\n    }\n  }\n  throw new Error(`Unterminated $localize metadata block in \"${raw}\".`);\n}"]}

@@ -44,6 +44,8 @@ import { __extends } from "tslib";

// Look up the translation using the messageId, and then the legacyId if available.
var translation = translations[message.messageId];
var translation = translations[message.id];
// If the messageId did not match a translation, try matching the legacy ids instead
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
if (message.legacyIds !== undefined) {
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
}
}

@@ -73,4 +75,4 @@ if (translation === undefined) {

*/
export function parseTranslation(message) {
var parts = message.split(/{\$([^}]*)}/);
export function parseTranslation(messageString) {
var parts = messageString.split(/{\$([^}]*)}/);
var messageParts = [parts[0]];

@@ -83,3 +85,7 @@ var placeholderNames = [];

var rawMessageParts = messageParts.map(function (part) { return part.charAt(0) === BLOCK_MARKER ? '\\' + part : part; });
return { messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames: placeholderNames };
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, rawMessageParts),
placeholderNames: placeholderNames,
};
}

@@ -94,3 +100,11 @@ /**

if (placeholderNames === void 0) { placeholderNames = []; }
return { messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames: placeholderNames };
var messageString = messageParts[0];
for (var i = 0; i < placeholderNames.length - 1; i++) {
messageString += "{$" + placeholderNames[i] + "}" + messageParts[i + 1];
}
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, messageParts),
placeholderNames: placeholderNames
};
}

@@ -109,4 +123,7 @@ /**

var meaningString = message.meaning && " - \"" + message.meaning + "\"";
return "\"" + message.messageId + "\" (\"" + message.messageString + "\"" + meaningString + ")";
var legacy = message.legacyIds && message.legacyIds.length > 0 ?
" [" + message.legacyIds.map(function (l) { return "\"" + l + "\""; }).join(', ') + "]" :
'';
return "\"" + message.id + "\"" + legacy + " (\"" + message.text + "\"" + meaningString + ")";
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translations.js","sourceRoot":"","sources":["../../../../../../../../../../../../../packages/localize/src/utils/src/translations.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 {BLOCK_MARKER} from './constants';\nimport {MessageId, ParsedMessage, parseMessage, TargetMessage} from './messages';\n\n\n/**\n * A translation message that has been processed to extract the message parts and placeholders.\n */\nexport interface ParsedTranslation {\n  messageParts: TemplateStringsArray;\n  placeholderNames: string[];\n}\n\n/**\n * The internal structure used by the runtime localization to translate messages.\n */\nexport type ParsedTranslations = Record<MessageId, ParsedTranslation>;\n\nexport class MissingTranslationError extends Error {\n  private readonly type = 'MissingTranslationError';\n  constructor(readonly parsedMessage: ParsedMessage) {\n    super(`No translation found for ${describeMessage(parsedMessage)}.`);\n  }\n}\n\nexport function isMissingTranslationError(e: any): e is MissingTranslationError {\n  return e.type === 'MissingTranslationError';\n}\n\n/**\n * Translate the text of the `$localize` tagged-string (i.e. `messageParts` and\n * `substitutions`) using the given `translations`.\n *\n * The tagged-string is parsed to extract its `messageId` which is used to find an appropriate\n * `ParsedTranslation`. If this doesn't match and there are legacy ids then try matching a\n * translation using those.\n *\n * If one is found then it is used to translate the message into a new set of `messageParts` and\n * `substitutions`.\n * The translation may reorder (or remove) substitutions as appropriate.\n *\n * If there is no translation with a matching message id then an error is thrown.\n * If a translation contains a placeholder that is not found in the message being translated then an\n * error is thrown.\n */\nexport function translate(\n    translations: Record<string, ParsedTranslation>, messageParts: TemplateStringsArray,\n    substitutions: readonly any[]): [TemplateStringsArray, readonly any[]] {\n  const message = parseMessage(messageParts, substitutions);\n  // Look up the translation using the messageId, and then the legacyId if available.\n  let translation = translations[message.messageId];\n  // If the messageId did not match a translation, try matching the legacy ids instead\n  for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {\n    translation = translations[message.legacyIds[i]];\n  }\n  if (translation === undefined) {\n    throw new MissingTranslationError(message);\n  }\n  return [\n    translation.messageParts, translation.placeholderNames.map(placeholder => {\n      if (message.substitutions.hasOwnProperty(placeholder)) {\n        return message.substitutions[placeholder];\n      } else {\n        throw new Error(\n            `There is a placeholder name mismatch with the translation provided for the message ${\n                describeMessage(message)}.\\n` +\n            `The translation contains a placeholder with name ${\n                placeholder}, which does not exist in the message.`);\n      }\n    })\n  ];\n}\n\n/**\n * Parse the `messageParts` and `placeholderNames` out of a target `message`.\n *\n * Used by `loadTranslations()` to convert target message strings into a structure that is more\n * appropriate for doing translation.\n *\n * @param message the message to be parsed.\n */\nexport function parseTranslation(message: TargetMessage): ParsedTranslation {\n  const parts = message.split(/{\\$([^}]*)}/);\n  const messageParts = [parts[0]];\n  const placeholderNames: string[] = [];\n  for (let i = 1; i < parts.length - 1; i += 2) {\n    placeholderNames.push(parts[i]);\n    messageParts.push(`${parts[i + 1]}`);\n  }\n  const rawMessageParts =\n      messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\\\' + part : part);\n  return {messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames};\n}\n\n/**\n * Create a `ParsedTranslation` from a set of `messageParts` and `placeholderNames`.\n *\n * @param messageParts The message parts to appear in the ParsedTranslation.\n * @param placeholderNames The names of the placeholders to intersperse between the `messageParts`.\n */\nexport function makeParsedTranslation(\n    messageParts: string[], placeholderNames: string[] = []): ParsedTranslation {\n  return {messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames};\n}\n\n/**\n * Create the specialized array that is passed to tagged-string tag functions.\n *\n * @param cooked The message parts with their escape codes processed.\n * @param raw The message parts with their escaped codes as-is.\n */\nexport function makeTemplateObject(cooked: string[], raw: string[]): TemplateStringsArray {\n  Object.defineProperty(cooked, 'raw', {value: raw});\n  return cooked as any;\n}\n\n\nfunction describeMessage(message: ParsedMessage): string {\n  const meaningString = message.meaning && ` - \"${message.meaning}\"`;\n  return `\"${message.messageId}\" (\"${message.messageString}\"${meaningString})`;\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translations.js","sourceRoot":"","sources":["../../../../../../../../../../../../../packages/localize/src/utils/src/translations.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 {BLOCK_MARKER} from './constants';\nimport {MessageId, MessageMetadata, ParsedMessage, parseMessage, TargetMessage} from './messages';\n\n\n/**\n * A translation message that has been processed to extract the message parts and placeholders.\n */\nexport interface ParsedTranslation extends MessageMetadata {\n  messageParts: TemplateStringsArray;\n  placeholderNames: string[];\n}\n\n/**\n * The internal structure used by the runtime localization to translate messages.\n */\nexport type ParsedTranslations = Record<MessageId, ParsedTranslation>;\n\nexport class MissingTranslationError extends Error {\n  private readonly type = 'MissingTranslationError';\n  constructor(readonly parsedMessage: ParsedMessage) {\n    super(`No translation found for ${describeMessage(parsedMessage)}.`);\n  }\n}\n\nexport function isMissingTranslationError(e: any): e is MissingTranslationError {\n  return e.type === 'MissingTranslationError';\n}\n\n/**\n * Translate the text of the `$localize` tagged-string (i.e. `messageParts` and\n * `substitutions`) using the given `translations`.\n *\n * The tagged-string is parsed to extract its `messageId` which is used to find an appropriate\n * `ParsedTranslation`. If this doesn't match and there are legacy ids then try matching a\n * translation using those.\n *\n * If one is found then it is used to translate the message into a new set of `messageParts` and\n * `substitutions`.\n * The translation may reorder (or remove) substitutions as appropriate.\n *\n * If there is no translation with a matching message id then an error is thrown.\n * If a translation contains a placeholder that is not found in the message being translated then an\n * error is thrown.\n */\nexport function translate(\n    translations: Record<string, ParsedTranslation>, messageParts: TemplateStringsArray,\n    substitutions: readonly any[]): [TemplateStringsArray, readonly any[]] {\n  const message = parseMessage(messageParts, substitutions);\n  // Look up the translation using the messageId, and then the legacyId if available.\n  let translation = translations[message.id];\n  // If the messageId did not match a translation, try matching the legacy ids instead\n  if (message.legacyIds !== undefined) {\n    for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {\n      translation = translations[message.legacyIds[i]];\n    }\n  }\n  if (translation === undefined) {\n    throw new MissingTranslationError(message);\n  }\n  return [\n    translation.messageParts, translation.placeholderNames.map(placeholder => {\n      if (message.substitutions.hasOwnProperty(placeholder)) {\n        return message.substitutions[placeholder];\n      } else {\n        throw new Error(\n            `There is a placeholder name mismatch with the translation provided for the message ${\n                describeMessage(message)}.\\n` +\n            `The translation contains a placeholder with name ${\n                placeholder}, which does not exist in the message.`);\n      }\n    })\n  ];\n}\n\n/**\n * Parse the `messageParts` and `placeholderNames` out of a target `message`.\n *\n * Used by `loadTranslations()` to convert target message strings into a structure that is more\n * appropriate for doing translation.\n *\n * @param message the message to be parsed.\n */\nexport function parseTranslation(messageString: TargetMessage): ParsedTranslation {\n  const parts = messageString.split(/{\\$([^}]*)}/);\n  const messageParts = [parts[0]];\n  const placeholderNames: string[] = [];\n  for (let i = 1; i < parts.length - 1; i += 2) {\n    placeholderNames.push(parts[i]);\n    messageParts.push(`${parts[i + 1]}`);\n  }\n  const rawMessageParts =\n      messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\\\' + part : part);\n  return {\n    text: messageString,\n    messageParts: makeTemplateObject(messageParts, rawMessageParts),\n    placeholderNames,\n  };\n}\n\n/**\n * Create a `ParsedTranslation` from a set of `messageParts` and `placeholderNames`.\n *\n * @param messageParts The message parts to appear in the ParsedTranslation.\n * @param placeholderNames The names of the placeholders to intersperse between the `messageParts`.\n */\nexport function makeParsedTranslation(\n    messageParts: string[], placeholderNames: string[] = []): ParsedTranslation {\n  let messageString = messageParts[0];\n  for (let i = 0; i < placeholderNames.length - 1; i++) {\n    messageString += `{$${placeholderNames[i]}}${messageParts[i + 1]}`;\n  }\n  return {\n    text: messageString,\n    messageParts: makeTemplateObject(messageParts, messageParts),\n    placeholderNames\n  };\n}\n\n/**\n * Create the specialized array that is passed to tagged-string tag functions.\n *\n * @param cooked The message parts with their escape codes processed.\n * @param raw The message parts with their escaped codes as-is.\n */\nexport function makeTemplateObject(cooked: string[], raw: string[]): TemplateStringsArray {\n  Object.defineProperty(cooked, 'raw', {value: raw});\n  return cooked as any;\n}\n\n\nfunction describeMessage(message: ParsedMessage): string {\n  const meaningString = message.meaning && ` - \"${message.meaning}\"`;\n  const legacy = message.legacyIds && message.legacyIds.length > 0 ?\n      ` [${message.legacyIds.map(l => `\"${l}\"`).join(', ')}]` :\n      '';\n  return `\"${message.id}\"${legacy} (\"${message.text}\"${meaningString})`;\n}"]}
/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

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

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -80,3 +80,3 @@ * License: MIT

*/
function parseMessage(messageParts, expressions) {
function parseMessage(messageParts, expressions, location) {
const substitutions = {};

@@ -97,8 +97,8 @@ const metadata = parseMetadata(messageParts[0], messageParts.raw[0]);

const messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');
const legacyIds = metadata.legacyIds.filter(id => id !== messageId);
const legacyIds = metadata.legacyIds && metadata.legacyIds.filter(id => id !== messageId);
return {
messageId,
id: messageId,
legacyIds,
substitutions,
messageString,
text: messageString,
meaning: metadata.meaning || '',

@@ -108,2 +108,3 @@ description: metadata.description || '',

placeholderNames,
location,
};

@@ -138,5 +139,5 @@ }

function parseMetadata(cooked, raw) {
const { text, block } = splitBlock(cooked, raw);
const { text: messageString, block } = splitBlock(cooked, raw);
if (block === undefined) {
return { text, meaning: undefined, description: undefined, id: undefined, legacyIds: [] };
return { text: messageString };
}

@@ -154,3 +155,3 @@ else {

}
return { text, meaning, description, id, legacyIds };
return { text: messageString, meaning, description, id, legacyIds };
}

@@ -254,6 +255,8 @@ }

// Look up the translation using the messageId, and then the legacyId if available.
let translation = translations[message.messageId];
let translation = translations[message.id];
// If the messageId did not match a translation, try matching the legacy ids instead
for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
if (message.legacyIds !== undefined) {
for (let i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
}
}

@@ -283,4 +286,4 @@ if (translation === undefined) {

*/
function parseTranslation(message) {
const parts = message.split(/{\$([^}]*)}/);
function parseTranslation(messageString) {
const parts = messageString.split(/{\$([^}]*)}/);
const messageParts = [parts[0]];

@@ -293,3 +296,7 @@ const placeholderNames = [];

const rawMessageParts = messageParts.map(part => part.charAt(0) === BLOCK_MARKER ? '\\' + part : part);
return { messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames };
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, rawMessageParts),
placeholderNames,
};
}

@@ -303,3 +310,11 @@ /**

function makeParsedTranslation(messageParts, placeholderNames = []) {
return { messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames };
let messageString = messageParts[0];
for (let i = 0; i < placeholderNames.length - 1; i++) {
messageString += `{$${placeholderNames[i]}}${messageParts[i + 1]}`;
}
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, messageParts),
placeholderNames
};
}

@@ -318,3 +333,6 @@ /**

const meaningString = message.meaning && ` - "${message.meaning}"`;
return `"${message.messageId}" ("${message.messageString}"${meaningString})`;
const legacy = message.legacyIds && message.legacyIds.length > 0 ?
` [${message.legacyIds.map(l => `"${l}"`).join(', ')}]` :
'';
return `"${message.id}"${legacy} ("${message.text}"${meaningString})`;
}

@@ -321,0 +339,0 @@

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

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

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

@@ -74,3 +74,3 @@ * License: MIT

*/
function parseMessage(messageParts, expressions) {
function parseMessage(messageParts, expressions, location) {
var substitutions = {};

@@ -91,8 +91,8 @@ var metadata = parseMetadata(messageParts[0], messageParts.raw[0]);

var messageId = metadata.id || computeMsgId(messageString, metadata.meaning || '');
var legacyIds = metadata.legacyIds.filter(function (id) { return id !== messageId; });
var legacyIds = metadata.legacyIds && metadata.legacyIds.filter(function (id) { return id !== messageId; });
return {
messageId: messageId,
id: messageId,
legacyIds: legacyIds,
substitutions: substitutions,
messageString: messageString,
text: messageString,
meaning: metadata.meaning || '',

@@ -102,2 +102,3 @@ description: metadata.description || '',

placeholderNames: placeholderNames,
location: location,
};

@@ -132,5 +133,5 @@ }

function parseMetadata(cooked, raw) {
var _a = splitBlock(cooked, raw), text = _a.text, block = _a.block;
var _a = splitBlock(cooked, raw), messageString = _a.text, block = _a.block;
if (block === undefined) {
return { text: text, meaning: undefined, description: undefined, id: undefined, legacyIds: [] };
return { text: messageString };
}

@@ -148,3 +149,3 @@ else {

}
return { text: text, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
return { text: messageString, meaning: meaning, description: description, id: id, legacyIds: legacyIds };
}

@@ -244,6 +245,8 @@ }

// Look up the translation using the messageId, and then the legacyId if available.
var translation = translations[message.messageId];
var translation = translations[message.id];
// If the messageId did not match a translation, try matching the legacy ids instead
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
if (message.legacyIds !== undefined) {
for (var i = 0; i < message.legacyIds.length && translation === undefined; i++) {
translation = translations[message.legacyIds[i]];
}
}

@@ -273,4 +276,4 @@ if (translation === undefined) {

*/
function parseTranslation(message) {
var parts = message.split(/{\$([^}]*)}/);
function parseTranslation(messageString) {
var parts = messageString.split(/{\$([^}]*)}/);
var messageParts = [parts[0]];

@@ -283,3 +286,7 @@ var placeholderNames = [];

var rawMessageParts = messageParts.map(function (part) { return part.charAt(0) === BLOCK_MARKER ? '\\' + part : part; });
return { messageParts: makeTemplateObject(messageParts, rawMessageParts), placeholderNames: placeholderNames };
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, rawMessageParts),
placeholderNames: placeholderNames,
};
}

@@ -294,3 +301,11 @@ /**

if (placeholderNames === void 0) { placeholderNames = []; }
return { messageParts: makeTemplateObject(messageParts, messageParts), placeholderNames: placeholderNames };
var messageString = messageParts[0];
for (var i = 0; i < placeholderNames.length - 1; i++) {
messageString += "{$" + placeholderNames[i] + "}" + messageParts[i + 1];
}
return {
text: messageString,
messageParts: makeTemplateObject(messageParts, messageParts),
placeholderNames: placeholderNames
};
}

@@ -309,3 +324,6 @@ /**

var meaningString = message.meaning && " - \"" + message.meaning + "\"";
return "\"" + message.messageId + "\" (\"" + message.messageString + "\"" + meaningString + ")";
var legacy = message.legacyIds && message.legacyIds.length > 0 ?
" [" + message.legacyIds.map(function (l) { return "\"" + l + "\""; }).join(', ') + "]" :
'';
return "\"" + message.id + "\"" + legacy + " (\"" + message.text + "\"" + meaningString + ")";
}

@@ -312,0 +330,0 @@

/**
* @license Angular v10.0.0-next.3
* @license Angular v10.0.0-next.4
* (c) 2010-2020 Google LLC. https://angular.io/

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

{
"name": "@angular/localize",
"version": "10.0.0-next.3",
"version": "10.0.0-next.4",
"description": "Angular - library for localizing messages",

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

@@ -8,2 +8,2 @@ /**

*/
export { computeMsgId as ɵcomputeMsgId, findEndOfBlock as ɵfindEndOfBlock, isMissingTranslationError as ɵisMissingTranslationError, makeParsedTranslation as ɵmakeParsedTranslation, makeTemplateObject as ɵmakeTemplateObject, MessageId as ɵMessageId, MissingTranslationError as ɵMissingTranslationError, ParsedMessage as ɵParsedMessage, ParsedTranslation as ɵParsedTranslation, ParsedTranslations as ɵParsedTranslations, parseMessage as ɵparseMessage, parseMetadata as ɵparseMetadata, parseTranslation as ɵparseTranslation, SourceMessage as ɵSourceMessage, splitBlock as ɵsplitBlock, TargetMessage as ɵTargetMessage, translate as ɵtranslate } from './src/utils';
export { computeMsgId as ɵcomputeMsgId, findEndOfBlock as ɵfindEndOfBlock, isMissingTranslationError as ɵisMissingTranslationError, makeParsedTranslation as ɵmakeParsedTranslation, makeTemplateObject as ɵmakeTemplateObject, MessageId as ɵMessageId, MissingTranslationError as ɵMissingTranslationError, ParsedMessage as ɵParsedMessage, ParsedTranslation as ɵParsedTranslation, ParsedTranslations as ɵParsedTranslations, parseMessage as ɵparseMessage, parseMetadata as ɵparseMetadata, parseTranslation as ɵparseTranslation, SourceLocation as ɵSourceLocation, SourceMessage as ɵSourceMessage, splitBlock as ɵsplitBlock, TargetMessage as ɵTargetMessage, translate as ɵtranslate } from './src/utils';
#!/usr/bin/env node
/// <amd-module name="@angular/localize/src/tools/src/translate/main" />
import { Diagnostics } from '../diagnostics';
import { MissingTranslationStrategy } from '../source_file_utils';
import { OutputPathFn } from './output_path';
import { MissingTranslationStrategy } from './source_files/source_file_utils';
import { Diagnostics } from '../diagnostics';
export interface TranslateFilesOptions {

@@ -7,0 +7,0 @@ /**

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

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/main", ["require", "exports", "glob", "path", "yargs", "@angular/localize/src/tools/src/translate/asset_files/asset_translation_handler", "@angular/localize/src/tools/src/translate/output_path", "@angular/localize/src/tools/src/translate/source_files/source_file_translation_handler", "@angular/localize/src/tools/src/translate/translation_files/translation_loader", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser", "@angular/localize/src/tools/src/translate/translator", "@angular/localize/src/tools/src/diagnostics"], factory);
define("@angular/localize/src/tools/src/translate/main", ["require", "exports", "glob", "path", "yargs", "@angular/localize/src/tools/src/diagnostics", "@angular/localize/src/tools/src/translate/asset_files/asset_translation_handler", "@angular/localize/src/tools/src/translate/output_path", "@angular/localize/src/tools/src/translate/source_files/source_file_translation_handler", "@angular/localize/src/tools/src/translate/translation_files/translation_loader", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/simple_json_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff1_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xliff2_translation_parser", "@angular/localize/src/tools/src/translate/translation_files/translation_parsers/xtb_translation_parser", "@angular/localize/src/tools/src/translate/translator"], factory);
}

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

var yargs = require("yargs");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
var asset_translation_handler_1 = require("@angular/localize/src/tools/src/translate/asset_files/asset_translation_handler");

@@ -34,3 +35,2 @@ var output_path_1 = require("@angular/localize/src/tools/src/translate/output_path");

var translator_1 = require("@angular/localize/src/tools/src/translate/translator");
var diagnostics_1 = require("@angular/localize/src/tools/src/diagnostics");
if (require.main === module) {

@@ -118,2 +118,2 @@ var args = process.argv.slice(2);

});
//# 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          .strict()\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({\n    sourceRootPath,\n    sourceFilePaths,\n    translationFilePaths,\n    translationFileLocales,\n    outputPathFn,\n    diagnostics,\n    missingTranslation,\n    sourceLocale\n  });\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({\n  sourceRootPath,\n  sourceFilePaths,\n  translationFilePaths,\n  translationFileLocales,\n  outputPathFn,\n  diagnostics,\n  missingTranslation,\n  sourceLocale\n}: 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"]}
//# 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 {Diagnostics} from '../diagnostics';\nimport {MissingTranslationStrategy} from '../source_file_utils';\nimport {AssetTranslationHandler} from './asset_files/asset_translation_handler';\nimport {getOutputPathFn, OutputPathFn} from './output_path';\nimport {SourceFileTranslationHandler} from './source_files/source_file_translation_handler';\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';\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          .strict()\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({\n    sourceRootPath,\n    sourceFilePaths,\n    translationFilePaths,\n    translationFileLocales,\n    outputPathFn,\n    diagnostics,\n    missingTranslation,\n    sourceLocale\n  });\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({\n  sourceRootPath,\n  sourceFilePaths,\n  translationFilePaths,\n  translationFileLocales,\n  outputPathFn,\n  diagnostics,\n  missingTranslation,\n  sourceLocale\n}: 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"]}

@@ -12,3 +12,3 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/source_files/es2015_translate_plugin" />

import { Diagnostics } from '../../diagnostics';
import { TranslatePluginOptions } from './source_file_utils';
import { TranslatePluginOptions } from '../../source_file_utils';
export declare function makeEs2015TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions): PluginObj;

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

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/source_files/es2015_translate_plugin", ["require", "exports", "@angular/localize/src/tools/src/translate/source_files/source_file_utils"], factory);
define("@angular/localize/src/tools/src/translate/source_files/es2015_translate_plugin", ["require", "exports", "@angular/localize/src/tools/src/source_file_utils"], factory);
}

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

Object.defineProperty(exports, "__esModule", { value: true });
var source_file_utils_1 = require("@angular/localize/src/tools/src/translate/source_files/source_file_utils");
var source_file_utils_1 = require("@angular/localize/src/tools/src/source_file_utils");
function makeEs2015TranslatePlugin(diagnostics, translations, _a) {

@@ -42,2 +42,2 @@ var _b = _a === void 0 ? {} : _a, _c = _b.missingTranslation, missingTranslation = _c === void 0 ? 'error' : _c, _d = _b.localizeName, localizeName = _d === void 0 ? '$localize' : _d;

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFhQSw4R0FBMkw7SUFFM0wsU0FBZ0IseUJBQXlCLENBQ3JDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1Asd0JBQXdCLEVBQXhCLFVBQXlCLElBQXdDO29CQUMvRCxJQUFJO3dCQUNGLElBQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7d0JBQzVCLElBQUksOEJBQVUsQ0FBQyxHQUFHLEVBQUUsWUFBWSxDQUFDLEVBQUU7NEJBQ2pDLElBQU0sWUFBWSxHQUFHLHlEQUFxQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDOzRCQUNuRixJQUFNLFVBQVUsR0FBRyw2QkFBUyxDQUN4QixXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQ3BFLGtCQUFrQixDQUFDLENBQUM7NEJBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsNENBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzFFO3FCQUNGO29CQUFDLE9BQU8sQ0FBQyxFQUFFO3dCQUNWLElBQUkscUNBQWlCLENBQUMsQ0FBQyxDQUFDLEVBQUU7NEJBQ3hCLCtFQUErRTs0QkFDL0UsOEVBQThFOzRCQUM5RSwrQ0FBK0M7NEJBQy9DLE1BQU0sdUNBQW1CLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO3lCQUNwQztxQkFDRjtnQkFDSCxDQUFDO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQTNCRCw4REEyQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplJztcbmltcG9ydCB7Tm9kZVBhdGgsIFBsdWdpbk9ian0gZnJvbSAnQGJhYmVsL2NvcmUnO1xuaW1wb3J0IHtUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb259IGZyb20gJ0BiYWJlbC90eXBlcyc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcblxuaW1wb3J0IHtidWlsZENvZGVGcmFtZUVycm9yLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0xvY2FsaXplLCB0cmFuc2xhdGUsIFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21UZW1wbGF0ZUxpdGVyYWx9IGZyb20gJy4vc291cmNlX2ZpbGVfdXRpbHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gbWFrZUVzMjAxNVRyYW5zbGF0ZVBsdWdpbihcbiAgICBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9uczogUmVjb3JkPHN0cmluZywgybVQYXJzZWRUcmFuc2xhdGlvbj4sXG4gICAge21pc3NpbmdUcmFuc2xhdGlvbiA9ICdlcnJvcicsIGxvY2FsaXplTmFtZSA9ICckbG9jYWxpemUnfTogVHJhbnNsYXRlUGx1Z2luT3B0aW9ucyA9IHt9KTpcbiAgICBQbHVnaW5PYmoge1xuICByZXR1cm4ge1xuICAgIHZpc2l0b3I6IHtcbiAgICAgIFRhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbihwYXRoOiBOb2RlUGF0aDxUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgdGFnID0gcGF0aC5nZXQoJ3RhZycpO1xuICAgICAgICAgIGlmIChpc0xvY2FsaXplKHRhZywgbG9jYWxpemVOYW1lKSkge1xuICAgICAgICAgICAgY29uc3QgbWVzc2FnZVBhcnRzID0gdW53cmFwTWVzc2FnZVBhcnRzRnJvbVRlbXBsYXRlTGl0ZXJhbChwYXRoLm5vZGUucXVhc2kucXVhc2lzKTtcbiAgICAgICAgICAgIGNvbnN0IHRyYW5zbGF0ZWQgPSB0cmFuc2xhdGUoXG4gICAgICAgICAgICAgICAgZGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9ucywgbWVzc2FnZVBhcnRzLCBwYXRoLm5vZGUucXVhc2kuZXhwcmVzc2lvbnMsXG4gICAgICAgICAgICAgICAgbWlzc2luZ1RyYW5zbGF0aW9uKTtcbiAgICAgICAgICAgIHBhdGgucmVwbGFjZVdpdGgoYnVpbGRMb2NhbGl6ZVJlcGxhY2VtZW50KHRyYW5zbGF0ZWRbMF0sIHRyYW5zbGF0ZWRbMV0pKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICBpZiAoaXNCYWJlbFBhcnNlRXJyb3IoZSkpIHtcbiAgICAgICAgICAgIC8vIElmIHdlIGdldCBhIEJhYmVsUGFyc2VFcnJvciBoZXJlIHRoZW4gc29tZXRoaW5nIHdlbnQgd3Jvbmcgd2l0aCBCYWJlbCBpdHNlbGZcbiAgICAgICAgICAgIC8vIHNpbmNlIHRoZXJlIG11c3QgYmUgc29tZXRoaW5nIHdyb25nIHdpdGggdGhlIHN0cnVjdHVyZSBvZiB0aGUgQVNUIGdlbmVyYXRlZFxuICAgICAgICAgICAgLy8gYnkgQmFiZWwgcGFyc2luZyBhIFRhZ2dlZFRlbXBsYXRlRXhwcmVzc2lvbi5cbiAgICAgICAgICAgIHRocm93IGJ1aWxkQ29kZUZyYW1lRXJyb3IocGF0aCwgZSk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXMyMDE1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFhQSx1RkFBK0w7SUFFL0wsU0FBZ0IseUJBQXlCLENBQ3JDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1Asd0JBQXdCLEVBQXhCLFVBQXlCLElBQXdDO29CQUMvRCxJQUFJO3dCQUNGLElBQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7d0JBQzVCLElBQUksOEJBQVUsQ0FBQyxHQUFHLEVBQUUsWUFBWSxDQUFDLEVBQUU7NEJBQ2pDLElBQU0sWUFBWSxHQUFHLHlEQUFxQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDOzRCQUNuRixJQUFNLFVBQVUsR0FBRyw2QkFBUyxDQUN4QixXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQ3BFLGtCQUFrQixDQUFDLENBQUM7NEJBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsNENBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzFFO3FCQUNGO29CQUFDLE9BQU8sQ0FBQyxFQUFFO3dCQUNWLElBQUkscUNBQWlCLENBQUMsQ0FBQyxDQUFDLEVBQUU7NEJBQ3hCLCtFQUErRTs0QkFDL0UsOEVBQThFOzRCQUM5RSwrQ0FBK0M7NEJBQy9DLE1BQU0sdUNBQW1CLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO3lCQUNwQztxQkFDRjtnQkFDSCxDQUFDO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQTNCRCw4REEyQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplJztcbmltcG9ydCB7Tm9kZVBhdGgsIFBsdWdpbk9ian0gZnJvbSAnQGJhYmVsL2NvcmUnO1xuaW1wb3J0IHtUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb259IGZyb20gJ0BiYWJlbC90eXBlcyc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcblxuaW1wb3J0IHtidWlsZENvZGVGcmFtZUVycm9yLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0xvY2FsaXplLCB0cmFuc2xhdGUsIFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21UZW1wbGF0ZUxpdGVyYWx9IGZyb20gJy4uLy4uL3NvdXJjZV9maWxlX3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFczIwMTVUcmFuc2xhdGVQbHVnaW4oXG4gICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnM6IFJlY29yZDxzdHJpbmcsIMm1UGFyc2VkVHJhbnNsYXRpb24+LFxuICAgIHttaXNzaW5nVHJhbnNsYXRpb24gPSAnZXJyb3InLCBsb2NhbGl6ZU5hbWUgPSAnJGxvY2FsaXplJ306IFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMgPSB7fSk6XG4gICAgUGx1Z2luT2JqIHtcbiAgcmV0dXJuIHtcbiAgICB2aXNpdG9yOiB7XG4gICAgICBUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24ocGF0aDogTm9kZVBhdGg8VGFnZ2VkVGVtcGxhdGVFeHByZXNzaW9uPikge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IHRhZyA9IHBhdGguZ2V0KCd0YWcnKTtcbiAgICAgICAgICBpZiAoaXNMb2NhbGl6ZSh0YWcsIGxvY2FsaXplTmFtZSkpIHtcbiAgICAgICAgICAgIGNvbnN0IG1lc3NhZ2VQYXJ0cyA9IHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21UZW1wbGF0ZUxpdGVyYWwocGF0aC5ub2RlLnF1YXNpLnF1YXNpcyk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID0gdHJhbnNsYXRlKFxuICAgICAgICAgICAgICAgIGRpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnMsIG1lc3NhZ2VQYXJ0cywgcGF0aC5ub2RlLnF1YXNpLmV4cHJlc3Npb25zLFxuICAgICAgICAgICAgICAgIG1pc3NpbmdUcmFuc2xhdGlvbik7XG4gICAgICAgICAgICBwYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICAvLyBJZiB3ZSBnZXQgYSBCYWJlbFBhcnNlRXJyb3IgaGVyZSB0aGVuIHNvbWV0aGluZyB3ZW50IHdyb25nIHdpdGggQmFiZWwgaXRzZWxmXG4gICAgICAgICAgICAvLyBzaW5jZSB0aGVyZSBtdXN0IGJlIHNvbWV0aGluZyB3cm9uZyB3aXRoIHRoZSBzdHJ1Y3R1cmUgb2YgdGhlIEFTVCBnZW5lcmF0ZWRcbiAgICAgICAgICAgIC8vIGJ5IEJhYmVsIHBhcnNpbmcgYSBUYWdnZWRUZW1wbGF0ZUV4cHJlc3Npb24uXG4gICAgICAgICAgICB0aHJvdyBidWlsZENvZGVGcmFtZUVycm9yKHBhdGgsIGUpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfTtcbn1cbiJdfQ==

@@ -12,3 +12,3 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/source_files/es5_translate_plugin" />

import { Diagnostics } from '../../diagnostics';
import { TranslatePluginOptions } from './source_file_utils';
import { TranslatePluginOptions } from '../../source_file_utils';
export declare function makeEs5TranslatePlugin(diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>, { missingTranslation, localizeName }?: TranslatePluginOptions): PluginObj;

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

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/source_files/es5_translate_plugin", ["require", "exports", "@angular/localize/src/tools/src/translate/source_files/source_file_utils"], factory);
define("@angular/localize/src/tools/src/translate/source_files/es5_translate_plugin", ["require", "exports", "@angular/localize/src/tools/src/source_file_utils"], factory);
}

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

Object.defineProperty(exports, "__esModule", { value: true });
var source_file_utils_1 = require("@angular/localize/src/tools/src/translate/source_files/source_file_utils");
var source_file_utils_1 = require("@angular/localize/src/tools/src/source_file_utils");
function makeEs5TranslatePlugin(diagnostics, translations, _a) {

@@ -40,2 +40,2 @@ var _b = _a === void 0 ? {} : _a, _c = _b.missingTranslation, missingTranslation = _c === void 0 ? 'error' : _c, _d = _b.localizeName, localizeName = _d === void 0 ? '$localize' : _d;

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFhQSw4R0FBNk47SUFFN04sU0FBZ0Isc0JBQXNCLENBQ2xDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1AsY0FBYyxFQUFkLFVBQWUsUUFBa0M7b0JBQy9DLElBQUk7d0JBQ0YsSUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDMUMsSUFBSSw4QkFBVSxDQUFDLFVBQVUsRUFBRSxZQUFZLENBQUMsRUFBRTs0QkFDeEMsSUFBTSxZQUFZLEdBQUcsc0RBQWtDLENBQUMsUUFBUSxDQUFDLENBQUM7NEJBQ2xFLElBQU0sV0FBVyxHQUFHLHVEQUFtQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQzs0QkFDdkUsSUFBTSxVQUFVLEdBQ1osNkJBQVMsQ0FBQyxXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzs0QkFDeEYsUUFBUSxDQUFDLFdBQVcsQ0FBQyw0Q0FBd0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDOUU7cUJBQ0Y7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsSUFBSSxxQ0FBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRTs0QkFDeEIsV0FBVyxDQUFDLEtBQUssQ0FBQyx1Q0FBbUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDckQ7cUJBQ0Y7Z0JBQ0gsQ0FBQzthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUF4QkQsd0RBd0JDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtVBhcnNlZFRyYW5zbGF0aW9ufSBmcm9tICdAYW5ndWxhci9sb2NhbGl6ZSc7XG5pbXBvcnQge05vZGVQYXRoLCBQbHVnaW5PYmp9IGZyb20gJ0BiYWJlbC9jb3JlJztcbmltcG9ydCB7Q2FsbEV4cHJlc3Npb259IGZyb20gJ0BiYWJlbC90eXBlcyc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcblxuaW1wb3J0IHtidWlsZENvZGVGcmFtZUVycm9yLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0xvY2FsaXplLCB0cmFuc2xhdGUsIFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21Mb2NhbGl6ZUNhbGwsIHVud3JhcFN1YnN0aXR1dGlvbnNGcm9tTG9jYWxpemVDYWxsfSBmcm9tICcuL3NvdXJjZV9maWxlX3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFczVUcmFuc2xhdGVQbHVnaW4oXG4gICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnM6IFJlY29yZDxzdHJpbmcsIMm1UGFyc2VkVHJhbnNsYXRpb24+LFxuICAgIHttaXNzaW5nVHJhbnNsYXRpb24gPSAnZXJyb3InLCBsb2NhbGl6ZU5hbWUgPSAnJGxvY2FsaXplJ306IFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMgPSB7fSk6XG4gICAgUGx1Z2luT2JqIHtcbiAgcmV0dXJuIHtcbiAgICB2aXNpdG9yOiB7XG4gICAgICBDYWxsRXhwcmVzc2lvbihjYWxsUGF0aDogTm9kZVBhdGg8Q2FsbEV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FsbGVlUGF0aCA9IGNhbGxQYXRoLmdldCgnY2FsbGVlJyk7XG4gICAgICAgICAgaWYgKGlzTG9jYWxpemUoY2FsbGVlUGF0aCwgbG9jYWxpemVOYW1lKSkge1xuICAgICAgICAgICAgY29uc3QgbWVzc2FnZVBhcnRzID0gdW53cmFwTWVzc2FnZVBhcnRzRnJvbUxvY2FsaXplQ2FsbChjYWxsUGF0aCk7XG4gICAgICAgICAgICBjb25zdCBleHByZXNzaW9ucyA9IHVud3JhcFN1YnN0aXR1dGlvbnNGcm9tTG9jYWxpemVDYWxsKGNhbGxQYXRoLm5vZGUpO1xuICAgICAgICAgICAgY29uc3QgdHJhbnNsYXRlZCA9XG4gICAgICAgICAgICAgICAgdHJhbnNsYXRlKGRpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnMsIG1lc3NhZ2VQYXJ0cywgZXhwcmVzc2lvbnMsIG1pc3NpbmdUcmFuc2xhdGlvbik7XG4gICAgICAgICAgICBjYWxsUGF0aC5yZXBsYWNlV2l0aChidWlsZExvY2FsaXplUmVwbGFjZW1lbnQodHJhbnNsYXRlZFswXSwgdHJhbnNsYXRlZFsxXSkpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgIGlmIChpc0JhYmVsUGFyc2VFcnJvcihlKSkge1xuICAgICAgICAgICAgZGlhZ25vc3RpY3MuZXJyb3IoYnVpbGRDb2RlRnJhbWVFcnJvcihjYWxsUGF0aCwgZSkpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFhQSx1RkFBaU87SUFFak8sU0FBZ0Isc0JBQXNCLENBQ2xDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1AsY0FBYyxFQUFkLFVBQWUsUUFBa0M7b0JBQy9DLElBQUk7d0JBQ0YsSUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDMUMsSUFBSSw4QkFBVSxDQUFDLFVBQVUsRUFBRSxZQUFZLENBQUMsRUFBRTs0QkFDeEMsSUFBTSxZQUFZLEdBQUcsc0RBQWtDLENBQUMsUUFBUSxDQUFDLENBQUM7NEJBQ2xFLElBQU0sV0FBVyxHQUFHLHVEQUFtQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQzs0QkFDdkUsSUFBTSxVQUFVLEdBQ1osNkJBQVMsQ0FBQyxXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzs0QkFDeEYsUUFBUSxDQUFDLFdBQVcsQ0FBQyw0Q0FBd0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDOUU7cUJBQ0Y7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsSUFBSSxxQ0FBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRTs0QkFDeEIsV0FBVyxDQUFDLEtBQUssQ0FBQyx1Q0FBbUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDckQ7cUJBQ0Y7Z0JBQ0gsQ0FBQzthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUF4QkQsd0RBd0JDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtVBhcnNlZFRyYW5zbGF0aW9ufSBmcm9tICdAYW5ndWxhci9sb2NhbGl6ZSc7XG5pbXBvcnQge05vZGVQYXRoLCBQbHVnaW5PYmp9IGZyb20gJ0BiYWJlbC9jb3JlJztcbmltcG9ydCB7Q2FsbEV4cHJlc3Npb259IGZyb20gJ0BiYWJlbC90eXBlcyc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcblxuaW1wb3J0IHtidWlsZENvZGVGcmFtZUVycm9yLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0xvY2FsaXplLCB0cmFuc2xhdGUsIFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21Mb2NhbGl6ZUNhbGwsIHVud3JhcFN1YnN0aXR1dGlvbnNGcm9tTG9jYWxpemVDYWxsfSBmcm9tICcuLi8uLi9zb3VyY2VfZmlsZV91dGlscyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlRXM1VHJhbnNsYXRlUGx1Z2luKFxuICAgIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcywgdHJhbnNsYXRpb25zOiBSZWNvcmQ8c3RyaW5nLCDJtVBhcnNlZFRyYW5zbGF0aW9uPixcbiAgICB7bWlzc2luZ1RyYW5zbGF0aW9uID0gJ2Vycm9yJywgbG9jYWxpemVOYW1lID0gJyRsb2NhbGl6ZSd9OiBUcmFuc2xhdGVQbHVnaW5PcHRpb25zID0ge30pOlxuICAgIFBsdWdpbk9iaiB7XG4gIHJldHVybiB7XG4gICAgdmlzaXRvcjoge1xuICAgICAgQ2FsbEV4cHJlc3Npb24oY2FsbFBhdGg6IE5vZGVQYXRoPENhbGxFeHByZXNzaW9uPikge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IGNhbGxlZVBhdGggPSBjYWxsUGF0aC5nZXQoJ2NhbGxlZScpO1xuICAgICAgICAgIGlmIChpc0xvY2FsaXplKGNhbGxlZVBhdGgsIGxvY2FsaXplTmFtZSkpIHtcbiAgICAgICAgICAgIGNvbnN0IG1lc3NhZ2VQYXJ0cyA9IHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21Mb2NhbGl6ZUNhbGwoY2FsbFBhdGgpO1xuICAgICAgICAgICAgY29uc3QgZXhwcmVzc2lvbnMgPSB1bndyYXBTdWJzdGl0dXRpb25zRnJvbUxvY2FsaXplQ2FsbChjYWxsUGF0aC5ub2RlKTtcbiAgICAgICAgICAgIGNvbnN0IHRyYW5zbGF0ZWQgPVxuICAgICAgICAgICAgICAgIHRyYW5zbGF0ZShkaWFnbm9zdGljcywgdHJhbnNsYXRpb25zLCBtZXNzYWdlUGFydHMsIGV4cHJlc3Npb25zLCBtaXNzaW5nVHJhbnNsYXRpb24pO1xuICAgICAgICAgICAgY2FsbFBhdGgucmVwbGFjZVdpdGgoYnVpbGRMb2NhbGl6ZVJlcGxhY2VtZW50KHRyYW5zbGF0ZWRbMF0sIHRyYW5zbGF0ZWRbMV0pKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICBpZiAoaXNCYWJlbFBhcnNlRXJyb3IoZSkpIHtcbiAgICAgICAgICAgIGRpYWdub3N0aWNzLmVycm9yKGJ1aWxkQ29kZUZyYW1lRXJyb3IoY2FsbFBhdGgsIGUpKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH07XG59XG4iXX0=

@@ -10,3 +10,3 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/source_files/locale_plugin" />

import { PluginObj } from '@babel/core';
import { TranslatePluginOptions } from './source_file_utils';
import { TranslatePluginOptions } from '../../source_file_utils';
/**

@@ -13,0 +13,0 @@ * This Babel plugin will replace the following code forms with a string literal containing the

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

else if (typeof define === "function" && define.amd) {
define("@angular/localize/src/tools/src/translate/source_files/locale_plugin", ["require", "exports", "@babel/types", "@angular/localize/src/tools/src/translate/source_files/source_file_utils"], factory);
define("@angular/localize/src/tools/src/translate/source_files/locale_plugin", ["require", "exports", "@babel/types", "@angular/localize/src/tools/src/source_file_utils"], factory);
}

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

var types_1 = require("@babel/types");
var source_file_utils_1 = require("@angular/localize/src/tools/src/translate/source_files/source_file_utils");
var source_file_utils_1 = require("@angular/localize/src/tools/src/source_file_utils");
/**

@@ -95,2 +95,2 @@ * This Babel plugin will replace the following code forms with a string literal containing the

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"locale_plugin.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/locale_plugin.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 {NodePath, PluginObj} from '@babel/core';\nimport {MemberExpression, stringLiteral} from '@babel/types';\n\nimport {isLocalize, TranslatePluginOptions} from './source_file_utils';\n\n/**\n * This Babel plugin will replace the following code forms with a string literal containing the\n * given `locale`.\n *\n * * `$localize.locale`                                            -> `\"locale\"`\n * * `typeof $localize !== \"undefined\" && $localize.locale`        -> `\"locale\"`\n * * `xxx && typeof $localize !== \"undefined\" && $localize.locale` -> `\"xxx && locale\"`\n * * `$localize.locale || default`                                 -> `\"locale\" || default`\n *\n * @param locale The name of the locale to inline into the code.\n * @param options Additional options including the name of the `$localize` function.\n */\nexport function makeLocalePlugin(\n    locale: string, {localizeName = '$localize'}: TranslatePluginOptions = {}): PluginObj {\n  return {\n    visitor: {\n      MemberExpression(expression: NodePath<MemberExpression>) {\n        const obj = expression.get('object');\n        if (!isLocalize(obj, localizeName)) {\n          return;\n        }\n        const property = expression.get('property') as NodePath;\n        if (!property.isIdentifier({name: 'locale'})) {\n          return;\n        }\n        if (expression.parentPath.isAssignmentExpression() &&\n            expression.parentPath.get('left') === expression) {\n          return;\n        }\n        // Check for the `$localize.locale` being guarded by a check on the existence of\n        // `$localize`.\n        const parent = expression.parentPath;\n        if (parent.isLogicalExpression({operator: '&&'}) && parent.get('right') === expression) {\n          const left = parent.get('left');\n          if (isLocalizeGuard(left, localizeName)) {\n            // Replace `typeof $localize !== \"undefined\" && $localize.locale` with\n            // `$localize.locale`\n            parent.replaceWith(expression);\n          } else if (\n              left.isLogicalExpression({operator: '&&'}) &&\n              isLocalizeGuard(left.get('right'), localizeName)) {\n            // The `$localize` is part of a preceding logical AND.\n            // Replace XXX && typeof $localize !== \"undefined\" && $localize.locale` with `XXX &&\n            // $localize.locale`\n            left.replaceWith(left.get('left'));\n          }\n        }\n        // Replace the `$localize.locale` with the string literal\n        expression.replaceWith(stringLiteral(locale));\n      }\n    }\n  };\n}\n\n/**\n * Returns true if the expression one of:\n * * `typeof $localize !== \"undefined\"`\n * * `\"undefined\" !== typeof $localize`\n * * `typeof $localize != \"undefined\"`\n * * `\"undefined\" != typeof $localize`\n *\n * @param expression the expression to check\n * @param localizeName the name of the `$localize` symbol\n */\nfunction isLocalizeGuard(expression: NodePath, localizeName: string): boolean {\n  if (!expression.isBinaryExpression() ||\n      !(expression.node.operator === '!==' || expression.node.operator === '!=')) {\n    return false;\n  }\n  const left = expression.get('left');\n  const right = expression.get('right');\n\n  return (left.isUnaryExpression({operator: 'typeof'}) &&\n          isLocalize(left.get('argument'), localizeName) &&\n          right.isStringLiteral({value: 'undefined'})) ||\n      (right.isUnaryExpression({operator: 'typeof'}) &&\n       isLocalize(right.get('argument'), localizeName) &&\n       left.isStringLiteral({value: 'undefined'}));\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"locale_plugin.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/locale_plugin.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 {NodePath, PluginObj} from '@babel/core';\nimport {MemberExpression, stringLiteral} from '@babel/types';\n\nimport {isLocalize, TranslatePluginOptions} from '../../source_file_utils';\n\n/**\n * This Babel plugin will replace the following code forms with a string literal containing the\n * given `locale`.\n *\n * * `$localize.locale`                                            -> `\"locale\"`\n * * `typeof $localize !== \"undefined\" && $localize.locale`        -> `\"locale\"`\n * * `xxx && typeof $localize !== \"undefined\" && $localize.locale` -> `\"xxx && locale\"`\n * * `$localize.locale || default`                                 -> `\"locale\" || default`\n *\n * @param locale The name of the locale to inline into the code.\n * @param options Additional options including the name of the `$localize` function.\n */\nexport function makeLocalePlugin(\n    locale: string, {localizeName = '$localize'}: TranslatePluginOptions = {}): PluginObj {\n  return {\n    visitor: {\n      MemberExpression(expression: NodePath<MemberExpression>) {\n        const obj = expression.get('object');\n        if (!isLocalize(obj, localizeName)) {\n          return;\n        }\n        const property = expression.get('property') as NodePath;\n        if (!property.isIdentifier({name: 'locale'})) {\n          return;\n        }\n        if (expression.parentPath.isAssignmentExpression() &&\n            expression.parentPath.get('left') === expression) {\n          return;\n        }\n        // Check for the `$localize.locale` being guarded by a check on the existence of\n        // `$localize`.\n        const parent = expression.parentPath;\n        if (parent.isLogicalExpression({operator: '&&'}) && parent.get('right') === expression) {\n          const left = parent.get('left');\n          if (isLocalizeGuard(left, localizeName)) {\n            // Replace `typeof $localize !== \"undefined\" && $localize.locale` with\n            // `$localize.locale`\n            parent.replaceWith(expression);\n          } else if (\n              left.isLogicalExpression({operator: '&&'}) &&\n              isLocalizeGuard(left.get('right'), localizeName)) {\n            // The `$localize` is part of a preceding logical AND.\n            // Replace XXX && typeof $localize !== \"undefined\" && $localize.locale` with `XXX &&\n            // $localize.locale`\n            left.replaceWith(left.get('left'));\n          }\n        }\n        // Replace the `$localize.locale` with the string literal\n        expression.replaceWith(stringLiteral(locale));\n      }\n    }\n  };\n}\n\n/**\n * Returns true if the expression one of:\n * * `typeof $localize !== \"undefined\"`\n * * `\"undefined\" !== typeof $localize`\n * * `typeof $localize != \"undefined\"`\n * * `\"undefined\" != typeof $localize`\n *\n * @param expression the expression to check\n * @param localizeName the name of the `$localize` symbol\n */\nfunction isLocalizeGuard(expression: NodePath, localizeName: string): boolean {\n  if (!expression.isBinaryExpression() ||\n      !(expression.node.operator === '!==' || expression.node.operator === '!=')) {\n    return false;\n  }\n  const left = expression.get('left');\n  const right = expression.get('right');\n\n  return (left.isUnaryExpression({operator: 'typeof'}) &&\n          isLocalize(left.get('argument'), localizeName) &&\n          right.isStringLiteral({value: 'undefined'})) ||\n      (right.isUnaryExpression({operator: 'typeof'}) &&\n       isLocalize(right.get('argument'), localizeName) &&\n       left.isStringLiteral({value: 'undefined'}));\n}\n"]}
/// <amd-module name="@angular/localize/src/tools/src/translate/source_files/source_file_translation_handler" />
import { Diagnostics } from '../../diagnostics';
import { TranslatePluginOptions } from '../../source_file_utils';
import { OutputPathFn } from '../output_path';
import { TranslationBundle, TranslationHandler } from '../translator';
import { TranslatePluginOptions } from './source_file_utils';
/**

@@ -7,0 +7,0 @@ * Translate a file by inlining all messages tagged by `$localize` with the appropriate translated

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

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_translation_handler.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/source_file_translation_handler.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 {parseSync, transformFromAstSync} from '@babel/core';\nimport {File, Program} from '@babel/types';\nimport {extname, join} from 'path';\nimport {Diagnostics} from '../../diagnostics';\nimport {FileUtils} from '../../file_utils';\nimport {OutputPathFn} from '../output_path';\nimport {TranslationBundle, TranslationHandler} from '../translator';\nimport {makeEs2015TranslatePlugin} from './es2015_translate_plugin';\nimport {makeEs5TranslatePlugin} from './es5_translate_plugin';\nimport {makeLocalePlugin} from './locale_plugin';\nimport {TranslatePluginOptions} from './source_file_utils';\n\n/**\n * Translate a file by inlining all messages tagged by `$localize` with the appropriate translated\n * message.\n */\nexport class SourceFileTranslationHandler implements TranslationHandler {\n  private sourceLocaleOptions:\n      TranslatePluginOptions = {...this.translationOptions, missingTranslation: 'ignore'};\n  constructor(private translationOptions: TranslatePluginOptions = {}) {}\n\n  canTranslate(relativeFilePath: string, _contents: Buffer): boolean {\n    return extname(relativeFilePath) === '.js';\n  }\n\n  translate(\n      diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer,\n      outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void {\n    const sourceCode = contents.toString('utf8');\n    // A short-circuit check to avoid parsing the file into an AST if it does not contain any\n    // `$localize` identifiers.\n    if (!sourceCode.includes('$localize')) {\n      for (const translation of translations) {\n        FileUtils.writeFile(outputPathFn(translation.locale, relativeFilePath), contents);\n      }\n      if (sourceLocale !== undefined) {\n        FileUtils.writeFile(outputPathFn(sourceLocale, relativeFilePath), contents);\n      }\n    } else {\n      const ast = parseSync(sourceCode, {sourceRoot, filename: relativeFilePath});\n      if (!ast) {\n        diagnostics.error(`Unable to parse source file: ${join(sourceRoot, relativeFilePath)}`);\n        return;\n      }\n      // Output a translated copy of the file for each locale.\n      for (const translationBundle of translations) {\n        this.translateFile(\n            diagnostics, ast, translationBundle, sourceRoot, relativeFilePath, outputPathFn,\n            this.translationOptions);\n      }\n      if (sourceLocale !== undefined) {\n        // Also output a copy of the file for the source locale.\n        // There will be no translations - by definition - so we \"ignore\" `missingTranslations`.\n        this.translateFile(\n            diagnostics, ast, {locale: sourceLocale, translations: {}}, sourceRoot,\n            relativeFilePath, outputPathFn, this.sourceLocaleOptions);\n      }\n    }\n  }\n\n  private translateFile(\n      diagnostics: Diagnostics, ast: File|Program, translationBundle: TranslationBundle,\n      sourceRoot: string, filename: string, outputPathFn: OutputPathFn,\n      options: TranslatePluginOptions) {\n    const translated = transformFromAstSync(ast, undefined, {\n      compact: true,\n      generatorOpts: {minified: true},\n      plugins: [\n        makeLocalePlugin(translationBundle.locale),\n        makeEs2015TranslatePlugin(diagnostics, translationBundle.translations, options),\n        makeEs5TranslatePlugin(diagnostics, translationBundle.translations, options),\n      ],\n      filename,\n    });\n    if (translated && translated.code) {\n      FileUtils.writeFile(outputPathFn(translationBundle.locale, filename), translated.code);\n    } else {\n      diagnostics.error(`Unable to translate source file: ${join(sourceRoot, filename)}`);\n      return;\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_translation_handler.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/source_file_translation_handler.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 {parseSync, transformFromAstSync} from '@babel/core';\nimport {File, Program} from '@babel/types';\nimport {extname, join} from 'path';\nimport {Diagnostics} from '../../diagnostics';\nimport {FileUtils} from '../../file_utils';\nimport {TranslatePluginOptions} from '../../source_file_utils';\nimport {OutputPathFn} from '../output_path';\nimport {TranslationBundle, TranslationHandler} from '../translator';\nimport {makeEs2015TranslatePlugin} from './es2015_translate_plugin';\nimport {makeEs5TranslatePlugin} from './es5_translate_plugin';\nimport {makeLocalePlugin} from './locale_plugin';\n\n/**\n * Translate a file by inlining all messages tagged by `$localize` with the appropriate translated\n * message.\n */\nexport class SourceFileTranslationHandler implements TranslationHandler {\n  private sourceLocaleOptions:\n      TranslatePluginOptions = {...this.translationOptions, missingTranslation: 'ignore'};\n  constructor(private translationOptions: TranslatePluginOptions = {}) {}\n\n  canTranslate(relativeFilePath: string, _contents: Buffer): boolean {\n    return extname(relativeFilePath) === '.js';\n  }\n\n  translate(\n      diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer,\n      outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void {\n    const sourceCode = contents.toString('utf8');\n    // A short-circuit check to avoid parsing the file into an AST if it does not contain any\n    // `$localize` identifiers.\n    if (!sourceCode.includes('$localize')) {\n      for (const translation of translations) {\n        FileUtils.writeFile(outputPathFn(translation.locale, relativeFilePath), contents);\n      }\n      if (sourceLocale !== undefined) {\n        FileUtils.writeFile(outputPathFn(sourceLocale, relativeFilePath), contents);\n      }\n    } else {\n      const ast = parseSync(sourceCode, {sourceRoot, filename: relativeFilePath});\n      if (!ast) {\n        diagnostics.error(`Unable to parse source file: ${join(sourceRoot, relativeFilePath)}`);\n        return;\n      }\n      // Output a translated copy of the file for each locale.\n      for (const translationBundle of translations) {\n        this.translateFile(\n            diagnostics, ast, translationBundle, sourceRoot, relativeFilePath, outputPathFn,\n            this.translationOptions);\n      }\n      if (sourceLocale !== undefined) {\n        // Also output a copy of the file for the source locale.\n        // There will be no translations - by definition - so we \"ignore\" `missingTranslations`.\n        this.translateFile(\n            diagnostics, ast, {locale: sourceLocale, translations: {}}, sourceRoot,\n            relativeFilePath, outputPathFn, this.sourceLocaleOptions);\n      }\n    }\n  }\n\n  private translateFile(\n      diagnostics: Diagnostics, ast: File|Program, translationBundle: TranslationBundle,\n      sourceRoot: string, filename: string, outputPathFn: OutputPathFn,\n      options: TranslatePluginOptions) {\n    const translated = transformFromAstSync(ast, undefined, {\n      compact: true,\n      generatorOpts: {minified: true},\n      plugins: [\n        makeLocalePlugin(translationBundle.locale),\n        makeEs2015TranslatePlugin(diagnostics, translationBundle.translations, options),\n        makeEs5TranslatePlugin(diagnostics, translationBundle.translations, options),\n      ],\n      filename,\n    });\n    if (translated && translated.code) {\n      FileUtils.writeFile(outputPathFn(translationBundle.locale, filename), translated.code);\n    } else {\n      diagnostics.error(`Unable to translate source file: ${join(sourceRoot, filename)}`);\n      return;\n    }\n  }\n}\n"]}

@@ -22,2 +22,1 @@ /**

}
export declare function stripInterpolationMarkers(interpolation: string): string;

@@ -19,7 +19,3 @@ /**

Object.defineProperty(exports, "__esModule", { value: true });
function stripInterpolationMarkers(interpolation) {
return interpolation.replace(/^\{\{/, '').replace(/}}$/, '');
}
exports.stripInterpolationMarkers = stripInterpolationMarkers;
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZV9yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0aW9uX2ZpbGVzL21lc3NhZ2Vfc2VyaWFsaXphdGlvbi9tZXNzYWdlX3JlbmRlcmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBZ0JILFNBQWdCLHlCQUF5QixDQUFDLGFBQXFCO1FBQzdELE9BQU8sYUFBYSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRkQsOERBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgTWVzc2FnZVJlbmRlcmVyPFQ+IHtcbiAgbWVzc2FnZTogVDtcbiAgc3RhcnRSZW5kZXIoKTogdm9pZDtcbiAgZW5kUmVuZGVyKCk6IHZvaWQ7XG4gIHRleHQodGV4dDogc3RyaW5nKTogdm9pZDtcbiAgcGxhY2Vob2xkZXIobmFtZTogc3RyaW5nLCBib2R5OiBzdHJpbmd8dW5kZWZpbmVkKTogdm9pZDtcbiAgc3RhcnRQbGFjZWhvbGRlcihuYW1lOiBzdHJpbmcpOiB2b2lkO1xuICBjbG9zZVBsYWNlaG9sZGVyKG5hbWU6IHN0cmluZyk6IHZvaWQ7XG4gIHN0YXJ0Q29udGFpbmVyKCk6IHZvaWQ7XG4gIGNsb3NlQ29udGFpbmVyKCk6IHZvaWQ7XG4gIHN0YXJ0SWN1KCk6IHZvaWQ7XG4gIGVuZEljdSgpOiB2b2lkO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc3RyaXBJbnRlcnBvbGF0aW9uTWFya2VycyhpbnRlcnBvbGF0aW9uOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gaW50ZXJwb2xhdGlvbi5yZXBsYWNlKC9eXFx7XFx7LywgJycpLnJlcGxhY2UoL319JC8sICcnKTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZV9yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0aW9uX2ZpbGVzL21lc3NhZ2Vfc2VyaWFsaXphdGlvbi9tZXNzYWdlX3JlbmRlcmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IGludGVyZmFjZSBNZXNzYWdlUmVuZGVyZXI8VD4ge1xuICBtZXNzYWdlOiBUO1xuICBzdGFydFJlbmRlcigpOiB2b2lkO1xuICBlbmRSZW5kZXIoKTogdm9pZDtcbiAgdGV4dCh0ZXh0OiBzdHJpbmcpOiB2b2lkO1xuICBwbGFjZWhvbGRlcihuYW1lOiBzdHJpbmcsIGJvZHk6IHN0cmluZ3x1bmRlZmluZWQpOiB2b2lkO1xuICBzdGFydFBsYWNlaG9sZGVyKG5hbWU6IHN0cmluZyk6IHZvaWQ7XG4gIGNsb3NlUGxhY2Vob2xkZXIobmFtZTogc3RyaW5nKTogdm9pZDtcbiAgc3RhcnRDb250YWluZXIoKTogdm9pZDtcbiAgY2xvc2VDb250YWluZXIoKTogdm9pZDtcbiAgc3RhcnRJY3UoKTogdm9pZDtcbiAgZW5kSWN1KCk6IHZvaWQ7XG59XG4iXX0=

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

*/
export declare class SimpleJsonTranslationParser implements TranslationParser {
canParse(filePath: string, _contents: string): boolean;
parse(_filePath: string, contents: string): ParsedTranslationBundle;
export declare class SimpleJsonTranslationParser implements TranslationParser<Object> {
canParse(filePath: string, contents: string): Object | false;
parse(_filePath: string, contents: string, json?: Object): ParsedTranslationBundle;
}

@@ -38,7 +38,16 @@ (function (factory) {

}
SimpleJsonTranslationParser.prototype.canParse = function (filePath, _contents) {
return (path_1.extname(filePath) === '.json');
SimpleJsonTranslationParser.prototype.canParse = function (filePath, contents) {
if (path_1.extname(filePath) !== '.json') {
return false;
}
try {
var json = JSON.parse(contents);
return (typeof json.locale === 'string' && typeof json.translations === 'object') && json;
}
catch (_a) {
return false;
}
};
SimpleJsonTranslationParser.prototype.parse = function (_filePath, contents) {
var _a = JSON.parse(contents), parsedLocale = _a.locale, translations = _a.translations;
SimpleJsonTranslationParser.prototype.parse = function (_filePath, contents, json) {
var _a = json || JSON.parse(contents), parsedLocale = _a.locale, translations = _a.translations;
var parsedTranslations = {};

@@ -55,2 +64,2 @@ for (var messageId in translations) {

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlX2pzb25fdHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy9zaW1wbGVfanNvbl90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFBQTs7Ozs7O09BTUc7SUFDSCw4Q0FBb0Y7SUFDcEYsNkJBQTZCO0lBQzdCLDJFQUFpRDtJQUdqRDs7Ozs7Ozs7Ozs7O09BWUc7SUFDSDtRQUFBO1FBY0EsQ0FBQztRQWJDLDhDQUFRLEdBQVIsVUFBUyxRQUFnQixFQUFFLFNBQWlCO1lBQzFDLE9BQU8sQ0FBQyxjQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssT0FBTyxDQUFDLENBQUM7UUFDekMsQ0FBQztRQUVELDJDQUFLLEdBQUwsVUFBTSxTQUFpQixFQUFFLFFBQWdCO1lBQ2pDLElBQUEseUJBQTJELEVBQTFELHdCQUFvQixFQUFFLDhCQUFvQyxDQUFDO1lBQ2xFLElBQU0sa0JBQWtCLEdBQTJDLEVBQUUsQ0FBQztZQUN0RSxLQUFLLElBQU0sU0FBUyxJQUFJLFlBQVksRUFBRTtnQkFDcEMsSUFBTSxhQUFhLEdBQUcsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUM5QyxrQkFBa0IsQ0FBQyxTQUFTLENBQUMsR0FBRyw0QkFBaUIsQ0FBQyxhQUFhLENBQUMsQ0FBQzthQUNsRTtZQUNELE9BQU8sRUFBQyxNQUFNLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxXQUFXLEVBQUUsSUFBSSx5QkFBVyxFQUFFLEVBQUMsQ0FBQztRQUNsRyxDQUFDO1FBQ0gsa0NBQUM7SUFBRCxDQUFDLEFBZEQsSUFjQztJQWRZLGtFQUEyQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVNZXNzYWdlSWQsIMm1UGFyc2VkVHJhbnNsYXRpb24sIMm1cGFyc2VUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtleHRuYW1lfSBmcm9tICdwYXRoJztcbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uLy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7UGFyc2VkVHJhbnNsYXRpb25CdW5kbGUsIFRyYW5zbGF0aW9uUGFyc2VyfSBmcm9tICcuL3RyYW5zbGF0aW9uX3BhcnNlcic7XG5cbi8qKlxuICogQSB0cmFuc2xhdGlvbiBwYXJzZXIgdGhhdCBjYW4gcGFyc2UgSlNPTiB0aGF0IGhhcyB0aGUgZm9ybTpcbiAqXG4gKiBgYGBcbiAqIHtcbiAqICAgXCJsb2NhbGVcIjogXCIuLi5cIixcbiAqICAgXCJ0cmFuc2xhdGlvbnNcIjoge1xuICogICAgIFwibWVzc2FnZS1pZFwiOiBcIlRhcmdldCBtZXNzYWdlIHN0cmluZ1wiLFxuICogICAgIC4uLlxuICogICB9XG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFNpbXBsZUpzb25UcmFuc2xhdGlvblBhcnNlciBpbXBsZW1lbnRzIFRyYW5zbGF0aW9uUGFyc2VyIHtcbiAgY2FuUGFyc2UoZmlsZVBhdGg6IHN0cmluZywgX2NvbnRlbnRzOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gKGV4dG5hbWUoZmlsZVBhdGgpID09PSAnLmpzb24nKTtcbiAgfVxuXG4gIHBhcnNlKF9maWxlUGF0aDogc3RyaW5nLCBjb250ZW50czogc3RyaW5nKTogUGFyc2VkVHJhbnNsYXRpb25CdW5kbGUge1xuICAgIGNvbnN0IHtsb2NhbGU6IHBhcnNlZExvY2FsZSwgdHJhbnNsYXRpb25zfSA9IEpTT04ucGFyc2UoY29udGVudHMpO1xuICAgIGNvbnN0IHBhcnNlZFRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPiA9IHt9O1xuICAgIGZvciAoY29uc3QgbWVzc2FnZUlkIGluIHRyYW5zbGF0aW9ucykge1xuICAgICAgY29uc3QgdGFyZ2V0TWVzc2FnZSA9IHRyYW5zbGF0aW9uc1ttZXNzYWdlSWRdO1xuICAgICAgcGFyc2VkVHJhbnNsYXRpb25zW21lc3NhZ2VJZF0gPSDJtXBhcnNlVHJhbnNsYXRpb24odGFyZ2V0TWVzc2FnZSk7XG4gICAgfVxuICAgIHJldHVybiB7bG9jYWxlOiBwYXJzZWRMb2NhbGUsIHRyYW5zbGF0aW9uczogcGFyc2VkVHJhbnNsYXRpb25zLCBkaWFnbm9zdGljczogbmV3IERpYWdub3N0aWNzKCl9O1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlX2pzb25fdHJhbnNsYXRpb25fcGFyc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbG9jYWxpemUvc3JjL3Rvb2xzL3NyYy90cmFuc2xhdGUvdHJhbnNsYXRpb25fZmlsZXMvdHJhbnNsYXRpb25fcGFyc2Vycy9zaW1wbGVfanNvbl90cmFuc2xhdGlvbl9wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFBQTs7Ozs7O09BTUc7SUFDSCw4Q0FBb0Y7SUFDcEYsNkJBQTZCO0lBQzdCLDJFQUFpRDtJQUdqRDs7Ozs7Ozs7Ozs7O09BWUc7SUFDSDtRQUFBO1FBc0JBLENBQUM7UUFyQkMsOENBQVEsR0FBUixVQUFTLFFBQWdCLEVBQUUsUUFBZ0I7WUFDekMsSUFBSSxjQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssT0FBTyxFQUFFO2dCQUNqQyxPQUFPLEtBQUssQ0FBQzthQUNkO1lBQ0QsSUFBSTtnQkFDRixJQUFNLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUNsQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsTUFBTSxLQUFLLFFBQVEsSUFBSSxPQUFPLElBQUksQ0FBQyxZQUFZLEtBQUssUUFBUSxDQUFDLElBQUksSUFBSSxDQUFDO2FBQzNGO1lBQUMsV0FBTTtnQkFDTixPQUFPLEtBQUssQ0FBQzthQUNkO1FBQ0gsQ0FBQztRQUVELDJDQUFLLEdBQUwsVUFBTSxTQUFpQixFQUFFLFFBQWdCLEVBQUUsSUFBYTtZQUNoRCxJQUFBLGlDQUFtRSxFQUFsRSx3QkFBb0IsRUFBRSw4QkFBNEMsQ0FBQztZQUMxRSxJQUFNLGtCQUFrQixHQUEyQyxFQUFFLENBQUM7WUFDdEUsS0FBSyxJQUFNLFNBQVMsSUFBSSxZQUFZLEVBQUU7Z0JBQ3BDLElBQU0sYUFBYSxHQUFHLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDOUMsa0JBQWtCLENBQUMsU0FBUyxDQUFDLEdBQUcsNEJBQWlCLENBQUMsYUFBYSxDQUFDLENBQUM7YUFDbEU7WUFDRCxPQUFPLEVBQUMsTUFBTSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsV0FBVyxFQUFFLElBQUkseUJBQVcsRUFBRSxFQUFDLENBQUM7UUFDbEcsQ0FBQztRQUNILGtDQUFDO0lBQUQsQ0FBQyxBQXRCRCxJQXNCQztJQXRCWSxrRUFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uLCDJtXBhcnNlVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplJztcbmltcG9ydCB7ZXh0bmFtZX0gZnJvbSAncGF0aCc7XG5pbXBvcnQge0RpYWdub3N0aWNzfSBmcm9tICcuLi8uLi8uLi9kaWFnbm9zdGljcyc7XG5pbXBvcnQge1BhcnNlZFRyYW5zbGF0aW9uQnVuZGxlLCBUcmFuc2xhdGlvblBhcnNlcn0gZnJvbSAnLi90cmFuc2xhdGlvbl9wYXJzZXInO1xuXG4vKipcbiAqIEEgdHJhbnNsYXRpb24gcGFyc2VyIHRoYXQgY2FuIHBhcnNlIEpTT04gdGhhdCBoYXMgdGhlIGZvcm06XG4gKlxuICogYGBgXG4gKiB7XG4gKiAgIFwibG9jYWxlXCI6IFwiLi4uXCIsXG4gKiAgIFwidHJhbnNsYXRpb25zXCI6IHtcbiAqICAgICBcIm1lc3NhZ2UtaWRcIjogXCJUYXJnZXQgbWVzc2FnZSBzdHJpbmdcIixcbiAqICAgICAuLi5cbiAqICAgfVxuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW1wbGVKc29uVHJhbnNsYXRpb25QYXJzZXIgaW1wbGVtZW50cyBUcmFuc2xhdGlvblBhcnNlcjxPYmplY3Q+IHtcbiAgY2FuUGFyc2UoZmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IHN0cmluZyk6IE9iamVjdHxmYWxzZSB7XG4gICAgaWYgKGV4dG5hbWUoZmlsZVBhdGgpICE9PSAnLmpzb24nKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHRyeSB7XG4gICAgICBjb25zdCBqc29uID0gSlNPTi5wYXJzZShjb250ZW50cyk7XG4gICAgICByZXR1cm4gKHR5cGVvZiBqc29uLmxvY2FsZSA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIGpzb24udHJhbnNsYXRpb25zID09PSAnb2JqZWN0JykgJiYganNvbjtcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICBwYXJzZShfZmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IHN0cmluZywganNvbj86IE9iamVjdCk6IFBhcnNlZFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgICBjb25zdCB7bG9jYWxlOiBwYXJzZWRMb2NhbGUsIHRyYW5zbGF0aW9uc30gPSBqc29uIHx8IEpTT04ucGFyc2UoY29udGVudHMpO1xuICAgIGNvbnN0IHBhcnNlZFRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPiA9IHt9O1xuICAgIGZvciAoY29uc3QgbWVzc2FnZUlkIGluIHRyYW5zbGF0aW9ucykge1xuICAgICAgY29uc3QgdGFyZ2V0TWVzc2FnZSA9IHRyYW5zbGF0aW9uc1ttZXNzYWdlSWRdO1xuICAgICAgcGFyc2VkVHJhbnNsYXRpb25zW21lc3NhZ2VJZF0gPSDJtXBhcnNlVHJhbnNsYXRpb24odGFyZ2V0TWVzc2FnZSk7XG4gICAgfVxuICAgIHJldHVybiB7bG9jYWxlOiBwYXJzZWRMb2NhbGUsIHRyYW5zbGF0aW9uczogcGFyc2VkVHJhbnNsYXRpb25zLCBkaWFnbm9zdGljczogbmV3IERpYWdub3N0aWNzKCl9O1xuICB9XG59XG4iXX0=

@@ -27,2 +27,52 @@ /**

/**
* The location of the message
*/
export interface SourceLocation {
start: {
line: number;
column: number;
};
end: {
line: number;
column: number;
};
file: string;
}
/**
* Additional information that can be associated with a message.
*/
export interface MessageMetadata {
/**
* A human readable rendering of the message
*/
text: string;
/**
* A unique identifier for this message.
*/
id?: MessageId;
/**
* Legacy message ids, if provided.
*
* In legacy message formats the message id can only be computed directly from the original
* template source.
*
* Since this information is not available in `$localize` calls, the legacy message ids may be
* attached by the compiler to the `$localize` metablock so it can be used if needed at the point
* of translation if the translations are encoded using the legacy message id.
*/
legacyIds?: string[];
/**
* The meaning of the `message`, used to distinguish identical `messageString`s.
*/
meaning?: string;
/**
* The description of the `message`, used to aid translation.
*/
description?: string;
/**
* The location of the message in the source.
*/
location?: SourceLocation;
}
/**
* Information parsed from a `$localize` tagged string that is used to translate it.

@@ -41,3 +91,3 @@ *

* {
* messageId: '6998194507597730591',
* id: '6998194507597730591',
* substitutions: { title: 'Jo Bloggs' },

@@ -48,18 +98,9 @@ * messageString: 'Hello {$title}!',

*/
export interface ParsedMessage {
export interface ParsedMessage extends MessageMetadata {
/**
* The key used to look up the appropriate translation target.
*/
messageId: MessageId;
/**
* Legacy message ids, if provided.
*
* In legacy message formats the message id can only be computed directly from the original
* template source.
*
* Since this information is not available in `$localize` calls, the legacy message ids may be
* attached by the compiler to the `$localize` metablock so it can be used if needed at the point
* of translation if the translations are encoded using the legacy message id.
* In `ParsedMessage` this is a required field, whereas it is optional in `MessageMetadata`.
*/
legacyIds: MessageId[];
id: MessageId;
/**

@@ -70,14 +111,2 @@ * A mapping of placeholder names to substitution values.

/**
* A human readable rendering of the message
*/
messageString: string;
/**
* The meaning of the `message`, used to distinguish identical `messageString`s.
*/
meaning: string;
/**
* The description of the `message`, used to aid translation.
*/
description: string;
/**
* The static parts of the message.

@@ -96,10 +125,3 @@ */

*/
export declare function parseMessage(messageParts: TemplateStringsArray, expressions?: readonly any[]): ParsedMessage;
export interface MessageMetadata {
text: string;
meaning: string | undefined;
description: string | undefined;
id: string | undefined;
legacyIds: string[];
}
export declare function parseMessage(messageParts: TemplateStringsArray, expressions?: readonly any[], location?: SourceLocation): ParsedMessage;
/**

@@ -106,0 +128,0 @@ * Parse the given message part (`cooked` + `raw`) to extract the message metadata from the text.

@@ -1,6 +0,6 @@

import { MessageId, ParsedMessage, TargetMessage } from './messages';
import { MessageId, MessageMetadata, ParsedMessage, TargetMessage } from './messages';
/**
* A translation message that has been processed to extract the message parts and placeholders.
*/
export interface ParsedTranslation {
export interface ParsedTranslation extends MessageMetadata {
messageParts: TemplateStringsArray;

@@ -44,3 +44,3 @@ placeholderNames: string[];

*/
export declare function parseTranslation(message: TargetMessage): ParsedTranslation;
export declare function parseTranslation(messageString: TargetMessage): ParsedTranslation;
/**

@@ -47,0 +47,0 @@ * Create a `ParsedTranslation` from a set of `messageParts` and `placeholderNames`.

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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
  • Changelog

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc