Socket
Socket
Sign inDemoInstall

@angular/localize

Package Overview
Dependencies
Maintainers
1
Versions
544
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 9.0.0-next.10 to 9.0.0-next.11

2

bundles/localize-init.umd.js
/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

/**
* @license Angular v9.0.0-next.10
* @license Angular v9.0.0-next.11
* (c) 2010-2019 Google LLC. https://angular.io/

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

{
"name": "@angular/localize",
"version": "9.0.0-next.10",
"version": "9.0.0-next.11",
"description": "Angular - library for localizing messages",

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

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

canTranslate(_relativeFilePath: string, _contents: Buffer): boolean;
translate(diagnostics: Diagnostics, _sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[]): void;
translate(diagnostics: Diagnostics, _sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void;
}

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

AssetTranslationHandler.prototype.canTranslate = function (_relativeFilePath, _contents) { return true; };
AssetTranslationHandler.prototype.translate = function (diagnostics, _sourceRoot, relativeFilePath, contents, outputPathFn, translations) {
AssetTranslationHandler.prototype.translate = function (diagnostics, _sourceRoot, relativeFilePath, contents, outputPathFn, translations, sourceLocale) {
var e_1, _a;

@@ -42,2 +42,10 @@ try {

}
if (sourceLocale !== undefined) {
try {
file_utils_1.FileUtils.writeFile(outputPathFn(sourceLocale, relativeFilePath), contents);
}
catch (e) {
diagnostics.error(e.message);
}
}
};

@@ -48,2 +56,2 @@ return AssetTranslationHandler;

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRfdHJhbnNsYXRpb25faGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL2Fzc2V0X2ZpbGVzL2Fzc2V0X3RyYW5zbGF0aW9uX2hhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEseUVBQTJDO0lBTTNDOztPQUVHO0lBQ0g7UUFBQTtRQWFBLENBQUM7UUFaQyw4Q0FBWSxHQUFaLFVBQWEsaUJBQXlCLEVBQUUsU0FBaUIsSUFBYSxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDcEYsMkNBQVMsR0FBVCxVQUNJLFdBQXdCLEVBQUUsV0FBbUIsRUFBRSxnQkFBd0IsRUFBRSxRQUFnQixFQUN6RixZQUEwQixFQUFFLFlBQWlDOzs7Z0JBQy9ELEtBQTBCLElBQUEsaUJBQUEsaUJBQUEsWUFBWSxDQUFBLDBDQUFBLG9FQUFFO29CQUFuQyxJQUFNLFdBQVcseUJBQUE7b0JBQ3BCLElBQUk7d0JBQ0Ysc0JBQVMsQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztxQkFDbkY7b0JBQUMsT0FBTyxDQUFDLEVBQUU7d0JBQ1YsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7cUJBQzlCO2lCQUNGOzs7Ozs7Ozs7UUFDSCxDQUFDO1FBQ0gsOEJBQUM7SUFBRCxDQUFDLEFBYkQsSUFhQztJQWJZLDBEQUF1QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7RmlsZVV0aWxzfSBmcm9tICcuLi8uLi9maWxlX3V0aWxzJztcbmltcG9ydCB7T3V0cHV0UGF0aEZufSBmcm9tICcuLi9vdXRwdXRfcGF0aCc7XG5pbXBvcnQge1RyYW5zbGF0aW9uQnVuZGxlLCBUcmFuc2xhdGlvbkhhbmRsZXJ9IGZyb20gJy4uL3RyYW5zbGF0b3InO1xuXG5cblxuLyoqXG4gKiBUcmFuc2xhdGUgYW4gYXNzZXQgZmlsZSBieSBzaW1wbHkgY29weWluZyBpdCB0byB0aGUgYXBwcm9wcmlhdGUgdHJhbnNsYXRpb24gb3V0cHV0IHBhdGhzLlxuICovXG5leHBvcnQgY2xhc3MgQXNzZXRUcmFuc2xhdGlvbkhhbmRsZXIgaW1wbGVtZW50cyBUcmFuc2xhdGlvbkhhbmRsZXIge1xuICBjYW5UcmFuc2xhdGUoX3JlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgX2NvbnRlbnRzOiBCdWZmZXIpOiBib29sZWFuIHsgcmV0dXJuIHRydWU7IH1cbiAgdHJhbnNsYXRlKFxuICAgICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCBfc291cmNlUm9vdDogc3RyaW5nLCByZWxhdGl2ZUZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBCdWZmZXIsXG4gICAgICBvdXRwdXRQYXRoRm46IE91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zOiBUcmFuc2xhdGlvbkJ1bmRsZVtdKTogdm9pZCB7XG4gICAgZm9yIChjb25zdCB0cmFuc2xhdGlvbiBvZiB0cmFuc2xhdGlvbnMpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIEZpbGVVdGlscy53cml0ZUZpbGUob3V0cHV0UGF0aEZuKHRyYW5zbGF0aW9uLmxvY2FsZSwgcmVsYXRpdmVGaWxlUGF0aCksIGNvbnRlbnRzKTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgZGlhZ25vc3RpY3MuZXJyb3IoZS5tZXNzYWdlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRfdHJhbnNsYXRpb25faGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL2Fzc2V0X2ZpbGVzL2Fzc2V0X3RyYW5zbGF0aW9uX2hhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEseUVBQTJDO0lBTTNDOztPQUVHO0lBQ0g7UUFBQTtRQW9CQSxDQUFDO1FBbkJDLDhDQUFZLEdBQVosVUFBYSxpQkFBeUIsRUFBRSxTQUFpQixJQUFhLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQztRQUNwRiwyQ0FBUyxHQUFULFVBQ0ksV0FBd0IsRUFBRSxXQUFtQixFQUFFLGdCQUF3QixFQUFFLFFBQWdCLEVBQ3pGLFlBQTBCLEVBQUUsWUFBaUMsRUFBRSxZQUFxQjs7O2dCQUN0RixLQUEwQixJQUFBLGlCQUFBLGlCQUFBLFlBQVksQ0FBQSwwQ0FBQSxvRUFBRTtvQkFBbkMsSUFBTSxXQUFXLHlCQUFBO29CQUNwQixJQUFJO3dCQUNGLHNCQUFTLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLGdCQUFnQixDQUFDLEVBQUUsUUFBUSxDQUFDLENBQUM7cUJBQ25GO29CQUFDLE9BQU8sQ0FBQyxFQUFFO3dCQUNWLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO3FCQUM5QjtpQkFDRjs7Ozs7Ozs7O1lBQ0QsSUFBSSxZQUFZLEtBQUssU0FBUyxFQUFFO2dCQUM5QixJQUFJO29CQUNGLHNCQUFTLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztpQkFDN0U7Z0JBQUMsT0FBTyxDQUFDLEVBQUU7b0JBQ1YsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7aUJBQzlCO2FBQ0Y7UUFDSCxDQUFDO1FBQ0gsOEJBQUM7SUFBRCxDQUFDLEFBcEJELElBb0JDO0lBcEJZLDBEQUF1QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7RmlsZVV0aWxzfSBmcm9tICcuLi8uLi9maWxlX3V0aWxzJztcbmltcG9ydCB7T3V0cHV0UGF0aEZufSBmcm9tICcuLi9vdXRwdXRfcGF0aCc7XG5pbXBvcnQge1RyYW5zbGF0aW9uQnVuZGxlLCBUcmFuc2xhdGlvbkhhbmRsZXJ9IGZyb20gJy4uL3RyYW5zbGF0b3InO1xuXG5cblxuLyoqXG4gKiBUcmFuc2xhdGUgYW4gYXNzZXQgZmlsZSBieSBzaW1wbHkgY29weWluZyBpdCB0byB0aGUgYXBwcm9wcmlhdGUgdHJhbnNsYXRpb24gb3V0cHV0IHBhdGhzLlxuICovXG5leHBvcnQgY2xhc3MgQXNzZXRUcmFuc2xhdGlvbkhhbmRsZXIgaW1wbGVtZW50cyBUcmFuc2xhdGlvbkhhbmRsZXIge1xuICBjYW5UcmFuc2xhdGUoX3JlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgX2NvbnRlbnRzOiBCdWZmZXIpOiBib29sZWFuIHsgcmV0dXJuIHRydWU7IH1cbiAgdHJhbnNsYXRlKFxuICAgICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCBfc291cmNlUm9vdDogc3RyaW5nLCByZWxhdGl2ZUZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBCdWZmZXIsXG4gICAgICBvdXRwdXRQYXRoRm46IE91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zOiBUcmFuc2xhdGlvbkJ1bmRsZVtdLCBzb3VyY2VMb2NhbGU/OiBzdHJpbmcpOiB2b2lkIHtcbiAgICBmb3IgKGNvbnN0IHRyYW5zbGF0aW9uIG9mIHRyYW5zbGF0aW9ucykge1xuICAgICAgdHJ5IHtcbiAgICAgICAgRmlsZVV0aWxzLndyaXRlRmlsZShvdXRwdXRQYXRoRm4odHJhbnNsYXRpb24ubG9jYWxlLCByZWxhdGl2ZUZpbGVQYXRoKSwgY29udGVudHMpO1xuICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICBkaWFnbm9zdGljcy5lcnJvcihlLm1lc3NhZ2UpO1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoc291cmNlTG9jYWxlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIEZpbGVVdGlscy53cml0ZUZpbGUob3V0cHV0UGF0aEZuKHNvdXJjZUxvY2FsZSwgcmVsYXRpdmVGaWxlUGF0aCksIGNvbnRlbnRzKTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgZGlhZ25vc3RpY3MuZXJyb3IoZS5tZXNzYWdlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==

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

missingTranslation: MissingTranslationStrategy;
sourceLocale?: string;
}
export declare function translateFiles({ sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn, diagnostics, missingTranslation }: TranslateFilesOptions): void;
export declare function translateFiles({ sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn, diagnostics, missingTranslation, sourceLocale }: TranslateFilesOptions): void;

@@ -45,2 +45,6 @@ #!/usr/bin/env node

})
.option('l', {
alias: 'source-locale',
describe: '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.',
})
.option('t', {

@@ -70,4 +74,5 @@ alias: 'translations',

var missingTranslation = options['m'];
var sourceLocale = options['l'];
translateFiles({ sourceRootPath: sourceRootPath, sourceFilePaths: sourceFilePaths, translationFilePaths: translationFilePaths, outputPathFn: outputPathFn, diagnostics: diagnostics,
missingTranslation: missingTranslation });
missingTranslation: missingTranslation, sourceLocale: sourceLocale });
diagnostics.messages.forEach(function (m) { return console.warn(m.type + ": " + m.message); });

@@ -77,3 +82,3 @@ process.exit(diagnostics.hasErrors ? 1 : 0);

function translateFiles(_a) {
var sourceRootPath = _a.sourceRootPath, sourceFilePaths = _a.sourceFilePaths, translationFilePaths = _a.translationFilePaths, outputPathFn = _a.outputPathFn, diagnostics = _a.diagnostics, missingTranslation = _a.missingTranslation;
var sourceRootPath = _a.sourceRootPath, sourceFilePaths = _a.sourceFilePaths, translationFilePaths = _a.translationFilePaths, outputPathFn = _a.outputPathFn, diagnostics = _a.diagnostics, missingTranslation = _a.missingTranslation, sourceLocale = _a.sourceLocale;
var translationLoader = new translation_file_loader_1.TranslationLoader([

@@ -90,6 +95,6 @@ new xliff2_translation_parser_1.Xliff2TranslationParser(),

sourceRootPath = path_1.resolve(sourceRootPath);
resourceProcessor.translateFiles(sourceFilePaths, sourceRootPath, outputPathFn, translations);
resourceProcessor.translateFiles(sourceFilePaths, sourceRootPath, outputPathFn, translations, sourceLocale);
}
exports.translateFiles = translateFiles;
});
//# 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_file_loader';\nimport {SimpleJsonTranslationParser} from './translation_files/translation_parsers/simple_json/simple_json_translation_parser';\nimport {Xliff1TranslationParser} from './translation_files/translation_parsers/xliff1/xliff1_translation_parser';\nimport {Xliff2TranslationParser} from './translation_files/translation_parsers/xliff2/xliff2_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('t', {\n            alias: 'translations',\n            required: true,\n            describe:\n                'A glob pattern indicating what translation files to load, either absolute or relative to the current working directory. E.g. `my_proj/src/locale/messages.*.xlf.',\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          .option('m', {\n            alias: 'missingTranslation',\n            describe: 'How to handle missing translations.',\n            choices: ['error', 'warning', 'ignore'],\n            default: 'warning',\n          })\n          .help()\n          .parse(args);\n\n  const sourceRootPath = options['r'];\n  const sourceFilePaths =\n      glob.sync(options['s'], {absolute: true, cwd: sourceRootPath, nodir: true});\n  const translationFilePaths = glob.sync(options['t'], {absolute: true, nodir: true});\n  const outputPathFn = getOutputPathFn(options['o']);\n  const diagnostics = new Diagnostics();\n  const missingTranslation: MissingTranslationStrategy = options['m'];\n\n  translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn, diagnostics,\n                  missingTranslation});\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  sourceRootPath: string;\n  sourceFilePaths: string[];\n  translationFilePaths: string[];\n  outputPathFn: OutputPathFn;\n  diagnostics: Diagnostics;\n  missingTranslation: MissingTranslationStrategy;\n}\n\nexport function translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn,\n                                diagnostics, missingTranslation}: TranslateFilesOptions) {\n  const translationLoader = new TranslationLoader([\n    new Xliff2TranslationParser(),\n    new Xliff1TranslationParser(),\n    new SimpleJsonTranslationParser(),\n  ]);\n\n  const resourceProcessor = new Translator(\n      [\n        new SourceFileTranslationHandler({missingTranslation}),\n        new AssetTranslationHandler(),\n      ],\n      diagnostics);\n\n  const translations = translationLoader.loadBundles(translationFilePaths);\n  sourceRootPath = resolve(sourceRootPath);\n  resourceProcessor.translateFiles(sourceFilePaths, sourceRootPath, outputPathFn, translations);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../../../../packages/localize/src/tools/src/translate/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as glob from 'glob';\nimport {resolve} from 'path';\nimport * as yargs from 'yargs';\n\nimport {AssetTranslationHandler} from './asset_files/asset_translation_handler';\nimport {getOutputPathFn, OutputPathFn} from './output_path';\nimport {SourceFileTranslationHandler} from './source_files/source_file_translation_handler';\nimport {MissingTranslationStrategy} from './source_files/source_file_utils';\nimport {TranslationLoader} from './translation_files/translation_file_loader';\nimport {SimpleJsonTranslationParser} from './translation_files/translation_parsers/simple_json/simple_json_translation_parser';\nimport {Xliff1TranslationParser} from './translation_files/translation_parsers/xliff1/xliff1_translation_parser';\nimport {Xliff2TranslationParser} from './translation_files/translation_parsers/xliff2/xliff2_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            describe:\n                'A glob pattern indicating what translation files to load, either absolute or relative to the current working directory. E.g. `my_proj/src/locale/messages.*.xlf.',\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          .option('m', {\n            alias: 'missingTranslation',\n            describe: 'How to handle missing translations.',\n            choices: ['error', 'warning', 'ignore'],\n            default: 'warning',\n          })\n          .help()\n          .parse(args);\n\n  const sourceRootPath = options['r'];\n  const sourceFilePaths =\n      glob.sync(options['s'], {absolute: true, cwd: sourceRootPath, nodir: true});\n  const translationFilePaths = glob.sync(options['t'], {absolute: true, nodir: true});\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\n  translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn, diagnostics,\n                  missingTranslation, sourceLocale});\n\n  diagnostics.messages.forEach(m => console.warn(`${m.type}: ${m.message}`));\n  process.exit(diagnostics.hasErrors ? 1 : 0);\n}\n\nexport interface TranslateFilesOptions {\n  sourceRootPath: string;\n  sourceFilePaths: string[];\n  translationFilePaths: string[];\n  outputPathFn: OutputPathFn;\n  diagnostics: Diagnostics;\n  missingTranslation: MissingTranslationStrategy;\n  sourceLocale?: string;\n}\n\nexport function translateFiles({sourceRootPath, sourceFilePaths, translationFilePaths, outputPathFn,\n                                diagnostics, missingTranslation,\n                                sourceLocale}: TranslateFilesOptions) {\n  const translationLoader = new TranslationLoader([\n    new Xliff2TranslationParser(),\n    new Xliff1TranslationParser(),\n    new SimpleJsonTranslationParser(),\n  ]);\n\n  const resourceProcessor = new Translator(\n      [\n        new SourceFileTranslationHandler({missingTranslation}),\n        new AssetTranslationHandler(),\n      ],\n      diagnostics);\n\n  const translations = translationLoader.loadBundles(translationFilePaths);\n  sourceRootPath = resolve(sourceRootPath);\n  resourceProcessor.translateFiles(\n      sourceFilePaths, sourceRootPath, outputPathFn, translations, sourceLocale);\n}\n"]}

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

if (source_file_utils_1.isNamedIdentifier(calleePath, localizeName) && source_file_utils_1.isGlobalIdentifier(calleePath)) {
var messageParts = source_file_utils_1.unwrapMessagePartsFromLocalizeCall(callPath.node);
var messageParts = source_file_utils_1.unwrapMessagePartsFromLocalizeCall(callPath);
var expressions = source_file_utils_1.unwrapSubstitutionsFromLocalizeCall(callPath.node);

@@ -39,2 +39,2 @@ var translated = source_file_utils_1.translate(diagnostics, translations, messageParts, expressions, missingTranslation);

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFXQSw4R0FBbU87SUFFbk8sU0FBZ0Isc0JBQXNCLENBQ2xDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1AsY0FBYyxFQUFkLFVBQWUsUUFBa0M7b0JBQy9DLElBQUk7d0JBQ0YsSUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDMUMsSUFBSSxxQ0FBaUIsQ0FBQyxVQUFVLEVBQUUsWUFBWSxDQUFDLElBQUksc0NBQWtCLENBQUMsVUFBVSxDQUFDLEVBQUU7NEJBQ2pGLElBQU0sWUFBWSxHQUFHLHNEQUFrQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQzs0QkFDdkUsSUFBTSxXQUFXLEdBQUcsdURBQW1DLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDOzRCQUN2RSxJQUFNLFVBQVUsR0FDWiw2QkFBUyxDQUFDLFdBQVcsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDOzRCQUN4RixRQUFRLENBQUMsV0FBVyxDQUFDLDRDQUF3QixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO3lCQUM5RTtxQkFDRjtvQkFBQyxPQUFPLENBQUMsRUFBRTt3QkFDVixJQUFJLHFDQUFpQixDQUFDLENBQUMsQ0FBQyxFQUFFOzRCQUN4QixXQUFXLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO3lCQUNyRjtxQkFDRjtnQkFDSCxDQUFDO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQXhCRCx3REF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1UGFyc2VkVHJhbnNsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2xvY2FsaXplJztcbmltcG9ydCB7Tm9kZVBhdGgsIFBsdWdpbk9ian0gZnJvbSAnQGJhYmVsL2NvcmUnO1xuaW1wb3J0IHtDYWxsRXhwcmVzc2lvbn0gZnJvbSAnQGJhYmVsL3R5cGVzJztcbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uLy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7VHJhbnNsYXRlUGx1Z2luT3B0aW9ucywgYnVpbGRMb2NhbGl6ZVJlcGxhY2VtZW50LCBpc0JhYmVsUGFyc2VFcnJvciwgaXNHbG9iYWxJZGVudGlmaWVyLCBpc05hbWVkSWRlbnRpZmllciwgdHJhbnNsYXRlLCB1bndyYXBNZXNzYWdlUGFydHNGcm9tTG9jYWxpemVDYWxsLCB1bndyYXBTdWJzdGl0dXRpb25zRnJvbUxvY2FsaXplQ2FsbH0gZnJvbSAnLi9zb3VyY2VfZmlsZV91dGlscyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlRXM1VHJhbnNsYXRlUGx1Z2luKFxuICAgIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcywgdHJhbnNsYXRpb25zOiBSZWNvcmQ8c3RyaW5nLCDJtVBhcnNlZFRyYW5zbGF0aW9uPixcbiAgICB7bWlzc2luZ1RyYW5zbGF0aW9uID0gJ2Vycm9yJywgbG9jYWxpemVOYW1lID0gJyRsb2NhbGl6ZSd9OiBUcmFuc2xhdGVQbHVnaW5PcHRpb25zID0ge30pOlxuICAgIFBsdWdpbk9iaiB7XG4gIHJldHVybiB7XG4gICAgdmlzaXRvcjoge1xuICAgICAgQ2FsbEV4cHJlc3Npb24oY2FsbFBhdGg6IE5vZGVQYXRoPENhbGxFeHByZXNzaW9uPikge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IGNhbGxlZVBhdGggPSBjYWxsUGF0aC5nZXQoJ2NhbGxlZScpO1xuICAgICAgICAgIGlmIChpc05hbWVkSWRlbnRpZmllcihjYWxsZWVQYXRoLCBsb2NhbGl6ZU5hbWUpICYmIGlzR2xvYmFsSWRlbnRpZmllcihjYWxsZWVQYXRoKSkge1xuICAgICAgICAgICAgY29uc3QgbWVzc2FnZVBhcnRzID0gdW53cmFwTWVzc2FnZVBhcnRzRnJvbUxvY2FsaXplQ2FsbChjYWxsUGF0aC5ub2RlKTtcbiAgICAgICAgICAgIGNvbnN0IGV4cHJlc3Npb25zID0gdW53cmFwU3Vic3RpdHV0aW9uc0Zyb21Mb2NhbGl6ZUNhbGwoY2FsbFBhdGgubm9kZSk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID1cbiAgICAgICAgICAgICAgICB0cmFuc2xhdGUoZGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9ucywgbWVzc2FnZVBhcnRzLCBleHByZXNzaW9ucywgbWlzc2luZ1RyYW5zbGF0aW9uKTtcbiAgICAgICAgICAgIGNhbGxQYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICBkaWFnbm9zdGljcy5lcnJvcihjYWxsUGF0aC5odWIuZmlsZS5idWlsZENvZGVGcmFtZUVycm9yKGUubm9kZSwgZS5tZXNzYWdlKS5tZXNzYWdlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXM1X3RyYW5zbGF0ZV9wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sb2NhbGl6ZS9zcmMvdG9vbHMvc3JjL3RyYW5zbGF0ZS9zb3VyY2VfZmlsZXMvZXM1X3RyYW5zbGF0ZV9wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFXQSw4R0FBbU87SUFFbk8sU0FBZ0Isc0JBQXNCLENBQ2xDLFdBQXdCLEVBQUUsWUFBZ0QsRUFDMUUsRUFBdUY7WUFBdkYsNEJBQXVGLEVBQXRGLDBCQUE0QixFQUE1QixpREFBNEIsRUFBRSxvQkFBMEIsRUFBMUIsK0NBQTBCO1FBRTNELE9BQU87WUFDTCxPQUFPLEVBQUU7Z0JBQ1AsY0FBYyxFQUFkLFVBQWUsUUFBa0M7b0JBQy9DLElBQUk7d0JBQ0YsSUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDMUMsSUFBSSxxQ0FBaUIsQ0FBQyxVQUFVLEVBQUUsWUFBWSxDQUFDLElBQUksc0NBQWtCLENBQUMsVUFBVSxDQUFDLEVBQUU7NEJBQ2pGLElBQU0sWUFBWSxHQUFHLHNEQUFrQyxDQUFDLFFBQVEsQ0FBQyxDQUFDOzRCQUNsRSxJQUFNLFdBQVcsR0FBRyx1REFBbUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7NEJBQ3ZFLElBQU0sVUFBVSxHQUNaLDZCQUFTLENBQUMsV0FBVyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixDQUFDLENBQUM7NEJBQ3hGLFFBQVEsQ0FBQyxXQUFXLENBQUMsNENBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzlFO3FCQUNGO29CQUFDLE9BQU8sQ0FBQyxFQUFFO3dCQUNWLElBQUkscUNBQWlCLENBQUMsQ0FBQyxDQUFDLEVBQUU7NEJBQ3hCLFdBQVcsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7eUJBQ3JGO3FCQUNGO2dCQUNILENBQUM7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0lBeEJELHdEQXdCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7ybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtOb2RlUGF0aCwgUGx1Z2luT2JqfSBmcm9tICdAYmFiZWwvY29yZSc7XG5pbXBvcnQge0NhbGxFeHByZXNzaW9ufSBmcm9tICdAYmFiZWwvdHlwZXMnO1xuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vLi4vZGlhZ25vc3RpY3MnO1xuaW1wb3J0IHtUcmFuc2xhdGVQbHVnaW5PcHRpb25zLCBidWlsZExvY2FsaXplUmVwbGFjZW1lbnQsIGlzQmFiZWxQYXJzZUVycm9yLCBpc0dsb2JhbElkZW50aWZpZXIsIGlzTmFtZWRJZGVudGlmaWVyLCB0cmFuc2xhdGUsIHVud3JhcE1lc3NhZ2VQYXJ0c0Zyb21Mb2NhbGl6ZUNhbGwsIHVud3JhcFN1YnN0aXR1dGlvbnNGcm9tTG9jYWxpemVDYWxsfSBmcm9tICcuL3NvdXJjZV9maWxlX3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFczVUcmFuc2xhdGVQbHVnaW4oXG4gICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCB0cmFuc2xhdGlvbnM6IFJlY29yZDxzdHJpbmcsIMm1UGFyc2VkVHJhbnNsYXRpb24+LFxuICAgIHttaXNzaW5nVHJhbnNsYXRpb24gPSAnZXJyb3InLCBsb2NhbGl6ZU5hbWUgPSAnJGxvY2FsaXplJ306IFRyYW5zbGF0ZVBsdWdpbk9wdGlvbnMgPSB7fSk6XG4gICAgUGx1Z2luT2JqIHtcbiAgcmV0dXJuIHtcbiAgICB2aXNpdG9yOiB7XG4gICAgICBDYWxsRXhwcmVzc2lvbihjYWxsUGF0aDogTm9kZVBhdGg8Q2FsbEV4cHJlc3Npb24+KSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FsbGVlUGF0aCA9IGNhbGxQYXRoLmdldCgnY2FsbGVlJyk7XG4gICAgICAgICAgaWYgKGlzTmFtZWRJZGVudGlmaWVyKGNhbGxlZVBhdGgsIGxvY2FsaXplTmFtZSkgJiYgaXNHbG9iYWxJZGVudGlmaWVyKGNhbGxlZVBhdGgpKSB7XG4gICAgICAgICAgICBjb25zdCBtZXNzYWdlUGFydHMgPSB1bndyYXBNZXNzYWdlUGFydHNGcm9tTG9jYWxpemVDYWxsKGNhbGxQYXRoKTtcbiAgICAgICAgICAgIGNvbnN0IGV4cHJlc3Npb25zID0gdW53cmFwU3Vic3RpdHV0aW9uc0Zyb21Mb2NhbGl6ZUNhbGwoY2FsbFBhdGgubm9kZSk7XG4gICAgICAgICAgICBjb25zdCB0cmFuc2xhdGVkID1cbiAgICAgICAgICAgICAgICB0cmFuc2xhdGUoZGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9ucywgbWVzc2FnZVBhcnRzLCBleHByZXNzaW9ucywgbWlzc2luZ1RyYW5zbGF0aW9uKTtcbiAgICAgICAgICAgIGNhbGxQYXRoLnJlcGxhY2VXaXRoKGJ1aWxkTG9jYWxpemVSZXBsYWNlbWVudCh0cmFuc2xhdGVkWzBdLCB0cmFuc2xhdGVkWzFdKSk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgaWYgKGlzQmFiZWxQYXJzZUVycm9yKGUpKSB7XG4gICAgICAgICAgICBkaWFnbm9zdGljcy5lcnJvcihjYWxsUGF0aC5odWIuZmlsZS5idWlsZENvZGVGcmFtZUVycm9yKGUubm9kZSwgZS5tZXNzYWdlKS5tZXNzYWdlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH07XG59XG4iXX0=

@@ -13,5 +13,7 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/source_files/source_file_translation_handler" />

private translationOptions;
private sourceLocaleOptions;
constructor(translationOptions?: TranslatePluginOptions);
canTranslate(relativeFilePath: string, contents: Buffer): boolean;
translate(diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[]): void;
canTranslate(relativeFilePath: string, _contents: Buffer): boolean;
translate(diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void;
private translateFile;
}

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

var tslib_1 = require("tslib");
/**
* @license
* Copyright Google Inc. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
var core_1 = require("@babel/core");

@@ -34,7 +27,8 @@ var path_1 = require("path");

this.translationOptions = translationOptions;
this.sourceLocaleOptions = tslib_1.__assign({}, this.translationOptions, { missingTranslation: 'ignore' });
}
SourceFileTranslationHandler.prototype.canTranslate = function (relativeFilePath, contents) {
SourceFileTranslationHandler.prototype.canTranslate = function (relativeFilePath, _contents) {
return path_1.extname(relativeFilePath) === '.js';
};
SourceFileTranslationHandler.prototype.translate = function (diagnostics, sourceRoot, relativeFilePath, contents, outputPathFn, translations) {
SourceFileTranslationHandler.prototype.translate = function (diagnostics, sourceRoot, relativeFilePath, contents, outputPathFn, translations, sourceLocale) {
var e_1, _a, e_2, _b;

@@ -58,2 +52,5 @@ var sourceCode = contents.toString('utf8');

}
if (sourceLocale !== undefined) {
file_utils_1.FileUtils.writeFile(outputPathFn(sourceLocale, relativeFilePath), contents);
}
}

@@ -67,20 +64,6 @@ else {

try {
// Output a translated copy of the file for each locale.
for (var translations_2 = tslib_1.__values(translations), translations_2_1 = translations_2.next(); !translations_2_1.done; translations_2_1 = translations_2.next()) {
var translationBundle = translations_2_1.value;
var translated = core_1.transformFromAstSync(ast, sourceCode, {
compact: true,
generatorOpts: { minified: true },
plugins: [
es2015_translate_plugin_1.makeEs2015TranslatePlugin(diagnostics, translationBundle.translations, this.translationOptions),
es5_translate_plugin_1.makeEs5TranslatePlugin(diagnostics, translationBundle.translations, this.translationOptions),
],
filename: relativeFilePath,
});
if (translated && translated.code) {
file_utils_1.FileUtils.writeFile(outputPathFn(translationBundle.locale, relativeFilePath), translated.code);
}
else {
diagnostics.error("Unable to translate source file: " + path_1.join(sourceRoot, relativeFilePath));
return;
}
this.translateFile(diagnostics, ast, translationBundle, sourceRoot, relativeFilePath, outputPathFn, this.translationOptions);
}

@@ -95,4 +78,27 @@ }

}
if (sourceLocale !== undefined) {
// Also output a copy of the file for the source locale.
// There will be no translations - by definition - so we "ignore" `missingTranslations`.
this.translateFile(diagnostics, ast, { locale: sourceLocale, translations: {} }, sourceRoot, relativeFilePath, outputPathFn, this.sourceLocaleOptions);
}
}
};
SourceFileTranslationHandler.prototype.translateFile = function (diagnostics, ast, translationBundle, sourceRoot, filename, outputPathFn, options) {
var translated = core_1.transformFromAstSync(ast, undefined, {
compact: true,
generatorOpts: { minified: true },
plugins: [
es2015_translate_plugin_1.makeEs2015TranslatePlugin(diagnostics, translationBundle.translations, options),
es5_translate_plugin_1.makeEs5TranslatePlugin(diagnostics, translationBundle.translations, options),
],
filename: filename,
});
if (translated && translated.code) {
file_utils_1.FileUtils.writeFile(outputPathFn(translationBundle.locale, filename), translated.code);
}
else {
diagnostics.error("Unable to translate source file: " + path_1.join(sourceRoot, filename));
return;
}
};
return SourceFileTranslationHandler;

@@ -102,2 +108,2 @@ }());

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlX2ZpbGVfdHJhbnNsYXRpb25faGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3NvdXJjZV9maWxlcy9zb3VyY2VfZmlsZV90cmFuc2xhdGlvbl9oYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILG9DQUE0RDtJQUM1RCw2QkFBbUM7SUFHbkMseUVBQTJDO0lBSTNDLDBIQUFvRTtJQUNwRSxvSEFBOEQ7SUFHOUQ7OztPQUdHO0lBQ0g7UUFDRSxzQ0FBb0Isa0JBQStDO1lBQS9DLG1DQUFBLEVBQUEsdUJBQStDO1lBQS9DLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBNkI7UUFBRyxDQUFDO1FBRXZFLG1EQUFZLEdBQVosVUFBYSxnQkFBd0IsRUFBRSxRQUFnQjtZQUNyRCxPQUFPLGNBQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEtBQUssQ0FBQztRQUM3QyxDQUFDO1FBRUQsZ0RBQVMsR0FBVCxVQUNJLFdBQXdCLEVBQUUsVUFBa0IsRUFBRSxnQkFBd0IsRUFBRSxRQUFnQixFQUN4RixZQUEwQixFQUFFLFlBQWlDOztZQUMvRCxJQUFNLFVBQVUsR0FBRyxRQUFRLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzdDLHlGQUF5RjtZQUN6RiwyQkFBMkI7WUFDM0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLEVBQUU7O29CQUNyQyxLQUEwQixJQUFBLGlCQUFBLGlCQUFBLFlBQVksQ0FBQSwwQ0FBQSxvRUFBRTt3QkFBbkMsSUFBTSxXQUFXLHlCQUFBO3dCQUNwQixzQkFBUyxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDO3FCQUNuRjs7Ozs7Ozs7O2FBQ0Y7aUJBQU07Z0JBQ0wsSUFBTSxHQUFHLEdBQUcsZ0JBQVMsQ0FBQyxVQUFVLEVBQUUsRUFBQyxVQUFVLFlBQUEsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUMsQ0FBQyxDQUFDO2dCQUM1RSxJQUFJLENBQUMsR0FBRyxFQUFFO29CQUNSLFdBQVcsQ0FBQyxLQUFLLENBQUMsa0NBQWdDLFdBQUksQ0FBQyxVQUFVLEVBQUUsZ0JBQWdCLENBQUcsQ0FBQyxDQUFDO29CQUN4RixPQUFPO2lCQUNSOztvQkFDRCxLQUFnQyxJQUFBLGlCQUFBLGlCQUFBLFlBQVksQ0FBQSwwQ0FBQSxvRUFBRTt3QkFBekMsSUFBTSxpQkFBaUIseUJBQUE7d0JBQzFCLElBQU0sVUFBVSxHQUFHLDJCQUFvQixDQUFDLEdBQUcsRUFBRSxVQUFVLEVBQUU7NEJBQ3ZELE9BQU8sRUFBRSxJQUFJOzRCQUNiLGFBQWEsRUFBRSxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUM7NEJBQy9CLE9BQU8sRUFBRTtnQ0FDUCxtREFBeUIsQ0FDckIsV0FBVyxFQUFFLGlCQUFpQixDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUM7Z0NBQ3pFLDZDQUFzQixDQUNsQixXQUFXLEVBQUUsaUJBQWlCLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQzs2QkFDMUU7NEJBQ0QsUUFBUSxFQUFFLGdCQUFnQjt5QkFDM0IsQ0FBQyxDQUFDO3dCQUNILElBQUksVUFBVSxJQUFJLFVBQVUsQ0FBQyxJQUFJLEVBQUU7NEJBQ2pDLHNCQUFTLENBQUMsU0FBUyxDQUNmLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7eUJBQ2hGOzZCQUFNOzRCQUNMLFdBQVcsQ0FBQyxLQUFLLENBQ2Isc0NBQW9DLFdBQUksQ0FBQyxVQUFVLEVBQUUsZ0JBQWdCLENBQUcsQ0FBQyxDQUFDOzRCQUM5RSxPQUFPO3lCQUNSO3FCQUNGOzs7Ozs7Ozs7YUFDRjtRQUNILENBQUM7UUFDSCxtQ0FBQztJQUFELENBQUMsQUE5Q0QsSUE4Q0M7SUE5Q1ksb0VBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtwYXJzZVN5bmMsIHRyYW5zZm9ybUZyb21Bc3RTeW5jfSBmcm9tICdAYmFiZWwvY29yZSc7XG5pbXBvcnQge2V4dG5hbWUsIGpvaW59IGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0RpYWdub3N0aWNzfSBmcm9tICcuLi8uLi9kaWFnbm9zdGljcyc7XG5pbXBvcnQge0ZpbGVVdGlsc30gZnJvbSAnLi4vLi4vZmlsZV91dGlscyc7XG5pbXBvcnQge091dHB1dFBhdGhGbn0gZnJvbSAnLi4vb3V0cHV0X3BhdGgnO1xuaW1wb3J0IHtUcmFuc2xhdGlvbkJ1bmRsZSwgVHJhbnNsYXRpb25IYW5kbGVyfSBmcm9tICcuLi90cmFuc2xhdG9yJztcblxuaW1wb3J0IHttYWtlRXMyMDE1VHJhbnNsYXRlUGx1Z2lufSBmcm9tICcuL2VzMjAxNV90cmFuc2xhdGVfcGx1Z2luJztcbmltcG9ydCB7bWFrZUVzNVRyYW5zbGF0ZVBsdWdpbn0gZnJvbSAnLi9lczVfdHJhbnNsYXRlX3BsdWdpbic7XG5pbXBvcnQge1RyYW5zbGF0ZVBsdWdpbk9wdGlvbnN9IGZyb20gJy4vc291cmNlX2ZpbGVfdXRpbHMnO1xuXG4vKipcbiAqIFRyYW5zbGF0ZSBhIGZpbGUgYnkgaW5saW5pbmcgYWxsIG1lc3NhZ2VzIHRhZ2dlZCBieSBgJGxvY2FsaXplYCB3aXRoIHRoZSBhcHByb3ByaWF0ZSB0cmFuc2xhdGVkXG4gKiBtZXNzYWdlLlxuICovXG5leHBvcnQgY2xhc3MgU291cmNlRmlsZVRyYW5zbGF0aW9uSGFuZGxlciBpbXBsZW1lbnRzIFRyYW5zbGF0aW9uSGFuZGxlciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRpb25PcHRpb25zOiBUcmFuc2xhdGVQbHVnaW5PcHRpb25zID0ge30pIHt9XG5cbiAgY2FuVHJhbnNsYXRlKHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiBleHRuYW1lKHJlbGF0aXZlRmlsZVBhdGgpID09PSAnLmpzJztcbiAgfVxuXG4gIHRyYW5zbGF0ZShcbiAgICAgIGRpYWdub3N0aWNzOiBEaWFnbm9zdGljcywgc291cmNlUm9vdDogc3RyaW5nLCByZWxhdGl2ZUZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBCdWZmZXIsXG4gICAgICBvdXRwdXRQYXRoRm46IE91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zOiBUcmFuc2xhdGlvbkJ1bmRsZVtdKTogdm9pZCB7XG4gICAgY29uc3Qgc291cmNlQ29kZSA9IGNvbnRlbnRzLnRvU3RyaW5nKCd1dGY4Jyk7XG4gICAgLy8gQSBzaG9ydC1jaXJjdWl0IGNoZWNrIHRvIGF2b2lkIHBhcnNpbmcgdGhlIGZpbGUgaW50byBhbiBBU1QgaWYgaXQgZG9lcyBub3QgY29udGFpbiBhbnlcbiAgICAvLyBgJGxvY2FsaXplYCBpZGVudGlmaWVycy5cbiAgICBpZiAoIXNvdXJjZUNvZGUuaW5jbHVkZXMoJyRsb2NhbGl6ZScpKSB7XG4gICAgICBmb3IgKGNvbnN0IHRyYW5zbGF0aW9uIG9mIHRyYW5zbGF0aW9ucykge1xuICAgICAgICBGaWxlVXRpbHMud3JpdGVGaWxlKG91dHB1dFBhdGhGbih0cmFuc2xhdGlvbi5sb2NhbGUsIHJlbGF0aXZlRmlsZVBhdGgpLCBjb250ZW50cyk7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IGFzdCA9IHBhcnNlU3luYyhzb3VyY2VDb2RlLCB7c291cmNlUm9vdCwgZmlsZW5hbWU6IHJlbGF0aXZlRmlsZVBhdGh9KTtcbiAgICAgIGlmICghYXN0KSB7XG4gICAgICAgIGRpYWdub3N0aWNzLmVycm9yKGBVbmFibGUgdG8gcGFyc2Ugc291cmNlIGZpbGU6ICR7am9pbihzb3VyY2VSb290LCByZWxhdGl2ZUZpbGVQYXRoKX1gKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgZm9yIChjb25zdCB0cmFuc2xhdGlvbkJ1bmRsZSBvZiB0cmFuc2xhdGlvbnMpIHtcbiAgICAgICAgY29uc3QgdHJhbnNsYXRlZCA9IHRyYW5zZm9ybUZyb21Bc3RTeW5jKGFzdCwgc291cmNlQ29kZSwge1xuICAgICAgICAgIGNvbXBhY3Q6IHRydWUsXG4gICAgICAgICAgZ2VuZXJhdG9yT3B0czoge21pbmlmaWVkOiB0cnVlfSxcbiAgICAgICAgICBwbHVnaW5zOiBbXG4gICAgICAgICAgICBtYWtlRXMyMDE1VHJhbnNsYXRlUGx1Z2luKFxuICAgICAgICAgICAgICAgIGRpYWdub3N0aWNzLCB0cmFuc2xhdGlvbkJ1bmRsZS50cmFuc2xhdGlvbnMsIHRoaXMudHJhbnNsYXRpb25PcHRpb25zKSxcbiAgICAgICAgICAgIG1ha2VFczVUcmFuc2xhdGVQbHVnaW4oXG4gICAgICAgICAgICAgICAgZGlhZ25vc3RpY3MsIHRyYW5zbGF0aW9uQnVuZGxlLnRyYW5zbGF0aW9ucywgdGhpcy50cmFuc2xhdGlvbk9wdGlvbnMpLFxuICAgICAgICAgIF0sXG4gICAgICAgICAgZmlsZW5hbWU6IHJlbGF0aXZlRmlsZVBhdGgsXG4gICAgICAgIH0pO1xuICAgICAgICBpZiAodHJhbnNsYXRlZCAmJiB0cmFuc2xhdGVkLmNvZGUpIHtcbiAgICAgICAgICBGaWxlVXRpbHMud3JpdGVGaWxlKFxuICAgICAgICAgICAgICBvdXRwdXRQYXRoRm4odHJhbnNsYXRpb25CdW5kbGUubG9jYWxlLCByZWxhdGl2ZUZpbGVQYXRoKSwgdHJhbnNsYXRlZC5jb2RlKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBkaWFnbm9zdGljcy5lcnJvcihcbiAgICAgICAgICAgICAgYFVuYWJsZSB0byB0cmFuc2xhdGUgc291cmNlIGZpbGU6ICR7am9pbihzb3VyY2VSb290LCByZWxhdGl2ZUZpbGVQYXRoKX1gKTtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==
//# 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 {ɵMessageId, ɵParsedTranslation} from '@angular/localize/private';\nimport {parseSync, transformFromAstSync} from '@babel/core';\nimport {File, Program} from '@babel/types';\nimport {extname, join} from 'path';\n\nimport {Diagnostics} from '../../diagnostics';\nimport {FileUtils} from '../../file_utils';\nimport {OutputPathFn} from '../output_path';\nimport {TranslationBundle, TranslationHandler} from '../translator';\n\nimport {makeEs2015TranslatePlugin} from './es2015_translate_plugin';\nimport {makeEs5TranslatePlugin} from './es5_translate_plugin';\nimport {TranslatePluginOptions} from './source_file_utils';\n\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        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"]}

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

*/
export declare function unwrapMessagePartsFromLocalizeCall(call: t.CallExpression): TemplateStringsArray;
export declare function unwrapMessagePartsFromLocalizeCall(call: NodePath<t.CallExpression>): TemplateStringsArray;
export declare function unwrapSubstitutionsFromLocalizeCall(call: t.CallExpression): t.Expression[];

@@ -55,2 +55,19 @@ export declare function unwrapMessagePartsFromTemplateLiteral(elements: t.TemplateElement[]): TemplateStringsArray;

/**
* This expression is believed to be a call to a "lazy-load" template object helper function.
* This is expected to be of the form:
*
* ```ts
* function _templateObject() {
* var e = _taggedTemplateLiteral(['cooked string', 'raw string']);
* return _templateObject = function() { return e }, e
* }
* ```
*
* We unwrap this to return the call to `_taggedTemplateLiteral()`.
*
* @param call the call expression to unwrap
* @returns the call expression
*/
export declare function unwrapLazyLoadHelperCall(call: NodePath<t.CallExpression>): NodePath<t.CallExpression>;
/**
* Is the given `node` an array of literal strings?

@@ -57,0 +74,0 @@ *

@@ -62,28 +62,43 @@ (function (factory) {

function unwrapMessagePartsFromLocalizeCall(call) {
var cooked = call.arguments[0];
if (!t.isExpression(cooked)) {
throw new BabelParseError(call, 'Unexpected argument to `$localize`: ' + cooked);
var cooked = call.get('arguments')[0];
if (cooked === undefined) {
throw new BabelParseError(call.node, '`$localize` called without any arguments.');
}
if (!cooked.isExpression()) {
throw new BabelParseError(cooked.node, 'Unexpected argument to `$localize` (expected an array).');
}
// If there is no call to `__makeTemplateObject(...)`, then `raw` must be the same as `cooked`.
var raw = cooked;
// Check for cached call of the form `x || x = __makeTemplateObject(...)`
if (t.isLogicalExpression(cooked) && cooked.operator === '||' && t.isIdentifier(cooked.left) &&
t.isExpression(cooked.right)) {
if (t.isAssignmentExpression(cooked.right)) {
cooked = cooked.right.right;
if (cooked.isLogicalExpression() && cooked.node.operator === '||' &&
cooked.get('left').isIdentifier()) {
var right = cooked.get('right');
if (right.isAssignmentExpression()) {
cooked = right.get('right');
if (!cooked.isExpression()) {
throw new BabelParseError(cooked.node, 'Unexpected "makeTemplateObject()" function (expected an expression).');
}
}
}
// Check for `__makeTemplateObject(cooked, raw)` call
if (t.isCallExpression(cooked)) {
raw = cooked.arguments[1];
if (!t.isExpression(raw)) {
throw new BabelParseError(raw, 'Unexpected `raw` argument to the "makeTemplateObject()" function (expected an expression).');
// Check for `__makeTemplateObject(cooked, raw)` or `__templateObject()` calls.
if (cooked.isCallExpression()) {
var call_1 = cooked;
if (call_1.get('arguments').length === 0) {
// No arguments so perhaps it is a `__templateObject()` call.
// Unwrap this to get the `_taggedTemplateLiteral(cooked, raw)` call.
call_1 = unwrapLazyLoadHelperCall(call_1);
}
cooked = cooked.arguments[0];
if (!t.isExpression(cooked)) {
throw new BabelParseError(cooked, 'Unexpected `cooked` argument to the "makeTemplateObject()" function (expected an expression).');
cooked = call_1.get('arguments')[0];
if (!cooked.isExpression()) {
throw new BabelParseError(cooked.node, 'Unexpected `cooked` argument to the "makeTemplateObject()" function (expected an expression).');
}
var arg2 = call_1.get('arguments')[1];
if (arg2 && !arg2.isExpression()) {
throw new BabelParseError(arg2.node, 'Unexpected `raw` argument to the "makeTemplateObject()" function (expected an expression).');
}
// If there is no second argument then assume that raw and cooked are the same
raw = arg2 !== undefined ? arg2 : cooked;
}
var cookedStrings = unwrapStringLiteralArray(cooked);
var rawStrings = unwrapStringLiteralArray(raw);
var cookedStrings = unwrapStringLiteralArray(cooked.node);
var rawStrings = unwrapStringLiteralArray(raw.node);
return localize_1.ɵmakeTemplateObject(cookedStrings, rawStrings);

@@ -140,2 +155,87 @@ }

/**
* This expression is believed to be a call to a "lazy-load" template object helper function.
* This is expected to be of the form:
*
* ```ts
* function _templateObject() {
* var e = _taggedTemplateLiteral(['cooked string', 'raw string']);
* return _templateObject = function() { return e }, e
* }
* ```
*
* We unwrap this to return the call to `_taggedTemplateLiteral()`.
*
* @param call the call expression to unwrap
* @returns the call expression
*/
function unwrapLazyLoadHelperCall(call) {
var callee = call.get('callee');
if (!callee.isIdentifier()) {
throw new BabelParseError(callee.node, 'Unexpected lazy-load helper call (expected a call of the form `_templateObject()`).');
}
var lazyLoadBinding = call.scope.getBinding(callee.node.name);
if (!lazyLoadBinding) {
throw new BabelParseError(callee.node, 'Missing declaration for lazy-load helper function');
}
var lazyLoadFn = lazyLoadBinding.path;
if (!lazyLoadFn.isFunctionDeclaration()) {
throw new BabelParseError(lazyLoadFn.node, 'Unexpected expression (expected a function declaration');
}
var returnedNode = getReturnedExpression(lazyLoadFn);
if (returnedNode.isCallExpression()) {
return returnedNode;
}
if (returnedNode.isIdentifier()) {
var identifierName = returnedNode.node.name;
var declaration = returnedNode.scope.getBinding(identifierName);
if (declaration === undefined) {
throw new BabelParseError(returnedNode.node, 'Missing declaration for return value from helper.');
}
if (!declaration.path.isVariableDeclarator()) {
throw new BabelParseError(declaration.path.node, 'Unexpected helper return value declaration (expected a variable declaration).');
}
var initializer = declaration.path.get('init');
if (!initializer.isCallExpression()) {
throw new BabelParseError(declaration.path.node, 'Unexpected return value from helper (expected a call expression).');
}
// Remove the lazy load helper if this is the only reference to it.
if (lazyLoadBinding.references === 1) {
lazyLoadFn.remove();
}
return initializer;
}
return call;
}
exports.unwrapLazyLoadHelperCall = unwrapLazyLoadHelperCall;
function getReturnedExpression(fn) {
var e_1, _a;
var bodyStatements = fn.get('body').get('body');
try {
for (var bodyStatements_1 = tslib_1.__values(bodyStatements), bodyStatements_1_1 = bodyStatements_1.next(); !bodyStatements_1_1.done; bodyStatements_1_1 = bodyStatements_1.next()) {
var statement = bodyStatements_1_1.value;
if (statement.isReturnStatement()) {
var argument = statement.get('argument');
if (argument.isSequenceExpression()) {
var expressions = argument.get('expressions');
return Array.isArray(expressions) ? expressions[expressions.length - 1] : expressions;
}
else if (argument.isExpression()) {
return argument;
}
else {
throw new BabelParseError(statement.node, 'Invalid return argument in helper function (expected an expression).');
}
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (bodyStatements_1_1 && !bodyStatements_1_1.done && (_a = bodyStatements_1.return)) _a.call(bodyStatements_1);
}
finally { if (e_1) throw e_1.error; }
}
throw new BabelParseError(fn.node, 'Missing return statement in helper function.');
}
/**
* Is the given `node` an array of literal strings?

@@ -174,7 +274,12 @@ *

}
// Return the parsed message because this will have the meta blocks stripped
return [
localize_1.ɵmakeTemplateObject(e.parsedMessage.messageParts, e.parsedMessage.messageParts),
substitutions
];
}
else {
diagnostics.error(e.message);
return [messageParts, substitutions];
}
return [messageParts, substitutions];
}

@@ -199,2 +304,2 @@ }

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_utils.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/source_file_utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {ɵParsedTranslation, ɵisMissingTranslationError, ɵmakeTemplateObject, ɵtranslate} from '@angular/localize';\nimport {NodePath} from '@babel/traverse';\nimport * as t from '@babel/types';\nimport {Diagnostics} from '../../diagnostics';\n\n/**\n * Is the given `expression` an identifier with the correct name\n * @param expression The expression to check.\n */\nexport function isNamedIdentifier(\n    expression: NodePath<t.Expression>, name: string): expression is NodePath<t.Identifier> {\n  return expression.isIdentifier() && expression.node.name === name;\n}\n\n/**\n* Is the given `identifier` declared globally.\n* @param identifier The identifier to check.\n*/\nexport function isGlobalIdentifier(identifier: NodePath<t.Identifier>) {\n  return !identifier.scope || !identifier.scope.hasBinding(identifier.node.name);\n}\n\n/**\n* Build a translated expression to replace the call to `$localize`.\n* @param messageParts The static parts of the message.\n* @param substitutions The expressions to substitute into the message.\n*/\nexport function buildLocalizeReplacement(\n    messageParts: TemplateStringsArray, substitutions: readonly t.Expression[]): t.Expression {\n  let mappedString: t.Expression = t.stringLiteral(messageParts[0]);\n  for (let i = 1; i < messageParts.length; i++) {\n    mappedString =\n        t.binaryExpression('+', mappedString, wrapInParensIfNecessary(substitutions[i - 1]));\n    mappedString = t.binaryExpression('+', mappedString, t.stringLiteral(messageParts[i]));\n  }\n  return mappedString;\n}\n\n/**\n* Extract the message parts from the given `call` (to `$localize`).\n*\n* The message parts will either by the first argument to the `call` or it will be wrapped in call\n* to a helper function like `__makeTemplateObject`.\n*\n* @param call The AST node of the call to process.\n*/\nexport function unwrapMessagePartsFromLocalizeCall(call: t.CallExpression): TemplateStringsArray {\n  let cooked = call.arguments[0];\n  if (!t.isExpression(cooked)) {\n    throw new BabelParseError(call, 'Unexpected argument to `$localize`: ' + cooked);\n  }\n\n  // If there is no call to `__makeTemplateObject(...)`, then `raw` must be the same as `cooked`.\n  let raw = cooked;\n\n  // Check for cached call of the form `x || x = __makeTemplateObject(...)`\n  if (t.isLogicalExpression(cooked) && cooked.operator === '||' && t.isIdentifier(cooked.left) &&\n      t.isExpression(cooked.right)) {\n    if (t.isAssignmentExpression(cooked.right)) {\n      cooked = cooked.right.right;\n    }\n  }\n\n  // Check for `__makeTemplateObject(cooked, raw)` call\n  if (t.isCallExpression(cooked)) {\n    raw = cooked.arguments[1] as t.Expression;\n    if (!t.isExpression(raw)) {\n      throw new BabelParseError(\n          raw,\n          'Unexpected `raw` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    cooked = cooked.arguments[0];\n    if (!t.isExpression(cooked)) {\n      throw new BabelParseError(\n          cooked,\n          'Unexpected `cooked` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n  }\n\n  const cookedStrings = unwrapStringLiteralArray(cooked);\n  const rawStrings = unwrapStringLiteralArray(raw);\n  return ɵmakeTemplateObject(cookedStrings, rawStrings);\n}\n\n\nexport function unwrapSubstitutionsFromLocalizeCall(call: t.CallExpression): t.Expression[] {\n  const expressions = call.arguments.splice(1);\n  if (!isArrayOfExpressions(expressions)) {\n    const badExpression = expressions.find(expression => !t.isExpression(expression)) !;\n    throw new BabelParseError(\n        badExpression,\n        'Invalid substitutions for `$localize` (expected all substitution arguments to be expressions).');\n  }\n  return expressions;\n}\n\nexport function unwrapMessagePartsFromTemplateLiteral(elements: t.TemplateElement[]):\n    TemplateStringsArray {\n  const cooked = elements.map(q => {\n    if (q.value.cooked === undefined) {\n      throw new BabelParseError(\n          q, `Unexpected undefined message part in \"${elements.map(q => q.value.cooked)}\"`);\n    }\n    return q.value.cooked;\n  });\n  const raw = elements.map(q => q.value.raw);\n  return ɵmakeTemplateObject(cooked, raw);\n}\n\n/**\n* Wrap the given `expression` in parentheses if it is a binary expression.\n*\n* This ensures that this expression is evaluated correctly if it is embedded in another expression.\n*\n* @param expression The expression to potentially wrap.\n*/\nexport function wrapInParensIfNecessary(expression: t.Expression): t.Expression {\n  if (t.isBinaryExpression(expression)) {\n    return t.parenthesizedExpression(expression);\n  } else {\n    return expression;\n  }\n}\n\n/**\n* Extract the string values from an `array` of string literals.\n* @param array The array to unwrap.\n*/\nexport function unwrapStringLiteralArray(array: t.Expression): string[] {\n  if (!isStringLiteralArray(array)) {\n    throw new BabelParseError(\n        array, 'Unexpected messageParts for `$localize` (expected an array of strings).');\n  }\n  return array.elements.map((str: t.StringLiteral) => str.value);\n}\n\n/**\n* Is the given `node` an array of literal strings?\n*\n* @param node The node to test.\n*/\nexport function isStringLiteralArray(node: t.Node): node is t.Expression&\n    {elements: t.StringLiteral[]} {\n  return t.isArrayExpression(node) && node.elements.every(element => t.isStringLiteral(element));\n}\n\n/**\n* Are all the given `nodes` expressions?\n* @param nodes The nodes to test.\n*/\nexport function isArrayOfExpressions(nodes: t.Node[]): nodes is t.Expression[] {\n  return nodes.every(element => t.isExpression(element));\n}\n\n/** Options that affect how the `makeEsXXXTranslatePlugin()` functions work. */\nexport interface TranslatePluginOptions {\n  missingTranslation?: MissingTranslationStrategy;\n  localizeName?: string;\n}\n\n/**\n * How to handle missing translations.\n */\nexport type MissingTranslationStrategy = 'error' | 'warning' | 'ignore';\n\n/**\n * Translate the text of the given message, using the given translations.\n *\n * Logs as warning if the translation is not available\n */\nexport function translate(\n    diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>,\n    messageParts: TemplateStringsArray, substitutions: readonly any[],\n    missingTranslation: MissingTranslationStrategy): [TemplateStringsArray, readonly any[]] {\n  try {\n    return ɵtranslate(translations, messageParts, substitutions);\n  } catch (e) {\n    if (ɵisMissingTranslationError(e)) {\n      if (missingTranslation === 'error') {\n        diagnostics.error(e.message);\n      } else if (missingTranslation === 'warning') {\n        diagnostics.warn(e.message);\n      }\n    } else {\n      diagnostics.error(e.message);\n    }\n    return [messageParts, substitutions];\n  }\n}\n\nexport class BabelParseError extends Error {\n  private readonly type = 'BabelParseError';\n  constructor(public node: t.BaseNode, message: string) { super(message); }\n}\n\nexport function isBabelParseError(e: any): e is BabelParseError {\n  return e.type === 'BabelParseError';\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_utils.js","sourceRoot":"","sources":["../../../../../../../../../../packages/localize/src/tools/src/translate/source_files/source_file_utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {ɵParsedTranslation, ɵisMissingTranslationError, ɵmakeTemplateObject, ɵtranslate} from '@angular/localize';\nimport {NodePath} from '@babel/traverse';\nimport * as t from '@babel/types';\nimport {Diagnostics} from '../../diagnostics';\n\n/**\n * Is the given `expression` an identifier with the correct name\n * @param expression The expression to check.\n */\nexport function isNamedIdentifier(\n    expression: NodePath<t.Expression>, name: string): expression is NodePath<t.Identifier> {\n  return expression.isIdentifier() && expression.node.name === name;\n}\n\n/**\n* Is the given `identifier` declared globally.\n* @param identifier The identifier to check.\n*/\nexport function isGlobalIdentifier(identifier: NodePath<t.Identifier>) {\n  return !identifier.scope || !identifier.scope.hasBinding(identifier.node.name);\n}\n\n/**\n* Build a translated expression to replace the call to `$localize`.\n* @param messageParts The static parts of the message.\n* @param substitutions The expressions to substitute into the message.\n*/\nexport function buildLocalizeReplacement(\n    messageParts: TemplateStringsArray, substitutions: readonly t.Expression[]): t.Expression {\n  let mappedString: t.Expression = t.stringLiteral(messageParts[0]);\n  for (let i = 1; i < messageParts.length; i++) {\n    mappedString =\n        t.binaryExpression('+', mappedString, wrapInParensIfNecessary(substitutions[i - 1]));\n    mappedString = t.binaryExpression('+', mappedString, t.stringLiteral(messageParts[i]));\n  }\n  return mappedString;\n}\n\n/**\n* Extract the message parts from the given `call` (to `$localize`).\n*\n* The message parts will either by the first argument to the `call` or it will be wrapped in call\n* to a helper function like `__makeTemplateObject`.\n*\n* @param call The AST node of the call to process.\n*/\nexport function unwrapMessagePartsFromLocalizeCall(call: NodePath<t.CallExpression>):\n    TemplateStringsArray {\n  let cooked = call.get('arguments')[0];\n\n  if (cooked === undefined) {\n    throw new BabelParseError(call.node, '`$localize` called without any arguments.');\n  }\n  if (!cooked.isExpression()) {\n    throw new BabelParseError(\n        cooked.node, 'Unexpected argument to `$localize` (expected an array).');\n  }\n\n  // If there is no call to `__makeTemplateObject(...)`, then `raw` must be the same as `cooked`.\n  let raw = cooked;\n\n  // Check for cached call of the form `x || x = __makeTemplateObject(...)`\n  if (cooked.isLogicalExpression() && cooked.node.operator === '||' &&\n      cooked.get('left').isIdentifier()) {\n    const right = cooked.get('right');\n    if (right.isAssignmentExpression()) {\n      cooked = right.get('right');\n      if (!cooked.isExpression()) {\n        throw new BabelParseError(\n            cooked.node, 'Unexpected \"makeTemplateObject()\" function (expected an expression).');\n      }\n    }\n  }\n\n  // Check for `__makeTemplateObject(cooked, raw)` or `__templateObject()` calls.\n  if (cooked.isCallExpression()) {\n    let call = cooked;\n    if (call.get('arguments').length === 0) {\n      // No arguments so perhaps it is a `__templateObject()` call.\n      // Unwrap this to get the `_taggedTemplateLiteral(cooked, raw)` call.\n      call = unwrapLazyLoadHelperCall(call);\n    }\n\n    cooked = call.get('arguments')[0];\n    if (!cooked.isExpression()) {\n      throw new BabelParseError(\n          cooked.node,\n          'Unexpected `cooked` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    const arg2 = call.get('arguments')[1];\n    if (arg2 && !arg2.isExpression()) {\n      throw new BabelParseError(\n          arg2.node,\n          'Unexpected `raw` argument to the \"makeTemplateObject()\" function (expected an expression).');\n    }\n    // If there is no second argument then assume that raw and cooked are the same\n    raw = arg2 !== undefined ? arg2 : cooked;\n  }\n\n  const cookedStrings = unwrapStringLiteralArray(cooked.node);\n  const rawStrings = unwrapStringLiteralArray(raw.node);\n  return ɵmakeTemplateObject(cookedStrings, rawStrings);\n}\n\n\nexport function unwrapSubstitutionsFromLocalizeCall(call: t.CallExpression): t.Expression[] {\n  const expressions = call.arguments.splice(1);\n  if (!isArrayOfExpressions(expressions)) {\n    const badExpression = expressions.find(expression => !t.isExpression(expression)) !;\n    throw new BabelParseError(\n        badExpression,\n        'Invalid substitutions for `$localize` (expected all substitution arguments to be expressions).');\n  }\n  return expressions;\n}\n\nexport function unwrapMessagePartsFromTemplateLiteral(elements: t.TemplateElement[]):\n    TemplateStringsArray {\n  const cooked = elements.map(q => {\n    if (q.value.cooked === undefined) {\n      throw new BabelParseError(\n          q, `Unexpected undefined message part in \"${elements.map(q => q.value.cooked)}\"`);\n    }\n    return q.value.cooked;\n  });\n  const raw = elements.map(q => q.value.raw);\n  return ɵmakeTemplateObject(cooked, raw);\n}\n\n/**\n* Wrap the given `expression` in parentheses if it is a binary expression.\n*\n* This ensures that this expression is evaluated correctly if it is embedded in another expression.\n*\n* @param expression The expression to potentially wrap.\n*/\nexport function wrapInParensIfNecessary(expression: t.Expression): t.Expression {\n  if (t.isBinaryExpression(expression)) {\n    return t.parenthesizedExpression(expression);\n  } else {\n    return expression;\n  }\n}\n\n/**\n* Extract the string values from an `array` of string literals.\n* @param array The array to unwrap.\n*/\nexport function unwrapStringLiteralArray(array: t.Expression): string[] {\n  if (!isStringLiteralArray(array)) {\n    throw new BabelParseError(\n        array, 'Unexpected messageParts for `$localize` (expected an array of strings).');\n  }\n  return array.elements.map((str: t.StringLiteral) => str.value);\n}\n\n/**\n * This expression is believed to be a call to a \"lazy-load\" template object helper function.\n * This is expected to be of the form:\n *\n * ```ts\n *  function _templateObject() {\n *    var e = _taggedTemplateLiteral(['cooked string', 'raw string']);\n *    return _templateObject = function() { return e }, e\n *  }\n * ```\n *\n * We unwrap this to return the call to `_taggedTemplateLiteral()`.\n *\n * @param call the call expression to unwrap\n * @returns the  call expression\n */\nexport function unwrapLazyLoadHelperCall(call: NodePath<t.CallExpression>):\n    NodePath<t.CallExpression> {\n  const callee = call.get('callee');\n  if (!callee.isIdentifier()) {\n    throw new BabelParseError(\n        callee.node,\n        'Unexpected lazy-load helper call (expected a call of the form `_templateObject()`).');\n  }\n  const lazyLoadBinding = call.scope.getBinding(callee.node.name);\n  if (!lazyLoadBinding) {\n    throw new BabelParseError(callee.node, 'Missing declaration for lazy-load helper function');\n  }\n  const lazyLoadFn = lazyLoadBinding.path;\n  if (!lazyLoadFn.isFunctionDeclaration()) {\n    throw new BabelParseError(\n        lazyLoadFn.node, 'Unexpected expression (expected a function declaration');\n  }\n  const returnedNode = getReturnedExpression(lazyLoadFn);\n\n  if (returnedNode.isCallExpression()) {\n    return returnedNode;\n  }\n\n  if (returnedNode.isIdentifier()) {\n    const identifierName = returnedNode.node.name;\n    const declaration = returnedNode.scope.getBinding(identifierName);\n    if (declaration === undefined) {\n      throw new BabelParseError(\n          returnedNode.node, 'Missing declaration for return value from helper.');\n    }\n    if (!declaration.path.isVariableDeclarator()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected helper return value declaration (expected a variable declaration).');\n    }\n    const initializer = declaration.path.get('init');\n    if (!initializer.isCallExpression()) {\n      throw new BabelParseError(\n          declaration.path.node,\n          'Unexpected return value from helper (expected a call expression).');\n    }\n\n    // Remove the lazy load helper if this is the only reference to it.\n    if (lazyLoadBinding.references === 1) {\n      lazyLoadFn.remove();\n    }\n\n    return initializer;\n  }\n  return call;\n}\n\nfunction getReturnedExpression(fn: NodePath<t.FunctionDeclaration>): NodePath<t.Expression> {\n  const bodyStatements = fn.get('body').get('body');\n  for (const statement of bodyStatements) {\n    if (statement.isReturnStatement()) {\n      const argument = statement.get('argument');\n      if (argument.isSequenceExpression()) {\n        const expressions = argument.get('expressions');\n        return Array.isArray(expressions) ? expressions[expressions.length - 1] : expressions;\n      } else if (argument.isExpression()) {\n        return argument;\n      } else {\n        throw new BabelParseError(\n            statement.node, 'Invalid return argument in helper function (expected an expression).');\n      }\n    }\n  }\n  throw new BabelParseError(fn.node, 'Missing return statement in helper function.');\n}\n\n/**\n* Is the given `node` an array of literal strings?\n*\n* @param node The node to test.\n*/\nexport function isStringLiteralArray(node: t.Node): node is t.Expression&\n    {elements: t.StringLiteral[]} {\n  return t.isArrayExpression(node) && node.elements.every(element => t.isStringLiteral(element));\n}\n\n/**\n* Are all the given `nodes` expressions?\n* @param nodes The nodes to test.\n*/\nexport function isArrayOfExpressions(nodes: t.Node[]): nodes is t.Expression[] {\n  return nodes.every(element => t.isExpression(element));\n}\n\n/** Options that affect how the `makeEsXXXTranslatePlugin()` functions work. */\nexport interface TranslatePluginOptions {\n  missingTranslation?: MissingTranslationStrategy;\n  localizeName?: string;\n}\n\n/**\n * How to handle missing translations.\n */\nexport type MissingTranslationStrategy = 'error' | 'warning' | 'ignore';\n\n/**\n * Translate the text of the given message, using the given translations.\n *\n * Logs as warning if the translation is not available\n */\nexport function translate(\n    diagnostics: Diagnostics, translations: Record<string, ɵParsedTranslation>,\n    messageParts: TemplateStringsArray, substitutions: readonly any[],\n    missingTranslation: MissingTranslationStrategy): [TemplateStringsArray, readonly any[]] {\n  try {\n    return ɵtranslate(translations, messageParts, substitutions);\n  } catch (e) {\n    if (ɵisMissingTranslationError(e)) {\n      if (missingTranslation === 'error') {\n        diagnostics.error(e.message);\n      } else if (missingTranslation === 'warning') {\n        diagnostics.warn(e.message);\n      }\n      // Return the parsed message because this will have the meta blocks stripped\n      return [\n        ɵmakeTemplateObject(e.parsedMessage.messageParts, e.parsedMessage.messageParts),\n        substitutions\n      ];\n    } else {\n      diagnostics.error(e.message);\n      return [messageParts, substitutions];\n    }\n  }\n}\n\nexport class BabelParseError extends Error {\n  private readonly type = 'BabelParseError';\n  constructor(public node: t.BaseNode, message: string) { super(message); }\n}\n\nexport function isBabelParseError(e: any): e is BabelParseError {\n  return e.type === 'BabelParseError';\n}\n"]}

@@ -47,4 +47,7 @@ /// <amd-module name="@angular/localize/src/tools/src/translate/translator" />

* @param translations A collection of translations to apply to this file.
* @param sourceLocale The locale of the original application source. If provided then an
* additional copy of the application is created under this locale just with the `$localize` calls
* stripped out.
*/
translate(diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[]): void;
translate(diagnostics: Diagnostics, sourceRoot: string, relativeFilePath: string, contents: Buffer, outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void;
}

@@ -59,3 +62,3 @@ /**

constructor(resourceHandlers: TranslationHandler[], diagnostics: Diagnostics);
translateFiles(inputPaths: string[], rootPath: string, outputPathFn: OutputPathFn, translations: TranslationBundle[]): void;
translateFiles(inputPaths: string[], rootPath: string, outputPathFn: OutputPathFn, translations: TranslationBundle[], sourceLocale?: string): void;
}

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

}
Translator.prototype.translateFiles = function (inputPaths, rootPath, outputPathFn, translations) {
Translator.prototype.translateFiles = function (inputPaths, rootPath, outputPathFn, translations, sourceLocale) {
var _this = this;

@@ -35,3 +35,3 @@ inputPaths.forEach(function (inputPath) {

if (resourceHandler.canTranslate(relativePath, contents)) {
return resourceHandler.translate(_this.diagnostics, rootPath, relativePath, contents, outputPathFn, translations);
return resourceHandler.translate(_this.diagnostics, rootPath, relativePath, contents, outputPathFn, translations, sourceLocale);
}

@@ -54,2 +54,2 @@ }

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEsNkJBQThCO0lBRzlCLHlFQUF3QztJQWdEeEM7OztPQUdHO0lBQ0g7UUFDRSxvQkFBb0IsZ0JBQXNDLEVBQVUsV0FBd0I7WUFBeEUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFzQjtZQUFVLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQUcsQ0FBQztRQUVoRyxtQ0FBYyxHQUFkLFVBQ0ksVUFBb0IsRUFBRSxRQUFnQixFQUFFLFlBQTBCLEVBQ2xFLFlBQWlDO1lBRnJDLGlCQWNDO1lBWEMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxVQUFBLFNBQVM7O2dCQUMxQixJQUFNLFFBQVEsR0FBRyxzQkFBUyxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDckQsSUFBTSxZQUFZLEdBQUcsZUFBUSxDQUFDLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQzs7b0JBQ25ELEtBQThCLElBQUEsS0FBQSxpQkFBQSxLQUFJLENBQUMsZ0JBQWdCLENBQUEsZ0JBQUEsNEJBQUU7d0JBQWhELElBQU0sZUFBZSxXQUFBO3dCQUN4QixJQUFJLGVBQWUsQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLFFBQVEsQ0FBQyxFQUFFOzRCQUN4RCxPQUFPLGVBQWUsQ0FBQyxTQUFTLENBQzVCLEtBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFDO3lCQUNyRjtxQkFDRjs7Ozs7Ozs7O2dCQUNELEtBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLHFDQUFtQyxTQUFXLENBQUMsQ0FBQztZQUN6RSxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDSCxpQkFBQztJQUFELENBQUMsQUFsQkQsSUFrQkM7SUFsQlksZ0NBQVUiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge8m1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9ufSBmcm9tICdAYW5ndWxhci9sb2NhbGl6ZSc7XG5pbXBvcnQge3JlbGF0aXZlfSBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtEaWFnbm9zdGljc30gZnJvbSAnLi4vZGlhZ25vc3RpY3MnO1xuaW1wb3J0IHtGaWxlVXRpbHN9IGZyb20gJy4uL2ZpbGVfdXRpbHMnO1xuXG5pbXBvcnQge091dHB1dFBhdGhGbn0gZnJvbSAnLi9vdXRwdXRfcGF0aCc7XG5cblxuXG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGhvbGRzIHRyYW5zbGF0aW9ucyB0aGF0IGhhdmUgYmVlbiBsb2FkZWRcbiAqIGZyb20gYSB0cmFuc2xhdGlvbiBmaWxlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uQnVuZGxlIHtcbiAgbG9jYWxlOiBzdHJpbmc7XG4gIHRyYW5zbGF0aW9uczogUmVjb3JkPMm1TWVzc2FnZUlkLCDJtVBhcnNlZFRyYW5zbGF0aW9uPjtcbn1cblxuLyoqXG4gKiBJbXBsZW1lbnQgdGhpcyBpbnRlcmZhY2UgdG8gcHJvdmlkZSBhIGNsYXNzIHRoYXQgY2FuIGhhbmRsZSB0cmFuc2xhdGlvbiBmb3IgdGhlIGdpdmVuIHJlc291cmNlIGluXG4gKiBhbiBhcHByb3ByaWF0ZSBtYW5uZXIuXG4gKlxuICogRm9yIGV4YW1wbGUsIHNvdXJjZSBjb2RlIGZpbGVzIHdpbGwgbmVlZCB0byBiZSB0cmFuc2Zvcm1lZCBpZiB0aGV5IGNvbnRhaW4gYCRsb2NhbGl6ZWAgdGFnZ2VkXG4gKiB0ZW1wbGF0ZSBzdHJpbmdzLCB3aGlsZSBtb3N0IHN0YXRpYyBhc3NldHMgd2lsbCBqdXN0IG5lZWQgdG8gYmUgY29waWVkLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zbGF0aW9uSGFuZGxlciB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRydWUgaWYgdGhlIGdpdmVuIGZpbGUgY2FuIGJlIHRyYW5zbGF0ZWQgYnkgdGhpcyBoYW5kbGVyLlxuICAgKlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgcmVzb3VyY2UgZmlsZSB0byBoYW5kbGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gaGFuZGxlLlxuICAgKi9cbiAgY2FuVHJhbnNsYXRlKHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRyYW5zbGF0ZSB0aGUgZmlsZSBhdCBgcmVsYXRpdmVGaWxlUGF0aGAgY29udGFpbmluZyBgY29udGVudHNgLCB1c2luZyB0aGUgZ2l2ZW4gYHRyYW5zbGF0aW9uc2AsXG4gICAqIGFuZCB3cml0ZSB0aGUgdHJhbnNsYXRlZCBjb250ZW50IHRvIHRoZSBwYXRoIGNvbXB1dGVkIGJ5IGNhbGxpbmcgYG91dHB1dFBhdGhGbigpYC5cbiAgICpcbiAgICogQHBhcmFtIGRpYWdub3N0aWNzIEFuIG9iamVjdCBmb3IgY29sbGVjdGluZyB0cmFuc2xhdGlvbiBkaWFnbm9zdGljIG1lc3NhZ2VzLlxuICAgKiBAcGFyYW0gc291cmNlUm9vdCBBbiBhYnNvbHV0ZSBwYXRoIHRvIHRoZSByb290IG9mIHRoZSBmaWxlcyBiZWluZyB0cmFuc2xhdGVkLlxuICAgKiBAcGFyYW0gcmVsYXRpdmVGaWxlUGF0aCBBIHJlbGF0aXZlIHBhdGggZnJvbSB0aGUgc291cmNlUm9vdCB0byB0aGUgZmlsZSB0byB0cmFuc2xhdGUuXG4gICAqIEBwYXJhbSBjb250ZW50cyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUgdG8gdHJhbnNsYXRlLlxuICAgKiBAcGFyYW0gb3V0cHV0UGF0aEZuIEEgZnVuY3Rpb24gdGhhdCByZXR1cm5zIGFuIGFic29sdXRlIHBhdGggd2hlcmUgdGhlIG91dHB1dCBmaWxlIHNob3VsZCBiZVxuICAgKiB3cml0dGVuLlxuICAgKiBAcGFyYW0gdHJhbnNsYXRpb25zIEEgY29sbGVjdGlvbiBvZiB0cmFuc2xhdGlvbnMgdG8gYXBwbHkgdG8gdGhpcyBmaWxlLlxuICAgKi9cbiAgdHJhbnNsYXRlKFxuICAgICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCBzb3VyY2VSb290OiBzdHJpbmcsIHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcixcbiAgICAgIG91dHB1dFBhdGhGbjogT3V0cHV0UGF0aEZuLCB0cmFuc2xhdGlvbnM6IFRyYW5zbGF0aW9uQnVuZGxlW10pOiB2b2lkO1xufVxuXG4vKipcbiAqIFRyYW5zbGF0ZSBlYWNoIGZpbGUgKGUuZy4gc291cmNlIGZpbGUgb3Igc3RhdGljIGFzc2V0KSB1c2luZyB0aGUgZ2l2ZW4gYFRyYW5zbGF0aW9uSGFuZGxlcmBzLlxuICogVGhlIGZpbGUgd2lsbCBiZSB0cmFuc2xhdGVkIGJ5IHRoZSBmaXJzdCBoYW5kbGVyIHRoYXQgcmV0dXJucyB0cnVlIGZvciBgY2FuVHJhbnNsYXRlKClgLlxuICovXG5leHBvcnQgY2xhc3MgVHJhbnNsYXRvciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVzb3VyY2VIYW5kbGVyczogVHJhbnNsYXRpb25IYW5kbGVyW10sIHByaXZhdGUgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzKSB7fVxuXG4gIHRyYW5zbGF0ZUZpbGVzKFxuICAgICAgaW5wdXRQYXRoczogc3RyaW5nW10sIHJvb3RQYXRoOiBzdHJpbmcsIG91dHB1dFBhdGhGbjogT3V0cHV0UGF0aEZuLFxuICAgICAgdHJhbnNsYXRpb25zOiBUcmFuc2xhdGlvbkJ1bmRsZVtdKTogdm9pZCB7XG4gICAgaW5wdXRQYXRocy5mb3JFYWNoKGlucHV0UGF0aCA9PiB7XG4gICAgICBjb25zdCBjb250ZW50cyA9IEZpbGVVdGlscy5yZWFkRmlsZUJ1ZmZlcihpbnB1dFBhdGgpO1xuICAgICAgY29uc3QgcmVsYXRpdmVQYXRoID0gcmVsYXRpdmUocm9vdFBhdGgsIGlucHV0UGF0aCk7XG4gICAgICBmb3IgKGNvbnN0IHJlc291cmNlSGFuZGxlciBvZiB0aGlzLnJlc291cmNlSGFuZGxlcnMpIHtcbiAgICAgICAgaWYgKHJlc291cmNlSGFuZGxlci5jYW5UcmFuc2xhdGUocmVsYXRpdmVQYXRoLCBjb250ZW50cykpIHtcbiAgICAgICAgICByZXR1cm4gcmVzb3VyY2VIYW5kbGVyLnRyYW5zbGF0ZShcbiAgICAgICAgICAgICAgdGhpcy5kaWFnbm9zdGljcywgcm9vdFBhdGgsIHJlbGF0aXZlUGF0aCwgY29udGVudHMsIG91dHB1dFBhdGhGbiwgdHJhbnNsYXRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgdGhpcy5kaWFnbm9zdGljcy5lcnJvcihgVW5hYmxlIHRvIGhhbmRsZSByZXNvdXJjZSBmaWxlOiAke2lucHV0UGF0aH1gKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xvY2FsaXplL3NyYy90b29scy9zcmMvdHJhbnNsYXRlL3RyYW5zbGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBUUEsNkJBQThCO0lBRzlCLHlFQUF3QztJQW1EeEM7OztPQUdHO0lBQ0g7UUFDRSxvQkFBb0IsZ0JBQXNDLEVBQVUsV0FBd0I7WUFBeEUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFzQjtZQUFVLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQUcsQ0FBQztRQUVoRyxtQ0FBYyxHQUFkLFVBQ0ksVUFBb0IsRUFBRSxRQUFnQixFQUFFLFlBQTBCLEVBQ2xFLFlBQWlDLEVBQUUsWUFBcUI7WUFGNUQsaUJBZUM7WUFaQyxVQUFVLENBQUMsT0FBTyxDQUFDLFVBQUEsU0FBUzs7Z0JBQzFCLElBQU0sUUFBUSxHQUFHLHNCQUFTLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUNyRCxJQUFNLFlBQVksR0FBRyxlQUFRLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDOztvQkFDbkQsS0FBOEIsSUFBQSxLQUFBLGlCQUFBLEtBQUksQ0FBQyxnQkFBZ0IsQ0FBQSxnQkFBQSw0QkFBRTt3QkFBaEQsSUFBTSxlQUFlLFdBQUE7d0JBQ3hCLElBQUksZUFBZSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsUUFBUSxDQUFDLEVBQUU7NEJBQ3hELE9BQU8sZUFBZSxDQUFDLFNBQVMsQ0FDNUIsS0FBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUM5RSxZQUFZLENBQUMsQ0FBQzt5QkFDbkI7cUJBQ0Y7Ozs7Ozs7OztnQkFDRCxLQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxxQ0FBbUMsU0FBVyxDQUFDLENBQUM7WUFDekUsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0gsaUJBQUM7SUFBRCxDQUFDLEFBbkJELElBbUJDO0lBbkJZLGdDQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHvJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvbG9jYWxpemUnO1xuaW1wb3J0IHtyZWxhdGl2ZX0gZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7RGlhZ25vc3RpY3N9IGZyb20gJy4uL2RpYWdub3N0aWNzJztcbmltcG9ydCB7RmlsZVV0aWxzfSBmcm9tICcuLi9maWxlX3V0aWxzJztcblxuaW1wb3J0IHtPdXRwdXRQYXRoRm59IGZyb20gJy4vb3V0cHV0X3BhdGgnO1xuXG5cblxuLyoqXG4gKiBBbiBvYmplY3QgdGhhdCBob2xkcyB0cmFuc2xhdGlvbnMgdGhhdCBoYXZlIGJlZW4gbG9hZGVkXG4gKiBmcm9tIGEgdHJhbnNsYXRpb24gZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmFuc2xhdGlvbkJ1bmRsZSB7XG4gIGxvY2FsZTogc3RyaW5nO1xuICB0cmFuc2xhdGlvbnM6IFJlY29yZDzJtU1lc3NhZ2VJZCwgybVQYXJzZWRUcmFuc2xhdGlvbj47XG59XG5cbi8qKlxuICogSW1wbGVtZW50IHRoaXMgaW50ZXJmYWNlIHRvIHByb3ZpZGUgYSBjbGFzcyB0aGF0IGNhbiBoYW5kbGUgdHJhbnNsYXRpb24gZm9yIHRoZSBnaXZlbiByZXNvdXJjZSBpblxuICogYW4gYXBwcm9wcmlhdGUgbWFubmVyLlxuICpcbiAqIEZvciBleGFtcGxlLCBzb3VyY2UgY29kZSBmaWxlcyB3aWxsIG5lZWQgdG8gYmUgdHJhbnNmb3JtZWQgaWYgdGhleSBjb250YWluIGAkbG9jYWxpemVgIHRhZ2dlZFxuICogdGVtcGxhdGUgc3RyaW5ncywgd2hpbGUgbW9zdCBzdGF0aWMgYXNzZXRzIHdpbGwganVzdCBuZWVkIHRvIGJlIGNvcGllZC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmFuc2xhdGlvbkhhbmRsZXIge1xuICAvKipcbiAgICogUmV0dXJucyB0cnVlIGlmIHRoZSBnaXZlbiBmaWxlIGNhbiBiZSB0cmFuc2xhdGVkIGJ5IHRoaXMgaGFuZGxlci5cbiAgICpcbiAgICogQHBhcmFtIHJlbGF0aXZlRmlsZVBhdGggQSByZWxhdGl2ZSBwYXRoIGZyb20gdGhlIHNvdXJjZVJvb3QgdG8gdGhlIHJlc291cmNlIGZpbGUgdG8gaGFuZGxlLlxuICAgKiBAcGFyYW0gY29udGVudHMgVGhlIGNvbnRlbnRzIG9mIHRoZSBmaWxlIHRvIGhhbmRsZS5cbiAgICovXG4gIGNhblRyYW5zbGF0ZShyZWxhdGl2ZUZpbGVQYXRoOiBzdHJpbmcsIGNvbnRlbnRzOiBCdWZmZXIpOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUcmFuc2xhdGUgdGhlIGZpbGUgYXQgYHJlbGF0aXZlRmlsZVBhdGhgIGNvbnRhaW5pbmcgYGNvbnRlbnRzYCwgdXNpbmcgdGhlIGdpdmVuIGB0cmFuc2xhdGlvbnNgLFxuICAgKiBhbmQgd3JpdGUgdGhlIHRyYW5zbGF0ZWQgY29udGVudCB0byB0aGUgcGF0aCBjb21wdXRlZCBieSBjYWxsaW5nIGBvdXRwdXRQYXRoRm4oKWAuXG4gICAqXG4gICAqIEBwYXJhbSBkaWFnbm9zdGljcyBBbiBvYmplY3QgZm9yIGNvbGxlY3RpbmcgdHJhbnNsYXRpb24gZGlhZ25vc3RpYyBtZXNzYWdlcy5cbiAgICogQHBhcmFtIHNvdXJjZVJvb3QgQW4gYWJzb2x1dGUgcGF0aCB0byB0aGUgcm9vdCBvZiB0aGUgZmlsZXMgYmVpbmcgdHJhbnNsYXRlZC5cbiAgICogQHBhcmFtIHJlbGF0aXZlRmlsZVBhdGggQSByZWxhdGl2ZSBwYXRoIGZyb20gdGhlIHNvdXJjZVJvb3QgdG8gdGhlIGZpbGUgdG8gdHJhbnNsYXRlLlxuICAgKiBAcGFyYW0gY29udGVudHMgVGhlIGNvbnRlbnRzIG9mIHRoZSBmaWxlIHRvIHRyYW5zbGF0ZS5cbiAgICogQHBhcmFtIG91dHB1dFBhdGhGbiBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhbiBhYnNvbHV0ZSBwYXRoIHdoZXJlIHRoZSBvdXRwdXQgZmlsZSBzaG91bGQgYmVcbiAgICogd3JpdHRlbi5cbiAgICogQHBhcmFtIHRyYW5zbGF0aW9ucyBBIGNvbGxlY3Rpb24gb2YgdHJhbnNsYXRpb25zIHRvIGFwcGx5IHRvIHRoaXMgZmlsZS5cbiAgICogQHBhcmFtIHNvdXJjZUxvY2FsZSBUaGUgbG9jYWxlIG9mIHRoZSBvcmlnaW5hbCBhcHBsaWNhdGlvbiBzb3VyY2UuIElmIHByb3ZpZGVkIHRoZW4gYW5cbiAgICogYWRkaXRpb25hbCBjb3B5IG9mIHRoZSBhcHBsaWNhdGlvbiBpcyBjcmVhdGVkIHVuZGVyIHRoaXMgbG9jYWxlIGp1c3Qgd2l0aCB0aGUgYCRsb2NhbGl6ZWAgY2FsbHNcbiAgICogc3RyaXBwZWQgb3V0LlxuICAgKi9cbiAgdHJhbnNsYXRlKFxuICAgICAgZGlhZ25vc3RpY3M6IERpYWdub3N0aWNzLCBzb3VyY2VSb290OiBzdHJpbmcsIHJlbGF0aXZlRmlsZVBhdGg6IHN0cmluZywgY29udGVudHM6IEJ1ZmZlcixcbiAgICAgIG91dHB1dFBhdGhGbjogT3V0cHV0UGF0aEZuLCB0cmFuc2xhdGlvbnM6IFRyYW5zbGF0aW9uQnVuZGxlW10sIHNvdXJjZUxvY2FsZT86IHN0cmluZyk6IHZvaWQ7XG59XG5cbi8qKlxuICogVHJhbnNsYXRlIGVhY2ggZmlsZSAoZS5nLiBzb3VyY2UgZmlsZSBvciBzdGF0aWMgYXNzZXQpIHVzaW5nIHRoZSBnaXZlbiBgVHJhbnNsYXRpb25IYW5kbGVyYHMuXG4gKiBUaGUgZmlsZSB3aWxsIGJlIHRyYW5zbGF0ZWQgYnkgdGhlIGZpcnN0IGhhbmRsZXIgdGhhdCByZXR1cm5zIHRydWUgZm9yIGBjYW5UcmFuc2xhdGUoKWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBUcmFuc2xhdG9yIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZXNvdXJjZUhhbmRsZXJzOiBUcmFuc2xhdGlvbkhhbmRsZXJbXSwgcHJpdmF0ZSBkaWFnbm9zdGljczogRGlhZ25vc3RpY3MpIHt9XG5cbiAgdHJhbnNsYXRlRmlsZXMoXG4gICAgICBpbnB1dFBhdGhzOiBzdHJpbmdbXSwgcm9vdFBhdGg6IHN0cmluZywgb3V0cHV0UGF0aEZuOiBPdXRwdXRQYXRoRm4sXG4gICAgICB0cmFuc2xhdGlvbnM6IFRyYW5zbGF0aW9uQnVuZGxlW10sIHNvdXJjZUxvY2FsZT86IHN0cmluZyk6IHZvaWQge1xuICAgIGlucHV0UGF0aHMuZm9yRWFjaChpbnB1dFBhdGggPT4ge1xuICAgICAgY29uc3QgY29udGVudHMgPSBGaWxlVXRpbHMucmVhZEZpbGVCdWZmZXIoaW5wdXRQYXRoKTtcbiAgICAgIGNvbnN0IHJlbGF0aXZlUGF0aCA9IHJlbGF0aXZlKHJvb3RQYXRoLCBpbnB1dFBhdGgpO1xuICAgICAgZm9yIChjb25zdCByZXNvdXJjZUhhbmRsZXIgb2YgdGhpcy5yZXNvdXJjZUhhbmRsZXJzKSB7XG4gICAgICAgIGlmIChyZXNvdXJjZUhhbmRsZXIuY2FuVHJhbnNsYXRlKHJlbGF0aXZlUGF0aCwgY29udGVudHMpKSB7XG4gICAgICAgICAgcmV0dXJuIHJlc291cmNlSGFuZGxlci50cmFuc2xhdGUoXG4gICAgICAgICAgICAgIHRoaXMuZGlhZ25vc3RpY3MsIHJvb3RQYXRoLCByZWxhdGl2ZVBhdGgsIGNvbnRlbnRzLCBvdXRwdXRQYXRoRm4sIHRyYW5zbGF0aW9ucyxcbiAgICAgICAgICAgICAgc291cmNlTG9jYWxlKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgdGhpcy5kaWFnbm9zdGljcy5lcnJvcihgVW5hYmxlIHRvIGhhbmRsZSByZXNvdXJjZSBmaWxlOiAke2lucHV0UGF0aH1gKTtcbiAgICB9KTtcbiAgfVxufVxuIl19

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

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc