Comparing version 0.34.3 to 0.35.0
{ | ||
"name": "tsickle", | ||
"version": "0.34.3", | ||
"version": "0.35.0", | ||
"description": "Transpile TypeScript code to JavaScript with Closure annotations.", | ||
@@ -20,5 +20,6 @@ "main": "src/tsickle.js", | ||
"peerDependencies": { | ||
"typescript": "~3.3.1" | ||
"typescript": "~3.4.1" | ||
}, | ||
"devDependencies": { | ||
"@bazel/typescript": "^0.24.1", | ||
"@types/diff-match-patch": "^1.0.32", | ||
@@ -38,3 +39,3 @@ "@types/glob": "5.0.35", | ||
"tslint": "5.11.0", | ||
"typescript": "3.3.1" | ||
"typescript": "~3.4.1" | ||
}, | ||
@@ -41,0 +42,0 @@ "scripts": { |
@@ -52,2 +52,18 @@ # Tsickle - TypeScript to Closure Translator [![Build Status](https://circleci.com/gh/angular/tsickle.svg?style=svg)](https://circleci.com/gh/angular/tsickle) [![Windows build](https://ci.appveyor.com/api/projects/status/puxdblmlqbofqqt1/branch/master?svg=true)](https://ci.appveyor.com/project/alexeagle/tsickle/branch/master) | ||
### Output format | ||
Tsickle is designed to do whatever is necessary to make the code acceptable by | ||
Closure compiler. We view its output as a necessary intermediate form for | ||
communicating to the Closure compiler, and not something for humans. This means | ||
the tsickle output may be kind of ugly to read. Its only real use is to pass it | ||
on to the compiler. | ||
For one example, the syntax of types tsickle produces are specific to Closure. | ||
The type `{!Foo}` means "Foo, excluding null" and a type alias becomes a `var` | ||
statement that is tagged with `@typedef`. | ||
Tsickle emits modules using Closure's `goog.module` module system. This system | ||
is similar to but different from ES modules, and was supported by Closure before | ||
the ES module system was finalized. | ||
### Differences from TypeScript | ||
@@ -54,0 +70,0 @@ |
@@ -19,4 +19,4 @@ /** | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var assert = require("assert"); | ||
var path = require("path"); | ||
const assert = require("assert"); | ||
const path = require("path"); | ||
/** | ||
@@ -29,3 +29,3 @@ * asserts that the given fileName is an absolute path. | ||
function assertAbsolute(fileName) { | ||
assert(path.isAbsolute(fileName), "expected " + JSON.stringify(fileName) + " to be absolute"); | ||
assert(path.isAbsolute(fileName), `expected ${JSON.stringify(fileName)} to be absolute`); | ||
} | ||
@@ -57,3 +57,3 @@ exports.assertAbsolute = assertAbsolute; | ||
// Replace characters not supported by goog.module. | ||
var moduleName = fileName.replace(/\/|\\/g, '.').replace(/^[^a-zA-Z_$]/, '_').replace(/[^a-zA-Z0-9._$]/g, '_'); | ||
const moduleName = fileName.replace(/\/|\\/g, '.').replace(/^[^a-zA-Z_$]/, '_').replace(/[^a-zA-Z0-9._$]/g, '_'); | ||
return moduleName; | ||
@@ -63,2 +63,2 @@ } | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpX3N1cHBvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY2xpX3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSCwrQkFBaUM7SUFDakMsMkJBQTZCO0lBRTdCOzs7OztPQUtHO0lBQ0gsU0FBZ0IsY0FBYyxDQUFDLFFBQWdCO1FBQzdDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLGNBQVksSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsb0JBQWlCLENBQUMsQ0FBQztJQUMzRixDQUFDO0lBRkQsd0NBRUM7SUFFRDs7O09BR0c7SUFDSCxTQUFnQixnQkFBZ0IsQ0FDNUIsY0FBc0IsRUFBRSxPQUFlLEVBQUUsUUFBZ0I7UUFDM0QsUUFBUSxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbEQsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxFQUFFO1lBQ3ZCLHVCQUF1QjtZQUN2Qiw4REFBOEQ7WUFDOUQsUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUN2RDtRQUVELHdFQUF3RTtRQUN4RSw0RUFBNEU7UUFDNUUsc0NBQXNDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztZQUFFLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUUvRSx1RUFBdUU7UUFDdkUsaUVBQWlFO1FBRWpFLGtFQUFrRTtRQUNsRSw0QkFBNEI7UUFFNUIsSUFBSSxjQUFjLEVBQUU7WUFDbEIsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1NBQ3BEO1FBRUQsbURBQW1EO1FBQ25ELElBQU0sVUFBVSxHQUNaLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLGtCQUFrQixFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBRWxHLE9BQU8sVUFBVSxDQUFDO0lBQ3BCLENBQUM7SUE5QkQsNENBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgKiBhcyBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbi8qKlxuICogYXNzZXJ0cyB0aGF0IHRoZSBnaXZlbiBmaWxlTmFtZSBpcyBhbiBhYnNvbHV0ZSBwYXRoLlxuICpcbiAqIFRoZSBUeXBlU2NyaXB0IEFQSSB3b3JrcyBpbiBhYnNvbHV0ZSBwYXRocywgc28gd2UgbXVzdCBiZSBjYXJlZnVsIHRvIHJlc29sdmVcbiAqIHBhdGhzIGJlZm9yZSBoYW5kaW5nIHRoZW0gb3ZlciB0byBUeXBlU2NyaXB0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0QWJzb2x1dGUoZmlsZU5hbWU6IHN0cmluZykge1xuICBhc3NlcnQocGF0aC5pc0Fic29sdXRlKGZpbGVOYW1lKSwgYGV4cGVjdGVkICR7SlNPTi5zdHJpbmdpZnkoZmlsZU5hbWUpfSB0byBiZSBhYnNvbHV0ZWApO1xufVxuXG4vKipcbiAqIFRha2VzIGEgY29udGV4dCAodHMuU291cmNlRmlsZS5maWxlTmFtZSBvZiB0aGUgY3VycmVudCBmaWxlKSBhbmQgdGhlIGltcG9ydCBVUkwgb2YgYW4gRVM2XG4gKiBpbXBvcnQgYW5kIGdlbmVyYXRlcyBhIGdvb2dtb2R1bGUgbW9kdWxlIG5hbWUgZm9yIHRoZSBpbXBvcnRlZCBtb2R1bGUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXRoVG9Nb2R1bGVOYW1lKFxuICAgIHJvb3RNb2R1bGVQYXRoOiBzdHJpbmcsIGNvbnRleHQ6IHN0cmluZywgZmlsZU5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGZpbGVOYW1lID0gZmlsZU5hbWUucmVwbGFjZSgvKFxcLmQpP1xcLlt0al1zJC8sICcnKTtcblxuICBpZiAoZmlsZU5hbWVbMF0gPT09ICcuJykge1xuICAgIC8vICcuL2Zvbycgb3IgJy4uL2ZvbycuXG4gICAgLy8gUmVzb2x2ZSB0aGUgcGF0aCBhZ2FpbnN0IHRoZSBkaXJuYW1lIG9mIHRoZSBjdXJyZW50IG1vZHVsZS5cbiAgICBmaWxlTmFtZSA9IHBhdGguam9pbihwYXRoLmRpcm5hbWUoY29udGV4dCksIGZpbGVOYW1lKTtcbiAgfVxuXG4gIC8vIFRPRE8oZXZhbm0pOiB2YXJpb3VzIHRlc3RzIGFzc3VtZSB0aGV5IGNhbiBpbXBvcnQgcmVsYXRpdmUgcGF0aHMgbGlrZVxuICAvLyAnZm9vL2JhcicgYW5kIGhhdmUgdGhlbSBpbnRlcnByZXRlZCBhcyByb290LXJlbGF0aXZlOyBwcmVzZXJ2ZSB0aGF0IGhlcmUuXG4gIC8vIEZpeCB0aGlzIGJ5IHJlbW92aW5nIHRoZSBuZXh0IGxpbmUuXG4gIGlmICghcGF0aC5pc0Fic29sdXRlKGZpbGVOYW1lKSkgZmlsZU5hbWUgPSBwYXRoLmpvaW4ocm9vdE1vZHVsZVBhdGgsIGZpbGVOYW1lKTtcblxuICAvLyBUT0RPKGV2YW5tKTogdmFyaW91cyB0ZXN0cyBhc3N1bWUgdGhleSBjYW4gcGFzcyBpbiBhICdmaWxlTmFtZScgbGlrZVxuICAvLyAnZ29vZzpmb28uYmFyJyBhbmQgaGF2ZSB0aGlzIGZ1bmN0aW9uIGRvIHNvbWV0aGluZyByZWFzb25hYmxlLlxuXG4gIC8vIEZvciBjb3JyZWN0bmVzcywgdGhlIGFib3ZlIG11c3QgaGF2ZSBwcm9kdWNlZCBhbiBhYnNvbHV0ZSBwYXRoLlxuICAvLyBhc3NlcnRBYnNvbHV0ZShmaWxlTmFtZSk7XG5cbiAgaWYgKHJvb3RNb2R1bGVQYXRoKSB7XG4gICAgZmlsZU5hbWUgPSBwYXRoLnJlbGF0aXZlKHJvb3RNb2R1bGVQYXRoLCBmaWxlTmFtZSk7XG4gIH1cblxuICAvLyBSZXBsYWNlIGNoYXJhY3RlcnMgbm90IHN1cHBvcnRlZCBieSBnb29nLm1vZHVsZS5cbiAgY29uc3QgbW9kdWxlTmFtZSA9XG4gICAgICBmaWxlTmFtZS5yZXBsYWNlKC9cXC98XFxcXC9nLCAnLicpLnJlcGxhY2UoL15bXmEtekEtWl8kXS8sICdfJykucmVwbGFjZSgvW15hLXpBLVowLTkuXyRdL2csICdfJyk7XG5cbiAgcmV0dXJuIG1vZHVsZU5hbWU7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpX3N1cHBvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY2xpX3N1cHBvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSCxpQ0FBaUM7SUFDakMsNkJBQTZCO0lBRTdCOzs7OztPQUtHO0lBQ0gsU0FBZ0IsY0FBYyxDQUFDLFFBQWdCO1FBQzdDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLFlBQVksSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMzRixDQUFDO0lBRkQsd0NBRUM7SUFFRDs7O09BR0c7SUFDSCxTQUFnQixnQkFBZ0IsQ0FDNUIsY0FBc0IsRUFBRSxPQUFlLEVBQUUsUUFBZ0I7UUFDM0QsUUFBUSxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbEQsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxFQUFFO1lBQ3ZCLHVCQUF1QjtZQUN2Qiw4REFBOEQ7WUFDOUQsUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUN2RDtRQUVELHdFQUF3RTtRQUN4RSw0RUFBNEU7UUFDNUUsc0NBQXNDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztZQUFFLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUUvRSx1RUFBdUU7UUFDdkUsaUVBQWlFO1FBRWpFLGtFQUFrRTtRQUNsRSw0QkFBNEI7UUFFNUIsSUFBSSxjQUFjLEVBQUU7WUFDbEIsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1NBQ3BEO1FBRUQsbURBQW1EO1FBQ25ELE1BQU0sVUFBVSxHQUNaLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLGtCQUFrQixFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBRWxHLE9BQU8sVUFBVSxDQUFDO0lBQ3BCLENBQUM7SUE5QkQsNENBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgKiBhcyBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbi8qKlxuICogYXNzZXJ0cyB0aGF0IHRoZSBnaXZlbiBmaWxlTmFtZSBpcyBhbiBhYnNvbHV0ZSBwYXRoLlxuICpcbiAqIFRoZSBUeXBlU2NyaXB0IEFQSSB3b3JrcyBpbiBhYnNvbHV0ZSBwYXRocywgc28gd2UgbXVzdCBiZSBjYXJlZnVsIHRvIHJlc29sdmVcbiAqIHBhdGhzIGJlZm9yZSBoYW5kaW5nIHRoZW0gb3ZlciB0byBUeXBlU2NyaXB0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0QWJzb2x1dGUoZmlsZU5hbWU6IHN0cmluZykge1xuICBhc3NlcnQocGF0aC5pc0Fic29sdXRlKGZpbGVOYW1lKSwgYGV4cGVjdGVkICR7SlNPTi5zdHJpbmdpZnkoZmlsZU5hbWUpfSB0byBiZSBhYnNvbHV0ZWApO1xufVxuXG4vKipcbiAqIFRha2VzIGEgY29udGV4dCAodHMuU291cmNlRmlsZS5maWxlTmFtZSBvZiB0aGUgY3VycmVudCBmaWxlKSBhbmQgdGhlIGltcG9ydCBVUkwgb2YgYW4gRVM2XG4gKiBpbXBvcnQgYW5kIGdlbmVyYXRlcyBhIGdvb2dtb2R1bGUgbW9kdWxlIG5hbWUgZm9yIHRoZSBpbXBvcnRlZCBtb2R1bGUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXRoVG9Nb2R1bGVOYW1lKFxuICAgIHJvb3RNb2R1bGVQYXRoOiBzdHJpbmcsIGNvbnRleHQ6IHN0cmluZywgZmlsZU5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGZpbGVOYW1lID0gZmlsZU5hbWUucmVwbGFjZSgvKFxcLmQpP1xcLlt0al1zJC8sICcnKTtcblxuICBpZiAoZmlsZU5hbWVbMF0gPT09ICcuJykge1xuICAgIC8vICcuL2Zvbycgb3IgJy4uL2ZvbycuXG4gICAgLy8gUmVzb2x2ZSB0aGUgcGF0aCBhZ2FpbnN0IHRoZSBkaXJuYW1lIG9mIHRoZSBjdXJyZW50IG1vZHVsZS5cbiAgICBmaWxlTmFtZSA9IHBhdGguam9pbihwYXRoLmRpcm5hbWUoY29udGV4dCksIGZpbGVOYW1lKTtcbiAgfVxuXG4gIC8vIFRPRE8oZXZhbm0pOiB2YXJpb3VzIHRlc3RzIGFzc3VtZSB0aGV5IGNhbiBpbXBvcnQgcmVsYXRpdmUgcGF0aHMgbGlrZVxuICAvLyAnZm9vL2JhcicgYW5kIGhhdmUgdGhlbSBpbnRlcnByZXRlZCBhcyByb290LXJlbGF0aXZlOyBwcmVzZXJ2ZSB0aGF0IGhlcmUuXG4gIC8vIEZpeCB0aGlzIGJ5IHJlbW92aW5nIHRoZSBuZXh0IGxpbmUuXG4gIGlmICghcGF0aC5pc0Fic29sdXRlKGZpbGVOYW1lKSkgZmlsZU5hbWUgPSBwYXRoLmpvaW4ocm9vdE1vZHVsZVBhdGgsIGZpbGVOYW1lKTtcblxuICAvLyBUT0RPKGV2YW5tKTogdmFyaW91cyB0ZXN0cyBhc3N1bWUgdGhleSBjYW4gcGFzcyBpbiBhICdmaWxlTmFtZScgbGlrZVxuICAvLyAnZ29vZzpmb28uYmFyJyBhbmQgaGF2ZSB0aGlzIGZ1bmN0aW9uIGRvIHNvbWV0aGluZyByZWFzb25hYmxlLlxuXG4gIC8vIEZvciBjb3JyZWN0bmVzcywgdGhlIGFib3ZlIG11c3QgaGF2ZSBwcm9kdWNlZCBhbiBhYnNvbHV0ZSBwYXRoLlxuICAvLyBhc3NlcnRBYnNvbHV0ZShmaWxlTmFtZSk7XG5cbiAgaWYgKHJvb3RNb2R1bGVQYXRoKSB7XG4gICAgZmlsZU5hbWUgPSBwYXRoLnJlbGF0aXZlKHJvb3RNb2R1bGVQYXRoLCBmaWxlTmFtZSk7XG4gIH1cblxuICAvLyBSZXBsYWNlIGNoYXJhY3RlcnMgbm90IHN1cHBvcnRlZCBieSBnb29nLm1vZHVsZS5cbiAgY29uc3QgbW9kdWxlTmFtZSA9XG4gICAgICBmaWxlTmFtZS5yZXBsYWNlKC9cXC98XFxcXC9nLCAnLicpLnJlcGxhY2UoL15bXmEtekEtWl8kXS8sICdfJykucmVwbGFjZSgvW15hLXpBLVowLTkuXyRdL2csICdfJyk7XG5cbiAgcmV0dXJuIG1vZHVsZU5hbWU7XG59XG4iXX0= |
@@ -83,1 +83,17 @@ /** | ||
var SymbolConstructor; | ||
/** | ||
* This is a placeholder for a Closure type to be determined. | ||
* @constructor | ||
*/ | ||
function bigintPlaceholder() {} | ||
/** @typedef {!Object} */ | ||
var GlobalFetch; | ||
/** | ||
* @interface | ||
* @extends{WorkerGlobalScope} | ||
* @extends{Window} | ||
*/ | ||
var WindowOrWorkerGlobalScope; |
@@ -8,12 +8,2 @@ /** | ||
*/ | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
(function (factory) { | ||
@@ -30,4 +20,4 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var ts = require("typescript"); | ||
var transformer_util_1 = require("tsickle/src/transformer_util"); | ||
const ts = require("typescript"); | ||
const transformer_util_1 = require("tsickle/src/transformer_util"); | ||
/** | ||
@@ -38,3 +28,3 @@ * Returns the declarations for the given decorator. | ||
// Walk down the expression to find the identifier of the decorator function. | ||
var node = decorator; | ||
let node = decorator; | ||
while (node.kind !== ts.SyntaxKind.Identifier) { | ||
@@ -49,3 +39,3 @@ if (node.kind === ts.SyntaxKind.Decorator || node.kind === ts.SyntaxKind.CallExpression) { | ||
} | ||
var decSym = typeChecker.getSymbolAtLocation(node); | ||
let decSym = typeChecker.getSymbolAtLocation(node); | ||
if (!decSym) | ||
@@ -65,3 +55,3 @@ return []; | ||
return node.decorators && | ||
node.decorators.some(function (decorator) { return isExportingDecorator(decorator, typeChecker); }); | ||
node.decorators.some(decorator => isExportingDecorator(decorator, typeChecker)); | ||
} | ||
@@ -73,23 +63,12 @@ exports.hasExportingDecorator = hasExportingDecorator; | ||
function isExportingDecorator(decorator, typeChecker) { | ||
return getDecoratorDeclarations(decorator, typeChecker).some(function (declaration) { | ||
var e_1, _a; | ||
var range = transformer_util_1.getAllLeadingComments(declaration); | ||
return getDecoratorDeclarations(decorator, typeChecker).some(declaration => { | ||
const range = transformer_util_1.getAllLeadingComments(declaration); | ||
if (!range) { | ||
return false; | ||
} | ||
try { | ||
for (var range_1 = __values(range), range_1_1 = range_1.next(); !range_1_1.done; range_1_1 = range_1.next()) { | ||
var text = range_1_1.value.text; | ||
if (/@ExportDecoratedItems\b/.test(text)) { | ||
return true; | ||
} | ||
for (const { text } of range) { | ||
if (/@ExportDecoratedItems\b/.test(text)) { | ||
return true; | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (range_1_1 && !range_1_1.done && (_a = range_1.return)) _a.call(range_1); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
return false; | ||
@@ -99,2 +78,2 @@ }); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUVILCtCQUFpQztJQUVqQyxpRUFBeUQ7SUFFekQ7O09BRUc7SUFDSCxTQUFnQix3QkFBd0IsQ0FDcEMsU0FBdUIsRUFBRSxXQUEyQjtRQUN0RCw2RUFBNkU7UUFDN0UsSUFBSSxJQUFJLEdBQVksU0FBUyxDQUFDO1FBQzlCLE9BQU8sSUFBSSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRTtZQUM3QyxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssRUFBRSxDQUFDLFVBQVUsQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsVUFBVSxDQUFDLGNBQWMsRUFBRTtnQkFDdkYsSUFBSSxHQUFJLElBQXlDLENBQUMsVUFBVSxDQUFDO2FBQzlEO2lCQUFNO2dCQUNMLHVEQUF1RDtnQkFDdkQsT0FBTyxFQUFFLENBQUM7YUFDWDtTQUNGO1FBRUQsSUFBSSxNQUFNLEdBQUcsV0FBVyxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ25ELElBQUksQ0FBQyxNQUFNO1lBQUUsT0FBTyxFQUFFLENBQUM7UUFDdkIsSUFBSSxNQUFNLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFO1lBQ3ZDLE1BQU0sR0FBRyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDL0M7UUFDRCxPQUFPLE1BQU0sQ0FBQyxlQUFlLEVBQUUsSUFBSSxFQUFFLENBQUM7SUFDeEMsQ0FBQztJQW5CRCw0REFtQkM7SUFFRDs7O09BR0c7SUFDSCxTQUFnQixxQkFBcUIsQ0FBQyxJQUFhLEVBQUUsV0FBMkI7UUFDOUUsT0FBTyxJQUFJLENBQUMsVUFBVTtZQUNsQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxVQUFBLFNBQVMsSUFBSSxPQUFBLG9CQUFvQixDQUFDLFNBQVMsRUFBRSxXQUFXLENBQUMsRUFBNUMsQ0FBNEMsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFIRCxzREFHQztJQUVEOztPQUVHO0lBQ0gsU0FBUyxvQkFBb0IsQ0FBQyxTQUF1QixFQUFFLFdBQTJCO1FBQ2hGLE9BQU8sd0JBQXdCLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFBLFdBQVc7O1lBQ3RFLElBQU0sS0FBSyxHQUFHLHdDQUFxQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2pELElBQUksQ0FBQyxLQUFLLEVBQUU7Z0JBQ1YsT0FBTyxLQUFLLENBQUM7YUFDZDs7Z0JBQ0QsS0FBcUIsSUFBQSxVQUFBLFNBQUEsS0FBSyxDQUFBLDRCQUFBLCtDQUFFO29CQUFoQixJQUFBLDJCQUFJO29CQUNkLElBQUkseUJBQXlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO3dCQUN4QyxPQUFPLElBQUksQ0FBQztxQkFDYjtpQkFDRjs7Ozs7Ozs7O1lBQ0QsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCAqIGFzIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuXG5pbXBvcnQge2dldEFsbExlYWRpbmdDb21tZW50c30gZnJvbSAnLi90cmFuc2Zvcm1lcl91dGlsJztcblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBkZWNsYXJhdGlvbnMgZm9yIHRoZSBnaXZlbiBkZWNvcmF0b3IuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXREZWNvcmF0b3JEZWNsYXJhdGlvbnMoXG4gICAgZGVjb3JhdG9yOiB0cy5EZWNvcmF0b3IsIHR5cGVDaGVja2VyOiB0cy5UeXBlQ2hlY2tlcik6IHRzLkRlY2xhcmF0aW9uW10ge1xuICAvLyBXYWxrIGRvd24gdGhlIGV4cHJlc3Npb24gdG8gZmluZCB0aGUgaWRlbnRpZmllciBvZiB0aGUgZGVjb3JhdG9yIGZ1bmN0aW9uLlxuICBsZXQgbm9kZTogdHMuTm9kZSA9IGRlY29yYXRvcjtcbiAgd2hpbGUgKG5vZGUua2luZCAhPT0gdHMuU3ludGF4S2luZC5JZGVudGlmaWVyKSB7XG4gICAgaWYgKG5vZGUua2luZCA9PT0gdHMuU3ludGF4S2luZC5EZWNvcmF0b3IgfHwgbm9kZS5raW5kID09PSB0cy5TeW50YXhLaW5kLkNhbGxFeHByZXNzaW9uKSB7XG4gICAgICBub2RlID0gKG5vZGUgYXMgdHMuRGVjb3JhdG9yIHwgdHMuQ2FsbEV4cHJlc3Npb24pLmV4cHJlc3Npb247XG4gICAgfSBlbHNlIHtcbiAgICAgIC8vIFdlIGRvIG5vdCBrbm93IGhvdyB0byBoYW5kbGUgdGhpcyB0eXBlIG9mIGRlY29yYXRvci5cbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG4gIH1cblxuICBsZXQgZGVjU3ltID0gdHlwZUNoZWNrZXIuZ2V0U3ltYm9sQXRMb2NhdGlvbihub2RlKTtcbiAgaWYgKCFkZWNTeW0pIHJldHVybiBbXTtcbiAgaWYgKGRlY1N5bS5mbGFncyAmIHRzLlN5bWJvbEZsYWdzLkFsaWFzKSB7XG4gICAgZGVjU3ltID0gdHlwZUNoZWNrZXIuZ2V0QWxpYXNlZFN5bWJvbChkZWNTeW0pO1xuICB9XG4gIHJldHVybiBkZWNTeW0uZ2V0RGVjbGFyYXRpb25zKCkgfHwgW107XG59XG5cbi8qKlxuICogUmV0dXJucyB0cnVlIGlmIG5vZGUgaGFzIGFuIGV4cG9ydGluZyBkZWNvcmF0b3IgIChpLmUuLCBhIGRlY29yYXRvciB3aXRoIEBFeHBvcnREZWNvcmF0ZWRJdGVtc1xuICogaW4gaXRzIEpTRG9jKS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGhhc0V4cG9ydGluZ0RlY29yYXRvcihub2RlOiB0cy5Ob2RlLCB0eXBlQ2hlY2tlcjogdHMuVHlwZUNoZWNrZXIpIHtcbiAgcmV0dXJuIG5vZGUuZGVjb3JhdG9ycyAmJlxuICAgICAgbm9kZS5kZWNvcmF0b3JzLnNvbWUoZGVjb3JhdG9yID0+IGlzRXhwb3J0aW5nRGVjb3JhdG9yKGRlY29yYXRvciwgdHlwZUNoZWNrZXIpKTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgdGhlIGdpdmVuIGRlY29yYXRvciBoYXMgYW4gQEV4cG9ydERlY29yYXRlZEl0ZW1zIGRpcmVjdGl2ZSBpbiBpdHMgSlNEb2MuXG4gKi9cbmZ1bmN0aW9uIGlzRXhwb3J0aW5nRGVjb3JhdG9yKGRlY29yYXRvcjogdHMuRGVjb3JhdG9yLCB0eXBlQ2hlY2tlcjogdHMuVHlwZUNoZWNrZXIpIHtcbiAgcmV0dXJuIGdldERlY29yYXRvckRlY2xhcmF0aW9ucyhkZWNvcmF0b3IsIHR5cGVDaGVja2VyKS5zb21lKGRlY2xhcmF0aW9uID0+IHtcbiAgICBjb25zdCByYW5nZSA9IGdldEFsbExlYWRpbmdDb21tZW50cyhkZWNsYXJhdGlvbik7XG4gICAgaWYgKCFyYW5nZSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGNvbnN0IHt0ZXh0fSBvZiByYW5nZSkge1xuICAgICAgaWYgKC9ARXhwb3J0RGVjb3JhdGVkSXRlbXNcXGIvLnRlc3QodGV4dCkpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfSk7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBRUgsaUNBQWlDO0lBRWpDLG1FQUF5RDtJQUV6RDs7T0FFRztJQUNILFNBQWdCLHdCQUF3QixDQUNwQyxTQUF1QixFQUFFLFdBQTJCO1FBQ3RELDZFQUE2RTtRQUM3RSxJQUFJLElBQUksR0FBWSxTQUFTLENBQUM7UUFDOUIsT0FBTyxJQUFJLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFO1lBQzdDLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsVUFBVSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxVQUFVLENBQUMsY0FBYyxFQUFFO2dCQUN2RixJQUFJLEdBQUksSUFBeUMsQ0FBQyxVQUFVLENBQUM7YUFDOUQ7aUJBQU07Z0JBQ0wsdURBQXVEO2dCQUN2RCxPQUFPLEVBQUUsQ0FBQzthQUNYO1NBQ0Y7UUFFRCxJQUFJLE1BQU0sR0FBRyxXQUFXLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLE1BQU07WUFBRSxPQUFPLEVBQUUsQ0FBQztRQUN2QixJQUFJLE1BQU0sQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUU7WUFDdkMsTUFBTSxHQUFHLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUMvQztRQUNELE9BQU8sTUFBTSxDQUFDLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUN4QyxDQUFDO0lBbkJELDREQW1CQztJQUVEOzs7T0FHRztJQUNILFNBQWdCLHFCQUFxQixDQUFDLElBQWEsRUFBRSxXQUEyQjtRQUM5RSxPQUFPLElBQUksQ0FBQyxVQUFVO1lBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsb0JBQW9CLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUhELHNEQUdDO0lBRUQ7O09BRUc7SUFDSCxTQUFTLG9CQUFvQixDQUFDLFNBQXVCLEVBQUUsV0FBMkI7UUFDaEYsT0FBTyx3QkFBd0IsQ0FBQyxTQUFTLEVBQUUsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQ3pFLE1BQU0sS0FBSyxHQUFHLHdDQUFxQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2pELElBQUksQ0FBQyxLQUFLLEVBQUU7Z0JBQ1YsT0FBTyxLQUFLLENBQUM7YUFDZDtZQUNELEtBQUssTUFBTSxFQUFDLElBQUksRUFBQyxJQUFJLEtBQUssRUFBRTtnQkFDMUIsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQ3hDLE9BQU8sSUFBSSxDQUFDO2lCQUNiO2FBQ0Y7WUFDRCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0ICogYXMgdHMgZnJvbSAndHlwZXNjcmlwdCc7XG5cbmltcG9ydCB7Z2V0QWxsTGVhZGluZ0NvbW1lbnRzfSBmcm9tICcuL3RyYW5zZm9ybWVyX3V0aWwnO1xuXG4vKipcbiAqIFJldHVybnMgdGhlIGRlY2xhcmF0aW9ucyBmb3IgdGhlIGdpdmVuIGRlY29yYXRvci5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldERlY29yYXRvckRlY2xhcmF0aW9ucyhcbiAgICBkZWNvcmF0b3I6IHRzLkRlY29yYXRvciwgdHlwZUNoZWNrZXI6IHRzLlR5cGVDaGVja2VyKTogdHMuRGVjbGFyYXRpb25bXSB7XG4gIC8vIFdhbGsgZG93biB0aGUgZXhwcmVzc2lvbiB0byBmaW5kIHRoZSBpZGVudGlmaWVyIG9mIHRoZSBkZWNvcmF0b3IgZnVuY3Rpb24uXG4gIGxldCBub2RlOiB0cy5Ob2RlID0gZGVjb3JhdG9yO1xuICB3aGlsZSAobm9kZS5raW5kICE9PSB0cy5TeW50YXhLaW5kLklkZW50aWZpZXIpIHtcbiAgICBpZiAobm9kZS5raW5kID09PSB0cy5TeW50YXhLaW5kLkRlY29yYXRvciB8fCBub2RlLmtpbmQgPT09IHRzLlN5bnRheEtpbmQuQ2FsbEV4cHJlc3Npb24pIHtcbiAgICAgIG5vZGUgPSAobm9kZSBhcyB0cy5EZWNvcmF0b3IgfCB0cy5DYWxsRXhwcmVzc2lvbikuZXhwcmVzc2lvbjtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gV2UgZG8gbm90IGtub3cgaG93IHRvIGhhbmRsZSB0aGlzIHR5cGUgb2YgZGVjb3JhdG9yLlxuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cbiAgfVxuXG4gIGxldCBkZWNTeW0gPSB0eXBlQ2hlY2tlci5nZXRTeW1ib2xBdExvY2F0aW9uKG5vZGUpO1xuICBpZiAoIWRlY1N5bSkgcmV0dXJuIFtdO1xuICBpZiAoZGVjU3ltLmZsYWdzICYgdHMuU3ltYm9sRmxhZ3MuQWxpYXMpIHtcbiAgICBkZWNTeW0gPSB0eXBlQ2hlY2tlci5nZXRBbGlhc2VkU3ltYm9sKGRlY1N5bSk7XG4gIH1cbiAgcmV0dXJuIGRlY1N5bS5nZXREZWNsYXJhdGlvbnMoKSB8fCBbXTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgbm9kZSBoYXMgYW4gZXhwb3J0aW5nIGRlY29yYXRvciAgKGkuZS4sIGEgZGVjb3JhdG9yIHdpdGggQEV4cG9ydERlY29yYXRlZEl0ZW1zXG4gKiBpbiBpdHMgSlNEb2MpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFzRXhwb3J0aW5nRGVjb3JhdG9yKG5vZGU6IHRzLk5vZGUsIHR5cGVDaGVja2VyOiB0cy5UeXBlQ2hlY2tlcikge1xuICByZXR1cm4gbm9kZS5kZWNvcmF0b3JzICYmXG4gICAgICBub2RlLmRlY29yYXRvcnMuc29tZShkZWNvcmF0b3IgPT4gaXNFeHBvcnRpbmdEZWNvcmF0b3IoZGVjb3JhdG9yLCB0eXBlQ2hlY2tlcikpO1xufVxuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZ2l2ZW4gZGVjb3JhdG9yIGhhcyBhbiBARXhwb3J0RGVjb3JhdGVkSXRlbXMgZGlyZWN0aXZlIGluIGl0cyBKU0RvYy5cbiAqL1xuZnVuY3Rpb24gaXNFeHBvcnRpbmdEZWNvcmF0b3IoZGVjb3JhdG9yOiB0cy5EZWNvcmF0b3IsIHR5cGVDaGVja2VyOiB0cy5UeXBlQ2hlY2tlcikge1xuICByZXR1cm4gZ2V0RGVjb3JhdG9yRGVjbGFyYXRpb25zKGRlY29yYXRvciwgdHlwZUNoZWNrZXIpLnNvbWUoZGVjbGFyYXRpb24gPT4ge1xuICAgIGNvbnN0IHJhbmdlID0gZ2V0QWxsTGVhZGluZ0NvbW1lbnRzKGRlY2xhcmF0aW9uKTtcbiAgICBpZiAoIXJhbmdlKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAoY29uc3Qge3RleHR9IG9mIHJhbmdlKSB7XG4gICAgICBpZiAoL0BFeHBvcnREZWNvcmF0ZWRJdGVtc1xcYi8udGVzdCh0ZXh0KSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9KTtcbn1cbiJdfQ== |
@@ -8,12 +8,2 @@ /** | ||
*/ | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
(function (factory) { | ||
@@ -42,4 +32,4 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
*/ | ||
var ts = require("typescript"); | ||
var transformer_util_1 = require("tsickle/src/transformer_util"); | ||
const ts = require("typescript"); | ||
const transformer_util_1 = require("tsickle/src/transformer_util"); | ||
/** isInNamespace returns true if any of node's ancestors is a namespace (ModuleDeclaration). */ | ||
@@ -49,3 +39,3 @@ function isInNamespace(node) { | ||
// no longer being set. | ||
var parent = ts.getOriginalNode(node).parent; | ||
let parent = ts.getOriginalNode(node).parent; | ||
while (parent) { | ||
@@ -67,3 +57,3 @@ if (parent.kind === ts.SyntaxKind.ModuleDeclaration) { | ||
} | ||
var type = typeChecker.getTypeAtLocation(member.initializer); | ||
const type = typeChecker.getTypeAtLocation(member.initializer); | ||
// Note: checking against 'NumberLike' instead of just 'Number' means this code | ||
@@ -86,23 +76,12 @@ // handles both | ||
function getEnumType(typeChecker, enumDecl) { | ||
var e_1, _a; | ||
var hasNumber = false; | ||
var hasString = false; | ||
try { | ||
for (var _b = __values(enumDecl.members), _c = _b.next(); !_c.done; _c = _b.next()) { | ||
var member = _c.value; | ||
var type = getEnumMemberType(typeChecker, member); | ||
if (type === 'string') { | ||
hasString = true; | ||
} | ||
else if (type === 'number') { | ||
hasNumber = true; | ||
} | ||
let hasNumber = false; | ||
let hasString = false; | ||
for (const member of enumDecl.members) { | ||
const type = getEnumMemberType(typeChecker, member); | ||
if (type === 'string') { | ||
hasString = true; | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (_c && !_c.done && (_a = _b.return)) _a.call(_b); | ||
else if (type === 'number') { | ||
hasNumber = true; | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
@@ -128,5 +107,4 @@ if (hasNumber && hasString) { | ||
function enumTransformer(typeChecker, diagnostics) { | ||
return function (context) { | ||
return (context) => { | ||
function visitor(node) { | ||
var e_2, _a, e_3, _b; | ||
if (!ts.isEnumDeclaration(node)) | ||
@@ -144,58 +122,48 @@ return ts.visitEachChild(node, visitor, context); | ||
return ts.visitEachChild(node, visitor, context); | ||
var name = node.name.getText(); | ||
var isExported = transformer_util_1.hasModifierFlag(node, ts.ModifierFlags.Export); | ||
var enumType = getEnumType(typeChecker, node); | ||
var values = []; | ||
var enumIndex = 0; | ||
try { | ||
for (var _c = __values(node.members), _d = _c.next(); !_d.done; _d = _c.next()) { | ||
var member = _d.value; | ||
var enumValue = void 0; | ||
if (member.initializer) { | ||
var enumConstValue = typeChecker.getConstantValue(member); | ||
if (typeof enumConstValue === 'number') { | ||
enumIndex = enumConstValue + 1; | ||
enumValue = ts.createLiteral(enumConstValue); | ||
} | ||
else { | ||
// Non-numeric enum value (string or an expression). | ||
// Emit this initializer expression as-is. | ||
// Note: if the member's initializer expression refers to another | ||
// value within the enum (e.g. something like | ||
// enum Foo { | ||
// Field1, | ||
// Field2 = Field1 + something(), | ||
// } | ||
// Then when we emit the initializer we produce invalid code because | ||
// on the Closure side the reference to Field1 has to be namespaced, | ||
// e.g. written "Foo.Field1 + something()". | ||
// Hopefully this doesn't come up often -- if the enum instead has | ||
// something like | ||
// Field2 = Field1 + 3, | ||
// then it's still a constant expression and we inline the constant | ||
// value in the above branch of this "if" statement. | ||
enumValue = visitor(member.initializer); | ||
} | ||
const name = node.name.getText(); | ||
const isExported = transformer_util_1.hasModifierFlag(node, ts.ModifierFlags.Export); | ||
const enumType = getEnumType(typeChecker, node); | ||
const values = []; | ||
let enumIndex = 0; | ||
for (const member of node.members) { | ||
let enumValue; | ||
if (member.initializer) { | ||
const enumConstValue = typeChecker.getConstantValue(member); | ||
if (typeof enumConstValue === 'number') { | ||
enumIndex = enumConstValue + 1; | ||
enumValue = ts.createLiteral(enumConstValue); | ||
} | ||
else { | ||
enumValue = ts.createLiteral(enumIndex); | ||
enumIndex++; | ||
// Non-numeric enum value (string or an expression). | ||
// Emit this initializer expression as-is. | ||
// Note: if the member's initializer expression refers to another | ||
// value within the enum (e.g. something like | ||
// enum Foo { | ||
// Field1, | ||
// Field2 = Field1 + something(), | ||
// } | ||
// Then when we emit the initializer we produce invalid code because | ||
// on the Closure side the reference to Field1 has to be namespaced, | ||
// e.g. written "Foo.Field1 + something()". | ||
// Hopefully this doesn't come up often -- if the enum instead has | ||
// something like | ||
// Field2 = Field1 + 3, | ||
// then it's still a constant expression and we inline the constant | ||
// value in the above branch of this "if" statement. | ||
enumValue = visitor(member.initializer); | ||
} | ||
var memberName = member.name.getText(); | ||
values.push(ts.setOriginalNode(ts.setTextRange(ts.createPropertyAssignment(memberName, enumValue), member), member)); | ||
} | ||
} | ||
catch (e_2_1) { e_2 = { error: e_2_1 }; } | ||
finally { | ||
try { | ||
if (_d && !_d.done && (_a = _c.return)) _a.call(_c); | ||
else { | ||
enumValue = ts.createLiteral(enumIndex); | ||
enumIndex++; | ||
} | ||
finally { if (e_2) throw e_2.error; } | ||
const memberName = member.name.getText(); | ||
values.push(ts.setOriginalNode(ts.setTextRange(ts.createPropertyAssignment(memberName, enumValue), member), member)); | ||
} | ||
var varDecl = ts.createVariableStatement( | ||
const varDecl = ts.createVariableStatement( | ||
/* modifiers */ undefined, ts.createVariableDeclarationList([ts.createVariableDeclaration(name, undefined, ts.createObjectLiteral(ts.setTextRange(ts.createNodeArray(values, true), node.members), true))], | ||
/* create a const var */ ts.NodeFlags.Const)); | ||
var comment = { | ||
const comment = { | ||
kind: ts.SyntaxKind.MultiLineCommentTrivia, | ||
text: "* @enum {" + enumType + "} ", | ||
text: `* @enum {${enumType}} `, | ||
hasTrailingNewLine: true, | ||
@@ -206,3 +174,3 @@ pos: -1, | ||
ts.setSyntheticLeadingComments(varDecl, [comment]); | ||
var resultNodes = [varDecl]; | ||
const resultNodes = [varDecl]; | ||
if (isExported) { | ||
@@ -220,39 +188,29 @@ // Create a separate export {...} statement, so that the enum name can be used in local | ||
} | ||
try { | ||
// Emit the reverse mapping of foo[foo.BAR] = 'BAR'; lines for number enum members | ||
for (var _e = __values(node.members), _f = _e.next(); !_f.done; _f = _e.next()) { | ||
var member = _f.value; | ||
var memberName = member.name; | ||
var memberType = getEnumMemberType(typeChecker, member); | ||
if (memberType !== 'number') | ||
continue; | ||
// TypeScript enum members can have Identifier names or String names. | ||
// We need to emit slightly different code to support these two syntaxes: | ||
var nameExpr = void 0; | ||
var memberAccess = void 0; | ||
if (ts.isIdentifier(memberName)) { | ||
// Foo[Foo.ABC] = "ABC"; | ||
nameExpr = transformer_util_1.createSingleQuoteStringLiteral(memberName.text); | ||
// Make sure to create a clean, new identifier, so comments do not get emitted twice. | ||
var ident = ts.createIdentifier(transformer_util_1.getIdentifierText(memberName)); | ||
memberAccess = ts.createPropertyAccess(ts.createIdentifier(name), ident); | ||
} | ||
else { | ||
// Foo[Foo["A B C"]] = "A B C"; or Foo[Foo[expression]] = expression; | ||
nameExpr = ts.isComputedPropertyName(memberName) ? memberName.expression : memberName; | ||
memberAccess = ts.createElementAccess(ts.createIdentifier(name), nameExpr); | ||
} | ||
resultNodes.push(ts.createStatement(ts.createAssignment(ts.createElementAccess(ts.createIdentifier(name), memberAccess), nameExpr))); | ||
// Emit the reverse mapping of foo[foo.BAR] = 'BAR'; lines for number enum members | ||
for (const member of node.members) { | ||
const memberName = member.name; | ||
const memberType = getEnumMemberType(typeChecker, member); | ||
if (memberType !== 'number') | ||
continue; | ||
// TypeScript enum members can have Identifier names or String names. | ||
// We need to emit slightly different code to support these two syntaxes: | ||
let nameExpr; | ||
let memberAccess; | ||
if (ts.isIdentifier(memberName)) { | ||
// Foo[Foo.ABC] = "ABC"; | ||
nameExpr = transformer_util_1.createSingleQuoteStringLiteral(memberName.text); | ||
// Make sure to create a clean, new identifier, so comments do not get emitted twice. | ||
const ident = ts.createIdentifier(transformer_util_1.getIdentifierText(memberName)); | ||
memberAccess = ts.createPropertyAccess(ts.createIdentifier(name), ident); | ||
} | ||
} | ||
catch (e_3_1) { e_3 = { error: e_3_1 }; } | ||
finally { | ||
try { | ||
if (_f && !_f.done && (_b = _e.return)) _b.call(_e); | ||
else { | ||
// Foo[Foo["A B C"]] = "A B C"; or Foo[Foo[expression]] = expression; | ||
nameExpr = ts.isComputedPropertyName(memberName) ? memberName.expression : memberName; | ||
memberAccess = ts.createElementAccess(ts.createIdentifier(name), nameExpr); | ||
} | ||
finally { if (e_3) throw e_3.error; } | ||
resultNodes.push(ts.createStatement(ts.createAssignment(ts.createElementAccess(ts.createIdentifier(name), memberAccess), nameExpr))); | ||
} | ||
return resultNodes; | ||
} | ||
return function (sf) { return visitor(sf); }; | ||
return (sf) => visitor(sf); | ||
}; | ||
@@ -262,2 +220,2 @@ } | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enum_transformer.js","sourceRoot":"","sources":["../../../../src/enum_transformer.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 */\n\n/**\n * @fileoverview Transforms TypeScript enum declarations to Closure enum declarations, which\n * look like:\n *\n *     /.. @enum {number} ./\n *     const Foo = {BAR: 0, BAZ: 1, ...};\n *     export {Foo};  // even if originally exported on one line.\n *\n * This declares an enum type for Closure Compiler (and Closure JS users of this TS code).\n * Splitting the enum into declaration and export is required so that local references to the\n * type resolve (\"@type {Foo}\").\n */\n\nimport * as ts from 'typescript';\n\nimport {createSingleQuoteStringLiteral, getIdentifierText, hasModifierFlag, isAmbient} from './transformer_util';\n\n/** isInNamespace returns true if any of node's ancestors is a namespace (ModuleDeclaration). */\nfunction isInNamespace(node: ts.Node) {\n  // Must use the original node because node might have already been transformed, with node.parent\n  // no longer being set.\n  let parent = ts.getOriginalNode(node).parent;\n  while (parent) {\n    if (parent.kind === ts.SyntaxKind.ModuleDeclaration) {\n      return true;\n    }\n    parent = parent.parent;\n  }\n  return false;\n}\n\n/**\n * getEnumMemberType computes the type of an enum member by inspecting its initializer expression.\n */\nfunction getEnumMemberType(typeChecker: ts.TypeChecker, member: ts.EnumMember): 'number'|'string' {\n  // Enum members without initialization have type 'number'\n  if (!member.initializer) {\n    return 'number';\n  }\n  const type = typeChecker.getTypeAtLocation(member.initializer);\n  // Note: checking against 'NumberLike' instead of just 'Number' means this code\n  // handles both\n  //   MEMBER = 3,  // TypeFlags.NumberLiteral\n  // and\n  //   MEMBER = someFunction(),  // TypeFlags.Number\n  if (type.flags & ts.TypeFlags.NumberLike) {\n    return 'number';\n  }\n  // If the value is not a number, it must be a string.\n  // TypeScript does not allow enum members to have any other type.\n  return 'string';\n}\n\n/**\n * getEnumType computes the Closure type of an enum, by iterating through the members and gathering\n * their types.\n */\nexport function getEnumType(typeChecker: ts.TypeChecker, enumDecl: ts.EnumDeclaration): 'number'|\n    'string'|'?' {\n  let hasNumber = false;\n  let hasString = false;\n  for (const member of enumDecl.members) {\n    const type = getEnumMemberType(typeChecker, member);\n    if (type === 'string') {\n      hasString = true;\n    } else if (type === 'number') {\n      hasNumber = true;\n    }\n  }\n  if (hasNumber && hasString) {\n    return '?';  // Closure's new type inference doesn't support enums of unions.\n  } else if (hasNumber) {\n    return 'number';\n  } else if (hasString) {\n    return 'string';\n  } else {\n    // Perhaps an empty enum?\n    return '?';\n  }\n}\n\n/**\n * Transformer factory for the enum transformer. See fileoverview for details.\n */\nexport function enumTransformer(typeChecker: ts.TypeChecker, diagnostics: ts.Diagnostic[]):\n    (context: ts.TransformationContext) => ts.Transformer<ts.SourceFile> {\n  return (context: ts.TransformationContext) => {\n    function visitor<T extends ts.Node>(node: T): T|ts.Node[] {\n      if (!ts.isEnumDeclaration(node)) return ts.visitEachChild(node, visitor, context);\n\n      // TODO(martinprobst): The enum transformer does not work for enums embedded in namespaces,\n      // because TS does not support splitting export and declaration (\"export {Foo};\") in\n      // namespaces. tsickle's emit for namespaces is unintelligible for Closure in any case, so\n      // this is left to fix for another day.\n      if (isInNamespace(node)) return ts.visitEachChild(node, visitor, context);\n\n      // TypeScript does not emit any code for ambient enums, so early exit here to prevent the code\n      // below from producing runtime values for an ambient structure.\n      if (isAmbient(node)) return ts.visitEachChild(node, visitor, context);\n\n      const name = node.name.getText();\n      const isExported = hasModifierFlag(node, ts.ModifierFlags.Export);\n      const enumType = getEnumType(typeChecker, node);\n\n      const values: ts.PropertyAssignment[] = [];\n      let enumIndex = 0;\n      for (const member of node.members) {\n        let enumValue: ts.Expression;\n        if (member.initializer) {\n          const enumConstValue = typeChecker.getConstantValue(member);\n          if (typeof enumConstValue === 'number') {\n            enumIndex = enumConstValue + 1;\n            enumValue = ts.createLiteral(enumConstValue);\n          } else {\n            // Non-numeric enum value (string or an expression).\n            // Emit this initializer expression as-is.\n            // Note: if the member's initializer expression refers to another\n            // value within the enum (e.g. something like\n            //   enum Foo {\n            //     Field1,\n            //     Field2 = Field1 + something(),\n            //   }\n            // Then when we emit the initializer we produce invalid code because\n            // on the Closure side the reference to Field1 has to be namespaced,\n            // e.g. written \"Foo.Field1 + something()\".\n            // Hopefully this doesn't come up often -- if the enum instead has\n            // something like\n            //     Field2 = Field1 + 3,\n            // then it's still a constant expression and we inline the constant\n            // value in the above branch of this \"if\" statement.\n            enumValue = visitor(member.initializer) as ts.Expression;\n          }\n        } else {\n          enumValue = ts.createLiteral(enumIndex);\n          enumIndex++;\n        }\n        const memberName = member.name.getText();\n        values.push(ts.setOriginalNode(\n            ts.setTextRange(ts.createPropertyAssignment(memberName, enumValue), member), member));\n      }\n\n      const varDecl = ts.createVariableStatement(\n          /* modifiers */ undefined,\n          ts.createVariableDeclarationList(\n              [ts.createVariableDeclaration(\n                  name, undefined,\n                  ts.createObjectLiteral(\n                      ts.setTextRange(ts.createNodeArray(values, true), node.members), true))],\n              /* create a const var */ ts.NodeFlags.Const));\n      const comment: ts.SynthesizedComment = {\n        kind: ts.SyntaxKind.MultiLineCommentTrivia,\n        text: `* @enum {${enumType}} `,\n        hasTrailingNewLine: true,\n        pos: -1,\n        end: -1\n      };\n      ts.setSyntheticLeadingComments(varDecl, [comment]);\n\n      const resultNodes: ts.Node[] = [varDecl];\n      if (isExported) {\n        // Create a separate export {...} statement, so that the enum name can be used in local\n        // type annotations within the file.\n        resultNodes.push(ts.createExportDeclaration(\n            undefined, undefined,\n            ts.createNamedExports([ts.createExportSpecifier(undefined, name)])));\n      }\n\n      if (hasModifierFlag(node, ts.ModifierFlags.Const)) {\n        // By TypeScript semantics, const enums disappear after TS compilation.\n        // We still need to generate the runtime value above to make Closure Compiler's type system\n        // happy and allow refering to enums from JS code, but we should at least not emit string\n        // value mappings.\n        return resultNodes;\n      }\n\n      // Emit the reverse mapping of foo[foo.BAR] = 'BAR'; lines for number enum members\n      for (const member of node.members) {\n        const memberName = member.name;\n        const memberType = getEnumMemberType(typeChecker, member);\n        if (memberType !== 'number') continue;\n\n        // TypeScript enum members can have Identifier names or String names.\n        // We need to emit slightly different code to support these two syntaxes:\n        let nameExpr: ts.Expression;\n        let memberAccess: ts.Expression;\n        if (ts.isIdentifier(memberName)) {\n          // Foo[Foo.ABC] = \"ABC\";\n          nameExpr = createSingleQuoteStringLiteral(memberName.text);\n          // Make sure to create a clean, new identifier, so comments do not get emitted twice.\n          const ident = ts.createIdentifier(getIdentifierText(memberName));\n          memberAccess = ts.createPropertyAccess(ts.createIdentifier(name), ident);\n        } else {\n          // Foo[Foo[\"A B C\"]] = \"A B C\"; or Foo[Foo[expression]] = expression;\n          nameExpr = ts.isComputedPropertyName(memberName) ? memberName.expression : memberName;\n          memberAccess = ts.createElementAccess(ts.createIdentifier(name), nameExpr);\n        }\n        resultNodes.push(ts.createStatement(ts.createAssignment(\n            ts.createElementAccess(ts.createIdentifier(name), memberAccess), nameExpr)));\n      }\n      return resultNodes;\n    }\n\n    return (sf: ts.SourceFile) => visitor(sf) as ts.SourceFile;\n  };\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enum_transformer.js","sourceRoot":"","sources":["../../../../src/enum_transformer.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 */\n\n/**\n * @fileoverview Transforms TypeScript enum declarations to Closure enum declarations, which\n * look like:\n *\n *     /.. @enum {number} ./\n *     const Foo = {BAR: 0, BAZ: 1, ...};\n *     export {Foo};  // even if originally exported on one line.\n *\n * This declares an enum type for Closure Compiler (and Closure JS users of this TS code).\n * Splitting the enum into declaration and export is required so that local references to the\n * type resolve (\"@type {Foo}\").\n */\n\nimport * as ts from 'typescript';\n\nimport {createSingleQuoteStringLiteral, getIdentifierText, hasModifierFlag, isAmbient} from './transformer_util';\n\n/** isInNamespace returns true if any of node's ancestors is a namespace (ModuleDeclaration). */\nfunction isInNamespace(node: ts.Node) {\n  // Must use the original node because node might have already been transformed, with node.parent\n  // no longer being set.\n  let parent = ts.getOriginalNode(node).parent;\n  while (parent) {\n    if (parent.kind === ts.SyntaxKind.ModuleDeclaration) {\n      return true;\n    }\n    parent = parent.parent;\n  }\n  return false;\n}\n\n/**\n * getEnumMemberType computes the type of an enum member by inspecting its initializer expression.\n */\nfunction getEnumMemberType(typeChecker: ts.TypeChecker, member: ts.EnumMember): 'number'|'string' {\n  // Enum members without initialization have type 'number'\n  if (!member.initializer) {\n    return 'number';\n  }\n  const type = typeChecker.getTypeAtLocation(member.initializer);\n  // Note: checking against 'NumberLike' instead of just 'Number' means this code\n  // handles both\n  //   MEMBER = 3,  // TypeFlags.NumberLiteral\n  // and\n  //   MEMBER = someFunction(),  // TypeFlags.Number\n  if (type.flags & ts.TypeFlags.NumberLike) {\n    return 'number';\n  }\n  // If the value is not a number, it must be a string.\n  // TypeScript does not allow enum members to have any other type.\n  return 'string';\n}\n\n/**\n * getEnumType computes the Closure type of an enum, by iterating through the members and gathering\n * their types.\n */\nexport function getEnumType(typeChecker: ts.TypeChecker, enumDecl: ts.EnumDeclaration): 'number'|\n    'string'|'?' {\n  let hasNumber = false;\n  let hasString = false;\n  for (const member of enumDecl.members) {\n    const type = getEnumMemberType(typeChecker, member);\n    if (type === 'string') {\n      hasString = true;\n    } else if (type === 'number') {\n      hasNumber = true;\n    }\n  }\n  if (hasNumber && hasString) {\n    return '?';  // Closure's new type inference doesn't support enums of unions.\n  } else if (hasNumber) {\n    return 'number';\n  } else if (hasString) {\n    return 'string';\n  } else {\n    // Perhaps an empty enum?\n    return '?';\n  }\n}\n\n/**\n * Transformer factory for the enum transformer. See fileoverview for details.\n */\nexport function enumTransformer(typeChecker: ts.TypeChecker, diagnostics: ts.Diagnostic[]):\n    (context: ts.TransformationContext) => ts.Transformer<ts.SourceFile> {\n  return (context: ts.TransformationContext) => {\n    function visitor<T extends ts.Node>(node: T): T|ts.Node[] {\n      if (!ts.isEnumDeclaration(node)) return ts.visitEachChild(node, visitor, context);\n\n      // TODO(martinprobst): The enum transformer does not work for enums embedded in namespaces,\n      // because TS does not support splitting export and declaration (\"export {Foo};\") in\n      // namespaces. tsickle's emit for namespaces is unintelligible for Closure in any case, so\n      // this is left to fix for another day.\n      if (isInNamespace(node)) return ts.visitEachChild(node, visitor, context);\n\n      // TypeScript does not emit any code for ambient enums, so early exit here to prevent the code\n      // below from producing runtime values for an ambient structure.\n      if (isAmbient(node)) return ts.visitEachChild(node, visitor, context);\n\n      const name = node.name.getText();\n      const isExported = hasModifierFlag(node, ts.ModifierFlags.Export);\n      const enumType = getEnumType(typeChecker, node);\n\n      const values: ts.PropertyAssignment[] = [];\n      let enumIndex = 0;\n      for (const member of node.members) {\n        let enumValue: ts.Expression;\n        if (member.initializer) {\n          const enumConstValue = typeChecker.getConstantValue(member);\n          if (typeof enumConstValue === 'number') {\n            enumIndex = enumConstValue + 1;\n            enumValue = ts.createLiteral(enumConstValue);\n          } else {\n            // Non-numeric enum value (string or an expression).\n            // Emit this initializer expression as-is.\n            // Note: if the member's initializer expression refers to another\n            // value within the enum (e.g. something like\n            //   enum Foo {\n            //     Field1,\n            //     Field2 = Field1 + something(),\n            //   }\n            // Then when we emit the initializer we produce invalid code because\n            // on the Closure side the reference to Field1 has to be namespaced,\n            // e.g. written \"Foo.Field1 + something()\".\n            // Hopefully this doesn't come up often -- if the enum instead has\n            // something like\n            //     Field2 = Field1 + 3,\n            // then it's still a constant expression and we inline the constant\n            // value in the above branch of this \"if\" statement.\n            enumValue = visitor(member.initializer) as ts.Expression;\n          }\n        } else {\n          enumValue = ts.createLiteral(enumIndex);\n          enumIndex++;\n        }\n        const memberName = member.name.getText();\n        values.push(ts.setOriginalNode(\n            ts.setTextRange(ts.createPropertyAssignment(memberName, enumValue), member), member));\n      }\n\n      const varDecl = ts.createVariableStatement(\n          /* modifiers */ undefined,\n          ts.createVariableDeclarationList(\n              [ts.createVariableDeclaration(\n                  name, undefined,\n                  ts.createObjectLiteral(\n                      ts.setTextRange(ts.createNodeArray(values, true), node.members), true))],\n              /* create a const var */ ts.NodeFlags.Const));\n      const comment: ts.SynthesizedComment = {\n        kind: ts.SyntaxKind.MultiLineCommentTrivia,\n        text: `* @enum {${enumType}} `,\n        hasTrailingNewLine: true,\n        pos: -1,\n        end: -1\n      };\n      ts.setSyntheticLeadingComments(varDecl, [comment]);\n\n      const resultNodes: ts.Node[] = [varDecl];\n      if (isExported) {\n        // Create a separate export {...} statement, so that the enum name can be used in local\n        // type annotations within the file.\n        resultNodes.push(ts.createExportDeclaration(\n            undefined, undefined,\n            ts.createNamedExports([ts.createExportSpecifier(undefined, name)])));\n      }\n\n      if (hasModifierFlag(node, ts.ModifierFlags.Const)) {\n        // By TypeScript semantics, const enums disappear after TS compilation.\n        // We still need to generate the runtime value above to make Closure Compiler's type system\n        // happy and allow refering to enums from JS code, but we should at least not emit string\n        // value mappings.\n        return resultNodes;\n      }\n\n      // Emit the reverse mapping of foo[foo.BAR] = 'BAR'; lines for number enum members\n      for (const member of node.members) {\n        const memberName = member.name;\n        const memberType = getEnumMemberType(typeChecker, member);\n        if (memberType !== 'number') continue;\n\n        // TypeScript enum members can have Identifier names or String names.\n        // We need to emit slightly different code to support these two syntaxes:\n        let nameExpr: ts.Expression;\n        let memberAccess: ts.Expression;\n        if (ts.isIdentifier(memberName)) {\n          // Foo[Foo.ABC] = \"ABC\";\n          nameExpr = createSingleQuoteStringLiteral(memberName.text);\n          // Make sure to create a clean, new identifier, so comments do not get emitted twice.\n          const ident = ts.createIdentifier(getIdentifierText(memberName));\n          memberAccess = ts.createPropertyAccess(ts.createIdentifier(name), ident);\n        } else {\n          // Foo[Foo[\"A B C\"]] = \"A B C\"; or Foo[Foo[expression]] = expression;\n          nameExpr = ts.isComputedPropertyName(memberName) ? memberName.expression : memberName;\n          memberAccess = ts.createElementAccess(ts.createIdentifier(name), nameExpr);\n        }\n        resultNodes.push(ts.createStatement(ts.createAssignment(\n            ts.createElementAccess(ts.createIdentifier(name), memberAccess), nameExpr)));\n      }\n      return resultNodes;\n    }\n\n    return (sf: ts.SourceFile) => visitor(sf) as ts.SourceFile;\n  };\n}\n"]} |
@@ -8,32 +8,2 @@ /** | ||
*/ | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
var __read = (this && this.__read) || function (o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
}; | ||
var __spread = (this && this.__spread) || function () { | ||
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
}; | ||
(function (factory) { | ||
@@ -50,5 +20,5 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var ts = require("typescript"); | ||
var jsdoc = require("tsickle/src/jsdoc"); | ||
var transformer_util_1 = require("tsickle/src/transformer_util"); | ||
const ts = require("typescript"); | ||
const jsdoc = require("tsickle/src/jsdoc"); | ||
const transformer_util_1 = require("tsickle/src/transformer_util"); | ||
/** | ||
@@ -58,3 +28,3 @@ * A set of JSDoc tags that mark a comment as a fileoverview comment. These are recognized by other | ||
*/ | ||
var FILEOVERVIEW_COMMENT_MARKERS = new Set(['fileoverview', 'externs', 'modName', 'mods', 'pintomodule']); | ||
const FILEOVERVIEW_COMMENT_MARKERS = new Set(['fileoverview', 'externs', 'modName', 'mods', 'pintomodule']); | ||
/** | ||
@@ -68,3 +38,3 @@ * Given a parsed \@fileoverview comment, ensures it has all the attributes we need. | ||
// Ensure we start with a @fileoverview. | ||
if (!tags.find(function (t) { return t.tagName === 'fileoverview'; })) { | ||
if (!tags.find(t => t.tagName === 'fileoverview')) { | ||
tags.splice(0, 0, { tagName: 'fileoverview', text: 'added by tsickle' }); | ||
@@ -75,6 +45,6 @@ } | ||
// only appear once and be merged. | ||
var suppressTag = tags.find(function (t) { return t.tagName === 'suppress'; }); | ||
var suppressions; | ||
let suppressTag = tags.find(t => t.tagName === 'suppress'); | ||
let suppressions; | ||
if (suppressTag) { | ||
suppressions = new Set((suppressTag.type || '').split(',').map(function (s) { return s.trim(); })); | ||
suppressions = new Set((suppressTag.type || '').split(',').map(s => s.trim())); | ||
} | ||
@@ -109,28 +79,17 @@ else { | ||
function transformFileoverviewCommentFactory(diagnostics) { | ||
return function () { | ||
return () => { | ||
function checkNoFileoverviewComments(context, comments, message) { | ||
var e_1, _a; | ||
try { | ||
for (var comments_1 = __values(comments), comments_1_1 = comments_1.next(); !comments_1_1.done; comments_1_1 = comments_1.next()) { | ||
var comment = comments_1_1.value; | ||
var parse = jsdoc.parse(comment); | ||
if (parse !== null && parse.tags.some(function (t) { return FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName); })) { | ||
// Report a warning; this should not break compilation in third party code. | ||
transformer_util_1.reportDiagnostic(diagnostics, context, message, comment.originalRange, ts.DiagnosticCategory.Warning); | ||
} | ||
for (const comment of comments) { | ||
const parse = jsdoc.parse(comment); | ||
if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) { | ||
// Report a warning; this should not break compilation in third party code. | ||
transformer_util_1.reportDiagnostic(diagnostics, context, message, comment.originalRange, ts.DiagnosticCategory.Warning); | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (comments_1_1 && !comments_1_1.done && (_a = comments_1.return)) _a.call(comments_1); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
} | ||
return function (sourceFile) { | ||
var text = sourceFile.getFullText(); | ||
var fileComments = []; | ||
var firstStatement = sourceFile.statements.length && sourceFile.statements[0] || null; | ||
var originalComments = ts.getLeadingCommentRanges(text, 0) || []; | ||
return (sourceFile) => { | ||
const text = sourceFile.getFullText(); | ||
let fileComments = []; | ||
const firstStatement = sourceFile.statements.length && sourceFile.statements[0] || null; | ||
const originalComments = ts.getLeadingCommentRanges(text, 0) || []; | ||
if (!firstStatement) { | ||
@@ -145,4 +104,4 @@ // In an empty source file, all comments are file-level comments. | ||
// fileoverview comment. | ||
for (var i = originalComments.length - 1; i >= 0; i--) { | ||
var end = originalComments[i].end; | ||
for (let i = originalComments.length - 1; i >= 0; i--) { | ||
const end = originalComments[i].end; | ||
if (!text.substring(end).startsWith('\n\n') && | ||
@@ -155,4 +114,4 @@ !text.substring(end).startsWith('\r\n\r\n')) { | ||
// NotEmittedStatement, so that they do not get lost later on. | ||
var synthesizedComments = jsdoc.synthesizeLeadingComments(firstStatement); | ||
var notEmitted = ts.createNotEmittedStatement(sourceFile); | ||
const synthesizedComments = jsdoc.synthesizeLeadingComments(firstStatement); | ||
const notEmitted = ts.createNotEmittedStatement(sourceFile); | ||
// Modify the comments on the firstStatement in place by removing the file-level comments. | ||
@@ -162,3 +121,3 @@ fileComments = synthesizedComments.splice(0, i + 1); | ||
ts.setSyntheticLeadingComments(notEmitted, fileComments); | ||
sourceFile = transformer_util_1.updateSourceFileNode(sourceFile, ts.createNodeArray(__spread([notEmitted, firstStatement], sourceFile.statements.slice(1)))); | ||
sourceFile = transformer_util_1.updateSourceFileNode(sourceFile, ts.createNodeArray([notEmitted, firstStatement, ...sourceFile.statements.slice(1)])); | ||
break; | ||
@@ -169,10 +128,10 @@ } | ||
// emit duplicated ones. | ||
for (var i = 0; i < sourceFile.statements.length; i++) { | ||
var stmt = sourceFile.statements[i]; | ||
for (let i = 0; i < sourceFile.statements.length; i++) { | ||
const stmt = sourceFile.statements[i]; | ||
// Accept the NotEmittedStatement inserted above. | ||
if (i === 0 && stmt.kind === ts.SyntaxKind.NotEmittedStatement) | ||
continue; | ||
var comments = jsdoc.synthesizeLeadingComments(stmt); | ||
checkNoFileoverviewComments(stmt, comments, "file comments must be at the top of the file, " + | ||
"separated from the file body by an empty line."); | ||
const comments = jsdoc.synthesizeLeadingComments(stmt); | ||
checkNoFileoverviewComments(stmt, comments, `file comments must be at the top of the file, ` + | ||
`separated from the file body by an empty line.`); | ||
} | ||
@@ -184,7 +143,7 @@ } | ||
// comment mentioning @fileoverview. | ||
var fileoverviewIdx = -1; | ||
var tags = []; | ||
for (var i = fileComments.length - 1; i >= 0; i--) { | ||
var parse = jsdoc.parseContents(fileComments[i].text); | ||
if (parse !== null && parse.tags.some(function (t) { return FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName); })) { | ||
let fileoverviewIdx = -1; | ||
let tags = []; | ||
for (let i = fileComments.length - 1; i >= 0; i--) { | ||
const parse = jsdoc.parseContents(fileComments[i].text); | ||
if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) { | ||
fileoverviewIdx = i; | ||
@@ -196,6 +155,6 @@ tags = parse.tags; | ||
if (fileoverviewIdx !== -1) { | ||
checkNoFileoverviewComments(firstStatement || sourceFile, fileComments.slice(0, fileoverviewIdx), "duplicate file level comment"); | ||
checkNoFileoverviewComments(firstStatement || sourceFile, fileComments.slice(0, fileoverviewIdx), `duplicate file level comment`); | ||
} | ||
augmentFileoverviewComments(tags); | ||
var commentText = jsdoc.toStringWithoutStartEnd(tags); | ||
const commentText = jsdoc.toStringWithoutStartEnd(tags); | ||
if (fileoverviewIdx < 0) { | ||
@@ -213,7 +172,7 @@ // No existing comment to merge with, just emit a new one. | ||
function addNewFileoverviewComment(sf, commentText) { | ||
var syntheticFirstStatement = transformer_util_1.createNotEmittedStatement(sf); | ||
let syntheticFirstStatement = transformer_util_1.createNotEmittedStatement(sf); | ||
syntheticFirstStatement = ts.addSyntheticTrailingComment(syntheticFirstStatement, ts.SyntaxKind.MultiLineCommentTrivia, commentText, true); | ||
return transformer_util_1.updateSourceFileNode(sf, ts.createNodeArray(__spread([syntheticFirstStatement], sf.statements))); | ||
return transformer_util_1.updateSourceFileNode(sf, ts.createNodeArray([syntheticFirstStatement, ...sf.statements])); | ||
} | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fileoverview_comment_transformer.js","sourceRoot":"","sources":["../../../../src/fileoverview_comment_transformer.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 */\n\nimport * as ts from 'typescript';\n\nimport * as jsdoc from './jsdoc';\nimport {createNotEmittedStatement, reportDiagnostic, synthesizeCommentRanges, updateSourceFileNode} from './transformer_util';\n\n/**\n * A set of JSDoc tags that mark a comment as a fileoverview comment. These are recognized by other\n * pieces of infrastructure (Closure Compiler, module system, ...).\n */\nconst FILEOVERVIEW_COMMENT_MARKERS: ReadonlySet<string> =\n    new Set(['fileoverview', 'externs', 'modName', 'mods', 'pintomodule']);\n\n/**\n * Given a parsed \\@fileoverview comment, ensures it has all the attributes we need.\n * This function can be called to modify an existing comment or to make a new one.\n *\n * @param tags Comment as parsed list of tags; modified in-place.\n */\nfunction augmentFileoverviewComments(tags: jsdoc.Tag[]) {\n  // Ensure we start with a @fileoverview.\n  if (!tags.find(t => t.tagName === 'fileoverview')) {\n    tags.splice(0, 0, {tagName: 'fileoverview', text: 'added by tsickle'});\n  }\n\n  // Find or create a @suppress tag.\n  // Closure compiler barfs if there's a duplicated @suppress tag in a file, so the tag must\n  // only appear once and be merged.\n  let suppressTag = tags.find(t => t.tagName === 'suppress');\n  let suppressions: Set<string>;\n  if (suppressTag) {\n    suppressions = new Set((suppressTag.type || '').split(',').map(s => s.trim()));\n  } else {\n    suppressTag = {tagName: 'suppress', text: 'checked by tsc'};\n    tags.push(suppressTag);\n    suppressions = new Set();\n  }\n\n  // Ensure our suppressions are included in the @suppress tag:\n  // 1) Suppress checkTypes.  We believe the code has already been type-checked by TypeScript,\n  // and we cannot model all the TypeScript type decisions in Closure syntax.\n  suppressions.add('checkTypes');\n  // 2) Suppress extraRequire.  We remove extra requires at the TypeScript level, so any require\n  // that gets to the JS level is a load-bearing require.\n  suppressions.add('extraRequire');\n  // 3) Suppress uselessCode.  We emit an \"if (false)\" around type declarations,\n  // which is flagged as unused code unless we suppress it.\n  suppressions.add('uselessCode');\n  // 4) Suppress some checks for user errors that TS already checks.\n  suppressions.add('missingReturn');\n  suppressions.add('unusedPrivateMembers');\n  // 5) Suppress checking for @override, because TS doesn't model it.\n  suppressions.add('missingOverride');\n  suppressTag.type = Array.from(suppressions.values()).sort().join(',');\n\n  return tags;\n}\n\n/**\n * A transformer that ensures the emitted JS file has an \\@fileoverview comment that contains an\n * \\@suppress {checkTypes} annotation by either adding or updating an existing comment.\n */\nexport function transformFileoverviewCommentFactory(diagnostics: ts.Diagnostic[]) {\n  return (): (sourceFile: ts.SourceFile) => ts.SourceFile => {\n    function checkNoFileoverviewComments(\n        context: ts.Node, comments: jsdoc.SynthesizedCommentWithOriginal[], message: string) {\n      for (const comment of comments) {\n        const parse = jsdoc.parse(comment);\n        if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) {\n          // Report a warning; this should not break compilation in third party code.\n          reportDiagnostic(\n              diagnostics, context, message, comment.originalRange, ts.DiagnosticCategory.Warning);\n        }\n      }\n    }\n\n    return (sourceFile: ts.SourceFile) => {\n      const text = sourceFile.getFullText();\n\n      let fileComments: ts.SynthesizedComment[] = [];\n      const firstStatement = sourceFile.statements.length && sourceFile.statements[0] || null;\n\n      const originalComments = ts.getLeadingCommentRanges(text, 0) || [];\n      if (!firstStatement) {\n        // In an empty source file, all comments are file-level comments.\n        fileComments = synthesizeCommentRanges(sourceFile, originalComments);\n      } else {\n        // Search for the last comment split from the file with a \\n\\n. All comments before that are\n        // considered fileoverview comments, all comments after that belong to the next\n        // statement(s). If none found, comments remains empty, and the code below will insert a new\n        // fileoverview comment.\n        for (let i = originalComments.length - 1; i >= 0; i--) {\n          const end = originalComments[i].end;\n          if (!text.substring(end).startsWith('\\n\\n') &&\n              !text.substring(end).startsWith('\\r\\n\\r\\n')) {\n            continue;\n          }\n          // This comment is separated from the source file with a double break, marking it (and any\n          // preceding comments) as a file-level comment. Split them off and attach them onto a\n          // NotEmittedStatement, so that they do not get lost later on.\n          const synthesizedComments = jsdoc.synthesizeLeadingComments(firstStatement);\n          const notEmitted = ts.createNotEmittedStatement(sourceFile);\n          // Modify the comments on the firstStatement in place by removing the file-level comments.\n          fileComments = synthesizedComments.splice(0, i + 1);\n          // Move the fileComments onto notEmitted.\n          ts.setSyntheticLeadingComments(notEmitted, fileComments);\n          sourceFile = updateSourceFileNode(\n              sourceFile,\n              ts.createNodeArray([notEmitted, firstStatement, ...sourceFile.statements.slice(1)]));\n          break;\n        }\n\n\n        // Now walk every top level statement and escape/drop any @fileoverview comments found.\n        // Closure ignores all @fileoverview comments but the last, so tsickle must make sure not to\n        // emit duplicated ones.\n        for (let i = 0; i < sourceFile.statements.length; i++) {\n          const stmt = sourceFile.statements[i];\n          // Accept the NotEmittedStatement inserted above.\n          if (i === 0 && stmt.kind === ts.SyntaxKind.NotEmittedStatement) continue;\n          const comments = jsdoc.synthesizeLeadingComments(stmt);\n          checkNoFileoverviewComments(\n              stmt, comments,\n              `file comments must be at the top of the file, ` +\n                  `separated from the file body by an empty line.`);\n        }\n      }\n\n      // Closure Compiler considers the *last* comment with @fileoverview (or @externs or\n      // @nocompile) that has not been attached to some other tree node to be the file overview\n      // comment, and only applies @suppress tags from it. Google-internal tooling considers *any*\n      // comment mentioning @fileoverview.\n      let fileoverviewIdx = -1;\n      let tags: jsdoc.Tag[] = [];\n      for (let i = fileComments.length - 1; i >= 0; i--) {\n        const parse = jsdoc.parseContents(fileComments[i].text);\n        if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) {\n          fileoverviewIdx = i;\n          tags = parse.tags;\n          break;\n        }\n      }\n\n      if (fileoverviewIdx !== -1) {\n        checkNoFileoverviewComments(\n            firstStatement || sourceFile, fileComments.slice(0, fileoverviewIdx),\n            `duplicate file level comment`);\n      }\n\n      augmentFileoverviewComments(tags);\n      const commentText = jsdoc.toStringWithoutStartEnd(tags);\n\n      if (fileoverviewIdx < 0) {\n        // No existing comment to merge with, just emit a new one.\n        return addNewFileoverviewComment(sourceFile, commentText);\n      }\n\n      fileComments[fileoverviewIdx].text = commentText;\n      // sf does not need to be updated, synthesized comments are mutable.\n      return sourceFile;\n    };\n  };\n}\n\nfunction addNewFileoverviewComment(sf: ts.SourceFile, commentText: string): ts.SourceFile {\n  let syntheticFirstStatement = createNotEmittedStatement(sf);\n  syntheticFirstStatement = ts.addSyntheticTrailingComment(\n      syntheticFirstStatement, ts.SyntaxKind.MultiLineCommentTrivia, commentText, true);\n  return updateSourceFileNode(sf, ts.createNodeArray([syntheticFirstStatement, ...sf.statements]));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fileoverview_comment_transformer.js","sourceRoot":"","sources":["../../../../src/fileoverview_comment_transformer.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAEH,iCAAiC;IAEjC,2CAAiC;IACjC,mEAA8H;IAE9H;;;OAGG;IACH,MAAM,4BAA4B,GAC9B,IAAI,GAAG,CAAC,CAAC,cAAc,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;IAE3E;;;;;OAKG;IACH,SAAS,2BAA2B,CAAC,IAAiB;QACpD,wCAAwC;QACxC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,cAAc,CAAC,EAAE;YACjD,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,EAAC,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;SACxE;QAED,kCAAkC;QAClC,0FAA0F;QAC1F,kCAAkC;QAClC,IAAI,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,UAAU,CAAC,CAAC;QAC3D,IAAI,YAAyB,CAAC;QAC9B,IAAI,WAAW,EAAE;YACf,YAAY,GAAG,IAAI,GAAG,CAAC,CAAC,WAAW,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;SAChF;aAAM;YACL,WAAW,GAAG,EAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,gBAAgB,EAAC,CAAC;YAC5D,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACvB,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;SAC1B;QAED,6DAA6D;QAC7D,4FAA4F;QAC5F,2EAA2E;QAC3E,YAAY,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC/B,8FAA8F;QAC9F,uDAAuD;QACvD,YAAY,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACjC,8EAA8E;QAC9E,yDAAyD;QACzD,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAChC,kEAAkE;QAClE,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAClC,YAAY,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;QACzC,mEAAmE;QACnE,YAAY,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACpC,WAAW,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEtE,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,SAAgB,mCAAmC,CAAC,WAA4B;QAC9E,OAAO,GAAiD,EAAE;YACxD,SAAS,2BAA2B,CAChC,OAAgB,EAAE,QAAgD,EAAE,OAAe;gBACrF,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;oBAC9B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBACnC,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,4BAA4B,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE;wBACvF,2EAA2E;wBAC3E,mCAAgB,CACZ,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;qBAC1F;iBACF;YACH,CAAC;YAED,OAAO,CAAC,UAAyB,EAAE,EAAE;gBACnC,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,EAAE,CAAC;gBAEtC,IAAI,YAAY,GAA4B,EAAE,CAAC;gBAC/C,MAAM,cAAc,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;gBAExF,MAAM,gBAAgB,GAAG,EAAE,CAAC,uBAAuB,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;gBACnE,IAAI,CAAC,cAAc,EAAE;oBACnB,iEAAiE;oBACjE,YAAY,GAAG,0CAAuB,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC;iBACtE;qBAAM;oBACL,4FAA4F;oBAC5F,+EAA+E;oBAC/E,4FAA4F;oBAC5F,wBAAwB;oBACxB,KAAK,IAAI,CAAC,GAAG,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;wBACrD,MAAM,GAAG,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;wBACpC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC;4BACvC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;4BAC/C,SAAS;yBACV;wBACD,0FAA0F;wBAC1F,qFAAqF;wBACrF,8DAA8D;wBAC9D,MAAM,mBAAmB,GAAG,KAAK,CAAC,yBAAyB,CAAC,cAAc,CAAC,CAAC;wBAC5E,MAAM,UAAU,GAAG,EAAE,CAAC,yBAAyB,CAAC,UAAU,CAAC,CAAC;wBAC5D,0FAA0F;wBAC1F,YAAY,GAAG,mBAAmB,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;wBACpD,yCAAyC;wBACzC,EAAE,CAAC,2BAA2B,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;wBACzD,UAAU,GAAG,uCAAoB,CAC7B,UAAU,EACV,EAAE,CAAC,eAAe,CAAC,CAAC,UAAU,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;wBACzF,MAAM;qBACP;oBAGD,uFAAuF;oBACvF,4FAA4F;oBAC5F,wBAAwB;oBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACrD,MAAM,IAAI,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;wBACtC,iDAAiD;wBACjD,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,EAAE,CAAC,UAAU,CAAC,mBAAmB;4BAAE,SAAS;wBACzE,MAAM,QAAQ,GAAG,KAAK,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;wBACvD,2BAA2B,CACvB,IAAI,EAAE,QAAQ,EACd,gDAAgD;4BAC5C,gDAAgD,CAAC,CAAC;qBAC3D;iBACF;gBAED,mFAAmF;gBACnF,yFAAyF;gBACzF,4FAA4F;gBAC5F,oCAAoC;gBACpC,IAAI,eAAe,GAAG,CAAC,CAAC,CAAC;gBACzB,IAAI,IAAI,GAAgB,EAAE,CAAC;gBAC3B,KAAK,IAAI,CAAC,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;oBACjD,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;oBACxD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,4BAA4B,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE;wBACvF,eAAe,GAAG,CAAC,CAAC;wBACpB,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;wBAClB,MAAM;qBACP;iBACF;gBAED,IAAI,eAAe,KAAK,CAAC,CAAC,EAAE;oBAC1B,2BAA2B,CACvB,cAAc,IAAI,UAAU,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,EACpE,8BAA8B,CAAC,CAAC;iBACrC;gBAED,2BAA2B,CAAC,IAAI,CAAC,CAAC;gBAClC,MAAM,WAAW,GAAG,KAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;gBAExD,IAAI,eAAe,GAAG,CAAC,EAAE;oBACvB,0DAA0D;oBAC1D,OAAO,yBAAyB,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;iBAC3D;gBAED,YAAY,CAAC,eAAe,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC;gBACjD,oEAAoE;gBACpE,OAAO,UAAU,CAAC;YACpB,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IApGD,kFAoGC;IAED,SAAS,yBAAyB,CAAC,EAAiB,EAAE,WAAmB;QACvE,IAAI,uBAAuB,GAAG,4CAAyB,CAAC,EAAE,CAAC,CAAC;QAC5D,uBAAuB,GAAG,EAAE,CAAC,2BAA2B,CACpD,uBAAuB,EAAE,EAAE,CAAC,UAAU,CAAC,sBAAsB,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QACtF,OAAO,uCAAoB,CAAC,EAAE,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACnG,CAAC","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 */\n\nimport * as ts from 'typescript';\n\nimport * as jsdoc from './jsdoc';\nimport {createNotEmittedStatement, reportDiagnostic, synthesizeCommentRanges, updateSourceFileNode} from './transformer_util';\n\n/**\n * A set of JSDoc tags that mark a comment as a fileoverview comment. These are recognized by other\n * pieces of infrastructure (Closure Compiler, module system, ...).\n */\nconst FILEOVERVIEW_COMMENT_MARKERS: ReadonlySet<string> =\n    new Set(['fileoverview', 'externs', 'modName', 'mods', 'pintomodule']);\n\n/**\n * Given a parsed \\@fileoverview comment, ensures it has all the attributes we need.\n * This function can be called to modify an existing comment or to make a new one.\n *\n * @param tags Comment as parsed list of tags; modified in-place.\n */\nfunction augmentFileoverviewComments(tags: jsdoc.Tag[]) {\n  // Ensure we start with a @fileoverview.\n  if (!tags.find(t => t.tagName === 'fileoverview')) {\n    tags.splice(0, 0, {tagName: 'fileoverview', text: 'added by tsickle'});\n  }\n\n  // Find or create a @suppress tag.\n  // Closure compiler barfs if there's a duplicated @suppress tag in a file, so the tag must\n  // only appear once and be merged.\n  let suppressTag = tags.find(t => t.tagName === 'suppress');\n  let suppressions: Set<string>;\n  if (suppressTag) {\n    suppressions = new Set((suppressTag.type || '').split(',').map(s => s.trim()));\n  } else {\n    suppressTag = {tagName: 'suppress', text: 'checked by tsc'};\n    tags.push(suppressTag);\n    suppressions = new Set();\n  }\n\n  // Ensure our suppressions are included in the @suppress tag:\n  // 1) Suppress checkTypes.  We believe the code has already been type-checked by TypeScript,\n  // and we cannot model all the TypeScript type decisions in Closure syntax.\n  suppressions.add('checkTypes');\n  // 2) Suppress extraRequire.  We remove extra requires at the TypeScript level, so any require\n  // that gets to the JS level is a load-bearing require.\n  suppressions.add('extraRequire');\n  // 3) Suppress uselessCode.  We emit an \"if (false)\" around type declarations,\n  // which is flagged as unused code unless we suppress it.\n  suppressions.add('uselessCode');\n  // 4) Suppress some checks for user errors that TS already checks.\n  suppressions.add('missingReturn');\n  suppressions.add('unusedPrivateMembers');\n  // 5) Suppress checking for @override, because TS doesn't model it.\n  suppressions.add('missingOverride');\n  suppressTag.type = Array.from(suppressions.values()).sort().join(',');\n\n  return tags;\n}\n\n/**\n * A transformer that ensures the emitted JS file has an \\@fileoverview comment that contains an\n * \\@suppress {checkTypes} annotation by either adding or updating an existing comment.\n */\nexport function transformFileoverviewCommentFactory(diagnostics: ts.Diagnostic[]) {\n  return (): (sourceFile: ts.SourceFile) => ts.SourceFile => {\n    function checkNoFileoverviewComments(\n        context: ts.Node, comments: jsdoc.SynthesizedCommentWithOriginal[], message: string) {\n      for (const comment of comments) {\n        const parse = jsdoc.parse(comment);\n        if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) {\n          // Report a warning; this should not break compilation in third party code.\n          reportDiagnostic(\n              diagnostics, context, message, comment.originalRange, ts.DiagnosticCategory.Warning);\n        }\n      }\n    }\n\n    return (sourceFile: ts.SourceFile) => {\n      const text = sourceFile.getFullText();\n\n      let fileComments: ts.SynthesizedComment[] = [];\n      const firstStatement = sourceFile.statements.length && sourceFile.statements[0] || null;\n\n      const originalComments = ts.getLeadingCommentRanges(text, 0) || [];\n      if (!firstStatement) {\n        // In an empty source file, all comments are file-level comments.\n        fileComments = synthesizeCommentRanges(sourceFile, originalComments);\n      } else {\n        // Search for the last comment split from the file with a \\n\\n. All comments before that are\n        // considered fileoverview comments, all comments after that belong to the next\n        // statement(s). If none found, comments remains empty, and the code below will insert a new\n        // fileoverview comment.\n        for (let i = originalComments.length - 1; i >= 0; i--) {\n          const end = originalComments[i].end;\n          if (!text.substring(end).startsWith('\\n\\n') &&\n              !text.substring(end).startsWith('\\r\\n\\r\\n')) {\n            continue;\n          }\n          // This comment is separated from the source file with a double break, marking it (and any\n          // preceding comments) as a file-level comment. Split them off and attach them onto a\n          // NotEmittedStatement, so that they do not get lost later on.\n          const synthesizedComments = jsdoc.synthesizeLeadingComments(firstStatement);\n          const notEmitted = ts.createNotEmittedStatement(sourceFile);\n          // Modify the comments on the firstStatement in place by removing the file-level comments.\n          fileComments = synthesizedComments.splice(0, i + 1);\n          // Move the fileComments onto notEmitted.\n          ts.setSyntheticLeadingComments(notEmitted, fileComments);\n          sourceFile = updateSourceFileNode(\n              sourceFile,\n              ts.createNodeArray([notEmitted, firstStatement, ...sourceFile.statements.slice(1)]));\n          break;\n        }\n\n\n        // Now walk every top level statement and escape/drop any @fileoverview comments found.\n        // Closure ignores all @fileoverview comments but the last, so tsickle must make sure not to\n        // emit duplicated ones.\n        for (let i = 0; i < sourceFile.statements.length; i++) {\n          const stmt = sourceFile.statements[i];\n          // Accept the NotEmittedStatement inserted above.\n          if (i === 0 && stmt.kind === ts.SyntaxKind.NotEmittedStatement) continue;\n          const comments = jsdoc.synthesizeLeadingComments(stmt);\n          checkNoFileoverviewComments(\n              stmt, comments,\n              `file comments must be at the top of the file, ` +\n                  `separated from the file body by an empty line.`);\n        }\n      }\n\n      // Closure Compiler considers the *last* comment with @fileoverview (or @externs or\n      // @nocompile) that has not been attached to some other tree node to be the file overview\n      // comment, and only applies @suppress tags from it. Google-internal tooling considers *any*\n      // comment mentioning @fileoverview.\n      let fileoverviewIdx = -1;\n      let tags: jsdoc.Tag[] = [];\n      for (let i = fileComments.length - 1; i >= 0; i--) {\n        const parse = jsdoc.parseContents(fileComments[i].text);\n        if (parse !== null && parse.tags.some(t => FILEOVERVIEW_COMMENT_MARKERS.has(t.tagName))) {\n          fileoverviewIdx = i;\n          tags = parse.tags;\n          break;\n        }\n      }\n\n      if (fileoverviewIdx !== -1) {\n        checkNoFileoverviewComments(\n            firstStatement || sourceFile, fileComments.slice(0, fileoverviewIdx),\n            `duplicate file level comment`);\n      }\n\n      augmentFileoverviewComments(tags);\n      const commentText = jsdoc.toStringWithoutStartEnd(tags);\n\n      if (fileoverviewIdx < 0) {\n        // No existing comment to merge with, just emit a new one.\n        return addNewFileoverviewComment(sourceFile, commentText);\n      }\n\n      fileComments[fileoverviewIdx].text = commentText;\n      // sf does not need to be updated, synthesized comments are mutable.\n      return sourceFile;\n    };\n  };\n}\n\nfunction addNewFileoverviewComment(sf: ts.SourceFile, commentText: string): ts.SourceFile {\n  let syntheticFirstStatement = createNotEmittedStatement(sf);\n  syntheticFirstStatement = ts.addSyntheticTrailingComment(\n      syntheticFirstStatement, ts.SyntaxKind.MultiLineCommentTrivia, commentText, true);\n  return updateSourceFileNode(sf, ts.createNodeArray([syntheticFirstStatement, ...sf.statements]));\n}\n"]} |
330
src/jsdoc.js
@@ -8,39 +8,2 @@ /** | ||
*/ | ||
var __assign = (this && this.__assign) || function () { | ||
__assign = Object.assign || function(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) | ||
t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
var __read = (this && this.__read) || function (o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
}; | ||
(function (factory) { | ||
@@ -57,5 +20,11 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var ts = require("typescript"); | ||
const ts = require("typescript"); | ||
/** | ||
* A list of all JSDoc tags allowed by the Closure compiler. | ||
* All tags other than these are escaped before emitting. | ||
* | ||
* Note that some of these tags are also rejected by tsickle when seen in | ||
* the user-provided source, but also that tsickle itself may generate some of these. | ||
* This whitelist is just used for controlling the output. | ||
* | ||
* The public Closure docs don't list all the tags it allows; this list comes | ||
@@ -66,3 +35,3 @@ * from the compiler source itself. | ||
*/ | ||
var JSDOC_TAGS_WHITELIST = new Set([ | ||
const JSDOC_TAGS_OUTPUT_WHITELIST = new Set([ | ||
'abstract', | ||
@@ -151,4 +120,5 @@ 'argument', | ||
* these will cause Closure Compiler issues and should not be used. | ||
* Note: 'template' is special-cased below; see where this set is queried. | ||
*/ | ||
var JSDOC_TAGS_BLACKLIST = new Set([ | ||
const JSDOC_TAGS_INPUT_BLACKLIST = new Set([ | ||
'augments', 'class', 'constructs', 'constructor', 'enum', 'extends', 'field', | ||
@@ -159,7 +129,9 @@ 'function', 'implements', 'interface', 'lends', 'namespace', 'private', 'public', | ||
/** | ||
* A list of JSDoc @tags that might include a {type} after them. Only banned when a type is passed. | ||
* Note that this does not include tags that carry a non-type system type, e.g. \@suppress. | ||
* JSDoc \@tags that might include a {type} after them. Specifying a type is forbidden, since it | ||
* would collide with TypeScript's type information. If a type *is* given, the entire tag will be | ||
* ignored. | ||
*/ | ||
var JSDOC_TAGS_WITH_TYPES = new Set([ | ||
const JSDOC_TAGS_WITH_TYPES = new Set([ | ||
'const', | ||
'define', | ||
'export', | ||
@@ -186,3 +158,3 @@ 'param', | ||
return null; | ||
var text = comment.text.substring(1).trim(); | ||
const text = comment.text.substring(1).trim(); | ||
return parseContents(text); | ||
@@ -205,3 +177,2 @@ } | ||
function parseContents(commentText) { | ||
var e_1, _a, _b, _c; | ||
// Make sure we have proper line endings before parsing on Windows. | ||
@@ -211,78 +182,82 @@ commentText = normalizeLineEndings(commentText); | ||
commentText = commentText.replace(/^\s*\*? ?/gm, ''); | ||
var lines = commentText.split('\n'); | ||
var tags = []; | ||
var warnings = []; | ||
try { | ||
for (var lines_1 = __values(lines), lines_1_1 = lines_1.next(); !lines_1_1.done; lines_1_1 = lines_1.next()) { | ||
var line = lines_1_1.value; | ||
var match = line.match(/^\s*@(\S+) *(.*)/); | ||
if (match) { | ||
var _d = __read(match, 3), _ = _d[0], tagName = _d[1], text = _d[2]; | ||
if (tagName === 'returns') { | ||
// A synonym for 'return'. | ||
tagName = 'return'; | ||
} | ||
var type = void 0; | ||
if (JSDOC_TAGS_BLACKLIST.has(tagName)) { | ||
warnings.push("@" + tagName + " annotations are redundant with TypeScript equivalents"); | ||
const lines = commentText.split('\n'); | ||
const tags = []; | ||
const warnings = []; | ||
for (const line of lines) { | ||
let match = line.match(/^\s*@(\S+) *(.*)/); | ||
if (match) { | ||
let [_, tagName, text] = match; | ||
if (tagName === 'returns') { | ||
// A synonym for 'return'. | ||
tagName = 'return'; | ||
} | ||
let type; | ||
if (JSDOC_TAGS_INPUT_BLACKLIST.has(tagName)) { | ||
if (tagName !== 'template') { | ||
// Tell the user to not write blacklisted tags, because there is TS | ||
// syntax available for them. | ||
warnings.push(`@${tagName} annotations are redundant with TypeScript equivalents`); | ||
continue; // Drop the tag so Closure won't process it. | ||
} | ||
else if (JSDOC_TAGS_WITH_TYPES.has(tagName) && text[0] === '{') { | ||
warnings.push("the type annotation on @" + tagName + " is redundant with its TypeScript type, " + | ||
"remove the {...} part"); | ||
else { | ||
// But @template in particular is special: it's ok for the user to | ||
// write it for documentation purposes, but we don't want the | ||
// user-written one making it into the output because Closure interprets | ||
// it as well. | ||
// Drop it without any warning. (We also don't ensure its correctness.) | ||
continue; | ||
} | ||
else if (tagName === 'suppress') { | ||
var suppressMatch = text.match(/^\{(.*)\}(.*)$/); | ||
if (!suppressMatch) { | ||
warnings.push("malformed @suppress tag: \"" + text + "\""); | ||
} | ||
else { | ||
_b = __read(suppressMatch, 3), type = _b[1], text = _b[2]; | ||
} | ||
} | ||
else if (tagName === 'dict') { | ||
warnings.push('use index signatures (`[k: string]: type`) instead of @dict'); | ||
} | ||
else if (JSDOC_TAGS_WITH_TYPES.has(tagName)) { | ||
if (text[0] === '{') { | ||
warnings.push(`the type annotation on @${tagName} is redundant with its TypeScript type, ` + | ||
`remove the {...} part`); | ||
continue; | ||
} | ||
// Grab the parameter name from @param tags. | ||
var parameterName = void 0; | ||
if (tagName === 'param') { | ||
match = text.match(/^(\S+) ?(.*)/); | ||
if (match) | ||
_c = __read(match, 3), _ = _c[0], parameterName = _c[1], text = _c[2]; | ||
} | ||
var tag = { tagName: tagName }; | ||
if (parameterName) | ||
tag.parameterName = parameterName; | ||
if (text) | ||
tag.text = text; | ||
if (type) | ||
tag.type = type; | ||
tags.push(tag); | ||
} | ||
else { | ||
// Text without a preceding @tag on it is either the plain text | ||
// documentation or a continuation of a previous tag. | ||
if (tags.length === 0) { | ||
tags.push({ tagName: '', text: line }); | ||
else if (tagName === 'suppress') { | ||
const typeMatch = text.match(/^\{(.*)\}(.*)$/); | ||
if (typeMatch) { | ||
[, type, text] = typeMatch; | ||
} | ||
else { | ||
var lastTag = tags[tags.length - 1]; | ||
lastTag.text = (lastTag.text || '') + '\n' + line; | ||
warnings.push(`malformed @${tagName} tag: "${text}"`); | ||
} | ||
} | ||
else if (tagName === 'dict') { | ||
warnings.push('use index signatures (`[k: string]: type`) instead of @dict'); | ||
continue; | ||
} | ||
// Grab the parameter name from @param tags. | ||
let parameterName; | ||
if (tagName === 'param') { | ||
match = text.match(/^(\S+) ?(.*)/); | ||
if (match) | ||
[_, parameterName, text] = match; | ||
} | ||
const tag = { tagName }; | ||
if (parameterName) | ||
tag.parameterName = parameterName; | ||
if (text) | ||
tag.text = text; | ||
if (type) | ||
tag.type = type; | ||
tags.push(tag); | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (lines_1_1 && !lines_1_1.done && (_a = lines_1.return)) _a.call(lines_1); | ||
else { | ||
// Text without a preceding @tag on it is either the plain text | ||
// documentation or a continuation of a previous tag. | ||
if (tags.length === 0) { | ||
tags.push({ tagName: '', text: line }); | ||
} | ||
else { | ||
const lastTag = tags[tags.length - 1]; | ||
lastTag.text = (lastTag.text || '') + '\n' + line; | ||
} | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
if (warnings.length > 0) { | ||
return { tags: tags, warnings: warnings }; | ||
return { tags, warnings }; | ||
} | ||
return { tags: tags }; | ||
return { tags }; | ||
} | ||
@@ -294,7 +269,6 @@ exports.parseContents = parseContents; | ||
*/ | ||
function tagToString(tag, escapeExtraTags) { | ||
if (escapeExtraTags === void 0) { escapeExtraTags = new Set(); } | ||
var out = ''; | ||
function tagToString(tag, escapeExtraTags = new Set()) { | ||
let out = ''; | ||
if (tag.tagName) { | ||
if (!JSDOC_TAGS_WHITELIST.has(tag.tagName) || escapeExtraTags.has(tag.tagName)) { | ||
if (!JSDOC_TAGS_OUTPUT_WHITELIST.has(tag.tagName) || escapeExtraTags.has(tag.tagName)) { | ||
// Escape tags we don't understand. This is a subtle | ||
@@ -311,6 +285,6 @@ // compromise between multiple issues. | ||
// responsibility of a linter. | ||
out += " \\@" + tag.tagName; | ||
out += ` \\@${tag.tagName}`; | ||
} | ||
else { | ||
out += " @" + tag.tagName; | ||
out += ` @${tag.tagName}`; | ||
} | ||
@@ -338,3 +312,3 @@ } | ||
/** Tags that must only occur onces in a comment (filtered below). */ | ||
var SINGLETON_TAGS = new Set(['deprecated']); | ||
const SINGLETON_TAGS = new Set(['deprecated']); | ||
/** Tags that conflict with \@type in Closure Compiler (e.g. \@param). */ | ||
@@ -348,7 +322,7 @@ exports.TAGS_CONFLICTING_WITH_TYPE = new Set(['param', 'return']); | ||
function synthesizeLeadingComments(node) { | ||
var existing = ts.getSyntheticLeadingComments(node); | ||
const existing = ts.getSyntheticLeadingComments(node); | ||
if (existing) | ||
return existing; | ||
var text = node.getFullText(); | ||
var synthComments = getLeadingCommentRangesSynthesized(text, node.getFullStart()); | ||
const text = node.getFullText(); | ||
const synthComments = getLeadingCommentRangesSynthesized(text, node.getFullStart()); | ||
if (synthComments.length) { | ||
@@ -367,12 +341,11 @@ ts.setSyntheticLeadingComments(node, synthComments); | ||
// VisibleForTesting | ||
function getLeadingCommentRangesSynthesized(text, offset) { | ||
if (offset === void 0) { offset = 0; } | ||
var comments = ts.getLeadingCommentRanges(text, 0) || []; | ||
return comments.map(function (cr) { | ||
function getLeadingCommentRangesSynthesized(text, offset = 0) { | ||
const comments = ts.getLeadingCommentRanges(text, 0) || []; | ||
return comments.map((cr) => { | ||
// Confusingly, CommentRange in TypeScript includes start and end markers, but | ||
// SynthesizedComments do not. | ||
var commentText = cr.kind === ts.SyntaxKind.SingleLineCommentTrivia ? | ||
const commentText = cr.kind === ts.SyntaxKind.SingleLineCommentTrivia ? | ||
text.substring(cr.pos + 2, cr.end) : | ||
text.substring(cr.pos + 2, cr.end - 2); | ||
return __assign({}, cr, { text: commentText, pos: -1, end: -1, originalRange: { pos: cr.pos + offset, end: cr.end + offset } }); | ||
return Object.assign({}, cr, { text: commentText, pos: -1, end: -1, originalRange: { pos: cr.pos + offset, end: cr.end + offset } }); | ||
}); | ||
@@ -392,7 +365,7 @@ } | ||
// the copied node to have comments emitted. | ||
var originalStart = node.getFullStart(); | ||
var actualStart = node.getStart(); | ||
const originalStart = node.getFullStart(); | ||
const actualStart = node.getStart(); | ||
function suppressCommentsInternal(node) { | ||
ts.setEmitFlags(node, ts.EmitFlags.NoLeadingComments); | ||
return !!ts.forEachChild(node, function (child) { | ||
return !!ts.forEachChild(node, (child) => { | ||
if (child.pos !== originalStart) | ||
@@ -417,4 +390,3 @@ return true; | ||
/** Serializes a Comment out to a string, but does not include the start and end comment tokens. */ | ||
function toStringWithoutStartEnd(tags, escapeExtraTags) { | ||
if (escapeExtraTags === void 0) { escapeExtraTags = new Set(); } | ||
function toStringWithoutStartEnd(tags, escapeExtraTags = new Set()) { | ||
return serialize(tags, false, escapeExtraTags); | ||
@@ -424,14 +396,11 @@ } | ||
/** Serializes a Comment out to a string usable in source code. */ | ||
function toString(tags, escapeExtraTags) { | ||
if (escapeExtraTags === void 0) { escapeExtraTags = new Set(); } | ||
function toString(tags, escapeExtraTags = new Set()) { | ||
return serialize(tags, true, escapeExtraTags); | ||
} | ||
exports.toString = toString; | ||
function serialize(tags, includeStartEnd, escapeExtraTags) { | ||
if (escapeExtraTags === void 0) { escapeExtraTags = new Set(); } | ||
var e_2, _a; | ||
function serialize(tags, includeStartEnd, escapeExtraTags = new Set()) { | ||
if (tags.length === 0) | ||
return ''; | ||
if (tags.length === 1) { | ||
var tag = tags[0]; | ||
const tag = tags[0]; | ||
if ((tag.tagName === 'type' || tag.tagName === 'typedef' || tag.tagName === 'nocollapse') && | ||
@@ -441,29 +410,19 @@ (!tag.text || !tag.text.match('\n'))) { | ||
// /** @type {foo} */ | ||
var text = tagToString(tag, escapeExtraTags); | ||
return includeStartEnd ? "/**" + text + " */" : "*" + text + " "; | ||
const text = tagToString(tag, escapeExtraTags); | ||
return includeStartEnd ? `/**${text} */` : `*${text} `; | ||
} | ||
// Otherwise, fall through to the multi-line output. | ||
} | ||
var out = includeStartEnd ? '/**\n' : '*\n'; | ||
var emitted = new Set(); | ||
try { | ||
for (var tags_1 = __values(tags), tags_1_1 = tags_1.next(); !tags_1_1.done; tags_1_1 = tags_1.next()) { | ||
var tag = tags_1_1.value; | ||
if (emitted.has(tag.tagName) && SINGLETON_TAGS.has(tag.tagName)) { | ||
continue; | ||
} | ||
emitted.add(tag.tagName); | ||
out += ' *'; | ||
// If the tagToString is multi-line, insert " * " prefixes on subsequent lines. | ||
out += tagToString(tag, escapeExtraTags).split('\n').join('\n * '); | ||
out += '\n'; | ||
let out = includeStartEnd ? '/**\n' : '*\n'; | ||
const emitted = new Set(); | ||
for (const tag of tags) { | ||
if (emitted.has(tag.tagName) && SINGLETON_TAGS.has(tag.tagName)) { | ||
continue; | ||
} | ||
emitted.add(tag.tagName); | ||
out += ' *'; | ||
// If the tagToString is multi-line, insert " * " prefixes on subsequent lines. | ||
out += tagToString(tag, escapeExtraTags).split('\n').join('\n * '); | ||
out += '\n'; | ||
} | ||
catch (e_2_1) { e_2 = { error: e_2_1 }; } | ||
finally { | ||
try { | ||
if (tags_1_1 && !tags_1_1.done && (_a = tags_1.return)) _a.call(tags_1); | ||
} | ||
finally { if (e_2) throw e_2.error; } | ||
} | ||
out += includeStartEnd ? ' */\n' : ' '; | ||
@@ -474,43 +433,32 @@ return out; | ||
function merge(tags) { | ||
var e_3, _a; | ||
var tagNames = new Set(); | ||
var parameterNames = new Set(); | ||
var types = new Set(); | ||
var texts = new Set(); | ||
const tagNames = new Set(); | ||
const parameterNames = new Set(); | ||
const types = new Set(); | ||
const texts = new Set(); | ||
// If any of the tags are optional/rest, then the merged output is optional/rest. | ||
var optional = false; | ||
var restParam = false; | ||
try { | ||
for (var tags_2 = __values(tags), tags_2_1 = tags_2.next(); !tags_2_1.done; tags_2_1 = tags_2.next()) { | ||
var tag_1 = tags_2_1.value; | ||
tagNames.add(tag_1.tagName); | ||
if (tag_1.parameterName !== undefined) | ||
parameterNames.add(tag_1.parameterName); | ||
if (tag_1.type !== undefined) | ||
types.add(tag_1.type); | ||
if (tag_1.text !== undefined) | ||
texts.add(tag_1.text); | ||
if (tag_1.optional) | ||
optional = true; | ||
if (tag_1.restParam) | ||
restParam = true; | ||
} | ||
let optional = false; | ||
let restParam = false; | ||
for (const tag of tags) { | ||
tagNames.add(tag.tagName); | ||
if (tag.parameterName !== undefined) | ||
parameterNames.add(tag.parameterName); | ||
if (tag.type !== undefined) | ||
types.add(tag.type); | ||
if (tag.text !== undefined) | ||
texts.add(tag.text); | ||
if (tag.optional) | ||
optional = true; | ||
if (tag.restParam) | ||
restParam = true; | ||
} | ||
catch (e_3_1) { e_3 = { error: e_3_1 }; } | ||
finally { | ||
try { | ||
if (tags_2_1 && !tags_2_1.done && (_a = tags_2.return)) _a.call(tags_2); | ||
} | ||
finally { if (e_3) throw e_3.error; } | ||
} | ||
if (tagNames.size !== 1) { | ||
throw new Error("cannot merge differing tags: " + JSON.stringify(tags)); | ||
throw new Error(`cannot merge differing tags: ${JSON.stringify(tags)}`); | ||
} | ||
var tagName = tagNames.values().next().value; | ||
var parameterName = parameterNames.size > 0 ? Array.from(parameterNames).join('_or_') : undefined; | ||
var type = types.size > 0 ? Array.from(types).join('|') : undefined; | ||
const tagName = tagNames.values().next().value; | ||
const parameterName = parameterNames.size > 0 ? Array.from(parameterNames).join('_or_') : undefined; | ||
const type = types.size > 0 ? Array.from(types).join('|') : undefined; | ||
// @template uses text (not type!) to declare its type parameters, with ','-separated text. | ||
var isTemplateTag = tagName === 'template'; | ||
var text = texts.size > 0 ? Array.from(texts).join(isTemplateTag ? ',' : ' / ') : undefined; | ||
var tag = { tagName: tagName, parameterName: parameterName, type: type, text: text }; | ||
const isTemplateTag = tagName === 'template'; | ||
const text = texts.size > 0 ? Array.from(texts).join(isTemplateTag ? ',' : ' / ') : undefined; | ||
const tag = { tagName, parameterName, type, text }; | ||
// Note: a param can either be optional or a rest param; if we merged an | ||
@@ -528,2 +476,2 @@ // optional and rest param together, prefer marking it as a rest param. | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsdoc.js","sourceRoot":"","sources":["../../../../src/jsdoc.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 */\n\nimport * as ts from 'typescript';\n\n/**\n * TypeScript has an API for JSDoc already, but it's not exposed.\n * https://github.com/Microsoft/TypeScript/issues/7393\n * For now we create types that are similar to theirs so that migrating\n * to their API will be easier.  See e.g. ts.JSDocTag and ts.JSDocComment.\n */\nexport interface Tag {\n  /**\n   * tagName is e.g. \"param\" in an @param declaration.  It is the empty string\n   * for the plain text documentation that occurs before any @foo lines.\n   */\n  tagName: string;\n  /**\n   * parameterName is the the name of the function parameter, e.g. \"foo\"\n   * in `\\@param foo The foo param`\n   */\n  parameterName?: string;\n  /**\n   * The type of a JSDoc \\@param, \\@type etc tag, rendered in curly braces.\n   * Can also hold the type of an \\@suppress.\n   */\n  type?: string;\n  /** optional is true for optional function parameters. */\n  optional?: boolean;\n  /** restParam is true for \"...x: foo[]\" function parameters. */\n  restParam?: boolean;\n  /**\n   * destructuring is true for destructuring bind parameters, which require\n   * non-null arguments on the Closure side.  Can likely remove this\n   * once TypeScript nullable types are available.\n   */\n  destructuring?: boolean;\n  /** Any remaining text on the tag, e.g. the description. */\n  text?: string;\n}\n\n/**\n * A list of all JSDoc tags allowed by the Closure compiler.\n * The public Closure docs don't list all the tags it allows; this list comes\n * from the compiler source itself.\n * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/parsing/Annotation.java\n * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/parsing/ParserConfig.properties\n */\nconst JSDOC_TAGS_WHITELIST = new Set([\n  'abstract',\n  'argument',\n  'author',\n  'consistentIdGenerator',\n  'const',\n  'constant',\n  'constructor',\n  'copyright',\n  'define',\n  'deprecated',\n  'desc',\n  'dict',\n  'disposes',\n  'enhance',\n  'enhanceable',\n  'enum',\n  'export',\n  'expose',\n  'extends',\n  'externs',\n  'fileoverview',\n  'final',\n  'hassoydelcall',\n  'hassoydeltemplate',\n  'hidden',\n  'id',\n  'idGenerator',\n  'ignore',\n  'implements',\n  'implicitCast',\n  'inheritDoc',\n  'interface',\n  'jaggerInject',\n  'jaggerModule',\n  'jaggerProvide',\n  'jaggerProvidePromise',\n  'lends',\n  'license',\n  'link',\n  'meaning',\n  'modifies',\n  'modName',\n  'mods',\n  'ngInject',\n  'noalias',\n  'nocollapse',\n  'nocompile',\n  'nosideeffects',\n  'override',\n  'owner',\n  'package',\n  'param',\n  'pintomodule',\n  'polymer',\n  'polymerBehavior',\n  'preserve',\n  'preserveTry',\n  'private',\n  'protected',\n  'public',\n  'record',\n  'requirecss',\n  'requires',\n  'return',\n  'returns',\n  'see',\n  'stableIdGenerator',\n  'struct',\n  'suppress',\n  'template',\n  'this',\n  'throws',\n  'type',\n  'typedef',\n  'unrestricted',\n  'version',\n  'wizaction',\n  'wizmodule',\n]);\n\n/**\n * A list of JSDoc @tags that are never allowed in TypeScript source. These are Closure tags that\n * can be expressed in the TypeScript surface syntax. As tsickle's emit will mangle type names,\n * these will cause Closure Compiler issues and should not be used.\n */\nconst JSDOC_TAGS_BLACKLIST = new Set([\n  'augments', 'class',      'constructs', 'constructor', 'enum',      'extends', 'field',\n  'function', 'implements', 'interface',  'lends',       'namespace', 'private', 'public',\n  'record',   'static',     'template',   'this',        'type',      'typedef',\n]);\n\n/**\n * A list of JSDoc @tags that might include a {type} after them. Only banned when a type is passed.\n * Note that this does not include tags that carry a non-type system type, e.g. \\@suppress.\n */\nconst JSDOC_TAGS_WITH_TYPES = new Set([\n  'const',\n  'export',\n  'param',\n  'return',\n]);\n\n/**\n * Result of parsing a JSDoc comment. Such comments essentially are built of a list of tags.\n * In addition to the tags, this might also contain warnings to indicate non-fatal problems\n * while finding the tags.\n */\nexport interface ParsedJSDocComment {\n  tags: Tag[];\n  warnings?: string[];\n}\n\n/**\n * parse parses JSDoc out of a comment string.\n * Returns null if comment is not JSDoc.\n */\n// TODO(martinprobst): representing JSDoc as a list of tags is too simplistic. We need functionality\n// such as merging (below), de-duplicating certain tags (@deprecated), and special treatment for\n// others (e.g. @suppress). We should introduce a proper model class with a more suitable data\n// strucure (e.g. a Map<TagName, Values[]>).\nexport function parse(comment: ts.SynthesizedComment): ParsedJSDocComment|null {\n  // TODO(evanm): this is a pile of hacky regexes for now, because we\n  // would rather use the better TypeScript implementation of JSDoc\n  // parsing.  https://github.com/Microsoft/TypeScript/issues/7393\n  if (comment.kind !== ts.SyntaxKind.MultiLineCommentTrivia) return null;\n  // comment.text does not include /* and */, so must start with '*' for JSDoc.\n  if (comment.text[0] !== '*') return null;\n  const text = comment.text.substring(1).trim();\n  return parseContents(text);\n}\n\n/**\n * Returns the input string with line endings normalized to '\\n'.\n */\nexport function normalizeLineEndings(input: string): string {\n  return input.replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * parseContents parses JSDoc out of a comment text.\n * Returns null if comment is not JSDoc.\n *\n * @param commentText a comment's text content, i.e. the comment w/o /* and * /.\n */\nexport function parseContents(commentText: string): ParsedJSDocComment|null {\n  // Make sure we have proper line endings before parsing on Windows.\n  commentText = normalizeLineEndings(commentText);\n  // Strip all the \" * \" bits from the front of each line.\n  commentText = commentText.replace(/^\\s*\\*? ?/gm, '');\n  const lines = commentText.split('\\n');\n  const tags: Tag[] = [];\n  const warnings: string[] = [];\n  for (const line of lines) {\n    let match = line.match(/^\\s*@(\\S+) *(.*)/);\n    if (match) {\n      let [_, tagName, text] = match;\n      if (tagName === 'returns') {\n        // A synonym for 'return'.\n        tagName = 'return';\n      }\n      let type: string|undefined;\n      if (JSDOC_TAGS_BLACKLIST.has(tagName)) {\n        warnings.push(`@${tagName} annotations are redundant with TypeScript equivalents`);\n        continue;  // Drop the tag so Closure won't process it.\n      } else if (JSDOC_TAGS_WITH_TYPES.has(tagName) && text[0] === '{') {\n        warnings.push(\n            `the type annotation on @${tagName} is redundant with its TypeScript type, ` +\n            `remove the {...} part`);\n        continue;\n      } else if (tagName === 'suppress') {\n        const suppressMatch = text.match(/^\\{(.*)\\}(.*)$/);\n        if (!suppressMatch) {\n          warnings.push(`malformed @suppress tag: \"${text}\"`);\n        } else {\n          [, type, text] = suppressMatch;\n        }\n      } else if (tagName === 'dict') {\n        warnings.push('use index signatures (`[k: string]: type`) instead of @dict');\n        continue;\n      }\n\n      // Grab the parameter name from @param tags.\n      let parameterName: string|undefined;\n      if (tagName === 'param') {\n        match = text.match(/^(\\S+) ?(.*)/);\n        if (match) [_, parameterName, text] = match;\n      }\n\n      const tag: Tag = {tagName};\n      if (parameterName) tag.parameterName = parameterName;\n      if (text) tag.text = text;\n      if (type) tag.type = type;\n      tags.push(tag);\n    } else {\n      // Text without a preceding @tag on it is either the plain text\n      // documentation or a continuation of a previous tag.\n      if (tags.length === 0) {\n        tags.push({tagName: '', text: line});\n      } else {\n        const lastTag = tags[tags.length - 1];\n        lastTag.text = (lastTag.text || '') + '\\n' + line;\n      }\n    }\n  }\n  if (warnings.length > 0) {\n    return {tags, warnings};\n  }\n  return {tags};\n}\n\n/**\n * Serializes a Tag into a string usable in a comment.\n * Returns a string like \" @foo {bar} baz\" (note the whitespace).\n */\nfunction tagToString(tag: Tag, escapeExtraTags = new Set<string>()): string {\n  let out = '';\n  if (tag.tagName) {\n    if (!JSDOC_TAGS_WHITELIST.has(tag.tagName) || escapeExtraTags.has(tag.tagName)) {\n      // Escape tags we don't understand.  This is a subtle\n      // compromise between multiple issues.\n      // 1) If we pass through these non-Closure tags, the user will\n      //    get a warning from Closure, and the point of tsickle is\n      //    to insulate the user from Closure.\n      // 2) The output of tsickle is for Closure but also may be read\n      //    by humans, for example non-TypeScript users of Angular.\n      // 3) Finally, we don't want to warn because users should be\n      //    free to add whichever JSDoc they feel like.  If the user\n      //    wants help ensuring they didn't typo a tag, that is the\n      //    responsibility of a linter.\n      out += ` \\\\@${tag.tagName}`;\n    } else {\n      out += ` @${tag.tagName}`;\n    }\n  }\n  if (tag.type) {\n    out += ' {';\n    if (tag.restParam) {\n      out += '...';\n    }\n    out += tag.type;\n    if (tag.optional) {\n      out += '=';\n    }\n    out += '}';\n  }\n  if (tag.parameterName) {\n    out += ' ' + tag.parameterName;\n  }\n  if (tag.text) {\n    out += ' ' + tag.text.replace(/@/g, '\\\\@');\n  }\n  return out;\n}\n\n/** Tags that must only occur onces in a comment (filtered below). */\nconst SINGLETON_TAGS = new Set(['deprecated']);\n\n/** Tags that conflict with \\@type in Closure Compiler (e.g. \\@param). */\nexport const TAGS_CONFLICTING_WITH_TYPE = new Set(['param', 'return']);\n\n/**\n * A synthesized comment that (possibly) includes the original comment range it was created from.\n */\nexport interface SynthesizedCommentWithOriginal extends ts.SynthesizedComment {\n  /**\n   * The original text range of the comment (relative to the source file's full text).\n   */\n  originalRange?: ts.TextRange;\n}\n\n/**\n * synthesizeLeadingComments parses the leading comments of node, converts them\n * to synthetic comments, and makes sure the original text comments do not get\n * emitted by TypeScript.\n */\nexport function synthesizeLeadingComments(node: ts.Node): SynthesizedCommentWithOriginal[] {\n  const existing = ts.getSyntheticLeadingComments(node);\n  if (existing) return existing;\n  const text = node.getFullText();\n  const synthComments = getLeadingCommentRangesSynthesized(text, node.getFullStart());\n  if (synthComments.length) {\n    ts.setSyntheticLeadingComments(node, synthComments);\n    suppressLeadingCommentsRecursively(node);\n  }\n  return synthComments;\n}\n\n/**\n * parseLeadingCommentRangesSynthesized parses the leading comment ranges out of the given text and\n * converts them to SynthesizedComments.\n * @param offset the offset of text in the source file, e.g. node.getFullStart().\n */\n// VisibleForTesting\nexport function getLeadingCommentRangesSynthesized(\n    text: string, offset = 0): SynthesizedCommentWithOriginal[] {\n  const comments = ts.getLeadingCommentRanges(text, 0) || [];\n  return comments.map((cr): SynthesizedCommentWithOriginal => {\n    // Confusingly, CommentRange in TypeScript includes start and end markers, but\n    // SynthesizedComments do not.\n    const commentText = cr.kind === ts.SyntaxKind.SingleLineCommentTrivia ?\n        text.substring(cr.pos + 2, cr.end) :\n        text.substring(cr.pos + 2, cr.end - 2);\n    return {\n      ...cr,\n      text: commentText,\n      pos: -1,\n      end: -1,\n      originalRange: {pos: cr.pos + offset, end: cr.end + offset}\n    };\n  });\n}\n\n/**\n * suppressCommentsRecursively prevents emit of leading comments on node, and any recursive nodes\n * underneath it that start at the same offset.\n */\nexport function suppressLeadingCommentsRecursively(node: ts.Node) {\n  // TypeScript emits leading comments on a node, unless:\n  // - the comment was emitted by the parent node\n  // - the node has the NoLeadingComments emit flag.\n  // However, transformation steps sometimes copy nodes without keeping their emit flags, so just\n  // setting NoLeadingComments recursively is not enough, we must also set the text range to avoid\n  // the copied node to have comments emitted.\n  const originalStart = node.getFullStart();\n  const actualStart = node.getStart();\n  function suppressCommentsInternal(node: ts.Node): boolean {\n    ts.setEmitFlags(node, ts.EmitFlags.NoLeadingComments);\n    return !!ts.forEachChild(node, (child) => {\n      if (child.pos !== originalStart) return true;\n      return suppressCommentsInternal(child);\n    });\n  }\n  suppressCommentsInternal(node);\n}\n\nexport function toSynthesizedComment(\n    tags: Tag[], escapeExtraTags?: Set<string>): ts.SynthesizedComment {\n  return {\n    kind: ts.SyntaxKind.MultiLineCommentTrivia,\n    text: toStringWithoutStartEnd(tags, escapeExtraTags),\n    pos: -1,\n    end: -1,\n    hasTrailingNewLine: true,\n  };\n}\n\n/** Serializes a Comment out to a string, but does not include the start and end comment tokens. */\nexport function toStringWithoutStartEnd(tags: Tag[], escapeExtraTags = new Set<string>()): string {\n  return serialize(tags, false, escapeExtraTags);\n}\n\n/** Serializes a Comment out to a string usable in source code. */\nexport function toString(tags: Tag[], escapeExtraTags = new Set<string>()): string {\n  return serialize(tags, true, escapeExtraTags);\n}\n\nfunction serialize(\n    tags: Tag[], includeStartEnd: boolean, escapeExtraTags = new Set<string>()): string {\n  if (tags.length === 0) return '';\n  if (tags.length === 1) {\n    const tag = tags[0];\n    if ((tag.tagName === 'type' || tag.tagName === 'typedef' || tag.tagName === 'nocollapse') &&\n        (!tag.text || !tag.text.match('\\n'))) {\n      // Special-case one-liner \"type\" and \"nocollapse\" tags to fit on one line, e.g.\n      //   /** @type {foo} */\n      const text = tagToString(tag, escapeExtraTags);\n      return includeStartEnd ? `/**${text} */` : `*${text} `;\n    }\n    // Otherwise, fall through to the multi-line output.\n  }\n\n  let out = includeStartEnd ? '/**\\n' : '*\\n';\n  const emitted = new Set<string>();\n  for (const tag of tags) {\n    if (emitted.has(tag.tagName) && SINGLETON_TAGS.has(tag.tagName)) {\n      continue;\n    }\n    emitted.add(tag.tagName);\n    out += ' *';\n    // If the tagToString is multi-line, insert \" * \" prefixes on subsequent lines.\n    out += tagToString(tag, escapeExtraTags).split('\\n').join('\\n * ');\n    out += '\\n';\n  }\n  out += includeStartEnd ? ' */\\n' : ' ';\n  return out;\n}\n\n/** Merges multiple tags (of the same tagName type) into a single unified tag. */\nexport function merge(tags: Tag[]): Tag {\n  const tagNames = new Set<string>();\n  const parameterNames = new Set<string>();\n  const types = new Set<string>();\n  const texts = new Set<string>();\n  // If any of the tags are optional/rest, then the merged output is optional/rest.\n  let optional = false;\n  let restParam = false;\n  for (const tag of tags) {\n    tagNames.add(tag.tagName);\n    if (tag.parameterName !== undefined) parameterNames.add(tag.parameterName);\n    if (tag.type !== undefined) types.add(tag.type);\n    if (tag.text !== undefined) texts.add(tag.text);\n    if (tag.optional) optional = true;\n    if (tag.restParam) restParam = true;\n  }\n\n  if (tagNames.size !== 1) {\n    throw new Error(`cannot merge differing tags: ${JSON.stringify(tags)}`);\n  }\n  const tagName = tagNames.values().next().value;\n  const parameterName =\n      parameterNames.size > 0 ? Array.from(parameterNames).join('_or_') : undefined;\n  const type = types.size > 0 ? Array.from(types).join('|') : undefined;\n  // @template uses text (not type!) to declare its type parameters, with ','-separated text.\n  const isTemplateTag = tagName === 'template';\n  const text = texts.size > 0 ? Array.from(texts).join(isTemplateTag ? ',' : ' / ') : undefined;\n  const tag: Tag = {tagName, parameterName, type, text};\n  // Note: a param can either be optional or a rest param; if we merged an\n  // optional and rest param together, prefer marking it as a rest param.\n  if (restParam) {\n    tag.restParam = true;\n  } else if (optional) {\n    tag.optional = true;\n  }\n  return tag;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsdoc.js","sourceRoot":"","sources":["../../../../src/jsdoc.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 */\n\nimport * as ts from 'typescript';\n\n/**\n * TypeScript has an API for JSDoc already, but it's not exposed.\n * https://github.com/Microsoft/TypeScript/issues/7393\n * For now we create types that are similar to theirs so that migrating\n * to their API will be easier.  See e.g. ts.JSDocTag and ts.JSDocComment.\n */\nexport interface Tag {\n  /**\n   * tagName is e.g. \"param\" in an @param declaration.  It is the empty string\n   * for the plain text documentation that occurs before any @foo lines.\n   */\n  tagName: string;\n  /**\n   * parameterName is the the name of the function parameter, e.g. \"foo\"\n   * in `\\@param foo The foo param`\n   */\n  parameterName?: string;\n  /**\n   * The type of a JSDoc \\@param, \\@type etc tag, rendered in curly braces.\n   * Can also hold the type of an \\@suppress.\n   */\n  type?: string;\n  /** optional is true for optional function parameters. */\n  optional?: boolean;\n  /** restParam is true for \"...x: foo[]\" function parameters. */\n  restParam?: boolean;\n  /**\n   * destructuring is true for destructuring bind parameters, which require\n   * non-null arguments on the Closure side.  Can likely remove this\n   * once TypeScript nullable types are available.\n   */\n  destructuring?: boolean;\n  /** Any remaining text on the tag, e.g. the description. */\n  text?: string;\n}\n\n/**\n * A list of all JSDoc tags allowed by the Closure compiler.\n * All tags other than these are escaped before emitting.\n *\n * Note that some of these tags are also rejected by tsickle when seen in\n * the user-provided source, but also that tsickle itself may generate some of these.\n * This whitelist is just used for controlling the output.\n *\n * The public Closure docs don't list all the tags it allows; this list comes\n * from the compiler source itself.\n * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/parsing/Annotation.java\n * https://github.com/google/closure-compiler/blob/master/src/com/google/javascript/jscomp/parsing/ParserConfig.properties\n */\nconst JSDOC_TAGS_OUTPUT_WHITELIST = new Set([\n  'abstract',\n  'argument',\n  'author',\n  'consistentIdGenerator',\n  'const',\n  'constant',\n  'constructor',\n  'copyright',\n  'define',\n  'deprecated',\n  'desc',\n  'dict',\n  'disposes',\n  'enhance',\n  'enhanceable',\n  'enum',\n  'export',\n  'expose',\n  'extends',\n  'externs',\n  'fileoverview',\n  'final',\n  'hassoydelcall',\n  'hassoydeltemplate',\n  'hidden',\n  'id',\n  'idGenerator',\n  'ignore',\n  'implements',\n  'implicitCast',\n  'inheritDoc',\n  'interface',\n  'jaggerInject',\n  'jaggerModule',\n  'jaggerProvide',\n  'jaggerProvidePromise',\n  'lends',\n  'license',\n  'link',\n  'meaning',\n  'modifies',\n  'modName',\n  'mods',\n  'ngInject',\n  'noalias',\n  'nocollapse',\n  'nocompile',\n  'nosideeffects',\n  'override',\n  'owner',\n  'package',\n  'param',\n  'pintomodule',\n  'polymer',\n  'polymerBehavior',\n  'preserve',\n  'preserveTry',\n  'private',\n  'protected',\n  'public',\n  'record',\n  'requirecss',\n  'requires',\n  'return',\n  'returns',\n  'see',\n  'stableIdGenerator',\n  'struct',\n  'suppress',\n  'template',\n  'this',\n  'throws',\n  'type',\n  'typedef',\n  'unrestricted',\n  'version',\n  'wizaction',\n  'wizmodule',\n]);\n\n/**\n * A list of JSDoc @tags that are never allowed in TypeScript source. These are Closure tags that\n * can be expressed in the TypeScript surface syntax. As tsickle's emit will mangle type names,\n * these will cause Closure Compiler issues and should not be used.\n * Note: 'template' is special-cased below; see where this set is queried.\n */\nconst JSDOC_TAGS_INPUT_BLACKLIST = new Set([\n  'augments', 'class',      'constructs', 'constructor', 'enum',      'extends', 'field',\n  'function', 'implements', 'interface',  'lends',       'namespace', 'private', 'public',\n  'record',   'static',     'template',   'this',        'type',      'typedef',\n]);\n\n/**\n * JSDoc \\@tags that might include a {type} after them. Specifying a type is forbidden, since it\n * would collide with TypeScript's type information. If a type *is* given, the entire tag will be\n * ignored.\n */\nconst JSDOC_TAGS_WITH_TYPES = new Set([\n  'const',\n  'define',\n  'export',\n  'param',\n  'return',\n]);\n\n/**\n * Result of parsing a JSDoc comment. Such comments essentially are built of a list of tags.\n * In addition to the tags, this might also contain warnings to indicate non-fatal problems\n * while finding the tags.\n */\nexport interface ParsedJSDocComment {\n  tags: Tag[];\n  warnings?: string[];\n}\n\n/**\n * parse parses JSDoc out of a comment string.\n * Returns null if comment is not JSDoc.\n */\n// TODO(martinprobst): representing JSDoc as a list of tags is too simplistic. We need functionality\n// such as merging (below), de-duplicating certain tags (@deprecated), and special treatment for\n// others (e.g. @suppress). We should introduce a proper model class with a more suitable data\n// strucure (e.g. a Map<TagName, Values[]>).\nexport function parse(comment: ts.SynthesizedComment): ParsedJSDocComment|null {\n  // TODO(evanm): this is a pile of hacky regexes for now, because we\n  // would rather use the better TypeScript implementation of JSDoc\n  // parsing.  https://github.com/Microsoft/TypeScript/issues/7393\n  if (comment.kind !== ts.SyntaxKind.MultiLineCommentTrivia) return null;\n  // comment.text does not include /* and */, so must start with '*' for JSDoc.\n  if (comment.text[0] !== '*') return null;\n  const text = comment.text.substring(1).trim();\n  return parseContents(text);\n}\n\n/**\n * Returns the input string with line endings normalized to '\\n'.\n */\nexport function normalizeLineEndings(input: string): string {\n  return input.replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * parseContents parses JSDoc out of a comment text.\n * Returns null if comment is not JSDoc.\n *\n * @param commentText a comment's text content, i.e. the comment w/o /* and * /.\n */\nexport function parseContents(commentText: string): ParsedJSDocComment|null {\n  // Make sure we have proper line endings before parsing on Windows.\n  commentText = normalizeLineEndings(commentText);\n  // Strip all the \" * \" bits from the front of each line.\n  commentText = commentText.replace(/^\\s*\\*? ?/gm, '');\n  const lines = commentText.split('\\n');\n  const tags: Tag[] = [];\n  const warnings: string[] = [];\n  for (const line of lines) {\n    let match = line.match(/^\\s*@(\\S+) *(.*)/);\n    if (match) {\n      let [_, tagName, text] = match;\n      if (tagName === 'returns') {\n        // A synonym for 'return'.\n        tagName = 'return';\n      }\n      let type: string|undefined;\n      if (JSDOC_TAGS_INPUT_BLACKLIST.has(tagName)) {\n        if (tagName !== 'template') {\n          // Tell the user to not write blacklisted tags, because there is TS\n          // syntax available for them.\n          warnings.push(`@${tagName} annotations are redundant with TypeScript equivalents`);\n          continue;  // Drop the tag so Closure won't process it.\n        } else {\n          // But @template in particular is special: it's ok for the user to\n          // write it for documentation purposes, but we don't want the\n          // user-written one making it into the output because Closure interprets\n          // it as well.\n          // Drop it without any warning.  (We also don't ensure its correctness.)\n          continue;\n        }\n      } else if (JSDOC_TAGS_WITH_TYPES.has(tagName)) {\n        if (text[0] === '{') {\n          warnings.push(\n              `the type annotation on @${tagName} is redundant with its TypeScript type, ` +\n              `remove the {...} part`);\n          continue;\n        }\n      } else if (tagName === 'suppress') {\n        const typeMatch = text.match(/^\\{(.*)\\}(.*)$/);\n        if (typeMatch) {\n          [, type, text] = typeMatch;\n        } else {\n          warnings.push(`malformed @${tagName} tag: \"${text}\"`);\n        }\n      } else if (tagName === 'dict') {\n        warnings.push('use index signatures (`[k: string]: type`) instead of @dict');\n        continue;\n      }\n\n      // Grab the parameter name from @param tags.\n      let parameterName: string|undefined;\n      if (tagName === 'param') {\n        match = text.match(/^(\\S+) ?(.*)/);\n        if (match) [_, parameterName, text] = match;\n      }\n\n      const tag: Tag = {tagName};\n      if (parameterName) tag.parameterName = parameterName;\n      if (text) tag.text = text;\n      if (type) tag.type = type;\n      tags.push(tag);\n    } else {\n      // Text without a preceding @tag on it is either the plain text\n      // documentation or a continuation of a previous tag.\n      if (tags.length === 0) {\n        tags.push({tagName: '', text: line});\n      } else {\n        const lastTag = tags[tags.length - 1];\n        lastTag.text = (lastTag.text || '') + '\\n' + line;\n      }\n    }\n  }\n  if (warnings.length > 0) {\n    return {tags, warnings};\n  }\n  return {tags};\n}\n\n/**\n * Serializes a Tag into a string usable in a comment.\n * Returns a string like \" @foo {bar} baz\" (note the whitespace).\n */\nfunction tagToString(tag: Tag, escapeExtraTags = new Set<string>()): string {\n  let out = '';\n  if (tag.tagName) {\n    if (!JSDOC_TAGS_OUTPUT_WHITELIST.has(tag.tagName) || escapeExtraTags.has(tag.tagName)) {\n      // Escape tags we don't understand.  This is a subtle\n      // compromise between multiple issues.\n      // 1) If we pass through these non-Closure tags, the user will\n      //    get a warning from Closure, and the point of tsickle is\n      //    to insulate the user from Closure.\n      // 2) The output of tsickle is for Closure but also may be read\n      //    by humans, for example non-TypeScript users of Angular.\n      // 3) Finally, we don't want to warn because users should be\n      //    free to add whichever JSDoc they feel like.  If the user\n      //    wants help ensuring they didn't typo a tag, that is the\n      //    responsibility of a linter.\n      out += ` \\\\@${tag.tagName}`;\n    } else {\n      out += ` @${tag.tagName}`;\n    }\n  }\n  if (tag.type) {\n    out += ' {';\n    if (tag.restParam) {\n      out += '...';\n    }\n    out += tag.type;\n    if (tag.optional) {\n      out += '=';\n    }\n    out += '}';\n  }\n  if (tag.parameterName) {\n    out += ' ' + tag.parameterName;\n  }\n  if (tag.text) {\n    out += ' ' + tag.text.replace(/@/g, '\\\\@');\n  }\n  return out;\n}\n\n/** Tags that must only occur onces in a comment (filtered below). */\nconst SINGLETON_TAGS = new Set(['deprecated']);\n\n/** Tags that conflict with \\@type in Closure Compiler (e.g. \\@param). */\nexport const TAGS_CONFLICTING_WITH_TYPE = new Set(['param', 'return']);\n\n/**\n * A synthesized comment that (possibly) includes the original comment range it was created from.\n */\nexport interface SynthesizedCommentWithOriginal extends ts.SynthesizedComment {\n  /**\n   * The original text range of the comment (relative to the source file's full text).\n   */\n  originalRange?: ts.TextRange;\n}\n\n/**\n * synthesizeLeadingComments parses the leading comments of node, converts them\n * to synthetic comments, and makes sure the original text comments do not get\n * emitted by TypeScript.\n */\nexport function synthesizeLeadingComments(node: ts.Node): SynthesizedCommentWithOriginal[] {\n  const existing = ts.getSyntheticLeadingComments(node);\n  if (existing) return existing;\n  const text = node.getFullText();\n  const synthComments = getLeadingCommentRangesSynthesized(text, node.getFullStart());\n  if (synthComments.length) {\n    ts.setSyntheticLeadingComments(node, synthComments);\n    suppressLeadingCommentsRecursively(node);\n  }\n  return synthComments;\n}\n\n/**\n * parseLeadingCommentRangesSynthesized parses the leading comment ranges out of the given text and\n * converts them to SynthesizedComments.\n * @param offset the offset of text in the source file, e.g. node.getFullStart().\n */\n// VisibleForTesting\nexport function getLeadingCommentRangesSynthesized(\n    text: string, offset = 0): SynthesizedCommentWithOriginal[] {\n  const comments = ts.getLeadingCommentRanges(text, 0) || [];\n  return comments.map((cr): SynthesizedCommentWithOriginal => {\n    // Confusingly, CommentRange in TypeScript includes start and end markers, but\n    // SynthesizedComments do not.\n    const commentText = cr.kind === ts.SyntaxKind.SingleLineCommentTrivia ?\n        text.substring(cr.pos + 2, cr.end) :\n        text.substring(cr.pos + 2, cr.end - 2);\n    return {\n      ...cr,\n      text: commentText,\n      pos: -1,\n      end: -1,\n      originalRange: {pos: cr.pos + offset, end: cr.end + offset}\n    };\n  });\n}\n\n/**\n * suppressCommentsRecursively prevents emit of leading comments on node, and any recursive nodes\n * underneath it that start at the same offset.\n */\nexport function suppressLeadingCommentsRecursively(node: ts.Node) {\n  // TypeScript emits leading comments on a node, unless:\n  // - the comment was emitted by the parent node\n  // - the node has the NoLeadingComments emit flag.\n  // However, transformation steps sometimes copy nodes without keeping their emit flags, so just\n  // setting NoLeadingComments recursively is not enough, we must also set the text range to avoid\n  // the copied node to have comments emitted.\n  const originalStart = node.getFullStart();\n  const actualStart = node.getStart();\n  function suppressCommentsInternal(node: ts.Node): boolean {\n    ts.setEmitFlags(node, ts.EmitFlags.NoLeadingComments);\n    return !!ts.forEachChild(node, (child) => {\n      if (child.pos !== originalStart) return true;\n      return suppressCommentsInternal(child);\n    });\n  }\n  suppressCommentsInternal(node);\n}\n\nexport function toSynthesizedComment(\n    tags: Tag[], escapeExtraTags?: Set<string>): ts.SynthesizedComment {\n  return {\n    kind: ts.SyntaxKind.MultiLineCommentTrivia,\n    text: toStringWithoutStartEnd(tags, escapeExtraTags),\n    pos: -1,\n    end: -1,\n    hasTrailingNewLine: true,\n  };\n}\n\n/** Serializes a Comment out to a string, but does not include the start and end comment tokens. */\nexport function toStringWithoutStartEnd(tags: Tag[], escapeExtraTags = new Set<string>()): string {\n  return serialize(tags, false, escapeExtraTags);\n}\n\n/** Serializes a Comment out to a string usable in source code. */\nexport function toString(tags: Tag[], escapeExtraTags = new Set<string>()): string {\n  return serialize(tags, true, escapeExtraTags);\n}\n\nfunction serialize(\n    tags: Tag[], includeStartEnd: boolean, escapeExtraTags = new Set<string>()): string {\n  if (tags.length === 0) return '';\n  if (tags.length === 1) {\n    const tag = tags[0];\n    if ((tag.tagName === 'type' || tag.tagName === 'typedef' || tag.tagName === 'nocollapse') &&\n        (!tag.text || !tag.text.match('\\n'))) {\n      // Special-case one-liner \"type\" and \"nocollapse\" tags to fit on one line, e.g.\n      //   /** @type {foo} */\n      const text = tagToString(tag, escapeExtraTags);\n      return includeStartEnd ? `/**${text} */` : `*${text} `;\n    }\n    // Otherwise, fall through to the multi-line output.\n  }\n\n  let out = includeStartEnd ? '/**\\n' : '*\\n';\n  const emitted = new Set<string>();\n  for (const tag of tags) {\n    if (emitted.has(tag.tagName) && SINGLETON_TAGS.has(tag.tagName)) {\n      continue;\n    }\n    emitted.add(tag.tagName);\n    out += ' *';\n    // If the tagToString is multi-line, insert \" * \" prefixes on subsequent lines.\n    out += tagToString(tag, escapeExtraTags).split('\\n').join('\\n * ');\n    out += '\\n';\n  }\n  out += includeStartEnd ? ' */\\n' : ' ';\n  return out;\n}\n\n/** Merges multiple tags (of the same tagName type) into a single unified tag. */\nexport function merge(tags: Tag[]): Tag {\n  const tagNames = new Set<string>();\n  const parameterNames = new Set<string>();\n  const types = new Set<string>();\n  const texts = new Set<string>();\n  // If any of the tags are optional/rest, then the merged output is optional/rest.\n  let optional = false;\n  let restParam = false;\n  for (const tag of tags) {\n    tagNames.add(tag.tagName);\n    if (tag.parameterName !== undefined) parameterNames.add(tag.parameterName);\n    if (tag.type !== undefined) types.add(tag.type);\n    if (tag.text !== undefined) texts.add(tag.text);\n    if (tag.optional) optional = true;\n    if (tag.restParam) restParam = true;\n  }\n\n  if (tagNames.size !== 1) {\n    throw new Error(`cannot merge differing tags: ${JSON.stringify(tags)}`);\n  }\n  const tagName = tagNames.values().next().value;\n  const parameterName =\n      parameterNames.size > 0 ? Array.from(parameterNames).join('_or_') : undefined;\n  const type = types.size > 0 ? Array.from(types).join('|') : undefined;\n  // @template uses text (not type!) to declare its type parameters, with ','-separated text.\n  const isTemplateTag = tagName === 'template';\n  const text = texts.size > 0 ? Array.from(texts).join(isTemplateTag ? ',' : ' / ') : undefined;\n  const tag: Tag = {tagName, parameterName, type, text};\n  // Note: a param can either be optional or a rest param; if we merged an\n  // optional and rest param together, prefer marking it as a rest param.\n  if (restParam) {\n    tag.restParam = true;\n  } else if (optional) {\n    tag.optional = true;\n  }\n  return tag;\n}\n"]} |
#!/usr/bin/env node | ||
/** | ||
* @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 | ||
*/ | ||
/// <amd-module name="tsickle/src/main" /> | ||
@@ -7,4 +14,2 @@ import * as ts from 'typescript'; | ||
export interface Settings { | ||
/** If provided, modify quoting of property accesses to match the type declaration. */ | ||
enableAutoQuoting?: boolean; | ||
/** If provided, path to save externs to. */ | ||
@@ -11,0 +16,0 @@ externsPath?: string; |
187
src/main.js
#!/usr/bin/env node | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
/** | ||
* @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 | ||
*/ | ||
(function (factory) { | ||
@@ -23,12 +20,21 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var fs = require("fs"); | ||
var minimist = require("minimist"); | ||
var mkdirp = require("mkdirp"); | ||
var path = require("path"); | ||
var ts = require("typescript"); | ||
var cliSupport = require("tsickle/src/cli_support"); | ||
var tsickle = require("tsickle/src/tsickle"); | ||
var tsickle_1 = require("tsickle/src/tsickle"); | ||
const fs = require("fs"); | ||
const minimist = require("minimist"); | ||
const mkdirp = require("mkdirp"); | ||
const path = require("path"); | ||
const ts = require("typescript"); | ||
const cliSupport = require("tsickle/src/cli_support"); | ||
const tsickle = require("tsickle/src/tsickle"); | ||
const tsickle_1 = require("tsickle/src/tsickle"); | ||
function usage() { | ||
console.error("usage: tsickle [tsickle options] -- [tsc options]\n\nexample:\n tsickle --externs=foo/externs.js -- -p src --noImplicitAny\n\ntsickle flags are:\n --externs=PATH save generated Closure externs.js to PATH\n --typed [experimental] attempt to provide Closure types instead of {?}\n --enableAutoQuoting automatically apply quotes to property accesses\n --fatalWarnings whether warnings should be fatal, and cause tsickle to return a non-zero exit code\n"); | ||
console.error(`usage: tsickle [tsickle options] -- [tsc options] | ||
example: | ||
tsickle --externs=foo/externs.js -- -p src --noImplicitAny | ||
tsickle flags are: | ||
--externs=PATH save generated Closure externs.js to PATH | ||
--typed [experimental] attempt to provide Closure types instead of {?} | ||
--fatalWarnings whether warnings should be fatal, and cause tsickle to return a non-zero exit code | ||
`); | ||
} | ||
@@ -40,49 +46,35 @@ /** | ||
function loadSettingsFromArgs(args) { | ||
var e_1, _a; | ||
var settings = {}; | ||
var parsedArgs = minimist(args); | ||
try { | ||
for (var _b = __values(Object.keys(parsedArgs)), _c = _b.next(); !_c.done; _c = _b.next()) { | ||
var flag = _c.value; | ||
switch (flag) { | ||
case 'h': | ||
case 'help': | ||
usage(); | ||
process.exit(0); | ||
break; | ||
case 'externs': | ||
settings.externsPath = parsedArgs[flag]; | ||
break; | ||
case 'typed': | ||
settings.isTyped = true; | ||
break; | ||
case 'verbose': | ||
settings.verbose = true; | ||
break; | ||
case 'enableAutoQuoting': | ||
settings.enableAutoQuoting = true; | ||
break; | ||
case 'fatalWarnings': | ||
settings.fatalWarnings = true; | ||
break; | ||
case '_': | ||
// This is part of the minimist API, and holds args after the '--'. | ||
break; | ||
default: | ||
console.error("unknown flag '--" + flag + "'"); | ||
usage(); | ||
process.exit(1); | ||
} | ||
const settings = {}; | ||
const parsedArgs = minimist(args); | ||
for (const flag of Object.keys(parsedArgs)) { | ||
switch (flag) { | ||
case 'h': | ||
case 'help': | ||
usage(); | ||
process.exit(0); | ||
break; | ||
case 'externs': | ||
settings.externsPath = parsedArgs[flag]; | ||
break; | ||
case 'typed': | ||
settings.isTyped = true; | ||
break; | ||
case 'verbose': | ||
settings.verbose = true; | ||
break; | ||
case 'fatalWarnings': | ||
settings.fatalWarnings = true; | ||
break; | ||
case '_': | ||
// This is part of the minimist API, and holds args after the '--'. | ||
break; | ||
default: | ||
console.error(`unknown flag '--${flag}'`); | ||
usage(); | ||
process.exit(1); | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (_c && !_c.done && (_a = _b.return)) _a.call(_b); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
// Arguments after the '--' arg are arguments to tsc. | ||
var tscArgs = parsedArgs['_']; | ||
return { settings: settings, tscArgs: tscArgs }; | ||
const tscArgs = parsedArgs['_']; | ||
return { settings, tscArgs }; | ||
} | ||
@@ -93,7 +85,7 @@ /** | ||
function getCommonParentDirectory(fileNames) { | ||
var pathSplitter = /[\/\\]+/; | ||
var commonParent = fileNames[0].split(pathSplitter); | ||
for (var i = 1; i < fileNames.length; i++) { | ||
var thisPath = fileNames[i].split(pathSplitter); | ||
var j = 0; | ||
const pathSplitter = /[\/\\]+/; | ||
const commonParent = fileNames[0].split(pathSplitter); | ||
for (let i = 1; i < fileNames.length; i++) { | ||
const thisPath = fileNames[i].split(pathSplitter); | ||
let j = 0; | ||
while (thisPath[j] === commonParent[j]) { | ||
@@ -120,24 +112,24 @@ j++; | ||
function loadTscConfig(args) { | ||
var _a; | ||
// Gather tsc options/input files from command line. | ||
var _b = ts.parseCommandLine(args), options = _b.options, fileNames = _b.fileNames, errors = _b.errors; | ||
let { options, fileNames, errors } = ts.parseCommandLine(args); | ||
if (errors.length > 0) { | ||
return { options: {}, fileNames: [], errors: errors }; | ||
return { options: {}, fileNames: [], errors }; | ||
} | ||
// Store file arguments | ||
var tsFileArguments = fileNames; | ||
const tsFileArguments = fileNames; | ||
// Read further settings from tsconfig.json. | ||
var projectDir = options.project || '.'; | ||
var configFileName = path.join(projectDir, 'tsconfig.json'); | ||
var _c = ts.readConfigFile(configFileName, function (path) { return fs.readFileSync(path, 'utf-8'); }), json = _c.config, error = _c.error; | ||
const projectDir = options.project || '.'; | ||
const configFileName = path.join(projectDir, 'tsconfig.json'); | ||
const { config: json, error } = ts.readConfigFile(configFileName, path => fs.readFileSync(path, 'utf-8')); | ||
if (error) { | ||
return { options: {}, fileNames: [], errors: [error] }; | ||
} | ||
(_a = ts.parseJsonConfigFileContent(json, ts.sys, projectDir, options, configFileName), options = _a.options, fileNames = _a.fileNames, errors = _a.errors); | ||
({ options, fileNames, errors } = | ||
ts.parseJsonConfigFileContent(json, ts.sys, projectDir, options, configFileName)); | ||
if (errors.length > 0) { | ||
return { options: {}, fileNames: [], errors: errors }; | ||
return { options: {}, fileNames: [], errors }; | ||
} | ||
// if file arguments were given to the typescript transpiler then transpile only those files | ||
fileNames = tsFileArguments.length > 0 ? tsFileArguments : fileNames; | ||
return { options: options, fileNames: fileNames, errors: [] }; | ||
return { options, fileNames, errors: [] }; | ||
} | ||
@@ -150,16 +142,14 @@ /** | ||
// relative or absolute paths | ||
var absoluteFileNames = fileNames.map(function (i) { return path.resolve(i); }); | ||
var compilerHost = ts.createCompilerHost(options); | ||
var program = ts.createProgram(absoluteFileNames, options, compilerHost); | ||
var filesToProcess = new Set(absoluteFileNames); | ||
var rootModulePath = options.rootDir || getCommonParentDirectory(absoluteFileNames); | ||
var transformerHost = { | ||
shouldSkipTsickleProcessing: function (fileName) { | ||
const absoluteFileNames = fileNames.map(i => path.resolve(i)); | ||
const compilerHost = ts.createCompilerHost(options); | ||
const program = ts.createProgram(absoluteFileNames, options, compilerHost); | ||
const filesToProcess = new Set(absoluteFileNames); | ||
const rootModulePath = options.rootDir || getCommonParentDirectory(absoluteFileNames); | ||
const transformerHost = { | ||
shouldSkipTsickleProcessing: (fileName) => { | ||
return !filesToProcess.has(path.resolve(fileName)); | ||
}, | ||
shouldIgnoreWarningsForPath: function (fileName) { return !settings.fatalWarnings; }, | ||
pathToModuleName: function (context, fileName) { | ||
return cliSupport.pathToModuleName(rootModulePath, context, fileName); | ||
}, | ||
fileNameToModuleId: function (fileName) { return path.relative(rootModulePath, fileName); }, | ||
shouldIgnoreWarningsForPath: (fileName) => !settings.fatalWarnings, | ||
pathToModuleName: (context, fileName) => cliSupport.pathToModuleName(rootModulePath, context, fileName), | ||
fileNameToModuleId: (fileName) => path.relative(rootModulePath, fileName), | ||
es5Mode: true, | ||
@@ -170,12 +160,11 @@ googmodule: true, | ||
typeBlackListPaths: new Set(), | ||
enableAutoQuoting: settings.enableAutoQuoting, | ||
untyped: false, | ||
logWarning: function (warning) { return console.error(ts.formatDiagnostics([warning], compilerHost)); }, | ||
options: options, | ||
logWarning: (warning) => console.error(ts.formatDiagnostics([warning], compilerHost)), | ||
options, | ||
moduleResolutionHost: compilerHost, | ||
}; | ||
var diagnostics = ts.getPreEmitDiagnostics(program); | ||
const diagnostics = ts.getPreEmitDiagnostics(program); | ||
if (diagnostics.length > 0) { | ||
return { | ||
diagnostics: diagnostics, | ||
diagnostics, | ||
modulesManifest: new tsickle_1.ModulesManifest(), | ||
@@ -191,4 +180,4 @@ externs: {}, | ||
function main(args) { | ||
var _a = loadSettingsFromArgs(args), settings = _a.settings, tscArgs = _a.tscArgs; | ||
var config = loadTscConfig(tscArgs); | ||
const { settings, tscArgs } = loadSettingsFromArgs(args); | ||
const config = loadTscConfig(tscArgs); | ||
if (config.errors.length) { | ||
@@ -206,3 +195,3 @@ console.error(ts.formatDiagnostics(config.errors, ts.createCompilerHost(config.options))); | ||
// Run tsickle+TSC to convert inputs to Closure JS files. | ||
var result = toClosureJS(config.options, config.fileNames, settings, function (filePath, contents) { | ||
const result = toClosureJS(config.options, config.fileNames, settings, (filePath, contents) => { | ||
mkdirp.sync(path.dirname(filePath)); | ||
@@ -226,2 +215,2 @@ fs.writeFileSync(filePath, contents, { encoding: 'utf-8' }); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../src/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\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 */\n\nimport * as fs from 'fs';\nimport * as minimist from 'minimist';\nimport * as mkdirp from 'mkdirp';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport * as cliSupport from './cli_support';\nimport * as tsickle from './tsickle';\nimport {ModulesManifest} from './tsickle';\n\n/** Tsickle settings passed on the command line. */\nexport interface Settings {\n  /** If provided, modify quoting of property accesses to match the type declaration. */\n  enableAutoQuoting?: boolean;\n\n  /** If provided, path to save externs to. */\n  externsPath?: string;\n\n  /** If provided, attempt to provide types rather than {?}. */\n  isTyped?: boolean;\n\n  /** If true, log internal debug warnings to the console. */\n  verbose?: boolean;\n\n  /** If true, warnings cause a non-zero exit code. */\n  fatalWarnings?: boolean;\n}\n\nfunction usage() {\n  console.error(`usage: tsickle [tsickle options] -- [tsc options]\n\nexample:\n  tsickle --externs=foo/externs.js -- -p src --noImplicitAny\n\ntsickle flags are:\n  --externs=PATH        save generated Closure externs.js to PATH\n  --typed               [experimental] attempt to provide Closure types instead of {?}\n  --enableAutoQuoting   automatically apply quotes to property accesses\n  --fatalWarnings       whether warnings should be fatal, and cause tsickle to return a non-zero exit code\n`);\n}\n\n/**\n * Parses the command-line arguments, extracting the tsickle settings and\n * the arguments to pass on to tsc.\n */\nfunction loadSettingsFromArgs(args: string[]): {settings: Settings, tscArgs: string[]} {\n  const settings: Settings = {};\n  const parsedArgs = minimist(args);\n  for (const flag of Object.keys(parsedArgs)) {\n    switch (flag) {\n      case 'h':\n      case 'help':\n        usage();\n        process.exit(0);\n        break;\n      case 'externs':\n        settings.externsPath = parsedArgs[flag];\n        break;\n      case 'typed':\n        settings.isTyped = true;\n        break;\n      case 'verbose':\n        settings.verbose = true;\n        break;\n      case 'enableAutoQuoting':\n        settings.enableAutoQuoting = true;\n        break;\n      case 'fatalWarnings':\n        settings.fatalWarnings = true;\n        break;\n      case '_':\n        // This is part of the minimist API, and holds args after the '--'.\n        break;\n      default:\n        console.error(`unknown flag '--${flag}'`);\n        usage();\n        process.exit(1);\n    }\n  }\n  // Arguments after the '--' arg are arguments to tsc.\n  const tscArgs = parsedArgs['_'];\n  return {settings, tscArgs};\n}\n\n/**\n * Determine the lowest-level common parent directory of the given list of files.\n */\nexport function getCommonParentDirectory(fileNames: string[]): string {\n  const pathSplitter = /[\\/\\\\]+/;\n  const commonParent = fileNames[0].split(pathSplitter);\n  for (let i = 1; i < fileNames.length; i++) {\n    const thisPath = fileNames[i].split(pathSplitter);\n    let j = 0;\n    while (thisPath[j] === commonParent[j]) {\n      j++;\n    }\n    commonParent.length = j;  // Truncate without copying the array\n  }\n  if (commonParent.length === 0) {\n    return '/';\n  } else {\n    return commonParent.join(path.sep);\n  }\n}\n\n/**\n * Loads the tsconfig.json from a directory.\n *\n * TODO(martinprobst): use ts.findConfigFile to match tsc behaviour.\n *\n * @param args tsc command-line arguments.\n */\nfunction loadTscConfig(args: string[]):\n    {options: ts.CompilerOptions, fileNames: string[], errors: ts.Diagnostic[]} {\n  // Gather tsc options/input files from command line.\n  let {options, fileNames, errors} = ts.parseCommandLine(args);\n  if (errors.length > 0) {\n    return {options: {}, fileNames: [], errors};\n  }\n\n  // Store file arguments\n  const tsFileArguments = fileNames;\n\n  // Read further settings from tsconfig.json.\n  const projectDir = options.project || '.';\n  const configFileName = path.join(projectDir, 'tsconfig.json');\n  const {config: json, error} =\n      ts.readConfigFile(configFileName, path => fs.readFileSync(path, 'utf-8'));\n  if (error) {\n    return {options: {}, fileNames: [], errors: [error]};\n  }\n  ({options, fileNames, errors} =\n       ts.parseJsonConfigFileContent(json, ts.sys, projectDir, options, configFileName));\n  if (errors.length > 0) {\n    return {options: {}, fileNames: [], errors};\n  }\n\n  // if file arguments were given to the typescript transpiler then transpile only those files\n  fileNames = tsFileArguments.length > 0 ? tsFileArguments : fileNames;\n\n  return {options, fileNames, errors: []};\n}\n\n/**\n * Compiles TypeScript code into Closure-compiler-ready JS.\n */\nexport function toClosureJS(\n    options: ts.CompilerOptions, fileNames: string[], settings: Settings,\n    writeFile?: ts.WriteFileCallback): tsickle.EmitResult {\n  // Use absolute paths to determine what files to process since files may be imported using\n  // relative or absolute paths\n  const absoluteFileNames = fileNames.map(i => path.resolve(i));\n\n  const compilerHost = ts.createCompilerHost(options);\n  const program = ts.createProgram(absoluteFileNames, options, compilerHost);\n  const filesToProcess = new Set(absoluteFileNames);\n  const rootModulePath = options.rootDir || getCommonParentDirectory(absoluteFileNames);\n  const transformerHost: tsickle.TsickleHost = {\n    shouldSkipTsickleProcessing: (fileName: string) => {\n      return !filesToProcess.has(path.resolve(fileName));\n    },\n    shouldIgnoreWarningsForPath: (fileName: string) => !settings.fatalWarnings,\n    pathToModuleName: (context, fileName) =>\n        cliSupport.pathToModuleName(rootModulePath, context, fileName),\n    fileNameToModuleId: (fileName) => path.relative(rootModulePath, fileName),\n    es5Mode: true,\n    googmodule: true,\n    transformDecorators: true,\n    transformTypesToClosure: true,\n    typeBlackListPaths: new Set(),\n    enableAutoQuoting: settings.enableAutoQuoting,\n    untyped: false,\n    logWarning: (warning) => console.error(ts.formatDiagnostics([warning], compilerHost)),\n    options,\n    moduleResolutionHost: compilerHost,\n  };\n  const diagnostics = ts.getPreEmitDiagnostics(program);\n  if (diagnostics.length > 0) {\n    return {\n      diagnostics,\n      modulesManifest: new ModulesManifest(),\n      externs: {},\n      emitSkipped: true,\n      emittedFiles: [],\n    };\n  }\n  return tsickle.emitWithTsickle(\n      program, transformerHost, compilerHost, options, undefined, writeFile);\n}\n\nfunction main(args: string[]): number {\n  const {settings, tscArgs} = loadSettingsFromArgs(args);\n  const config = loadTscConfig(tscArgs);\n  if (config.errors.length) {\n    console.error(ts.formatDiagnostics(config.errors, ts.createCompilerHost(config.options)));\n    return 1;\n  }\n\n  if (config.options.module !== ts.ModuleKind.CommonJS) {\n    // This is not an upstream TypeScript diagnostic, therefore it does not go\n    // through the diagnostics array mechanism.\n    console.error(\n        'tsickle converts TypeScript modules to Closure modules via CommonJS internally. ' +\n        'Set tsconfig.js \"module\": \"commonjs\"');\n    return 1;\n  }\n\n  // Run tsickle+TSC to convert inputs to Closure JS files.\n  const result = toClosureJS(\n      config.options, config.fileNames, settings, (filePath: string, contents: string) => {\n        mkdirp.sync(path.dirname(filePath));\n        fs.writeFileSync(filePath, contents, {encoding: 'utf-8'});\n      });\n  if (result.diagnostics.length) {\n    console.error(ts.formatDiagnostics(result.diagnostics, ts.createCompilerHost(config.options)));\n    return 1;\n  }\n\n  if (settings.externsPath) {\n    mkdirp.sync(path.dirname(settings.externsPath));\n    fs.writeFileSync(\n        settings.externsPath,\n        tsickle.getGeneratedExterns(result.externs, config.options.rootDir || ''));\n  }\n  return 0;\n}\n\n// CLI entry point\nif (require.main === module) {\n  process.exit(main(process.argv.splice(2)));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../src/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\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 */\n\nimport * as fs from 'fs';\nimport * as minimist from 'minimist';\nimport * as mkdirp from 'mkdirp';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport * as cliSupport from './cli_support';\nimport * as tsickle from './tsickle';\nimport {ModulesManifest} from './tsickle';\n\n/** Tsickle settings passed on the command line. */\nexport interface Settings {\n  /** If provided, path to save externs to. */\n  externsPath?: string;\n\n  /** If provided, attempt to provide types rather than {?}. */\n  isTyped?: boolean;\n\n  /** If true, log internal debug warnings to the console. */\n  verbose?: boolean;\n\n  /** If true, warnings cause a non-zero exit code. */\n  fatalWarnings?: boolean;\n}\n\nfunction usage() {\n  console.error(`usage: tsickle [tsickle options] -- [tsc options]\n\nexample:\n  tsickle --externs=foo/externs.js -- -p src --noImplicitAny\n\ntsickle flags are:\n  --externs=PATH        save generated Closure externs.js to PATH\n  --typed               [experimental] attempt to provide Closure types instead of {?}\n  --fatalWarnings       whether warnings should be fatal, and cause tsickle to return a non-zero exit code\n`);\n}\n\n/**\n * Parses the command-line arguments, extracting the tsickle settings and\n * the arguments to pass on to tsc.\n */\nfunction loadSettingsFromArgs(args: string[]): {settings: Settings, tscArgs: string[]} {\n  const settings: Settings = {};\n  const parsedArgs = minimist(args);\n  for (const flag of Object.keys(parsedArgs)) {\n    switch (flag) {\n      case 'h':\n      case 'help':\n        usage();\n        process.exit(0);\n        break;\n      case 'externs':\n        settings.externsPath = parsedArgs[flag];\n        break;\n      case 'typed':\n        settings.isTyped = true;\n        break;\n      case 'verbose':\n        settings.verbose = true;\n        break;\n      case 'fatalWarnings':\n        settings.fatalWarnings = true;\n        break;\n      case '_':\n        // This is part of the minimist API, and holds args after the '--'.\n        break;\n      default:\n        console.error(`unknown flag '--${flag}'`);\n        usage();\n        process.exit(1);\n    }\n  }\n  // Arguments after the '--' arg are arguments to tsc.\n  const tscArgs = parsedArgs['_'];\n  return {settings, tscArgs};\n}\n\n/**\n * Determine the lowest-level common parent directory of the given list of files.\n */\nexport function getCommonParentDirectory(fileNames: string[]): string {\n  const pathSplitter = /[\\/\\\\]+/;\n  const commonParent = fileNames[0].split(pathSplitter);\n  for (let i = 1; i < fileNames.length; i++) {\n    const thisPath = fileNames[i].split(pathSplitter);\n    let j = 0;\n    while (thisPath[j] === commonParent[j]) {\n      j++;\n    }\n    commonParent.length = j;  // Truncate without copying the array\n  }\n  if (commonParent.length === 0) {\n    return '/';\n  } else {\n    return commonParent.join(path.sep);\n  }\n}\n\n/**\n * Loads the tsconfig.json from a directory.\n *\n * TODO(martinprobst): use ts.findConfigFile to match tsc behaviour.\n *\n * @param args tsc command-line arguments.\n */\nfunction loadTscConfig(args: string[]):\n    {options: ts.CompilerOptions, fileNames: string[], errors: ts.Diagnostic[]} {\n  // Gather tsc options/input files from command line.\n  let {options, fileNames, errors} = ts.parseCommandLine(args);\n  if (errors.length > 0) {\n    return {options: {}, fileNames: [], errors};\n  }\n\n  // Store file arguments\n  const tsFileArguments = fileNames;\n\n  // Read further settings from tsconfig.json.\n  const projectDir = options.project || '.';\n  const configFileName = path.join(projectDir, 'tsconfig.json');\n  const {config: json, error} =\n      ts.readConfigFile(configFileName, path => fs.readFileSync(path, 'utf-8'));\n  if (error) {\n    return {options: {}, fileNames: [], errors: [error]};\n  }\n  ({options, fileNames, errors} =\n       ts.parseJsonConfigFileContent(json, ts.sys, projectDir, options, configFileName));\n  if (errors.length > 0) {\n    return {options: {}, fileNames: [], errors};\n  }\n\n  // if file arguments were given to the typescript transpiler then transpile only those files\n  fileNames = tsFileArguments.length > 0 ? tsFileArguments : fileNames;\n\n  return {options, fileNames, errors: []};\n}\n\n/**\n * Compiles TypeScript code into Closure-compiler-ready JS.\n */\nexport function toClosureJS(\n    options: ts.CompilerOptions, fileNames: string[], settings: Settings,\n    writeFile?: ts.WriteFileCallback): tsickle.EmitResult {\n  // Use absolute paths to determine what files to process since files may be imported using\n  // relative or absolute paths\n  const absoluteFileNames = fileNames.map(i => path.resolve(i));\n\n  const compilerHost = ts.createCompilerHost(options);\n  const program = ts.createProgram(absoluteFileNames, options, compilerHost);\n  const filesToProcess = new Set(absoluteFileNames);\n  const rootModulePath = options.rootDir || getCommonParentDirectory(absoluteFileNames);\n  const transformerHost: tsickle.TsickleHost = {\n    shouldSkipTsickleProcessing: (fileName: string) => {\n      return !filesToProcess.has(path.resolve(fileName));\n    },\n    shouldIgnoreWarningsForPath: (fileName: string) => !settings.fatalWarnings,\n    pathToModuleName: (context, fileName) =>\n        cliSupport.pathToModuleName(rootModulePath, context, fileName),\n    fileNameToModuleId: (fileName) => path.relative(rootModulePath, fileName),\n    es5Mode: true,\n    googmodule: true,\n    transformDecorators: true,\n    transformTypesToClosure: true,\n    typeBlackListPaths: new Set(),\n    untyped: false,\n    logWarning: (warning) => console.error(ts.formatDiagnostics([warning], compilerHost)),\n    options,\n    moduleResolutionHost: compilerHost,\n  };\n  const diagnostics = ts.getPreEmitDiagnostics(program);\n  if (diagnostics.length > 0) {\n    return {\n      diagnostics,\n      modulesManifest: new ModulesManifest(),\n      externs: {},\n      emitSkipped: true,\n      emittedFiles: [],\n    };\n  }\n  return tsickle.emitWithTsickle(\n      program, transformerHost, compilerHost, options, undefined, writeFile);\n}\n\nfunction main(args: string[]): number {\n  const {settings, tscArgs} = loadSettingsFromArgs(args);\n  const config = loadTscConfig(tscArgs);\n  if (config.errors.length) {\n    console.error(ts.formatDiagnostics(config.errors, ts.createCompilerHost(config.options)));\n    return 1;\n  }\n\n  if (config.options.module !== ts.ModuleKind.CommonJS) {\n    // This is not an upstream TypeScript diagnostic, therefore it does not go\n    // through the diagnostics array mechanism.\n    console.error(\n        'tsickle converts TypeScript modules to Closure modules via CommonJS internally. ' +\n        'Set tsconfig.js \"module\": \"commonjs\"');\n    return 1;\n  }\n\n  // Run tsickle+TSC to convert inputs to Closure JS files.\n  const result = toClosureJS(\n      config.options, config.fileNames, settings, (filePath: string, contents: string) => {\n        mkdirp.sync(path.dirname(filePath));\n        fs.writeFileSync(filePath, contents, {encoding: 'utf-8'});\n      });\n  if (result.diagnostics.length) {\n    console.error(ts.formatDiagnostics(result.diagnostics, ts.createCompilerHost(config.options)));\n    return 1;\n  }\n\n  if (settings.externsPath) {\n    mkdirp.sync(path.dirname(settings.externsPath));\n    fs.writeFileSync(\n        settings.externsPath,\n        tsickle.getGeneratedExterns(result.externs, config.options.rootDir || ''));\n  }\n  return 0;\n}\n\n// CLI entry point\nif (require.main === module) {\n  process.exit(main(process.argv.splice(2)));\n}\n"]} |
@@ -82,2 +82,7 @@ /** | ||
/** | ||
* Generates a somewhat human-readable module prefix for the given import context, to make | ||
* debugging the emitted Closure types a bit easier. | ||
*/ | ||
private generateModulePrefix; | ||
/** | ||
* Records that we we want a `const x = goog.requireType...` import of the given `importPath`, | ||
@@ -87,8 +92,6 @@ * which will be inserted when we emit. | ||
* | ||
* @param isExplicitImport True if this comes from an underlying 'import' statement, false | ||
* if this reference is needed just because a symbol's type relies on it. | ||
* @param isDefaultImport True if the import statement is a default import, e.g. | ||
* `import Foo from ...;`, which matters for adjusting whether we emit a `.default`. | ||
*/ | ||
requireType(importPath: string, moduleSymbol: ts.Symbol, isExplicitImport: boolean, isDefaultImport?: boolean): void; | ||
requireType(importPath: string, moduleSymbol: ts.Symbol, isDefaultImport?: boolean): void; | ||
protected ensureSymbolDeclared(sym: ts.Symbol): void; | ||
@@ -95,0 +98,0 @@ insertAdditionalImports(sourceFile: ts.SourceFile): ts.SourceFile; |
@@ -20,4 +20,4 @@ /** | ||
/** A class that maintains the module dependency graph of output JS files. */ | ||
var ModulesManifest = /** @class */ (function () { | ||
function ModulesManifest() { | ||
class ModulesManifest { | ||
constructor() { | ||
/** Map of googmodule module name to file name */ | ||
@@ -28,37 +28,28 @@ this.moduleToFileName = {}; | ||
} | ||
ModulesManifest.prototype.addManifest = function (other) { | ||
addManifest(other) { | ||
Object.assign(this.moduleToFileName, other.moduleToFileName); | ||
Object.assign(this.referencedModules, other.referencedModules); | ||
}; | ||
ModulesManifest.prototype.addModule = function (fileName, module) { | ||
} | ||
addModule(fileName, module) { | ||
this.moduleToFileName[module] = fileName; | ||
this.referencedModules[fileName] = []; | ||
}; | ||
ModulesManifest.prototype.addReferencedModule = function (fileName, resolvedModule) { | ||
} | ||
addReferencedModule(fileName, resolvedModule) { | ||
this.referencedModules[fileName].push(resolvedModule); | ||
}; | ||
Object.defineProperty(ModulesManifest.prototype, "modules", { | ||
get: function () { | ||
return Object.keys(this.moduleToFileName); | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
ModulesManifest.prototype.getFileNameFromModule = function (module) { | ||
} | ||
get modules() { | ||
return Object.keys(this.moduleToFileName); | ||
} | ||
getFileNameFromModule(module) { | ||
return this.moduleToFileName[module]; | ||
}; | ||
Object.defineProperty(ModulesManifest.prototype, "fileNames", { | ||
get: function () { | ||
return Object.keys(this.referencedModules); | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
ModulesManifest.prototype.getReferencedModules = function (fileName) { | ||
} | ||
get fileNames() { | ||
return Object.keys(this.referencedModules); | ||
} | ||
getReferencedModules(fileName) { | ||
return this.referencedModules[fileName]; | ||
}; | ||
return ModulesManifest; | ||
}()); | ||
} | ||
} | ||
exports.ModulesManifest = ModulesManifest; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlc19tYW5pZmVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9tb2R1bGVzX21hbmlmZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBTUgsNkVBQTZFO0lBQzdFO1FBQUE7WUFDRSxpREFBaUQ7WUFDekMscUJBQWdCLEdBQW9CLEVBQUUsQ0FBQztZQUMvQyxxRUFBcUU7WUFDN0Qsc0JBQWlCLEdBQXNCLEVBQUUsQ0FBQztRQStCcEQsQ0FBQztRQTdCQyxxQ0FBVyxHQUFYLFVBQVksS0FBc0I7WUFDaEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFDN0QsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDakUsQ0FBQztRQUVELG1DQUFTLEdBQVQsVUFBVSxRQUFnQixFQUFFLE1BQWM7WUFDeEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQztZQUN6QyxJQUFJLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ3hDLENBQUM7UUFFRCw2Q0FBbUIsR0FBbkIsVUFBb0IsUUFBZ0IsRUFBRSxjQUFzQjtZQUMxRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFFRCxzQkFBSSxvQ0FBTztpQkFBWDtnQkFDRSxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFDNUMsQ0FBQzs7O1dBQUE7UUFFRCwrQ0FBcUIsR0FBckIsVUFBc0IsTUFBYztZQUNsQyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN2QyxDQUFDO1FBRUQsc0JBQUksc0NBQVM7aUJBQWI7Z0JBQ0UsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1lBQzdDLENBQUM7OztXQUFBO1FBRUQsOENBQW9CLEdBQXBCLFVBQXFCLFFBQWdCO1lBQ25DLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzFDLENBQUM7UUFDSCxzQkFBQztJQUFELENBQUMsQUFuQ0QsSUFtQ0M7SUFuQ1ksMENBQWUiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZU1hcDxUPiB7XG4gIFtmaWxlTmFtZTogc3RyaW5nXTogVDtcbn1cblxuLyoqIEEgY2xhc3MgdGhhdCBtYWludGFpbnMgdGhlIG1vZHVsZSBkZXBlbmRlbmN5IGdyYXBoIG9mIG91dHB1dCBKUyBmaWxlcy4gKi9cbmV4cG9ydCBjbGFzcyBNb2R1bGVzTWFuaWZlc3Qge1xuICAvKiogTWFwIG9mIGdvb2dtb2R1bGUgbW9kdWxlIG5hbWUgdG8gZmlsZSBuYW1lICovXG4gIHByaXZhdGUgbW9kdWxlVG9GaWxlTmFtZTogRmlsZU1hcDxzdHJpbmc+ID0ge307XG4gIC8qKiBNYXAgb2YgZmlsZSBuYW1lIHRvIGFycmF5cyBvZiBpbXBvcnRlZCBnb29nbW9kdWxlIG1vZHVsZSBuYW1lcyAqL1xuICBwcml2YXRlIHJlZmVyZW5jZWRNb2R1bGVzOiBGaWxlTWFwPHN0cmluZ1tdPiA9IHt9O1xuXG4gIGFkZE1hbmlmZXN0KG90aGVyOiBNb2R1bGVzTWFuaWZlc3QpIHtcbiAgICBPYmplY3QuYXNzaWduKHRoaXMubW9kdWxlVG9GaWxlTmFtZSwgb3RoZXIubW9kdWxlVG9GaWxlTmFtZSk7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLnJlZmVyZW5jZWRNb2R1bGVzLCBvdGhlci5yZWZlcmVuY2VkTW9kdWxlcyk7XG4gIH1cblxuICBhZGRNb2R1bGUoZmlsZU5hbWU6IHN0cmluZywgbW9kdWxlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLm1vZHVsZVRvRmlsZU5hbWVbbW9kdWxlXSA9IGZpbGVOYW1lO1xuICAgIHRoaXMucmVmZXJlbmNlZE1vZHVsZXNbZmlsZU5hbWVdID0gW107XG4gIH1cblxuICBhZGRSZWZlcmVuY2VkTW9kdWxlKGZpbGVOYW1lOiBzdHJpbmcsIHJlc29sdmVkTW9kdWxlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnJlZmVyZW5jZWRNb2R1bGVzW2ZpbGVOYW1lXS5wdXNoKHJlc29sdmVkTW9kdWxlKTtcbiAgfVxuXG4gIGdldCBtb2R1bGVzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXModGhpcy5tb2R1bGVUb0ZpbGVOYW1lKTtcbiAgfVxuXG4gIGdldEZpbGVOYW1lRnJvbU1vZHVsZShtb2R1bGU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubW9kdWxlVG9GaWxlTmFtZVttb2R1bGVdO1xuICB9XG5cbiAgZ2V0IGZpbGVOYW1lcygpOiBzdHJpbmdbXSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKHRoaXMucmVmZXJlbmNlZE1vZHVsZXMpO1xuICB9XG5cbiAgZ2V0UmVmZXJlbmNlZE1vZHVsZXMoZmlsZU5hbWU6IHN0cmluZyk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gdGhpcy5yZWZlcmVuY2VkTW9kdWxlc1tmaWxlTmFtZV07XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlc19tYW5pZmVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9tb2R1bGVzX21hbmlmZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBTUgsNkVBQTZFO0lBQzdFLE1BQWEsZUFBZTtRQUE1QjtZQUNFLGlEQUFpRDtZQUN6QyxxQkFBZ0IsR0FBb0IsRUFBRSxDQUFDO1lBQy9DLHFFQUFxRTtZQUM3RCxzQkFBaUIsR0FBc0IsRUFBRSxDQUFDO1FBK0JwRCxDQUFDO1FBN0JDLFdBQVcsQ0FBQyxLQUFzQjtZQUNoQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztZQUM3RCxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNqRSxDQUFDO1FBRUQsU0FBUyxDQUFDLFFBQWdCLEVBQUUsTUFBYztZQUN4QyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDO1lBQ3pDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDeEMsQ0FBQztRQUVELG1CQUFtQixDQUFDLFFBQWdCLEVBQUUsY0FBc0I7WUFDMUQsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUN4RCxDQUFDO1FBRUQsSUFBSSxPQUFPO1lBQ1QsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVDLENBQUM7UUFFRCxxQkFBcUIsQ0FBQyxNQUFjO1lBQ2xDLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7UUFFRCxJQUFJLFNBQVM7WUFDWCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDN0MsQ0FBQztRQUVELG9CQUFvQixDQUFDLFFBQWdCO1lBQ25DLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzFDLENBQUM7S0FDRjtJQW5DRCwwQ0FtQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZU1hcDxUPiB7XG4gIFtmaWxlTmFtZTogc3RyaW5nXTogVDtcbn1cblxuLyoqIEEgY2xhc3MgdGhhdCBtYWludGFpbnMgdGhlIG1vZHVsZSBkZXBlbmRlbmN5IGdyYXBoIG9mIG91dHB1dCBKUyBmaWxlcy4gKi9cbmV4cG9ydCBjbGFzcyBNb2R1bGVzTWFuaWZlc3Qge1xuICAvKiogTWFwIG9mIGdvb2dtb2R1bGUgbW9kdWxlIG5hbWUgdG8gZmlsZSBuYW1lICovXG4gIHByaXZhdGUgbW9kdWxlVG9GaWxlTmFtZTogRmlsZU1hcDxzdHJpbmc+ID0ge307XG4gIC8qKiBNYXAgb2YgZmlsZSBuYW1lIHRvIGFycmF5cyBvZiBpbXBvcnRlZCBnb29nbW9kdWxlIG1vZHVsZSBuYW1lcyAqL1xuICBwcml2YXRlIHJlZmVyZW5jZWRNb2R1bGVzOiBGaWxlTWFwPHN0cmluZ1tdPiA9IHt9O1xuXG4gIGFkZE1hbmlmZXN0KG90aGVyOiBNb2R1bGVzTWFuaWZlc3QpIHtcbiAgICBPYmplY3QuYXNzaWduKHRoaXMubW9kdWxlVG9GaWxlTmFtZSwgb3RoZXIubW9kdWxlVG9GaWxlTmFtZSk7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLnJlZmVyZW5jZWRNb2R1bGVzLCBvdGhlci5yZWZlcmVuY2VkTW9kdWxlcyk7XG4gIH1cblxuICBhZGRNb2R1bGUoZmlsZU5hbWU6IHN0cmluZywgbW9kdWxlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLm1vZHVsZVRvRmlsZU5hbWVbbW9kdWxlXSA9IGZpbGVOYW1lO1xuICAgIHRoaXMucmVmZXJlbmNlZE1vZHVsZXNbZmlsZU5hbWVdID0gW107XG4gIH1cblxuICBhZGRSZWZlcmVuY2VkTW9kdWxlKGZpbGVOYW1lOiBzdHJpbmcsIHJlc29sdmVkTW9kdWxlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnJlZmVyZW5jZWRNb2R1bGVzW2ZpbGVOYW1lXS5wdXNoKHJlc29sdmVkTW9kdWxlKTtcbiAgfVxuXG4gIGdldCBtb2R1bGVzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXModGhpcy5tb2R1bGVUb0ZpbGVOYW1lKTtcbiAgfVxuXG4gIGdldEZpbGVOYW1lRnJvbU1vZHVsZShtb2R1bGU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubW9kdWxlVG9GaWxlTmFtZVttb2R1bGVdO1xuICB9XG5cbiAgZ2V0IGZpbGVOYW1lcygpOiBzdHJpbmdbXSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKHRoaXMucmVmZXJlbmNlZE1vZHVsZXMpO1xuICB9XG5cbiAgZ2V0UmVmZXJlbmNlZE1vZHVsZXMoZmlsZU5hbWU6IHN0cmluZyk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gdGhpcy5yZWZlcmVuY2VkTW9kdWxlc1tmaWxlTmFtZV07XG4gIH1cbn1cbiJdfQ== |
@@ -8,33 +8,2 @@ /** | ||
*/ | ||
var __assign = (this && this.__assign) || function () { | ||
__assign = Object.assign || function(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) | ||
t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
var __read = (this && this.__read) || function (o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
}; | ||
var __spread = (this && this.__spread) || function () { | ||
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
}; | ||
(function (factory) { | ||
@@ -51,3 +20,3 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var ts = require("typescript"); | ||
const ts = require("typescript"); | ||
/** @return true if node has the specified modifier flag set. */ | ||
@@ -60,3 +29,3 @@ function hasModifierFlag(declaration, flag) { | ||
function isAmbient(node) { | ||
var current = node; | ||
let current = node; | ||
while (current) { | ||
@@ -96,3 +65,3 @@ if (hasModifierFlag(current, ts.ModifierFlags.Ambient)) { | ||
// See the private function unescapeIdentifier in TypeScript's utilities.ts. | ||
var str = name; | ||
const str = name; | ||
if (str.startsWith('___')) | ||
@@ -111,6 +80,6 @@ return str.substring(1); | ||
function createNotEmittedStatementWithComments(sourceFile, original) { | ||
var replacement = ts.createNotEmittedStatement(original); | ||
let replacement = ts.createNotEmittedStatement(original); | ||
// NB: synthetic nodes can have pos/end == -1. This is handled by the underlying implementation. | ||
var leading = ts.getLeadingCommentRanges(sourceFile.text, original.pos) || []; | ||
var trailing = ts.getTrailingCommentRanges(sourceFile.text, original.end) || []; | ||
const leading = ts.getLeadingCommentRanges(sourceFile.text, original.pos) || []; | ||
const trailing = ts.getTrailingCommentRanges(sourceFile.text, original.end) || []; | ||
replacement = | ||
@@ -127,6 +96,5 @@ ts.setSyntheticLeadingComments(replacement, synthesizeCommentRanges(sourceFile, leading)); | ||
function synthesizeCommentRanges(sourceFile, parsedComments) { | ||
var synthesizedComments = []; | ||
parsedComments.forEach(function (_a, commentIdx) { | ||
var kind = _a.kind, pos = _a.pos, end = _a.end, hasTrailingNewLine = _a.hasTrailingNewLine; | ||
var commentText = sourceFile.text.substring(pos, end).trim(); | ||
const synthesizedComments = []; | ||
parsedComments.forEach(({ kind, pos, end, hasTrailingNewLine }, commentIdx) => { | ||
let commentText = sourceFile.text.substring(pos, end).trim(); | ||
if (kind === ts.SyntaxKind.MultiLineCommentTrivia) { | ||
@@ -142,3 +110,3 @@ commentText = commentText.replace(/(^\/\*)|(\*\/$)/g, ''); | ||
} | ||
synthesizedComments.push({ kind: kind, text: commentText, hasTrailingNewLine: hasTrailingNewLine, pos: -1, end: -1 }); | ||
synthesizedComments.push({ kind, text: commentText, hasTrailingNewLine, pos: -1, end: -1 }); | ||
}); | ||
@@ -152,3 +120,3 @@ return synthesizedComments; | ||
function createNotEmittedStatement(sourceFile) { | ||
var stmt = ts.createNotEmittedStatement(sourceFile); | ||
const stmt = ts.createNotEmittedStatement(sourceFile); | ||
ts.setOriginalNode(stmt, undefined); | ||
@@ -171,3 +139,3 @@ ts.setTextRange(stmt, { pos: 0, end: 0 }); | ||
if (node.kind === ts.SyntaxKind.SourceFile) { | ||
var sf = node; | ||
const sf = node; | ||
return updateSourceFileNode(sf, ts.visitLexicalEnvironment(sf.statements, visitor, context)); | ||
@@ -214,3 +182,3 @@ } | ||
function createSingleQuoteStringLiteral(text) { | ||
var stringLiteral = ts.createLiteral(text); | ||
const stringLiteral = ts.createLiteral(text); | ||
// tslint:disable-next-line:no-any accessing TS internal API. | ||
@@ -223,3 +191,3 @@ stringLiteral.singleQuote = true; | ||
function createSingleLineComment(original, text) { | ||
var comment = { | ||
const comment = { | ||
kind: ts.SyntaxKind.SingleLineCommentTrivia, | ||
@@ -236,3 +204,3 @@ text: ' ' + text, | ||
function createMultiLineComment(original, text) { | ||
var comment = { | ||
const comment = { | ||
kind: ts.SyntaxKind.MultiLineCommentTrivia, | ||
@@ -273,4 +241,3 @@ text: ' ' + text, | ||
*/ | ||
function reportDiagnostic(diagnostics, node, messageText, textRange, category) { | ||
if (category === void 0) { category = ts.DiagnosticCategory.Error; } | ||
function reportDiagnostic(diagnostics, node, messageText, textRange, category = ts.DiagnosticCategory.Error) { | ||
diagnostics.push(createDiagnostic(node, messageText, textRange, category)); | ||
@@ -280,3 +247,3 @@ } | ||
function createDiagnostic(node, messageText, textRange, category) { | ||
var start, length; | ||
let start, length; | ||
if (textRange) { | ||
@@ -293,6 +260,6 @@ start = textRange.pos; | ||
file: node.getSourceFile(), | ||
start: start, | ||
length: length, | ||
messageText: messageText, | ||
category: category, | ||
start, | ||
length, | ||
messageText, | ||
category, | ||
code: 0, | ||
@@ -307,10 +274,10 @@ }; | ||
function getAllLeadingComments(node) { | ||
var allRanges = []; | ||
var nodeText = node.getFullText(); | ||
var cr = ts.getLeadingCommentRanges(nodeText, 0); | ||
const allRanges = []; | ||
const nodeText = node.getFullText(); | ||
const cr = ts.getLeadingCommentRanges(nodeText, 0); | ||
if (cr) | ||
allRanges.push.apply(allRanges, __spread(cr.map(function (c) { return (__assign({}, c, { text: nodeText.substring(c.pos, c.end) })); }))); | ||
var synthetic = ts.getSyntheticLeadingComments(node); | ||
allRanges.push(...cr.map(c => (Object.assign({}, c, { text: nodeText.substring(c.pos, c.end) })))); | ||
const synthetic = ts.getSyntheticLeadingComments(node); | ||
if (synthetic) | ||
allRanges.push.apply(allRanges, __spread(synthetic)); | ||
allRanges.push(...synthetic); | ||
return allRanges; | ||
@@ -320,2 +287,2 @@ } | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer_util.js","sourceRoot":"","sources":["../../../../src/transformer_util.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 */\n\nimport * as ts from 'typescript';\n\n/** @return true if node has the specified modifier flag set. */\nexport function hasModifierFlag(declaration: ts.Declaration, flag: ts.ModifierFlags): boolean {\n  return (ts.getCombinedModifierFlags(declaration) & flag) !== 0;\n}\n\n/** @return true if node has the specified modifier flag set. */\nexport function isAmbient(node: ts.Node): boolean {\n  let current: ts.Node|undefined = node;\n  while (current) {\n    if (hasModifierFlag(current as ts.Declaration, ts.ModifierFlags.Ambient)) {\n      return true;\n    }\n    current = current.parent;\n  }\n  return false;\n}\n\n/** Returns true if fileName is a .d.ts file. */\nexport function isDtsFileName(fileName: string): boolean {\n  return fileName.endsWith('.d.ts');\n}\n\n/** Returns the string contents of a ts.Identifier. */\nexport function getIdentifierText(identifier: ts.Identifier): string {\n  // NOTE: 'escapedText' on an Identifier may be escaped if it starts with '__'. The alternative,\n  // getText(), cannot be used on synthesized nodes, so unescape the identifier below.\n  return unescapeName(identifier.escapedText);\n}\n\n/** Returns a dot-joined qualified name (foo.bar.Baz). */\nexport function getEntityNameText(name: ts.EntityName): string {\n  if (ts.isIdentifier(name)) {\n    return getIdentifierText(name);\n  }\n  return getEntityNameText(name.left) + '.' + getIdentifierText(name.right);\n}\n\n/**\n * Converts an escaped TypeScript name into the original source name.\n */\nexport function unescapeName(name: ts.__String): string {\n  // See the private function unescapeIdentifier in TypeScript's utilities.ts.\n  const str = name as string;\n  if (str.startsWith('___')) return str.substring(1);\n  return str;\n}\n\n/**\n * ts.createNotEmittedStatement will create a node, but the comments covered by its text range are\n * never emittedm except for very specific special cases (/// comments).\n *\n * createNotEmittedStatementWithComments creates a not emitted statement and adds comment ranges\n * from the original statement as synthetic comments to it, so that they get retained in the output.\n */\nexport function createNotEmittedStatementWithComments(\n    sourceFile: ts.SourceFile, original: ts.Node): ts.Statement {\n  let replacement = ts.createNotEmittedStatement(original);\n  // NB: synthetic nodes can have pos/end == -1. This is handled by the underlying implementation.\n  const leading = ts.getLeadingCommentRanges(sourceFile.text, original.pos) || [];\n  const trailing = ts.getTrailingCommentRanges(sourceFile.text, original.end) || [];\n  replacement =\n      ts.setSyntheticLeadingComments(replacement, synthesizeCommentRanges(sourceFile, leading));\n  replacement =\n      ts.setSyntheticTrailingComments(replacement, synthesizeCommentRanges(sourceFile, trailing));\n  return replacement;\n}\n\n/**\n * Converts `ts.CommentRange`s into `ts.SynthesizedComment`s.\n */\nexport function synthesizeCommentRanges(\n    sourceFile: ts.SourceFile, parsedComments: ts.CommentRange[]): ts.SynthesizedComment[] {\n  const synthesizedComments: ts.SynthesizedComment[] = [];\n  parsedComments.forEach(({kind, pos, end, hasTrailingNewLine}, commentIdx) => {\n    let commentText = sourceFile.text.substring(pos, end).trim();\n    if (kind === ts.SyntaxKind.MultiLineCommentTrivia) {\n      commentText = commentText.replace(/(^\\/\\*)|(\\*\\/$)/g, '');\n    } else if (kind === ts.SyntaxKind.SingleLineCommentTrivia) {\n      if (commentText.startsWith('///')) {\n        // triple-slash comments are typescript specific, ignore them in the output.\n        return;\n      }\n      commentText = commentText.replace(/(^\\/\\/)/g, '');\n    }\n    synthesizedComments.push({kind, text: commentText, hasTrailingNewLine, pos: -1, end: -1});\n  });\n  return synthesizedComments;\n}\n\n/**\n * Creates a non emitted statement that can be used to store synthesized comments.\n */\nexport function createNotEmittedStatement(sourceFile: ts.SourceFile): ts.NotEmittedStatement {\n  const stmt = ts.createNotEmittedStatement(sourceFile);\n  ts.setOriginalNode(stmt, undefined);\n  ts.setTextRange(stmt, {pos: 0, end: 0});\n  ts.setEmitFlags(stmt, ts.EmitFlags.CustomPrologue);\n  return stmt;\n}\n\n/**\n * This is a version of `ts.visitEachChild` that works that calls our version\n * of `updateSourceFileNode`, so that typescript doesn't lose type information\n * for property decorators.\n * See https://github.com/Microsoft/TypeScript/issues/17384\n *\n * @param sf\n * @param statements\n */\nexport function visitEachChild(\n    node: ts.Node, visitor: ts.Visitor, context: ts.TransformationContext): ts.Node {\n  if (node.kind === ts.SyntaxKind.SourceFile) {\n    const sf = node as ts.SourceFile;\n    return updateSourceFileNode(sf, ts.visitLexicalEnvironment(sf.statements, visitor, context));\n  }\n\n  return ts.visitEachChild(node, visitor, context);\n}\n\n/**\n * This is a version of `ts.updateSourceFileNode` that works\n * well with property decorators.\n * See https://github.com/Microsoft/TypeScript/issues/17384\n * TODO(#634): This has been fixed in TS 2.5. Investigate removal.\n *\n * @param sf\n * @param statements\n */\nexport function updateSourceFileNode(\n    sf: ts.SourceFile, statements: ts.NodeArray<ts.Statement>): ts.SourceFile {\n  if (statements === sf.statements) {\n    return sf;\n  }\n  // Note: Need to clone the original file (and not use `ts.updateSourceFileNode`)\n  // as otherwise TS fails when resolving types for decorators.\n  sf = ts.getMutableClone(sf);\n  sf.statements = statements;\n  return sf;\n}\n\n// Copied from TypeScript\nexport function isTypeNodeKind(kind: ts.SyntaxKind) {\n  return (kind >= ts.SyntaxKind.FirstTypeNode && kind <= ts.SyntaxKind.LastTypeNode) ||\n      kind === ts.SyntaxKind.AnyKeyword || kind === ts.SyntaxKind.NumberKeyword ||\n      kind === ts.SyntaxKind.ObjectKeyword || kind === ts.SyntaxKind.BooleanKeyword ||\n      kind === ts.SyntaxKind.StringKeyword || kind === ts.SyntaxKind.SymbolKeyword ||\n      kind === ts.SyntaxKind.ThisKeyword || kind === ts.SyntaxKind.VoidKeyword ||\n      kind === ts.SyntaxKind.UndefinedKeyword || kind === ts.SyntaxKind.NullKeyword ||\n      kind === ts.SyntaxKind.NeverKeyword || kind === ts.SyntaxKind.ExpressionWithTypeArguments;\n}\n\n/**\n * Creates a string literal that uses single quotes. Purely cosmetic, but increases fidelity to the\n * existing test suite.\n */\nexport function createSingleQuoteStringLiteral(text: string): ts.StringLiteral {\n  const stringLiteral = ts.createLiteral(text);\n  // tslint:disable-next-line:no-any accessing TS internal API.\n  (stringLiteral as any).singleQuote = true;\n  return stringLiteral;\n}\n\n/** Creates a not emitted statement with the given text as a single line comment. */\nexport function createSingleLineComment(original: ts.Node, text: string) {\n  const comment: ts.SynthesizedComment = {\n    kind: ts.SyntaxKind.SingleLineCommentTrivia,\n    text: ' ' + text,\n    hasTrailingNewLine: true,\n    pos: -1,\n    end: -1,\n  };\n  return ts.setSyntheticTrailingComments(ts.createNotEmittedStatement(original), [comment]);\n}\n\n/** Creates a not emitted statement with the given text as a single line comment. */\nexport function createMultiLineComment(original: ts.Node, text: string) {\n  const comment: ts.SynthesizedComment = {\n    kind: ts.SyntaxKind.MultiLineCommentTrivia,\n    text: ' ' + text,\n    hasTrailingNewLine: true,\n    pos: -1,\n    end: -1,\n  };\n  return ts.setSyntheticTrailingComments(ts.createNotEmittedStatement(original), [comment]);\n}\n\n/**\n * debugWarn logs a debug warning.\n *\n * These should only be used for cases where tsickle is making a questionable judgement about what\n * to do. By default, tsickle does not report any warnings to the caller, and warnings are hidden\n * behind a debug flag, as warnings are only for tsickle to debug itself.\n */\nexport function reportDebugWarning(\n    host: {logWarning ? (d: ts.Diagnostic) : void}, node: ts.Node, messageText: string) {\n  if (!host.logWarning) return;\n  host.logWarning(createDiagnostic(\n      node, messageText, /* textRange */ undefined, ts.DiagnosticCategory.Warning));\n}\n\n/**\n * Creates and reports a diagnostic by adding it to the given array.\n *\n * This is used for errors and warnings in tsickle's input. Emit errors (the default) if tsickle\n * cannot emit a correct result given the input. Emit warnings for questionable input if there's a\n * good chance that the output will work.\n *\n * For typical tsickle users, errors are always reported and break the compilation operation,\n * warnings will only be emitted for first party code (and break the compilation there), but wil be\n * ignored for third party code.\n *\n * @param textRange pass to overrride the text range from the node with a more specific range.\n */\nexport function reportDiagnostic(\n    diagnostics: ts.Diagnostic[], node: ts.Node, messageText: string, textRange?: ts.TextRange,\n    category = ts.DiagnosticCategory.Error) {\n  diagnostics.push(createDiagnostic(node, messageText, textRange, category));\n}\n\nfunction createDiagnostic(\n    node: ts.Node, messageText: string, textRange: ts.TextRange|undefined,\n    category: ts.DiagnosticCategory): ts.Diagnostic {\n  let start, length: number;\n  if (textRange) {\n    start = textRange.pos;\n    length = textRange.end - textRange.pos;\n  } else {\n    // Only use getStart if node has a valid pos, as it might be synthesized.\n    start = node.pos >= 0 ? node.getStart() : 0;\n    length = node.end - node.pos;\n  }\n  return {\n    file: node.getSourceFile(),\n    start,\n    length,\n    messageText,\n    category,\n    code: 0,\n  };\n}\n\n/**\n * A replacement for ts.getLeadingCommentRanges that returns the union of synthetic and\n * non-synthetic comments on the given node, with their text included. The returned comments must\n * not be mutated, as their content might or might not be reflected back into the AST.\n */\nexport function getAllLeadingComments(node: ts.Node):\n    ReadonlyArray<Readonly<ts.CommentRange&{text: string}>> {\n  const allRanges: Array<Readonly<ts.CommentRange&{text: string}>> = [];\n  const nodeText = node.getFullText();\n  const cr = ts.getLeadingCommentRanges(nodeText, 0);\n  if (cr) allRanges.push(...cr.map(c => ({...c, text: nodeText.substring(c.pos, c.end)})));\n  const synthetic = ts.getSyntheticLeadingComments(node);\n  if (synthetic) allRanges.push(...synthetic);\n  return allRanges;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer_util.js","sourceRoot":"","sources":["../../../../src/transformer_util.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 */\n\nimport * as ts from 'typescript';\n\n/** @return true if node has the specified modifier flag set. */\nexport function hasModifierFlag(declaration: ts.Declaration, flag: ts.ModifierFlags): boolean {\n  return (ts.getCombinedModifierFlags(declaration) & flag) !== 0;\n}\n\n/** @return true if node has the specified modifier flag set. */\nexport function isAmbient(node: ts.Node): boolean {\n  let current: ts.Node|undefined = node;\n  while (current) {\n    if (hasModifierFlag(current as ts.Declaration, ts.ModifierFlags.Ambient)) {\n      return true;\n    }\n    current = current.parent;\n  }\n  return false;\n}\n\n/** Returns true if fileName is a .d.ts file. */\nexport function isDtsFileName(fileName: string): boolean {\n  return fileName.endsWith('.d.ts');\n}\n\n/** Returns the string contents of a ts.Identifier. */\nexport function getIdentifierText(identifier: ts.Identifier): string {\n  // NOTE: 'escapedText' on an Identifier may be escaped if it starts with '__'. The alternative,\n  // getText(), cannot be used on synthesized nodes, so unescape the identifier below.\n  return unescapeName(identifier.escapedText);\n}\n\n/** Returns a dot-joined qualified name (foo.bar.Baz). */\nexport function getEntityNameText(name: ts.EntityName): string {\n  if (ts.isIdentifier(name)) {\n    return getIdentifierText(name);\n  }\n  return getEntityNameText(name.left) + '.' + getIdentifierText(name.right);\n}\n\n/**\n * Converts an escaped TypeScript name into the original source name.\n */\nexport function unescapeName(name: ts.__String): string {\n  // See the private function unescapeIdentifier in TypeScript's utilities.ts.\n  const str = name as string;\n  if (str.startsWith('___')) return str.substring(1);\n  return str;\n}\n\n/**\n * ts.createNotEmittedStatement will create a node, but the comments covered by its text range are\n * never emittedm except for very specific special cases (/// comments).\n *\n * createNotEmittedStatementWithComments creates a not emitted statement and adds comment ranges\n * from the original statement as synthetic comments to it, so that they get retained in the output.\n */\nexport function createNotEmittedStatementWithComments(\n    sourceFile: ts.SourceFile, original: ts.Node): ts.Statement {\n  let replacement = ts.createNotEmittedStatement(original);\n  // NB: synthetic nodes can have pos/end == -1. This is handled by the underlying implementation.\n  const leading = ts.getLeadingCommentRanges(sourceFile.text, original.pos) || [];\n  const trailing = ts.getTrailingCommentRanges(sourceFile.text, original.end) || [];\n  replacement =\n      ts.setSyntheticLeadingComments(replacement, synthesizeCommentRanges(sourceFile, leading));\n  replacement =\n      ts.setSyntheticTrailingComments(replacement, synthesizeCommentRanges(sourceFile, trailing));\n  return replacement;\n}\n\n/**\n * Converts `ts.CommentRange`s into `ts.SynthesizedComment`s.\n */\nexport function synthesizeCommentRanges(\n    sourceFile: ts.SourceFile, parsedComments: ts.CommentRange[]): ts.SynthesizedComment[] {\n  const synthesizedComments: ts.SynthesizedComment[] = [];\n  parsedComments.forEach(({kind, pos, end, hasTrailingNewLine}, commentIdx) => {\n    let commentText = sourceFile.text.substring(pos, end).trim();\n    if (kind === ts.SyntaxKind.MultiLineCommentTrivia) {\n      commentText = commentText.replace(/(^\\/\\*)|(\\*\\/$)/g, '');\n    } else if (kind === ts.SyntaxKind.SingleLineCommentTrivia) {\n      if (commentText.startsWith('///')) {\n        // triple-slash comments are typescript specific, ignore them in the output.\n        return;\n      }\n      commentText = commentText.replace(/(^\\/\\/)/g, '');\n    }\n    synthesizedComments.push({kind, text: commentText, hasTrailingNewLine, pos: -1, end: -1});\n  });\n  return synthesizedComments;\n}\n\n/**\n * Creates a non emitted statement that can be used to store synthesized comments.\n */\nexport function createNotEmittedStatement(sourceFile: ts.SourceFile): ts.NotEmittedStatement {\n  const stmt = ts.createNotEmittedStatement(sourceFile);\n  ts.setOriginalNode(stmt, undefined);\n  ts.setTextRange(stmt, {pos: 0, end: 0});\n  ts.setEmitFlags(stmt, ts.EmitFlags.CustomPrologue);\n  return stmt;\n}\n\n/**\n * This is a version of `ts.visitEachChild` that works that calls our version\n * of `updateSourceFileNode`, so that typescript doesn't lose type information\n * for property decorators.\n * See https://github.com/Microsoft/TypeScript/issues/17384\n *\n * @param sf\n * @param statements\n */\nexport function visitEachChild(\n    node: ts.Node, visitor: ts.Visitor, context: ts.TransformationContext): ts.Node {\n  if (node.kind === ts.SyntaxKind.SourceFile) {\n    const sf = node as ts.SourceFile;\n    return updateSourceFileNode(sf, ts.visitLexicalEnvironment(sf.statements, visitor, context));\n  }\n\n  return ts.visitEachChild(node, visitor, context);\n}\n\n/**\n * This is a version of `ts.updateSourceFileNode` that works\n * well with property decorators.\n * See https://github.com/Microsoft/TypeScript/issues/17384\n * TODO(#634): This has been fixed in TS 2.5. Investigate removal.\n *\n * @param sf\n * @param statements\n */\nexport function updateSourceFileNode(\n    sf: ts.SourceFile, statements: ts.NodeArray<ts.Statement>): ts.SourceFile {\n  if (statements === sf.statements) {\n    return sf;\n  }\n  // Note: Need to clone the original file (and not use `ts.updateSourceFileNode`)\n  // as otherwise TS fails when resolving types for decorators.\n  sf = ts.getMutableClone(sf);\n  sf.statements = statements;\n  return sf;\n}\n\n// Copied from TypeScript\nexport function isTypeNodeKind(kind: ts.SyntaxKind) {\n  return (kind >= ts.SyntaxKind.FirstTypeNode && kind <= ts.SyntaxKind.LastTypeNode) ||\n      kind === ts.SyntaxKind.AnyKeyword || kind === ts.SyntaxKind.NumberKeyword ||\n      kind === ts.SyntaxKind.ObjectKeyword || kind === ts.SyntaxKind.BooleanKeyword ||\n      kind === ts.SyntaxKind.StringKeyword || kind === ts.SyntaxKind.SymbolKeyword ||\n      kind === ts.SyntaxKind.ThisKeyword || kind === ts.SyntaxKind.VoidKeyword ||\n      kind === ts.SyntaxKind.UndefinedKeyword || kind === ts.SyntaxKind.NullKeyword ||\n      kind === ts.SyntaxKind.NeverKeyword || kind === ts.SyntaxKind.ExpressionWithTypeArguments;\n}\n\n/**\n * Creates a string literal that uses single quotes. Purely cosmetic, but increases fidelity to the\n * existing test suite.\n */\nexport function createSingleQuoteStringLiteral(text: string): ts.StringLiteral {\n  const stringLiteral = ts.createLiteral(text);\n  // tslint:disable-next-line:no-any accessing TS internal API.\n  (stringLiteral as any).singleQuote = true;\n  return stringLiteral;\n}\n\n/** Creates a not emitted statement with the given text as a single line comment. */\nexport function createSingleLineComment(original: ts.Node, text: string) {\n  const comment: ts.SynthesizedComment = {\n    kind: ts.SyntaxKind.SingleLineCommentTrivia,\n    text: ' ' + text,\n    hasTrailingNewLine: true,\n    pos: -1,\n    end: -1,\n  };\n  return ts.setSyntheticTrailingComments(ts.createNotEmittedStatement(original), [comment]);\n}\n\n/** Creates a not emitted statement with the given text as a single line comment. */\nexport function createMultiLineComment(original: ts.Node, text: string) {\n  const comment: ts.SynthesizedComment = {\n    kind: ts.SyntaxKind.MultiLineCommentTrivia,\n    text: ' ' + text,\n    hasTrailingNewLine: true,\n    pos: -1,\n    end: -1,\n  };\n  return ts.setSyntheticTrailingComments(ts.createNotEmittedStatement(original), [comment]);\n}\n\n/**\n * debugWarn logs a debug warning.\n *\n * These should only be used for cases where tsickle is making a questionable judgement about what\n * to do. By default, tsickle does not report any warnings to the caller, and warnings are hidden\n * behind a debug flag, as warnings are only for tsickle to debug itself.\n */\nexport function reportDebugWarning(\n    host: {logWarning ? (d: ts.Diagnostic) : void}, node: ts.Node, messageText: string) {\n  if (!host.logWarning) return;\n  host.logWarning(createDiagnostic(\n      node, messageText, /* textRange */ undefined, ts.DiagnosticCategory.Warning));\n}\n\n/**\n * Creates and reports a diagnostic by adding it to the given array.\n *\n * This is used for errors and warnings in tsickle's input. Emit errors (the default) if tsickle\n * cannot emit a correct result given the input. Emit warnings for questionable input if there's a\n * good chance that the output will work.\n *\n * For typical tsickle users, errors are always reported and break the compilation operation,\n * warnings will only be emitted for first party code (and break the compilation there), but wil be\n * ignored for third party code.\n *\n * @param textRange pass to overrride the text range from the node with a more specific range.\n */\nexport function reportDiagnostic(\n    diagnostics: ts.Diagnostic[], node: ts.Node, messageText: string, textRange?: ts.TextRange,\n    category = ts.DiagnosticCategory.Error) {\n  diagnostics.push(createDiagnostic(node, messageText, textRange, category));\n}\n\nfunction createDiagnostic(\n    node: ts.Node, messageText: string, textRange: ts.TextRange|undefined,\n    category: ts.DiagnosticCategory): ts.Diagnostic {\n  let start, length: number;\n  if (textRange) {\n    start = textRange.pos;\n    length = textRange.end - textRange.pos;\n  } else {\n    // Only use getStart if node has a valid pos, as it might be synthesized.\n    start = node.pos >= 0 ? node.getStart() : 0;\n    length = node.end - node.pos;\n  }\n  return {\n    file: node.getSourceFile(),\n    start,\n    length,\n    messageText,\n    category,\n    code: 0,\n  };\n}\n\n/**\n * A replacement for ts.getLeadingCommentRanges that returns the union of synthetic and\n * non-synthetic comments on the given node, with their text included. The returned comments must\n * not be mutated, as their content might or might not be reflected back into the AST.\n */\nexport function getAllLeadingComments(node: ts.Node):\n    ReadonlyArray<Readonly<ts.CommentRange&{text: string}>> {\n  const allRanges: Array<Readonly<ts.CommentRange&{text: string}>> = [];\n  const nodeText = node.getFullText();\n  const cr = ts.getLeadingCommentRanges(nodeText, 0);\n  if (cr) allRanges.push(...cr.map(c => ({...c, text: nodeText.substring(c.pos, c.end)})));\n  const synthetic = ts.getSyntheticLeadingComments(node);\n  if (synthetic) allRanges.push(...synthetic);\n  return allRanges;\n}\n"]} |
@@ -8,32 +8,2 @@ /** | ||
*/ | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
var __read = (this && this.__read) || function (o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
}; | ||
var __spread = (this && this.__spread) || function () { | ||
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
}; | ||
(function (factory) { | ||
@@ -45,3 +15,3 @@ if (typeof module === "object" && typeof module.exports === "object") { | ||
else if (typeof define === "function" && define.amd) { | ||
define("tsickle/src/tsickle", ["require", "exports", "typescript", "tsickle/src/cli_support", "tsickle/src/decorator_downlevel_transformer", "tsickle/src/enum_transformer", "tsickle/src/externs", "tsickle/src/fileoverview_comment_transformer", "tsickle/src/googmodule", "tsickle/src/jsdoc_transformer", "tsickle/src/modules_manifest", "tsickle/src/quoting_transformer", "tsickle/src/transformer_util", "tsickle/src/externs", "tsickle/src/modules_manifest"], factory); | ||
define("tsickle/src/tsickle", ["require", "exports", "typescript", "tsickle/src/cli_support", "tsickle/src/decorator_downlevel_transformer", "tsickle/src/enum_transformer", "tsickle/src/externs", "tsickle/src/fileoverview_comment_transformer", "tsickle/src/googmodule", "tsickle/src/jsdoc_transformer", "tsickle/src/modules_manifest", "tsickle/src/transformer_util", "tsickle/src/externs", "tsickle/src/modules_manifest"], factory); | ||
} | ||
@@ -51,13 +21,12 @@ })(function (require, exports) { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var ts = require("typescript"); | ||
var cli_support_1 = require("tsickle/src/cli_support"); | ||
var decorator_downlevel_transformer_1 = require("tsickle/src/decorator_downlevel_transformer"); | ||
var enum_transformer_1 = require("tsickle/src/enum_transformer"); | ||
var externs_1 = require("tsickle/src/externs"); | ||
var fileoverview_comment_transformer_1 = require("tsickle/src/fileoverview_comment_transformer"); | ||
var googmodule = require("tsickle/src/googmodule"); | ||
var jsdoc_transformer_1 = require("tsickle/src/jsdoc_transformer"); | ||
var modules_manifest_1 = require("tsickle/src/modules_manifest"); | ||
var quoting_transformer_1 = require("tsickle/src/quoting_transformer"); | ||
var transformer_util_1 = require("tsickle/src/transformer_util"); | ||
const ts = require("typescript"); | ||
const cli_support_1 = require("tsickle/src/cli_support"); | ||
const decorator_downlevel_transformer_1 = require("tsickle/src/decorator_downlevel_transformer"); | ||
const enum_transformer_1 = require("tsickle/src/enum_transformer"); | ||
const externs_1 = require("tsickle/src/externs"); | ||
const fileoverview_comment_transformer_1 = require("tsickle/src/fileoverview_comment_transformer"); | ||
const googmodule = require("tsickle/src/googmodule"); | ||
const jsdoc_transformer_1 = require("tsickle/src/jsdoc_transformer"); | ||
const modules_manifest_1 = require("tsickle/src/modules_manifest"); | ||
const transformer_util_1 = require("tsickle/src/transformer_util"); | ||
// Retained here for API compatibility. | ||
@@ -69,47 +38,26 @@ var externs_2 = require("tsickle/src/externs"); | ||
function mergeEmitResults(emitResults) { | ||
var e_1, _a; | ||
var diagnostics = []; | ||
var emitSkipped = true; | ||
var emittedFiles = []; | ||
var externs = {}; | ||
var modulesManifest = new modules_manifest_1.ModulesManifest(); | ||
try { | ||
for (var emitResults_1 = __values(emitResults), emitResults_1_1 = emitResults_1.next(); !emitResults_1_1.done; emitResults_1_1 = emitResults_1.next()) { | ||
var er = emitResults_1_1.value; | ||
diagnostics.push.apply(diagnostics, __spread(er.diagnostics)); | ||
emitSkipped = emitSkipped || er.emitSkipped; | ||
emittedFiles.push.apply(emittedFiles, __spread(er.emittedFiles)); | ||
Object.assign(externs, er.externs); | ||
modulesManifest.addManifest(er.modulesManifest); | ||
const diagnostics = []; | ||
let emitSkipped = true; | ||
const emittedFiles = []; | ||
const externs = {}; | ||
const modulesManifest = new modules_manifest_1.ModulesManifest(); | ||
for (const er of emitResults) { | ||
diagnostics.push(...er.diagnostics); | ||
emitSkipped = emitSkipped || er.emitSkipped; | ||
if (er.emittedFiles) { | ||
emittedFiles.push(...er.emittedFiles); | ||
} | ||
Object.assign(externs, er.externs); | ||
modulesManifest.addManifest(er.modulesManifest); | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (emitResults_1_1 && !emitResults_1_1.done && (_a = emitResults_1.return)) _a.call(emitResults_1); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
return { diagnostics: diagnostics, emitSkipped: emitSkipped, emittedFiles: emittedFiles, externs: externs, modulesManifest: modulesManifest }; | ||
return { diagnostics, emitSkipped, emittedFiles, externs, modulesManifest }; | ||
} | ||
exports.mergeEmitResults = mergeEmitResults; | ||
function emitWithTsickle(program, host, tsHost, tsOptions, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers) { | ||
if (customTransformers === void 0) { customTransformers = {}; } | ||
var e_2, _a, e_3, _b; | ||
try { | ||
for (var _c = __values(program.getSourceFiles()), _d = _c.next(); !_d.done; _d = _c.next()) { | ||
var sf = _d.value; | ||
cli_support_1.assertAbsolute(sf.fileName); | ||
} | ||
function emitWithTsickle(program, host, tsHost, tsOptions, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers = {}) { | ||
for (const sf of program.getSourceFiles()) { | ||
cli_support_1.assertAbsolute(sf.fileName); | ||
} | ||
catch (e_2_1) { e_2 = { error: e_2_1 }; } | ||
finally { | ||
try { | ||
if (_d && !_d.done && (_a = _c.return)) _a.call(_c); | ||
} | ||
finally { if (e_2) throw e_2.error; } | ||
} | ||
var tsickleDiagnostics = []; | ||
var typeChecker = program.getTypeChecker(); | ||
var tsickleSourceTransformers = []; | ||
let tsickleDiagnostics = []; | ||
const typeChecker = program.getTypeChecker(); | ||
const tsickleSourceTransformers = []; | ||
if (host.transformTypesToClosure) { | ||
@@ -119,5 +67,2 @@ // Only add @suppress {checkTypes} comments when also adding type annotations. | ||
tsickleSourceTransformers.push(jsdoc_transformer_1.jsdocTransformer(host, tsOptions, tsHost, typeChecker, tsickleDiagnostics)); | ||
if (host.enableAutoQuoting) { | ||
tsickleSourceTransformers.push(quoting_transformer_1.quotingTransformer(host, typeChecker, tsickleDiagnostics)); | ||
} | ||
tsickleSourceTransformers.push(enum_transformer_1.enumTransformer(typeChecker, tsickleDiagnostics)); | ||
@@ -129,7 +74,14 @@ tsickleSourceTransformers.push(decorator_downlevel_transformer_1.decoratorDownlevelTransformer(typeChecker, tsickleDiagnostics)); | ||
} | ||
var modulesManifest = new modules_manifest_1.ModulesManifest(); | ||
var tsickleTransformers = { before: tsickleSourceTransformers }; | ||
var tsTransformers = { | ||
before: __spread((customTransformers.beforeTsickle || []), (tsickleTransformers.before || []).map(function (tf) { return skipTransformForSourceFileIfNeeded(host, tf); }), (customTransformers.beforeTs || [])), | ||
after: __spread((customTransformers.afterTs || []), (tsickleTransformers.after || []).map(function (tf) { return skipTransformForSourceFileIfNeeded(host, tf); })), | ||
const modulesManifest = new modules_manifest_1.ModulesManifest(); | ||
const tsickleTransformers = { before: tsickleSourceTransformers }; | ||
const tsTransformers = { | ||
before: [ | ||
...(customTransformers.beforeTsickle || []), | ||
...(tsickleTransformers.before || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)), | ||
...(customTransformers.beforeTs || []), | ||
], | ||
after: [ | ||
...(customTransformers.afterTs || []), | ||
...(tsickleTransformers.after || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)), | ||
], | ||
afterDeclarations: customTransformers.afterDeclarations, | ||
@@ -144,4 +96,4 @@ }; | ||
} | ||
var writeFileDelegate = writeFile || tsHost.writeFile.bind(tsHost); | ||
var writeFileImpl = function (fileName, content, writeByteOrderMark, onError, sourceFiles) { | ||
const writeFileDelegate = writeFile || tsHost.writeFile.bind(tsHost); | ||
const writeFileImpl = (fileName, content, writeByteOrderMark, onError, sourceFiles) => { | ||
cli_support_1.assertAbsolute(fileName); | ||
@@ -153,35 +105,25 @@ if (host.addDtsClutzAliases && transformer_util_1.isDtsFileName(fileName) && sourceFiles) { | ||
if (!sourceFiles || sourceFiles.length > 1) { | ||
throw new Error("expected exactly one source file for .d.ts emit, got " + sourceFiles.map(function (sf) { return sf.fileName; })); | ||
throw new Error(`expected exactly one source file for .d.ts emit, got ${sourceFiles.map(sf => sf.fileName)}`); | ||
} | ||
var originalSource = sourceFiles[0]; | ||
content = addClutzAliases(fileName, content, originalSource, typeChecker, host); | ||
const originalSource = sourceFiles[0]; | ||
content = addClutzAliases(content, originalSource, typeChecker, host); | ||
} | ||
writeFileDelegate(fileName, content, writeByteOrderMark, onError, sourceFiles); | ||
}; | ||
var _e = program.emit(targetSourceFile, writeFileImpl, cancellationToken, emitOnlyDtsFiles, tsTransformers), tsDiagnostics = _e.diagnostics, emitSkipped = _e.emitSkipped, emittedFiles = _e.emittedFiles; | ||
var externs = {}; | ||
const { diagnostics: tsDiagnostics, emitSkipped, emittedFiles } = program.emit(targetSourceFile, writeFileImpl, cancellationToken, emitOnlyDtsFiles, tsTransformers); | ||
const externs = {}; | ||
if (host.transformTypesToClosure) { | ||
var sourceFiles = targetSourceFile ? [targetSourceFile] : program.getSourceFiles(); | ||
try { | ||
for (var sourceFiles_1 = __values(sourceFiles), sourceFiles_1_1 = sourceFiles_1.next(); !sourceFiles_1_1.done; sourceFiles_1_1 = sourceFiles_1.next()) { | ||
var sourceFile = sourceFiles_1_1.value; | ||
var isDts = transformer_util_1.isDtsFileName(sourceFile.fileName); | ||
if (isDts && host.shouldSkipTsickleProcessing(sourceFile.fileName)) { | ||
continue; | ||
} | ||
var _f = externs_1.generateExterns(typeChecker, sourceFile, host, host.moduleResolutionHost, tsOptions), output = _f.output, diagnostics = _f.diagnostics; | ||
if (output) { | ||
externs[sourceFile.fileName] = output; | ||
} | ||
if (diagnostics) { | ||
tsickleDiagnostics.push.apply(tsickleDiagnostics, __spread(diagnostics)); | ||
} | ||
const sourceFiles = targetSourceFile ? [targetSourceFile] : program.getSourceFiles(); | ||
for (const sourceFile of sourceFiles) { | ||
const isDts = transformer_util_1.isDtsFileName(sourceFile.fileName); | ||
if (isDts && host.shouldSkipTsickleProcessing(sourceFile.fileName)) { | ||
continue; | ||
} | ||
} | ||
catch (e_3_1) { e_3 = { error: e_3_1 }; } | ||
finally { | ||
try { | ||
if (sourceFiles_1_1 && !sourceFiles_1_1.done && (_b = sourceFiles_1.return)) _b.call(sourceFiles_1); | ||
const { output, diagnostics } = externs_1.generateExterns(typeChecker, sourceFile, host, host.moduleResolutionHost, tsOptions); | ||
if (output) { | ||
externs[sourceFile.fileName] = output; | ||
} | ||
finally { if (e_3) throw e_3.error; } | ||
if (diagnostics) { | ||
tsickleDiagnostics.push(...diagnostics); | ||
} | ||
} | ||
@@ -193,10 +135,10 @@ } | ||
// warns and then fixes up the code to be Closure-compatible anyway. | ||
tsickleDiagnostics = tsickleDiagnostics.filter(function (d) { return d.category === ts.DiagnosticCategory.Error || | ||
!host.shouldIgnoreWarningsForPath(d.file.fileName); }); | ||
tsickleDiagnostics = tsickleDiagnostics.filter(d => d.category === ts.DiagnosticCategory.Error || | ||
!host.shouldIgnoreWarningsForPath(d.file.fileName)); | ||
return { | ||
modulesManifest: modulesManifest, | ||
emitSkipped: emitSkipped, | ||
modulesManifest, | ||
emitSkipped, | ||
emittedFiles: emittedFiles || [], | ||
diagnostics: __spread(tsDiagnostics, tsickleDiagnostics), | ||
externs: externs | ||
diagnostics: [...tsDiagnostics, ...tsickleDiagnostics], | ||
externs | ||
}; | ||
@@ -219,24 +161,73 @@ } | ||
*/ | ||
function addClutzAliases(fileName, dtsFileContent, sourceFile, typeChecker, host) { | ||
var e_4, _a; | ||
var moduleSymbol = typeChecker.getSymbolAtLocation(sourceFile); | ||
var moduleExports = moduleSymbol && typeChecker.getExportsOfModule(moduleSymbol); | ||
function addClutzAliases(dtsFileContent, sourceFile, typeChecker, host) { | ||
const moduleSymbol = typeChecker.getSymbolAtLocation(sourceFile); | ||
const moduleExports = moduleSymbol && typeChecker.getExportsOfModule(moduleSymbol); | ||
if (!moduleExports) | ||
return dtsFileContent; | ||
// .d.ts files can be transformed, too, so we need to compare the original node below. | ||
var origSourceFile = ts.getOriginalNode(sourceFile); | ||
// The module exports might be re-exports, and in the case of "export *" might not even be | ||
// available in the module scope, which makes them difficult to export. Avoid the problem by | ||
// filtering out symbols who do not have a declaration in the local module. | ||
var localExports = moduleExports.filter(function (e) { | ||
// If there are no declarations, be conservative and emit the aliases. | ||
const origSourceFile = ts.getOriginalNode(sourceFile); | ||
// In order to write aliases, the exported symbols need to be available in the | ||
// the module scope. That is not always the case: | ||
// | ||
// export | ||
// 1) export const X; // works | ||
// | ||
// reexport | ||
// 2) export {X} from './foo'; // doesn't | ||
// | ||
// imported reexport | ||
// 3) import {X} from './foo'; // works | ||
// export {X} from './foo'; | ||
// | ||
// getExportsOfModule returns all three types, but we need to separate 2). | ||
// For now we 'fix' 2) by simply not emitting a clutz alias, since clutz | ||
// interop is used in minority of scenarios. | ||
// | ||
// TODO(radokirov): attempt to add appropriate imports for 2) so that | ||
// currently finding out local appears even harder than fixing exports. | ||
const localExports = moduleExports.filter(e => { | ||
// If there are no declarations, be conservative and don't emit the aliases. | ||
// I don't know how can this happen, we have no tests that excercise it. | ||
if (!e.declarations) | ||
return true; | ||
return false; | ||
// Skip default exports, they are not currently supported. | ||
// default is a keyword in typescript, so the name of the export being default means that it's a | ||
// default export. | ||
// default is a keyword in typescript, so the name of the export being | ||
// default means that it's a default export. | ||
if (e.name === 'default') | ||
return false; | ||
// Otherwise check that some declaration is from the local module. | ||
return e.declarations.some(function (d) { return d.getSourceFile() === origSourceFile; }); | ||
// Use the declaration location to determine separate cases above. | ||
for (const d of e.declarations) { | ||
// This is a special case for export *. Technically, it is outside the | ||
// three cases outlined, but at this point we have rewritten it to a | ||
// reexport or an imported reexport. However, it appears that the | ||
// rewriting also has made it behave different from explicit named export | ||
// in the sense that the declaration appears to point at the original | ||
// location not the reexport location. Since we can't figure out whether | ||
// there is a local import here, we err on the side of less emit. | ||
if (d.getSourceFile() !== origSourceFile) { | ||
return false; | ||
} | ||
if (!ts.isExportSpecifier(d)) { | ||
// we have a pure export (case 1) thus safe to emit clutz alias. | ||
return true; | ||
} | ||
// The declaration d is useless to separate reexport and import-reexport | ||
// because they both point to the reexporting file and not to the original | ||
// one. However, there is another ts API that can do a deeper resolution. | ||
const localSymbol = typeChecker.getExportSpecifierLocalTargetSymbol(d); | ||
// I don't know how can this happen, but err on the side of less emit. | ||
if (!localSymbol) | ||
return false; | ||
// `declarations` is undefined for builtin symbols, such as `unknown`. | ||
if (!localSymbol.declarations) | ||
return false; | ||
// In case of no import we ended up in a declaration in foo.ts, while in | ||
// case of having an import localD is still in the reexporing file. | ||
for (const localD of localSymbol.declarations) { | ||
if (localD.getSourceFile() !== origSourceFile) { | ||
return false; | ||
} | ||
} | ||
} | ||
return true; | ||
}); | ||
@@ -247,5 +238,5 @@ if (!localExports.length) | ||
// module symbols come out, so sort here to make the tests stable. | ||
localExports.sort(function (a, b) { return stringCompare(a.name, b.name); }); | ||
var moduleName = host.pathToModuleName('', sourceFile.fileName); | ||
var clutzModuleName = moduleName.replace(/\./g, '$'); | ||
localExports.sort((a, b) => stringCompare(a.name, b.name)); | ||
const moduleName = host.pathToModuleName('', sourceFile.fileName); | ||
const clutzModuleName = moduleName.replace(/\./g, '$'); | ||
// Clutz might refer to the name in two different forms (stemming from goog.provide and | ||
@@ -258,28 +249,27 @@ // goog.module respectively). | ||
// Case (1) from above. | ||
var globalSymbols = ''; | ||
let globalSymbols = ''; | ||
// Case (2) from above. | ||
var nestedSymbols = ''; | ||
try { | ||
for (var localExports_1 = __values(localExports), localExports_1_1 = localExports_1.next(); !localExports_1_1.done; localExports_1_1 = localExports_1.next()) { | ||
var symbol = localExports_1_1.value; | ||
globalSymbols += | ||
"\t\texport {" + symbol.name + " as module$contents$" + clutzModuleName + "_" + symbol.name + "}\n"; | ||
nestedSymbols += | ||
"\t\texport {module$contents$" + clutzModuleName + "_" + symbol.name + " as " + symbol.name + "}\n"; | ||
let nestedSymbols = ''; | ||
for (const symbol of localExports) { | ||
let localName = symbol.name; | ||
const declaration = symbol.declarations.find(d => d.getSourceFile() === origSourceFile); | ||
if (declaration && ts.isExportSpecifier(declaration) && declaration.propertyName) { | ||
// If declared in an "export {X as Y};" export specifier, then X (stored in propertyName) is | ||
// the local name that resolves within the module, whereas Y is only available on the exports, | ||
// i.e. the name used to address the symbol from outside the module. | ||
// Use the localName for the export then, but publish under the external name. | ||
localName = declaration.propertyName.text; | ||
} | ||
globalSymbols += | ||
`\t\texport {${localName} as module$contents$${clutzModuleName}_${symbol.name}}\n`; | ||
nestedSymbols += | ||
`\t\texport {module$contents$${clutzModuleName}_${symbol.name} as ${symbol.name}}\n`; | ||
} | ||
catch (e_4_1) { e_4 = { error: e_4_1 }; } | ||
finally { | ||
try { | ||
if (localExports_1_1 && !localExports_1_1.done && (_a = localExports_1.return)) _a.call(localExports_1); | ||
} | ||
finally { if (e_4) throw e_4.error; } | ||
} | ||
dtsFileContent += 'declare global {\n'; | ||
dtsFileContent += "\tnamespace \u0CA0_\u0CA0.clutz {\n"; | ||
dtsFileContent += `\tnamespace ಠ_ಠ.clutz {\n`; | ||
dtsFileContent += globalSymbols; | ||
dtsFileContent += "\t}\n"; | ||
dtsFileContent += "\tnamespace \u0CA0_\u0CA0.clutz.module$exports$" + clutzModuleName + " {\n"; | ||
dtsFileContent += `\t}\n`; | ||
dtsFileContent += `\tnamespace ಠ_ಠ.clutz.module$exports$${clutzModuleName} {\n`; | ||
dtsFileContent += nestedSymbols; | ||
dtsFileContent += "\t}\n"; | ||
dtsFileContent += `\t}\n`; | ||
dtsFileContent += '}\n'; | ||
@@ -289,5 +279,5 @@ return dtsFileContent; | ||
function skipTransformForSourceFileIfNeeded(host, delegateFactory) { | ||
return function (context) { | ||
var delegate = delegateFactory(context); | ||
return function (sourceFile) { | ||
return (context) => { | ||
const delegate = delegateFactory(context); | ||
return (sourceFile) => { | ||
if (host.shouldSkipTsickleProcessing(sourceFile.fileName)) { | ||
@@ -301,2 +291,2 @@ return sourceFile; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsickle.js","sourceRoot":"","sources":["../../../../src/tsickle.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 */\n\nimport * as ts from 'typescript';\n\nimport {AnnotatorHost} from './annotator_host';\nimport {assertAbsolute} from './cli_support';\nimport {decoratorDownlevelTransformer} from './decorator_downlevel_transformer';\nimport {enumTransformer} from './enum_transformer';\nimport {generateExterns} from './externs';\nimport {transformFileoverviewCommentFactory} from './fileoverview_comment_transformer';\nimport * as googmodule from './googmodule';\nimport {jsdocTransformer, removeTypeAssertions} from './jsdoc_transformer';\nimport {ModulesManifest} from './modules_manifest';\nimport {quotingTransformer} from './quoting_transformer';\nimport {isDtsFileName} from './transformer_util';\n\n// Retained here for API compatibility.\nexport {getGeneratedExterns} from './externs';\nexport {FileMap, ModulesManifest} from './modules_manifest';\n\nexport interface TsickleHost extends googmodule.GoogModuleProcessorHost, AnnotatorHost {\n  /**\n   * Whether to downlevel decorators\n   */\n  transformDecorators?: boolean;\n  /**\n   * Whether to convers types to closure\n   */\n  transformTypesToClosure?: boolean;\n  /**\n   * Whether to add aliases to the .d.ts files to add the exports to the\n   * ಠ_ಠ.clutz namespace.\n   */\n  addDtsClutzAliases?: boolean;\n  /**\n   * If true, tsickle and decorator downlevel processing will be skipped for\n   * that file.\n   */\n  shouldSkipTsickleProcessing(fileName: string): boolean;\n  /**\n   * Tsickle treats warnings as errors, if true, ignore warnings.  This might be\n   * useful for e.g. third party code.\n   */\n  shouldIgnoreWarningsForPath(filePath: string): boolean;\n  /** Whether to convert CommonJS require() imports to goog.module() and goog.require() calls. */\n  googmodule: boolean;\n}\n\nexport function mergeEmitResults(emitResults: EmitResult[]): EmitResult {\n  const diagnostics: ts.Diagnostic[] = [];\n  let emitSkipped = true;\n  const emittedFiles: string[] = [];\n  const externs: {[fileName: string]: string} = {};\n  const modulesManifest = new ModulesManifest();\n  for (const er of emitResults) {\n    diagnostics.push(...er.diagnostics);\n    emitSkipped = emitSkipped || er.emitSkipped;\n    emittedFiles.push(...er.emittedFiles);\n    Object.assign(externs, er.externs);\n    modulesManifest.addManifest(er.modulesManifest);\n  }\n  return {diagnostics, emitSkipped, emittedFiles, externs, modulesManifest};\n}\n\nexport interface EmitResult extends ts.EmitResult {\n  // The manifest of JS modules output by the compiler.\n  modulesManifest: ModulesManifest;\n  /**\n   * externs.js files produced by tsickle, if any. module IDs are relative paths from\n   * fileNameToModuleId.\n   */\n  externs: {[moduleId: string]: string};\n}\n\nexport interface EmitTransformers {\n  /** Custom transformers to evaluate before Tsickle .js transformations. */\n  beforeTsickle?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate before built-in .js transformations. */\n  beforeTs?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate after built-in .js transformations. */\n  afterTs?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate after built-in .d.ts transformations. */\n  afterDeclarations?: Array<ts.TransformerFactory<ts.Bundle|ts.SourceFile>>;\n}\n\nexport function emitWithTsickle(\n    program: ts.Program, host: TsickleHost, tsHost: ts.CompilerHost, tsOptions: ts.CompilerOptions,\n    targetSourceFile?: ts.SourceFile, writeFile?: ts.WriteFileCallback,\n    cancellationToken?: ts.CancellationToken, emitOnlyDtsFiles?: boolean,\n    customTransformers: EmitTransformers = {}): EmitResult {\n  for (const sf of program.getSourceFiles()) {\n    assertAbsolute(sf.fileName);\n  }\n\n  let tsickleDiagnostics: ts.Diagnostic[] = [];\n  const typeChecker = program.getTypeChecker();\n  const tsickleSourceTransformers: Array<ts.TransformerFactory<ts.SourceFile>> = [];\n  if (host.transformTypesToClosure) {\n    // Only add @suppress {checkTypes} comments when also adding type annotations.\n    tsickleSourceTransformers.push(transformFileoverviewCommentFactory(tsickleDiagnostics));\n    tsickleSourceTransformers.push(\n        jsdocTransformer(host, tsOptions, tsHost, typeChecker, tsickleDiagnostics));\n    if (host.enableAutoQuoting) {\n      tsickleSourceTransformers.push(quotingTransformer(host, typeChecker, tsickleDiagnostics));\n    }\n    tsickleSourceTransformers.push(enumTransformer(typeChecker, tsickleDiagnostics));\n    tsickleSourceTransformers.push(decoratorDownlevelTransformer(typeChecker, tsickleDiagnostics));\n  } else if (host.transformDecorators) {\n    tsickleSourceTransformers.push(decoratorDownlevelTransformer(typeChecker, tsickleDiagnostics));\n  }\n  const modulesManifest = new ModulesManifest();\n  const tsickleTransformers: ts.CustomTransformers = {before: tsickleSourceTransformers};\n  const tsTransformers: ts.CustomTransformers = {\n    before: [\n      ...(customTransformers.beforeTsickle || []),\n      ...(tsickleTransformers.before || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)),\n      ...(customTransformers.beforeTs || []),\n    ],\n    after: [\n      ...(customTransformers.afterTs || []),\n      ...(tsickleTransformers.after || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)),\n    ],\n    afterDeclarations: customTransformers.afterDeclarations,\n  };\n  if (host.transformTypesToClosure) {\n    // See comment on remoteTypeAssertions.\n    tsTransformers.before!.push(removeTypeAssertions());\n  }\n  if (host.googmodule) {\n    tsTransformers.after!.push(googmodule.commonJsToGoogmoduleTransformer(\n        host, modulesManifest, typeChecker, tsickleDiagnostics));\n  }\n\n  const writeFileDelegate: ts.WriteFileCallback = writeFile || tsHost.writeFile.bind(tsHost);\n  const writeFileImpl: ts.WriteFileCallback =\n      (fileName, content, writeByteOrderMark, onError, sourceFiles) => {\n        assertAbsolute(fileName);\n        if (host.addDtsClutzAliases && isDtsFileName(fileName) && sourceFiles) {\n          // Only bundle emits pass more than one source file for .d.ts writes. Bundle emits however\n          // are not supported by tsickle, as we cannot annotate them for Closure in any meaningful\n          // way anyway.\n          if (!sourceFiles || sourceFiles.length > 1) {\n            throw new Error(`expected exactly one source file for .d.ts emit, got ${\n                sourceFiles.map(sf => sf.fileName)}`);\n          }\n          const originalSource = sourceFiles[0];\n          content = addClutzAliases(fileName, content, originalSource, typeChecker, host);\n        }\n        writeFileDelegate(fileName, content, writeByteOrderMark, onError, sourceFiles);\n      };\n\n  const {diagnostics: tsDiagnostics, emitSkipped, emittedFiles} = program.emit(\n      targetSourceFile, writeFileImpl, cancellationToken, emitOnlyDtsFiles, tsTransformers);\n\n  const externs: {[fileName: string]: string} = {};\n  if (host.transformTypesToClosure) {\n    const sourceFiles = targetSourceFile ? [targetSourceFile] : program.getSourceFiles();\n    for (const sourceFile of sourceFiles) {\n      const isDts = isDtsFileName(sourceFile.fileName);\n      if (isDts && host.shouldSkipTsickleProcessing(sourceFile.fileName)) {\n        continue;\n      }\n      const {output, diagnostics} =\n          generateExterns(typeChecker, sourceFile, host, host.moduleResolutionHost, tsOptions);\n      if (output) {\n        externs[sourceFile.fileName] = output;\n      }\n      if (diagnostics) {\n        tsickleDiagnostics.push(...diagnostics);\n      }\n    }\n  }\n  // All diagnostics (including warnings) are treated as errors.\n  // If the host decides to ignore warnings, just discard them.\n  // Warnings include stuff like \"don't use @type in your jsdoc\"; tsickle\n  // warns and then fixes up the code to be Closure-compatible anyway.\n  tsickleDiagnostics = tsickleDiagnostics.filter(\n      d => d.category === ts.DiagnosticCategory.Error ||\n          !host.shouldIgnoreWarningsForPath(d.file!.fileName));\n\n  return {\n    modulesManifest,\n    emitSkipped,\n    emittedFiles: emittedFiles || [],\n    diagnostics: [...tsDiagnostics, ...tsickleDiagnostics],\n    externs\n  };\n}\n\n/** Compares two strings and returns a number suitable for use in sort(). */\nfunction stringCompare(a: string, b: string): number {\n  if (a < b) return -1;\n  if (a > b) return 1;\n  return 0;\n}\n\n/**\n * A tsickle produced declaration file might be consumed be referenced by Clutz\n * produced .d.ts files, which use symbol names based on Closure's internal\n * naming conventions, so we need to provide aliases for all the exported symbols\n * in the Clutz naming convention.\n */\nfunction addClutzAliases(\n    fileName: string, dtsFileContent: string, sourceFile: ts.SourceFile,\n    typeChecker: ts.TypeChecker, host: TsickleHost): string {\n  const moduleSymbol = typeChecker.getSymbolAtLocation(sourceFile);\n  const moduleExports = moduleSymbol && typeChecker.getExportsOfModule(moduleSymbol);\n  if (!moduleExports) return dtsFileContent;\n\n  // .d.ts files can be transformed, too, so we need to compare the original node below.\n  const origSourceFile = ts.getOriginalNode(sourceFile);\n  // The module exports might be re-exports, and in the case of \"export *\" might not even be\n  // available in the module scope, which makes them difficult to export. Avoid the problem by\n  // filtering out symbols who do not have a declaration in the local module.\n  const localExports = moduleExports.filter(e => {\n    // If there are no declarations, be conservative and emit the aliases.\n    if (!e.declarations) return true;\n    // Skip default exports, they are not currently supported.\n    // default is a keyword in typescript, so the name of the export being default means that it's a\n    // default export.\n    if (e.name === 'default') return false;\n    // Otherwise check that some declaration is from the local module.\n    return e.declarations.some(d => d.getSourceFile() === origSourceFile);\n  });\n  if (!localExports.length) return dtsFileContent;\n\n  // TypeScript 2.8 and TypeScript 2.9 differ on the order in which the\n  // module symbols come out, so sort here to make the tests stable.\n  localExports.sort((a, b) => stringCompare(a.name, b.name));\n\n  const moduleName = host.pathToModuleName('', sourceFile.fileName);\n  const clutzModuleName = moduleName.replace(/\\./g, '$');\n\n  // Clutz might refer to the name in two different forms (stemming from goog.provide and\n  // goog.module respectively).\n  // 1) global in clutz:   ಠ_ಠ.clutz.module$contents$path$to$module_Symbol...\n  // 2) local in a module: ಠ_ಠ.clutz.module$exports$path$to$module.Symbol ..\n  // See examples at:\n  // https://github.com/angular/clutz/tree/master/src/test/java/com/google/javascript/clutz\n\n  // Case (1) from above.\n  let globalSymbols = '';\n  // Case (2) from above.\n  let nestedSymbols = '';\n  for (const symbol of localExports) {\n    globalSymbols +=\n        `\\t\\texport {${symbol.name} as module$contents$${clutzModuleName}_${symbol.name}}\\n`;\n    nestedSymbols +=\n        `\\t\\texport {module$contents$${clutzModuleName}_${symbol.name} as ${symbol.name}}\\n`;\n  }\n\n  dtsFileContent += 'declare global {\\n';\n  dtsFileContent += `\\tnamespace ಠ_ಠ.clutz {\\n`;\n  dtsFileContent += globalSymbols;\n  dtsFileContent += `\\t}\\n`;\n  dtsFileContent += `\\tnamespace ಠ_ಠ.clutz.module$exports$${clutzModuleName} {\\n`;\n  dtsFileContent += nestedSymbols;\n  dtsFileContent += `\\t}\\n`;\n  dtsFileContent += '}\\n';\n\n  return dtsFileContent;\n}\n\nfunction skipTransformForSourceFileIfNeeded(\n    host: TsickleHost,\n    delegateFactory: ts.TransformerFactory<ts.SourceFile>): ts.TransformerFactory<ts.SourceFile> {\n  return (context: ts.TransformationContext) => {\n    const delegate = delegateFactory(context);\n    return (sourceFile: ts.SourceFile) => {\n      if (host.shouldSkipTsickleProcessing(sourceFile.fileName)) {\n        return sourceFile;\n      }\n      return delegate(sourceFile);\n    };\n  };\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsickle.js","sourceRoot":"","sources":["../../../../src/tsickle.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 */\n\nimport * as ts from 'typescript';\n\nimport {AnnotatorHost} from './annotator_host';\nimport {assertAbsolute} from './cli_support';\nimport {decoratorDownlevelTransformer} from './decorator_downlevel_transformer';\nimport {enumTransformer} from './enum_transformer';\nimport {generateExterns} from './externs';\nimport {transformFileoverviewCommentFactory} from './fileoverview_comment_transformer';\nimport * as googmodule from './googmodule';\nimport {jsdocTransformer, removeTypeAssertions} from './jsdoc_transformer';\nimport {ModulesManifest} from './modules_manifest';\nimport {isDtsFileName} from './transformer_util';\n\n// Retained here for API compatibility.\nexport {getGeneratedExterns} from './externs';\nexport {FileMap, ModulesManifest} from './modules_manifest';\n\nexport interface TsickleHost extends googmodule.GoogModuleProcessorHost, AnnotatorHost {\n  /**\n   * Whether to downlevel decorators\n   */\n  transformDecorators?: boolean;\n  /**\n   * Whether to convers types to closure\n   */\n  transformTypesToClosure?: boolean;\n  /**\n   * Whether to add aliases to the .d.ts files to add the exports to the\n   * ಠ_ಠ.clutz namespace.\n   */\n  addDtsClutzAliases?: boolean;\n  /**\n   * If true, tsickle and decorator downlevel processing will be skipped for\n   * that file.\n   */\n  shouldSkipTsickleProcessing(fileName: string): boolean;\n  /**\n   * Tsickle treats warnings as errors, if true, ignore warnings.  This might be\n   * useful for e.g. third party code.\n   */\n  shouldIgnoreWarningsForPath(filePath: string): boolean;\n  /** Whether to convert CommonJS require() imports to goog.module() and goog.require() calls. */\n  googmodule: boolean;\n}\n\nexport function mergeEmitResults(emitResults: EmitResult[]): EmitResult {\n  const diagnostics: ts.Diagnostic[] = [];\n  let emitSkipped = true;\n  const emittedFiles: string[] = [];\n  const externs: {[fileName: string]: string} = {};\n  const modulesManifest = new ModulesManifest();\n  for (const er of emitResults) {\n    diagnostics.push(...er.diagnostics);\n    emitSkipped = emitSkipped || er.emitSkipped;\n    if (er.emittedFiles) {\n      emittedFiles.push(...er.emittedFiles);\n    }\n    Object.assign(externs, er.externs);\n    modulesManifest.addManifest(er.modulesManifest);\n  }\n  return {diagnostics, emitSkipped, emittedFiles, externs, modulesManifest};\n}\n\nexport interface EmitResult extends ts.EmitResult {\n  // The manifest of JS modules output by the compiler.\n  modulesManifest: ModulesManifest;\n  /**\n   * externs.js files produced by tsickle, if any. module IDs are relative paths from\n   * fileNameToModuleId.\n   */\n  externs: {[moduleId: string]: string};\n}\n\nexport interface EmitTransformers {\n  /** Custom transformers to evaluate before Tsickle .js transformations. */\n  beforeTsickle?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate before built-in .js transformations. */\n  beforeTs?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate after built-in .js transformations. */\n  afterTs?: Array<ts.TransformerFactory<ts.SourceFile>>;\n  /** Custom transformers to evaluate after built-in .d.ts transformations. */\n  afterDeclarations?: Array<ts.TransformerFactory<ts.Bundle|ts.SourceFile>>;\n}\n\nexport function emitWithTsickle(\n    program: ts.Program, host: TsickleHost, tsHost: ts.CompilerHost, tsOptions: ts.CompilerOptions,\n    targetSourceFile?: ts.SourceFile, writeFile?: ts.WriteFileCallback,\n    cancellationToken?: ts.CancellationToken, emitOnlyDtsFiles?: boolean,\n    customTransformers: EmitTransformers = {}): EmitResult {\n  for (const sf of program.getSourceFiles()) {\n    assertAbsolute(sf.fileName);\n  }\n\n  let tsickleDiagnostics: ts.Diagnostic[] = [];\n  const typeChecker = program.getTypeChecker();\n  const tsickleSourceTransformers: Array<ts.TransformerFactory<ts.SourceFile>> = [];\n  if (host.transformTypesToClosure) {\n    // Only add @suppress {checkTypes} comments when also adding type annotations.\n    tsickleSourceTransformers.push(transformFileoverviewCommentFactory(tsickleDiagnostics));\n    tsickleSourceTransformers.push(\n        jsdocTransformer(host, tsOptions, tsHost, typeChecker, tsickleDiagnostics));\n    tsickleSourceTransformers.push(enumTransformer(typeChecker, tsickleDiagnostics));\n    tsickleSourceTransformers.push(decoratorDownlevelTransformer(typeChecker, tsickleDiagnostics));\n  } else if (host.transformDecorators) {\n    tsickleSourceTransformers.push(decoratorDownlevelTransformer(typeChecker, tsickleDiagnostics));\n  }\n  const modulesManifest = new ModulesManifest();\n  const tsickleTransformers: ts.CustomTransformers = {before: tsickleSourceTransformers};\n  const tsTransformers: ts.CustomTransformers = {\n    before: [\n      ...(customTransformers.beforeTsickle || []),\n      ...(tsickleTransformers.before || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)),\n      ...(customTransformers.beforeTs || []),\n    ],\n    after: [\n      ...(customTransformers.afterTs || []),\n      ...(tsickleTransformers.after || []).map(tf => skipTransformForSourceFileIfNeeded(host, tf)),\n    ],\n    afterDeclarations: customTransformers.afterDeclarations,\n  };\n  if (host.transformTypesToClosure) {\n    // See comment on remoteTypeAssertions.\n    tsTransformers.before!.push(removeTypeAssertions());\n  }\n  if (host.googmodule) {\n    tsTransformers.after!.push(googmodule.commonJsToGoogmoduleTransformer(\n        host, modulesManifest, typeChecker, tsickleDiagnostics));\n  }\n\n  const writeFileDelegate: ts.WriteFileCallback = writeFile || tsHost.writeFile.bind(tsHost);\n  const writeFileImpl: ts.WriteFileCallback =\n      (fileName, content, writeByteOrderMark, onError, sourceFiles) => {\n        assertAbsolute(fileName);\n        if (host.addDtsClutzAliases && isDtsFileName(fileName) && sourceFiles) {\n          // Only bundle emits pass more than one source file for .d.ts writes. Bundle emits however\n          // are not supported by tsickle, as we cannot annotate them for Closure in any meaningful\n          // way anyway.\n          if (!sourceFiles || sourceFiles.length > 1) {\n            throw new Error(`expected exactly one source file for .d.ts emit, got ${\n                sourceFiles.map(sf => sf.fileName)}`);\n          }\n          const originalSource = sourceFiles[0];\n          content = addClutzAliases(content, originalSource, typeChecker, host);\n        }\n        writeFileDelegate(fileName, content, writeByteOrderMark, onError, sourceFiles);\n      };\n\n  const {diagnostics: tsDiagnostics, emitSkipped, emittedFiles} = program.emit(\n      targetSourceFile, writeFileImpl, cancellationToken, emitOnlyDtsFiles, tsTransformers);\n\n  const externs: {[fileName: string]: string} = {};\n  if (host.transformTypesToClosure) {\n    const sourceFiles = targetSourceFile ? [targetSourceFile] : program.getSourceFiles();\n    for (const sourceFile of sourceFiles) {\n      const isDts = isDtsFileName(sourceFile.fileName);\n      if (isDts && host.shouldSkipTsickleProcessing(sourceFile.fileName)) {\n        continue;\n      }\n      const {output, diagnostics} =\n          generateExterns(typeChecker, sourceFile, host, host.moduleResolutionHost, tsOptions);\n      if (output) {\n        externs[sourceFile.fileName] = output;\n      }\n      if (diagnostics) {\n        tsickleDiagnostics.push(...diagnostics);\n      }\n    }\n  }\n  // All diagnostics (including warnings) are treated as errors.\n  // If the host decides to ignore warnings, just discard them.\n  // Warnings include stuff like \"don't use @type in your jsdoc\"; tsickle\n  // warns and then fixes up the code to be Closure-compatible anyway.\n  tsickleDiagnostics = tsickleDiagnostics.filter(\n      d => d.category === ts.DiagnosticCategory.Error ||\n          !host.shouldIgnoreWarningsForPath(d.file!.fileName));\n\n  return {\n    modulesManifest,\n    emitSkipped,\n    emittedFiles: emittedFiles || [],\n    diagnostics: [...tsDiagnostics, ...tsickleDiagnostics],\n    externs\n  };\n}\n\n/** Compares two strings and returns a number suitable for use in sort(). */\nfunction stringCompare(a: string, b: string): number {\n  if (a < b) return -1;\n  if (a > b) return 1;\n  return 0;\n}\n\n/**\n * A tsickle produced declaration file might be consumed be referenced by Clutz\n * produced .d.ts files, which use symbol names based on Closure's internal\n * naming conventions, so we need to provide aliases for all the exported symbols\n * in the Clutz naming convention.\n */\nfunction addClutzAliases(\n    dtsFileContent: string, sourceFile: ts.SourceFile, typeChecker: ts.TypeChecker,\n    host: TsickleHost): string {\n  const moduleSymbol = typeChecker.getSymbolAtLocation(sourceFile);\n  const moduleExports = moduleSymbol && typeChecker.getExportsOfModule(moduleSymbol);\n  if (!moduleExports) return dtsFileContent;\n\n  // .d.ts files can be transformed, too, so we need to compare the original node below.\n  const origSourceFile = ts.getOriginalNode(sourceFile);\n  // In order to write aliases, the exported symbols need to be available in the\n  // the module scope. That is not always the case:\n  //\n  // export\n  // 1) export const X;           // works\n  //\n  // reexport\n  // 2) export {X} from './foo';  // doesn't\n  //\n  // imported reexport\n  // 3) import {X} from './foo';  // works\n  //    export {X} from './foo';\n  //\n  // getExportsOfModule returns all three types, but we need to separate 2).\n  // For now we 'fix' 2) by simply not emitting a clutz alias, since clutz\n  // interop is used in minority of scenarios.\n  //\n  // TODO(radokirov): attempt to add appropriate imports for 2) so that\n  // currently finding out local appears even harder than fixing exports.\n  const localExports = moduleExports.filter(e => {\n    // If there are no declarations, be conservative and don't emit the aliases.\n    // I don't know how can this happen, we have no tests that excercise it.\n    if (!e.declarations) return false;\n\n    // Skip default exports, they are not currently supported.\n    // default is a keyword in typescript, so the name of the export being\n    // default means that it's a default export.\n    if (e.name === 'default') return false;\n\n    // Use the declaration location to determine separate cases above.\n    for (const d of e.declarations) {\n      // This is a special case for export *. Technically, it is outside the\n      // three cases outlined, but at this point we have rewritten it to a\n      // reexport or an imported reexport. However, it appears that the\n      // rewriting also has made it behave different from explicit named export\n      // in the sense that the declaration appears to point at the original\n      // location not the reexport location.  Since we can't figure out whether\n      // there is a local import here, we err on the side of less emit.\n      if (d.getSourceFile() !== origSourceFile) {\n        return false;\n      }\n\n      if (!ts.isExportSpecifier(d)) {\n        // we have a pure export (case 1) thus safe to emit clutz alias.\n        return true;\n      }\n\n      // The declaration d is useless to separate reexport and import-reexport\n      // because they both point to the reexporting file and not to the original\n      // one.  However, there is another ts API that can do a deeper resolution.\n      const localSymbol = typeChecker.getExportSpecifierLocalTargetSymbol(d);\n      // I don't know how can this happen, but err on the side of less emit.\n      if (!localSymbol) return false;\n      // `declarations` is undefined for builtin symbols, such as `unknown`.\n      if (!localSymbol.declarations) return false;\n\n      // In case of no import we ended up in a declaration in foo.ts, while in\n      // case of having an import localD is still in the reexporing file.\n      for (const localD of localSymbol.declarations) {\n        if (localD.getSourceFile() !== origSourceFile) {\n          return false;\n        }\n      }\n    }\n    return true;\n  });\n  if (!localExports.length) return dtsFileContent;\n\n  // TypeScript 2.8 and TypeScript 2.9 differ on the order in which the\n  // module symbols come out, so sort here to make the tests stable.\n  localExports.sort((a, b) => stringCompare(a.name, b.name));\n\n  const moduleName = host.pathToModuleName('', sourceFile.fileName);\n  const clutzModuleName = moduleName.replace(/\\./g, '$');\n\n  // Clutz might refer to the name in two different forms (stemming from goog.provide and\n  // goog.module respectively).\n  // 1) global in clutz:   ಠ_ಠ.clutz.module$contents$path$to$module_Symbol...\n  // 2) local in a module: ಠ_ಠ.clutz.module$exports$path$to$module.Symbol ..\n  // See examples at:\n  // https://github.com/angular/clutz/tree/master/src/test/java/com/google/javascript/clutz\n\n  // Case (1) from above.\n  let globalSymbols = '';\n  // Case (2) from above.\n  let nestedSymbols = '';\n  for (const symbol of localExports) {\n    let localName = symbol.name;\n    const declaration = symbol.declarations.find(d => d.getSourceFile() === origSourceFile);\n    if (declaration && ts.isExportSpecifier(declaration) && declaration.propertyName) {\n      // If declared in an \"export {X as Y};\" export specifier, then X (stored in propertyName) is\n      // the local name that resolves within the module, whereas Y is only available on the exports,\n      // i.e. the name used to address the symbol from outside the module.\n      // Use the localName for the export then, but publish under the external name.\n      localName = declaration.propertyName.text;\n    }\n    globalSymbols +=\n        `\\t\\texport {${localName} as module$contents$${clutzModuleName}_${symbol.name}}\\n`;\n    nestedSymbols +=\n        `\\t\\texport {module$contents$${clutzModuleName}_${symbol.name} as ${symbol.name}}\\n`;\n  }\n\n  dtsFileContent += 'declare global {\\n';\n  dtsFileContent += `\\tnamespace ಠ_ಠ.clutz {\\n`;\n  dtsFileContent += globalSymbols;\n  dtsFileContent += `\\t}\\n`;\n  dtsFileContent += `\\tnamespace ಠ_ಠ.clutz.module$exports$${clutzModuleName} {\\n`;\n  dtsFileContent += nestedSymbols;\n  dtsFileContent += `\\t}\\n`;\n  dtsFileContent += '}\\n';\n\n  return dtsFileContent;\n}\n\nfunction skipTransformForSourceFileIfNeeded(\n    host: TsickleHost,\n    delegateFactory: ts.TransformerFactory<ts.SourceFile>): ts.TransformerFactory<ts.SourceFile> {\n  return (context: ts.TransformationContext) => {\n    const delegate = delegateFactory(context);\n    return (sourceFile: ts.SourceFile) => {\n      if (host.shouldSkipTsickleProcessing(sourceFile.fileName)) {\n        return sourceFile;\n      }\n      return delegate(sourceFile);\n    };\n  };\n}\n"]} |
@@ -57,4 +57,4 @@ /** | ||
* @param symbolsToAliasedNames a mapping from symbols (`Foo`) to a name in scope they should be | ||
* emitted as (e.g. `tsickle_forward_declare_1.Foo`). Can be augmented during type | ||
* translation, e.g. to blacklist a symbol. | ||
* emitted as (e.g. `tsickle_reqType_1.Foo`). Can be augmented during type translation, e.g. | ||
* to blacklist a symbol. | ||
*/ | ||
@@ -61,0 +61,0 @@ constructor(host: AnnotatorHost, typeChecker: ts.TypeChecker, node: ts.Node, pathBlackList?: Set<string> | undefined, symbolsToAliasedNames?: Map<ts.Symbol, string>, ensureSymbolDeclared?: (sym: ts.Symbol) => void); |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
197
938869
16
36
6815