summaryrefslogtreecommitdiff
path: root/node_modules/typescript/lib/tsc.js
diff options
context:
space:
mode:
Diffstat (limited to 'node_modules/typescript/lib/tsc.js')
-rw-r--r--node_modules/typescript/lib/tsc.js24060
1 files changed, 14202 insertions, 9858 deletions
diff --git a/node_modules/typescript/lib/tsc.js b/node_modules/typescript/lib/tsc.js
index e08661bd1..a690d219d 100644
--- a/node_modules/typescript/lib/tsc.js
+++ b/node_modules/typescript/lib/tsc.js
@@ -27,6 +27,16 @@ var ts;
ExitStatus[ExitStatus["DiagnosticsPresent_OutputsSkipped"] = 1] = "DiagnosticsPresent_OutputsSkipped";
ExitStatus[ExitStatus["DiagnosticsPresent_OutputsGenerated"] = 2] = "DiagnosticsPresent_OutputsGenerated";
})(ExitStatus = ts.ExitStatus || (ts.ExitStatus = {}));
+ var NodeBuilderFlags;
+ (function (NodeBuilderFlags) {
+ NodeBuilderFlags[NodeBuilderFlags["None"] = 0] = "None";
+ NodeBuilderFlags[NodeBuilderFlags["allowThisInObjectLiteral"] = 1] = "allowThisInObjectLiteral";
+ NodeBuilderFlags[NodeBuilderFlags["allowQualifedNameInPlaceOfIdentifier"] = 2] = "allowQualifedNameInPlaceOfIdentifier";
+ NodeBuilderFlags[NodeBuilderFlags["allowTypeParameterInQualifiedName"] = 4] = "allowTypeParameterInQualifiedName";
+ NodeBuilderFlags[NodeBuilderFlags["allowAnonymousIdentifier"] = 8] = "allowAnonymousIdentifier";
+ NodeBuilderFlags[NodeBuilderFlags["allowEmptyUnionOrIntersection"] = 16] = "allowEmptyUnionOrIntersection";
+ NodeBuilderFlags[NodeBuilderFlags["allowEmptyTuple"] = 32] = "allowEmptyTuple";
+ })(NodeBuilderFlags = ts.NodeBuilderFlags || (ts.NodeBuilderFlags = {}));
var TypeReferenceSerializationKind;
(function (TypeReferenceSerializationKind) {
TypeReferenceSerializationKind[TypeReferenceSerializationKind["Unknown"] = 0] = "Unknown";
@@ -88,32 +98,32 @@ var ts;
var measures;
function mark(markName) {
if (enabled) {
- marks[markName] = ts.timestamp();
- counts[markName] = (counts[markName] || 0) + 1;
+ marks.set(markName, ts.timestamp());
+ counts.set(markName, (counts.get(markName) || 0) + 1);
profilerEvent(markName);
}
}
performance.mark = mark;
function measure(measureName, startMarkName, endMarkName) {
if (enabled) {
- var end = endMarkName && marks[endMarkName] || ts.timestamp();
- var start = startMarkName && marks[startMarkName] || profilerStart;
- measures[measureName] = (measures[measureName] || 0) + (end - start);
+ var end = endMarkName && marks.get(endMarkName) || ts.timestamp();
+ var start = startMarkName && marks.get(startMarkName) || profilerStart;
+ measures.set(measureName, (measures.get(measureName) || 0) + (end - start));
}
}
performance.measure = measure;
function getCount(markName) {
- return counts && counts[markName] || 0;
+ return counts && counts.get(markName) || 0;
}
performance.getCount = getCount;
function getDuration(measureName) {
- return measures && measures[measureName] || 0;
+ return measures && measures.get(measureName) || 0;
}
performance.getDuration = getDuration;
function forEachMeasure(cb) {
- for (var key in measures) {
- cb(key, measures[key]);
- }
+ measures.forEach(function (measure, key) {
+ cb(key, measure);
+ });
}
performance.forEachMeasure = forEachMeasure;
function enable() {
@@ -132,22 +142,96 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- ts.version = "2.2.0-dev.20161127";
+ ts.version = "2.3.0-dev.20170419";
})(ts || (ts = {}));
(function (ts) {
- var createObject = Object.create;
- ts.collator = typeof Intl === "object" && typeof Intl.Collator === "function" ? new Intl.Collator() : undefined;
- function createMap(template) {
- var map = createObject(null);
+ ts.collator = typeof Intl === "object" && typeof Intl.Collator === "function" ? new Intl.Collator(undefined, { usage: "sort", sensitivity: "accent" }) : undefined;
+ ts.localeCompareIsCorrect = ts.collator && ts.collator.compare("a", "B") < 0;
+ function createDictionaryObject() {
+ var map = Object.create(null);
map["__"] = undefined;
delete map["__"];
+ return map;
+ }
+ function createMap() {
+ return new MapCtr();
+ }
+ ts.createMap = createMap;
+ function createMapFromTemplate(template) {
+ var map = new MapCtr();
for (var key in template)
if (hasOwnProperty.call(template, key)) {
- map[key] = template[key];
+ map.set(key, template[key]);
}
return map;
}
- ts.createMap = createMap;
+ ts.createMapFromTemplate = createMapFromTemplate;
+ var MapCtr = typeof Map !== "undefined" && "entries" in Map.prototype ? Map : shimMap();
+ function shimMap() {
+ var MapIterator = (function () {
+ function MapIterator(data, selector) {
+ this.index = 0;
+ this.data = data;
+ this.selector = selector;
+ this.keys = Object.keys(data);
+ }
+ MapIterator.prototype.next = function () {
+ var index = this.index;
+ if (index < this.keys.length) {
+ this.index++;
+ return { value: this.selector(this.data, this.keys[index]), done: false };
+ }
+ return { value: undefined, done: true };
+ };
+ return MapIterator;
+ }());
+ return (function () {
+ function class_1() {
+ this.data = createDictionaryObject();
+ this.size = 0;
+ }
+ class_1.prototype.get = function (key) {
+ return this.data[key];
+ };
+ class_1.prototype.set = function (key, value) {
+ if (!this.has(key)) {
+ this.size++;
+ }
+ this.data[key] = value;
+ return this;
+ };
+ class_1.prototype.has = function (key) {
+ return key in this.data;
+ };
+ class_1.prototype.delete = function (key) {
+ if (this.has(key)) {
+ this.size--;
+ delete this.data[key];
+ return true;
+ }
+ return false;
+ };
+ class_1.prototype.clear = function () {
+ this.data = createDictionaryObject();
+ this.size = 0;
+ };
+ class_1.prototype.keys = function () {
+ return new MapIterator(this.data, function (_data, key) { return key; });
+ };
+ class_1.prototype.values = function () {
+ return new MapIterator(this.data, function (data, key) { return data[key]; });
+ };
+ class_1.prototype.entries = function () {
+ return new MapIterator(this.data, function (data, key) { return [key, data[key]]; });
+ };
+ class_1.prototype.forEach = function (action) {
+ for (var key in this.data) {
+ action(this.data[key], key);
+ }
+ };
+ return class_1;
+ }());
+ }
function createFileMap(keyMapper) {
var files = createMap();
return {
@@ -160,32 +244,27 @@ var ts;
clear: clear,
};
function forEachValueInMap(f) {
- for (var key in files) {
- f(key, files[key]);
- }
+ files.forEach(function (file, key) {
+ f(key, file);
+ });
}
function getKeys() {
- var keys = [];
- for (var key in files) {
- keys.push(key);
- }
- return keys;
+ return arrayFrom(files.keys());
}
function get(path) {
- return files[toKey(path)];
+ return files.get(toKey(path));
}
function set(path, value) {
- files[toKey(path)] = value;
+ files.set(toKey(path), value);
}
function contains(path) {
- return toKey(path) in files;
+ return files.has(toKey(path));
}
function remove(path) {
- var key = toKey(path);
- delete files[key];
+ files.delete(toKey(path));
}
function clear() {
- files = createMap();
+ files.clear();
}
function toKey(path) {
return keyMapper ? keyMapper(path) : path;
@@ -199,9 +278,13 @@ var ts;
return getCanonicalFileName(nonCanonicalizedPath);
}
ts.toPath = toPath;
+ function length(array) {
+ return array ? array.length : 0;
+ }
+ ts.length = length;
function forEach(array, callback) {
if (array) {
- for (var i = 0, len = array.length; i < len; i++) {
+ for (var i = 0; i < array.length; i++) {
var result = callback(array[i], i);
if (result) {
return result;
@@ -211,6 +294,20 @@ var ts;
return undefined;
}
ts.forEach = forEach;
+ function findAncestor(node, callback) {
+ while (node) {
+ var result = callback(node);
+ if (result === "quit") {
+ return undefined;
+ }
+ else if (result) {
+ return node;
+ }
+ node = node.parent;
+ }
+ return undefined;
+ }
+ ts.findAncestor = findAncestor;
function zipWith(arrayA, arrayB, callback) {
Debug.assert(arrayA.length === arrayB.length);
for (var i = 0; i < arrayA.length; i++) {
@@ -220,7 +317,7 @@ var ts;
ts.zipWith = zipWith;
function every(array, callback) {
if (array) {
- for (var i = 0, len = array.length; i < len; i++) {
+ for (var i = 0; i < array.length; i++) {
if (!callback(array[i], i)) {
return false;
}
@@ -230,7 +327,7 @@ var ts;
}
ts.every = every;
function find(array, predicate) {
- for (var i = 0, len = array.length; i < len; i++) {
+ for (var i = 0; i < array.length; i++) {
var value = array[i];
if (predicate(value, i)) {
return value;
@@ -239,8 +336,17 @@ var ts;
return undefined;
}
ts.find = find;
+ function findIndex(array, predicate) {
+ for (var i = 0; i < array.length; i++) {
+ if (predicate(array[i], i)) {
+ return i;
+ }
+ }
+ return -1;
+ }
+ ts.findIndex = findIndex;
function findMap(array, callback) {
- for (var i = 0, len = array.length; i < len; i++) {
+ for (var i = 0; i < array.length; i++) {
var result = callback(array[i], i);
if (result) {
return result;
@@ -263,7 +369,7 @@ var ts;
ts.contains = contains;
function indexOf(array, value) {
if (array) {
- for (var i = 0, len = array.length; i < len; i++) {
+ for (var i = 0; i < array.length; i++) {
if (array[i] === value) {
return i;
}
@@ -273,7 +379,7 @@ var ts;
}
ts.indexOf = indexOf;
function indexOfAnyCharCode(text, charCodes, start) {
- for (var i = start || 0, len = text.length; i < len; i++) {
+ for (var i = start || 0; i < text.length; i++) {
if (contains(charCodes, text.charCodeAt(i))) {
return i;
}
@@ -460,21 +566,18 @@ var ts;
return result;
}
ts.spanMap = spanMap;
- function mapObject(object, f) {
- var result;
- if (object) {
- result = {};
- for (var _i = 0, _a = getOwnKeys(object); _i < _a.length; _i++) {
- var v = _a[_i];
- var _b = f(v, object[v]) || [undefined, undefined], key = _b[0], value = _b[1];
- if (key !== undefined) {
- result[key] = value;
- }
- }
+ function mapEntries(map, f) {
+ if (!map) {
+ return undefined;
}
+ var result = createMap();
+ map.forEach(function (value, key) {
+ var _a = f(key, value), newKey = _a[0], newValue = _a[1];
+ result.set(newKey, newValue);
+ });
return result;
}
- ts.mapObject = mapObject;
+ ts.mapEntries = mapEntries;
function some(array, predicate) {
if (array) {
if (predicate) {
@@ -758,38 +861,55 @@ var ts;
return keys;
}
ts.getOwnKeys = getOwnKeys;
- function forEachProperty(map, callback) {
- var result;
- for (var key in map) {
- if (result = callback(map[key], key))
- break;
+ function arrayFrom(iterator, map) {
+ var result = [];
+ for (var _a = iterator.next(), value = _a.value, done = _a.done; !done; _b = iterator.next(), value = _b.value, done = _b.done, _b) {
+ result.push(map ? map(value) : value);
}
return result;
+ var _b;
}
- ts.forEachProperty = forEachProperty;
- function someProperties(map, predicate) {
- for (var key in map) {
- if (!predicate || predicate(map[key], key))
- return true;
+ ts.arrayFrom = arrayFrom;
+ function convertToArray(iterator, f) {
+ var result = [];
+ for (var _a = iterator.next(), value = _a.value, done = _a.done; !done; _b = iterator.next(), value = _b.value, done = _b.done, _b) {
+ result.push(f(value));
}
- return false;
+ return result;
+ var _b;
}
- ts.someProperties = someProperties;
- function copyProperties(source, target) {
- for (var key in source) {
- target[key] = source[key];
+ ts.convertToArray = convertToArray;
+ function forEachEntry(map, callback) {
+ var iterator = map.entries();
+ for (var _a = iterator.next(), pair = _a.value, done = _a.done; !done; _b = iterator.next(), pair = _b.value, done = _b.done, _b) {
+ var key = pair[0], value = pair[1];
+ var result = callback(value, key);
+ if (result) {
+ return result;
+ }
}
+ return undefined;
+ var _b;
}
- ts.copyProperties = copyProperties;
- function appendProperty(map, key, value) {
- if (key === undefined || value === undefined)
- return map;
- if (map === undefined)
- map = createMap();
- map[key] = value;
- return map;
+ ts.forEachEntry = forEachEntry;
+ function forEachKey(map, callback) {
+ var iterator = map.keys();
+ for (var _a = iterator.next(), key = _a.value, done = _a.done; !done; _b = iterator.next(), key = _b.value, done = _b.done, _b) {
+ var result = callback(key);
+ if (result) {
+ return result;
+ }
+ }
+ return undefined;
+ var _b;
}
- ts.appendProperty = appendProperty;
+ ts.forEachKey = forEachKey;
+ function copyEntries(source, target) {
+ source.forEach(function (value, key) {
+ target.set(key, value);
+ });
+ }
+ ts.copyEntries = copyEntries;
function assign(t) {
var args = [];
for (var _i = 1; _i < arguments.length; _i++) {
@@ -797,31 +917,14 @@ var ts;
}
for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
var arg = args_1[_a];
- for (var _b = 0, _c = getOwnKeys(arg); _b < _c.length; _b++) {
- var p = _c[_b];
- t[p] = arg[p];
- }
+ for (var p in arg)
+ if (hasProperty(arg, p)) {
+ t[p] = arg[p];
+ }
}
return t;
}
ts.assign = assign;
- function reduceProperties(map, callback, initial) {
- var result = initial;
- for (var key in map) {
- result = callback(result, map[key], String(key));
- }
- return result;
- }
- ts.reduceProperties = reduceProperties;
- function reduceOwnProperties(map, callback, initial) {
- var result = initial;
- for (var key in map)
- if (hasOwnProperty.call(map, key)) {
- result = callback(result, map[key], String(key));
- }
- return result;
- }
- ts.reduceOwnProperties = reduceOwnProperties;
function equalOwnProperties(left, right, equalityComparer) {
if (left === right)
return true;
@@ -846,23 +949,14 @@ var ts;
var result = createMap();
for (var _i = 0, array_8 = array; _i < array_8.length; _i++) {
var value = array_8[_i];
- result[makeKey(value)] = makeValue ? makeValue(value) : value;
+ result.set(makeKey(value), makeValue ? makeValue(value) : value);
}
return result;
}
ts.arrayToMap = arrayToMap;
- function isEmpty(map) {
- for (var id in map) {
- if (hasProperty(map, id)) {
- return false;
- }
- }
- return true;
- }
- ts.isEmpty = isEmpty;
function cloneMap(map) {
var clone = createMap();
- copyProperties(map, clone);
+ copyEntries(map, clone);
return clone;
}
ts.cloneMap = cloneMap;
@@ -889,27 +983,32 @@ var ts;
return result;
}
ts.extend = extend;
- function multiMapAdd(map, key, value) {
- var values = map[key];
+ function createMultiMap() {
+ var map = createMap();
+ map.add = multiMapAdd;
+ map.remove = multiMapRemove;
+ return map;
+ }
+ ts.createMultiMap = createMultiMap;
+ function multiMapAdd(key, value) {
+ var values = this.get(key);
if (values) {
values.push(value);
- return values;
}
else {
- return map[key] = [value];
+ this.set(key, values = [value]);
}
+ return values;
}
- ts.multiMapAdd = multiMapAdd;
- function multiMapRemove(map, key, value) {
- var values = map[key];
+ function multiMapRemove(key, value) {
+ var values = this.get(key);
if (values) {
unorderedRemoveItem(values, value);
if (!values.length) {
- delete map[key];
+ this.delete(key);
}
}
}
- ts.multiMapRemove = multiMapRemove;
function isArray(value) {
return Array.isArray ? Array.isArray(value) : value instanceof Array;
}
@@ -985,6 +1084,7 @@ var ts;
baseIndex = baseIndex || 0;
return text.replace(/{(\d+)}/g, function (_match, index) { return args[+index + baseIndex]; });
}
+ ts.formatStringFromArgs = formatStringFromArgs;
ts.localizedDiagnosticMessages = undefined;
function getLocaleSpecificMessage(message) {
return ts.localizedDiagnosticMessages && ts.localizedDiagnosticMessages[message.key] || message.message;
@@ -1086,8 +1186,10 @@ var ts;
if (b === undefined)
return 1;
if (ignoreCase) {
- if (ts.collator && String.prototype.localeCompare) {
- var result = a.localeCompare(b, undefined, { usage: "sort", sensitivity: "accent" });
+ if (ts.collator) {
+ var result = ts.localeCompareIsCorrect ?
+ ts.collator.compare(a, b) :
+ a.localeCompare(b, undefined, { usage: "sort", sensitivity: "accent" });
return result < 0 ? -1 : result > 0 ? 1 : 0;
}
a = a.toUpperCase();
@@ -1469,36 +1571,26 @@ var ts;
var singleAsteriskRegexFragmentFiles = "([^./]|(\\.(?!min\\.js$))?)*";
var singleAsteriskRegexFragmentOther = "[^/]*";
function getRegularExpressionForWildcard(specs, basePath, usage) {
+ var patterns = getRegularExpressionsForWildcards(specs, basePath, usage);
+ if (!patterns || !patterns.length) {
+ return undefined;
+ }
+ var pattern = patterns.map(function (pattern) { return "(" + pattern + ")"; }).join("|");
+ var terminator = usage === "exclude" ? "($|/)" : "$";
+ return "^(" + pattern + ")" + terminator;
+ }
+ ts.getRegularExpressionForWildcard = getRegularExpressionForWildcard;
+ function getRegularExpressionsForWildcards(specs, basePath, usage) {
if (specs === undefined || specs.length === 0) {
return undefined;
}
var replaceWildcardCharacter = usage === "files" ? replaceWildCardCharacterFiles : replaceWildCardCharacterOther;
var singleAsteriskRegexFragment = usage === "files" ? singleAsteriskRegexFragmentFiles : singleAsteriskRegexFragmentOther;
var doubleAsteriskRegexFragment = usage === "exclude" ? "(/.+?)?" : "(/[^/.][^/]*)*?";
- var pattern = "";
- var hasWrittenSubpattern = false;
- for (var _i = 0, specs_1 = specs; _i < specs_1.length; _i++) {
- var spec = specs_1[_i];
- if (!spec) {
- continue;
- }
- var subPattern = getSubPatternFromSpec(spec, basePath, usage, singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter);
- if (subPattern === undefined) {
- continue;
- }
- if (hasWrittenSubpattern) {
- pattern += "|";
- }
- pattern += "(" + subPattern + ")";
- hasWrittenSubpattern = true;
- }
- if (!pattern) {
- return undefined;
- }
- var terminator = usage === "exclude" ? "($|/)" : "$";
- return "^(" + pattern + ")" + terminator;
+ return flatMap(specs, function (spec) {
+ return spec && getSubPatternFromSpec(spec, basePath, usage, singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter);
+ });
}
- ts.getRegularExpressionForWildcard = getRegularExpressionForWildcard;
function isImplicitGlob(lastPathComponent) {
return !/[.*?]/.test(lastPathComponent);
}
@@ -1568,6 +1660,7 @@ var ts;
currentDirectory = normalizePath(currentDirectory);
var absolutePath = combinePaths(currentDirectory, path);
return {
+ includeFilePatterns: map(getRegularExpressionsForWildcards(includes, absolutePath, "files"), function (pattern) { return "^" + pattern + "$"; }),
includeFilePattern: getRegularExpressionForWildcard(includes, absolutePath, "files"),
includeDirectoryPattern: getRegularExpressionForWildcard(includes, absolutePath, "directories"),
excludePattern: getRegularExpressionForWildcard(excludes, absolutePath, "exclude"),
@@ -1580,34 +1673,48 @@ var ts;
currentDirectory = normalizePath(currentDirectory);
var patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory);
var regexFlag = useCaseSensitiveFileNames ? "" : "i";
- var includeFileRegex = patterns.includeFilePattern && new RegExp(patterns.includeFilePattern, regexFlag);
+ var includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map(function (pattern) { return new RegExp(pattern, regexFlag); });
var includeDirectoryRegex = patterns.includeDirectoryPattern && new RegExp(patterns.includeDirectoryPattern, regexFlag);
var excludeRegex = patterns.excludePattern && new RegExp(patterns.excludePattern, regexFlag);
- var result = [];
+ var results = includeFileRegexes ? includeFileRegexes.map(function () { return []; }) : [[]];
+ var comparer = useCaseSensitiveFileNames ? compareStrings : compareStringsCaseInsensitive;
for (var _i = 0, _a = patterns.basePaths; _i < _a.length; _i++) {
var basePath = _a[_i];
visitDirectory(basePath, combinePaths(currentDirectory, basePath));
}
- return result;
+ return flatten(results);
function visitDirectory(path, absolutePath) {
var _a = getFileSystemEntries(path), files = _a.files, directories = _a.directories;
- for (var _i = 0, files_1 = files; _i < files_1.length; _i++) {
- var current = files_1[_i];
- var name_1 = combinePaths(path, current);
+ files = files.slice().sort(comparer);
+ directories = directories.slice().sort(comparer);
+ var _loop_1 = function (current) {
+ var name = combinePaths(path, current);
var absoluteName = combinePaths(absolutePath, current);
- if ((!extensions || fileExtensionIsAny(name_1, extensions)) &&
- (!includeFileRegex || includeFileRegex.test(absoluteName)) &&
- (!excludeRegex || !excludeRegex.test(absoluteName))) {
- result.push(name_1);
+ if (extensions && !fileExtensionIsAny(name, extensions))
+ return "continue";
+ if (excludeRegex && excludeRegex.test(absoluteName))
+ return "continue";
+ if (!includeFileRegexes) {
+ results[0].push(name);
+ }
+ else {
+ var includeIndex = findIndex(includeFileRegexes, function (re) { return re.test(absoluteName); });
+ if (includeIndex !== -1) {
+ results[includeIndex].push(name);
+ }
}
+ };
+ for (var _i = 0, files_1 = files; _i < files_1.length; _i++) {
+ var current = files_1[_i];
+ _loop_1(current);
}
for (var _b = 0, directories_1 = directories; _b < directories_1.length; _b++) {
var current = directories_1[_b];
- var name_2 = combinePaths(path, current);
+ var name = combinePaths(path, current);
var absoluteName = combinePaths(absolutePath, current);
if ((!includeDirectoryRegex || includeDirectoryRegex.test(absoluteName)) &&
(!excludeRegex || !excludeRegex.test(absoluteName))) {
- visitDirectory(name_2, absoluteName);
+ visitDirectory(name, absoluteName);
}
}
}
@@ -1623,14 +1730,14 @@ var ts;
includeBasePaths.push(getIncludeBasePath(absolute));
}
includeBasePaths.sort(useCaseSensitiveFileNames ? compareStrings : compareStringsCaseInsensitive);
- var _loop_1 = function (includeBasePath) {
+ var _loop_2 = function (includeBasePath) {
if (ts.every(basePaths, function (basePath) { return !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames); })) {
basePaths.push(includeBasePath);
}
};
for (var _a = 0, includeBasePaths_1 = includeBasePaths; _a < includeBasePaths_1.length; _a++) {
var includeBasePath = includeBasePaths_1[_a];
- _loop_1(includeBasePath);
+ _loop_2(includeBasePath);
}
}
return basePaths;
@@ -1668,8 +1775,19 @@ var ts;
ts.supportedTypescriptExtensionsForExtractExtension = [".d.ts", ".ts", ".tsx"];
ts.supportedJavascriptExtensions = [".js", ".jsx"];
var allSupportedExtensions = ts.supportedTypeScriptExtensions.concat(ts.supportedJavascriptExtensions);
- function getSupportedExtensions(options) {
- return options && options.allowJs ? allSupportedExtensions : ts.supportedTypeScriptExtensions;
+ function getSupportedExtensions(options, extraFileExtensions) {
+ var needAllExtensions = options && options.allowJs;
+ if (!extraFileExtensions || extraFileExtensions.length === 0 || !needAllExtensions) {
+ return needAllExtensions ? allSupportedExtensions : ts.supportedTypeScriptExtensions;
+ }
+ var extensions = allSupportedExtensions.slice(0);
+ for (var _i = 0, extraFileExtensions_1 = extraFileExtensions; _i < extraFileExtensions_1.length; _i++) {
+ var extInfo = extraFileExtensions_1[_i];
+ if (extensions.indexOf(extInfo.extension) === -1) {
+ extensions.push(extInfo.extension);
+ }
+ }
+ return extensions;
}
ts.getSupportedExtensions = getSupportedExtensions;
function hasJavaScriptFileExtension(fileName) {
@@ -1680,11 +1798,11 @@ var ts;
return forEach(ts.supportedTypeScriptExtensions, function (extension) { return fileExtensionIs(fileName, extension); });
}
ts.hasTypeScriptFileExtension = hasTypeScriptFileExtension;
- function isSupportedSourceFileName(fileName, compilerOptions) {
+ function isSupportedSourceFileName(fileName, compilerOptions, extraFileExtensions) {
if (!fileName) {
return false;
}
- for (var _i = 0, _a = getSupportedExtensions(compilerOptions); _i < _a.length; _i++) {
+ for (var _i = 0, _a = getSupportedExtensions(compilerOptions, extraFileExtensions); _i < _a.length; _i++) {
var extension = _a[_i];
if (fileExtensionIs(fileName, extension)) {
return true;
@@ -1696,30 +1814,30 @@ var ts;
function getExtensionPriority(path, supportedExtensions) {
for (var i = supportedExtensions.length - 1; i >= 0; i--) {
if (fileExtensionIs(path, supportedExtensions[i])) {
- return adjustExtensionPriority(i);
+ return adjustExtensionPriority(i, supportedExtensions);
}
}
return 0;
}
ts.getExtensionPriority = getExtensionPriority;
- function adjustExtensionPriority(extensionPriority) {
+ function adjustExtensionPriority(extensionPriority, supportedExtensions) {
if (extensionPriority < 2) {
return 0;
}
- else if (extensionPriority < 5) {
+ else if (extensionPriority < supportedExtensions.length) {
return 2;
}
else {
- return 5;
+ return supportedExtensions.length;
}
}
ts.adjustExtensionPriority = adjustExtensionPriority;
- function getNextLowestExtensionPriority(extensionPriority) {
+ function getNextLowestExtensionPriority(extensionPriority, supportedExtensions) {
if (extensionPriority < 2) {
return 2;
}
else {
- return 5;
+ return supportedExtensions.length;
}
}
ts.getNextLowestExtensionPriority = getNextLowestExtensionPriority;
@@ -1928,136 +2046,29 @@ var ts;
}
}
ts.tryGetExtensionFromPath = tryGetExtensionFromPath;
+ function isCheckJsEnabledForFile(sourceFile, compilerOptions) {
+ return sourceFile.checkJsDirective ? sourceFile.checkJsDirective.enabled : compilerOptions.checkJs;
+ }
+ ts.isCheckJsEnabledForFile = isCheckJsEnabledForFile;
})(ts || (ts = {}));
var ts;
(function (ts) {
- ts.sys = (function () {
- function getWScriptSystem() {
- var fso = new ActiveXObject("Scripting.FileSystemObject");
- var shell = new ActiveXObject("WScript.Shell");
- var fileStream = new ActiveXObject("ADODB.Stream");
- fileStream.Type = 2;
- var binaryStream = new ActiveXObject("ADODB.Stream");
- binaryStream.Type = 1;
- var args = [];
- for (var i = 0; i < WScript.Arguments.length; i++) {
- args[i] = WScript.Arguments.Item(i);
- }
- function readFile(fileName, encoding) {
- if (!fso.FileExists(fileName)) {
- return undefined;
- }
- fileStream.Open();
- try {
- if (encoding) {
- fileStream.Charset = encoding;
- fileStream.LoadFromFile(fileName);
- }
- else {
- fileStream.Charset = "x-ansi";
- fileStream.LoadFromFile(fileName);
- var bom = fileStream.ReadText(2) || "";
- fileStream.Position = 0;
- fileStream.Charset = bom.length >= 2 && (bom.charCodeAt(0) === 0xFF && bom.charCodeAt(1) === 0xFE || bom.charCodeAt(0) === 0xFE && bom.charCodeAt(1) === 0xFF) ? "unicode" : "utf-8";
- }
- return fileStream.ReadText();
- }
- catch (e) {
- throw e;
- }
- finally {
- fileStream.Close();
- }
- }
- function writeFile(fileName, data, writeByteOrderMark) {
- fileStream.Open();
- binaryStream.Open();
- try {
- fileStream.Charset = "utf-8";
- fileStream.WriteText(data);
- if (writeByteOrderMark) {
- fileStream.Position = 0;
- }
- else {
- fileStream.Position = 3;
- }
- fileStream.CopyTo(binaryStream);
- binaryStream.SaveToFile(fileName, 2);
- }
- finally {
- binaryStream.Close();
- fileStream.Close();
- }
- }
- function getNames(collection) {
- var result = [];
- for (var e = new Enumerator(collection); !e.atEnd(); e.moveNext()) {
- result.push(e.item().Name);
- }
- return result.sort();
- }
- function getDirectories(path) {
- var folder = fso.GetFolder(path);
- return getNames(folder.subfolders);
- }
- function getAccessibleFileSystemEntries(path) {
- try {
- var folder = fso.GetFolder(path || ".");
- var files = getNames(folder.files);
- var directories = getNames(folder.subfolders);
- return { files: files, directories: directories };
- }
- catch (e) {
- return { files: [], directories: [] };
- }
- }
- function readDirectory(path, extensions, excludes, includes) {
- return ts.matchFiles(path, extensions, excludes, includes, false, shell.CurrentDirectory, getAccessibleFileSystemEntries);
- }
- var wscriptSystem = {
- args: args,
- newLine: "\r\n",
- useCaseSensitiveFileNames: false,
- write: function (s) {
- WScript.StdOut.Write(s);
- },
- readFile: readFile,
- writeFile: writeFile,
- resolvePath: function (path) {
- return fso.GetAbsolutePathName(path);
- },
- fileExists: function (path) {
- return fso.FileExists(path);
- },
- directoryExists: function (path) {
- return fso.FolderExists(path);
- },
- createDirectory: function (directoryName) {
- if (!wscriptSystem.directoryExists(directoryName)) {
- fso.CreateFolder(directoryName);
- }
- },
- getExecutingFilePath: function () {
- return WScript.ScriptFullName;
- },
- getCurrentDirectory: function () {
- return shell.CurrentDirectory;
- },
- getDirectories: getDirectories,
- getEnvironmentVariable: function (name) {
- return new ActiveXObject("WScript.Shell").ExpandEnvironmentStrings("%" + name + "%");
- },
- readDirectory: readDirectory,
- exit: function (exitCode) {
- try {
- WScript.Quit(exitCode);
- }
- catch (e) {
- }
- }
- };
- return wscriptSystem;
+ function getNodeMajorVersion() {
+ if (typeof process === "undefined") {
+ return undefined;
+ }
+ var version = process.version;
+ if (!version) {
+ return undefined;
+ }
+ var dot = version.indexOf(".");
+ if (dot === -1) {
+ return undefined;
}
+ return parseInt(version.substring(1, dot));
+ }
+ ts.getNodeMajorVersion = getNodeMajorVersion;
+ ts.sys = (function () {
function getNodeSystem() {
var _fs = require("fs");
var _path = require("path");
@@ -2066,32 +2077,32 @@ var ts;
var useNonPollingWatchers = process.env["TSC_NONPOLLING_WATCHER"];
function createWatchedFileSet() {
var dirWatchers = ts.createMap();
- var fileWatcherCallbacks = ts.createMap();
+ var fileWatcherCallbacks = ts.createMultiMap();
return { addFile: addFile, removeFile: removeFile };
function reduceDirWatcherRefCountForFile(fileName) {
var dirName = ts.getDirectoryPath(fileName);
- var watcher = dirWatchers[dirName];
+ var watcher = dirWatchers.get(dirName);
if (watcher) {
watcher.referenceCount -= 1;
if (watcher.referenceCount <= 0) {
watcher.close();
- delete dirWatchers[dirName];
+ dirWatchers.delete(dirName);
}
}
}
function addDirWatcher(dirPath) {
- var watcher = dirWatchers[dirPath];
+ var watcher = dirWatchers.get(dirPath);
if (watcher) {
watcher.referenceCount += 1;
return;
}
watcher = _fs.watch(dirPath, { persistent: true }, function (eventName, relativeFileName) { return fileEventHandler(eventName, relativeFileName, dirPath); });
watcher.referenceCount = 1;
- dirWatchers[dirPath] = watcher;
+ dirWatchers.set(dirPath, watcher);
return;
}
function addFileWatcherCallback(filePath, callback) {
- ts.multiMapAdd(fileWatcherCallbacks, filePath, callback);
+ fileWatcherCallbacks.add(filePath, callback);
}
function addFile(fileName, callback) {
addFileWatcherCallback(fileName, callback);
@@ -2103,24 +2114,26 @@ var ts;
reduceDirWatcherRefCountForFile(watchedFile.fileName);
}
function removeFileWatcherCallback(filePath, callback) {
- ts.multiMapRemove(fileWatcherCallbacks, filePath, callback);
+ fileWatcherCallbacks.remove(filePath, callback);
}
function fileEventHandler(eventName, relativeFileName, baseDirPath) {
var fileName = typeof relativeFileName !== "string"
? undefined
: ts.getNormalizedAbsolutePath(relativeFileName, baseDirPath);
- if ((eventName === "change" || eventName === "rename") && fileWatcherCallbacks[fileName]) {
- for (var _i = 0, _a = fileWatcherCallbacks[fileName]; _i < _a.length; _i++) {
- var fileCallback = _a[_i];
- fileCallback(fileName);
+ if ((eventName === "change" || eventName === "rename")) {
+ var callbacks = fileWatcherCallbacks.get(fileName);
+ if (callbacks) {
+ for (var _i = 0, callbacks_1 = callbacks; _i < callbacks_1.length; _i++) {
+ var fileCallback = callbacks_1[_i];
+ fileCallback(fileName);
+ }
}
}
}
}
var watchedFileSet = createWatchedFileSet();
- function isNode4OrLater() {
- return parseInt(process.version.charAt(1)) >= 4;
- }
+ var nodeVersion = getNodeMajorVersion();
+ var isNode4OrLater = nodeVersion >= 4;
function isFileSystemCaseSensitive() {
if (platform === "win32" || platform === "win64") {
return false;
@@ -2177,10 +2190,10 @@ var ts;
if (entry === "." || entry === "..") {
continue;
}
- var name_3 = ts.combinePaths(path, entry);
+ var name = ts.combinePaths(path, entry);
var stat = void 0;
try {
- stat = _fs.statSync(name_3);
+ stat = _fs.statSync(name);
}
catch (e) {
continue;
@@ -2257,7 +2270,7 @@ var ts;
if (!directoryExists(directoryName)) {
return noOpFileWatcher;
}
- if (isNode4OrLater() && (process.platform === "win32" || process.platform === "darwin")) {
+ if (isNode4OrLater && (process.platform === "win32" || process.platform === "darwin")) {
options = { persistent: true, recursive: !!recursive };
}
else {
@@ -2267,7 +2280,6 @@ var ts;
if (eventName === "rename") {
callback(!relativeFileName ? relativeFileName : ts.normalizePath(ts.combinePaths(directoryName, relativeFileName)));
}
- ;
});
},
resolvePath: function (path) {
@@ -2384,9 +2396,6 @@ var ts;
if (typeof ChakraHost !== "undefined") {
sys = getChakraSystem();
}
- else if (typeof WScript !== "undefined" && typeof ActiveXObject === "function") {
- sys = getWScriptSystem();
- }
else if (typeof process !== "undefined" && process.nextTick && !process.browser && typeof require !== "undefined") {
sys = getNodeSystem();
}
@@ -2455,11 +2464,11 @@ var ts;
Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value: { code: 1055, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Prom_1055", message: "Type '{0}' is not a valid async function return type in ES5/ES3 because it does not refer to a Promise-compatible constructor value." },
Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher: { code: 1056, category: ts.DiagnosticCategory.Error, key: "Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher_1056", message: "Accessors are only available when targeting ECMAScript 5 and higher." },
An_async_function_or_method_must_have_a_valid_awaitable_return_type: { code: 1057, category: ts.DiagnosticCategory.Error, key: "An_async_function_or_method_must_have_a_valid_awaitable_return_type_1057", message: "An async function or method must have a valid awaitable return type." },
- Operand_for_await_does_not_have_a_valid_callable_then_member: { code: 1058, category: ts.DiagnosticCategory.Error, key: "Operand_for_await_does_not_have_a_valid_callable_then_member_1058", message: "Operand for 'await' does not have a valid callable 'then' member." },
- Return_expression_in_async_function_does_not_have_a_valid_callable_then_member: { code: 1059, category: ts.DiagnosticCategory.Error, key: "Return_expression_in_async_function_does_not_have_a_valid_callable_then_member_1059", message: "Return expression in async function does not have a valid callable 'then' member." },
- Expression_body_for_async_arrow_function_does_not_have_a_valid_callable_then_member: { code: 1060, category: ts.DiagnosticCategory.Error, key: "Expression_body_for_async_arrow_function_does_not_have_a_valid_callable_then_member_1060", message: "Expression body for async arrow function does not have a valid callable 'then' member." },
+ The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: { code: 1058, category: ts.DiagnosticCategory.Error, key: "The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_t_1058", message: "The return type of an async function must either be a valid promise or must not contain a callable 'then' member." },
+ A_promise_must_have_a_then_method: { code: 1059, category: ts.DiagnosticCategory.Error, key: "A_promise_must_have_a_then_method_1059", message: "A promise must have a 'then' method." },
+ The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback: { code: 1060, category: ts.DiagnosticCategory.Error, key: "The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback_1060", message: "The first parameter of the 'then' method of a promise must be a callback." },
Enum_member_must_have_initializer: { code: 1061, category: ts.DiagnosticCategory.Error, key: "Enum_member_must_have_initializer_1061", message: "Enum member must have initializer." },
- _0_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method: { code: 1062, category: ts.DiagnosticCategory.Error, key: "_0_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method_1062", message: "{0} is referenced directly or indirectly in the fulfillment callback of its own 'then' method." },
+ Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method: { code: 1062, category: ts.DiagnosticCategory.Error, key: "Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method_1062", message: "Type is referenced directly or indirectly in the fulfillment callback of its own 'then' method." },
An_export_assignment_cannot_be_used_in_a_namespace: { code: 1063, category: ts.DiagnosticCategory.Error, key: "An_export_assignment_cannot_be_used_in_a_namespace_1063", message: "An export assignment cannot be used in a namespace." },
The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type: { code: 1064, category: ts.DiagnosticCategory.Error, key: "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_1064", message: "The return type of an async function or method must be the global Promise<T> type." },
In_ambient_enum_declarations_member_initializer_must_be_constant_expression: { code: 1066, category: ts.DiagnosticCategory.Error, key: "In_ambient_enum_declarations_member_initializer_must_be_constant_expression_1066", message: "In ambient enum declarations member initializer must be constant expression." },
@@ -2468,7 +2477,7 @@ var ts;
_0_modifier_cannot_appear_on_an_index_signature: { code: 1071, category: ts.DiagnosticCategory.Error, key: "_0_modifier_cannot_appear_on_an_index_signature_1071", message: "'{0}' modifier cannot appear on an index signature." },
A_0_modifier_cannot_be_used_with_an_import_declaration: { code: 1079, category: ts.DiagnosticCategory.Error, key: "A_0_modifier_cannot_be_used_with_an_import_declaration_1079", message: "A '{0}' modifier cannot be used with an import declaration." },
Invalid_reference_directive_syntax: { code: 1084, category: ts.DiagnosticCategory.Error, key: "Invalid_reference_directive_syntax_1084", message: "Invalid 'reference' directive syntax." },
- Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher: { code: 1085, category: ts.DiagnosticCategory.Error, key: "Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher_1085", message: "Octal literals are not available when targeting ECMAScript 5 and higher." },
+ Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher_Use_the_syntax_0: { code: 1085, category: ts.DiagnosticCategory.Error, key: "Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher_Use_the_syntax_0_1085", message: "Octal literals are not available when targeting ECMAScript 5 and higher. Use the syntax '{0}'." },
An_accessor_cannot_be_declared_in_an_ambient_context: { code: 1086, category: ts.DiagnosticCategory.Error, key: "An_accessor_cannot_be_declared_in_an_ambient_context_1086", message: "An accessor cannot be declared in an ambient context." },
_0_modifier_cannot_appear_on_a_constructor_declaration: { code: 1089, category: ts.DiagnosticCategory.Error, key: "_0_modifier_cannot_appear_on_a_constructor_declaration_1089", message: "'{0}' modifier cannot appear on a constructor declaration." },
_0_modifier_cannot_appear_on_a_parameter: { code: 1090, category: ts.DiagnosticCategory.Error, key: "_0_modifier_cannot_appear_on_a_parameter_1090", message: "'{0}' modifier cannot appear on a parameter." },
@@ -2484,6 +2493,7 @@ var ts;
Invalid_use_of_0_in_strict_mode: { code: 1100, category: ts.DiagnosticCategory.Error, key: "Invalid_use_of_0_in_strict_mode_1100", message: "Invalid use of '{0}' in strict mode." },
with_statements_are_not_allowed_in_strict_mode: { code: 1101, category: ts.DiagnosticCategory.Error, key: "with_statements_are_not_allowed_in_strict_mode_1101", message: "'with' statements are not allowed in strict mode." },
delete_cannot_be_called_on_an_identifier_in_strict_mode: { code: 1102, category: ts.DiagnosticCategory.Error, key: "delete_cannot_be_called_on_an_identifier_in_strict_mode_1102", message: "'delete' cannot be called on an identifier in strict mode." },
+ A_for_await_of_statement_is_only_allowed_within_an_async_function_or_async_generator: { code: 1103, category: ts.DiagnosticCategory.Error, key: "A_for_await_of_statement_is_only_allowed_within_an_async_function_or_async_generator_1103", message: "A 'for-await-of' statement is only allowed within an async function or async generator." },
A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement: { code: 1104, category: ts.DiagnosticCategory.Error, key: "A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement_1104", message: "A 'continue' statement can only be used within an enclosing iteration statement." },
A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement: { code: 1105, category: ts.DiagnosticCategory.Error, key: "A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement_1105", message: "A 'break' statement can only be used within an enclosing iteration or switch statement." },
Jump_target_cannot_cross_function_boundary: { code: 1107, category: ts.DiagnosticCategory.Error, key: "Jump_target_cannot_cross_function_boundary_1107", message: "Jump target cannot cross function boundary." },
@@ -2491,7 +2501,7 @@ var ts;
Expression_expected: { code: 1109, category: ts.DiagnosticCategory.Error, key: "Expression_expected_1109", message: "Expression expected." },
Type_expected: { code: 1110, category: ts.DiagnosticCategory.Error, key: "Type_expected_1110", message: "Type expected." },
A_default_clause_cannot_appear_more_than_once_in_a_switch_statement: { code: 1113, category: ts.DiagnosticCategory.Error, key: "A_default_clause_cannot_appear_more_than_once_in_a_switch_statement_1113", message: "A 'default' clause cannot appear more than once in a 'switch' statement." },
- Duplicate_label_0: { code: 1114, category: ts.DiagnosticCategory.Error, key: "Duplicate_label_0_1114", message: "Duplicate label '{0}'" },
+ Duplicate_label_0: { code: 1114, category: ts.DiagnosticCategory.Error, key: "Duplicate_label_0_1114", message: "Duplicate label '{0}'." },
A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement: { code: 1115, category: ts.DiagnosticCategory.Error, key: "A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement_1115", message: "A 'continue' statement can only jump to a label of an enclosing iteration statement." },
A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement: { code: 1116, category: ts.DiagnosticCategory.Error, key: "A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement_1116", message: "A 'break' statement can only jump to a label of an enclosing statement." },
An_object_literal_cannot_have_multiple_properties_with_the_same_name_in_strict_mode: { code: 1117, category: ts.DiagnosticCategory.Error, key: "An_object_literal_cannot_have_multiple_properties_with_the_same_name_in_strict_mode_1117", message: "An object literal cannot have multiple properties with the same name in strict mode." },
@@ -2523,9 +2533,9 @@ var ts;
Declaration_expected: { code: 1146, category: ts.DiagnosticCategory.Error, key: "Declaration_expected_1146", message: "Declaration expected." },
Import_declarations_in_a_namespace_cannot_reference_a_module: { code: 1147, category: ts.DiagnosticCategory.Error, key: "Import_declarations_in_a_namespace_cannot_reference_a_module_1147", message: "Import declarations in a namespace cannot reference a module." },
Cannot_use_imports_exports_or_module_augmentations_when_module_is_none: { code: 1148, category: ts.DiagnosticCategory.Error, key: "Cannot_use_imports_exports_or_module_augmentations_when_module_is_none_1148", message: "Cannot use imports, exports, or module augmentations when '--module' is 'none'." },
- File_name_0_differs_from_already_included_file_name_1_only_in_casing: { code: 1149, category: ts.DiagnosticCategory.Error, key: "File_name_0_differs_from_already_included_file_name_1_only_in_casing_1149", message: "File name '{0}' differs from already included file name '{1}' only in casing" },
+ File_name_0_differs_from_already_included_file_name_1_only_in_casing: { code: 1149, category: ts.DiagnosticCategory.Error, key: "File_name_0_differs_from_already_included_file_name_1_only_in_casing_1149", message: "File name '{0}' differs from already included file name '{1}' only in casing." },
new_T_cannot_be_used_to_create_an_array_Use_new_Array_T_instead: { code: 1150, category: ts.DiagnosticCategory.Error, key: "new_T_cannot_be_used_to_create_an_array_Use_new_Array_T_instead_1150", message: "'new T[]' cannot be used to create an array. Use 'new Array<T>()' instead." },
- const_declarations_must_be_initialized: { code: 1155, category: ts.DiagnosticCategory.Error, key: "const_declarations_must_be_initialized_1155", message: "'const' declarations must be initialized" },
+ const_declarations_must_be_initialized: { code: 1155, category: ts.DiagnosticCategory.Error, key: "const_declarations_must_be_initialized_1155", message: "'const' declarations must be initialized." },
const_declarations_can_only_be_declared_inside_a_block: { code: 1156, category: ts.DiagnosticCategory.Error, key: "const_declarations_can_only_be_declared_inside_a_block_1156", message: "'const' declarations can only be declared inside a block." },
let_declarations_can_only_be_declared_inside_a_block: { code: 1157, category: ts.DiagnosticCategory.Error, key: "let_declarations_can_only_be_declared_inside_a_block_1157", message: "'let' declarations can only be declared inside a block." },
Unterminated_template_literal: { code: 1160, category: ts.DiagnosticCategory.Error, key: "Unterminated_template_literal_1160", message: "Unterminated template literal." },
@@ -2574,11 +2584,12 @@ var ts;
Cannot_compile_namespaces_when_the_isolatedModules_flag_is_provided: { code: 1208, category: ts.DiagnosticCategory.Error, key: "Cannot_compile_namespaces_when_the_isolatedModules_flag_is_provided_1208", message: "Cannot compile namespaces when the '--isolatedModules' flag is provided." },
Ambient_const_enums_are_not_allowed_when_the_isolatedModules_flag_is_provided: { code: 1209, category: ts.DiagnosticCategory.Error, key: "Ambient_const_enums_are_not_allowed_when_the_isolatedModules_flag_is_provided_1209", message: "Ambient const enums are not allowed when the '--isolatedModules' flag is provided." },
Invalid_use_of_0_Class_definitions_are_automatically_in_strict_mode: { code: 1210, category: ts.DiagnosticCategory.Error, key: "Invalid_use_of_0_Class_definitions_are_automatically_in_strict_mode_1210", message: "Invalid use of '{0}'. Class definitions are automatically in strict mode." },
- A_class_declaration_without_the_default_modifier_must_have_a_name: { code: 1211, category: ts.DiagnosticCategory.Error, key: "A_class_declaration_without_the_default_modifier_must_have_a_name_1211", message: "A class declaration without the 'default' modifier must have a name" },
- Identifier_expected_0_is_a_reserved_word_in_strict_mode: { code: 1212, category: ts.DiagnosticCategory.Error, key: "Identifier_expected_0_is_a_reserved_word_in_strict_mode_1212", message: "Identifier expected. '{0}' is a reserved word in strict mode" },
+ A_class_declaration_without_the_default_modifier_must_have_a_name: { code: 1211, category: ts.DiagnosticCategory.Error, key: "A_class_declaration_without_the_default_modifier_must_have_a_name_1211", message: "A class declaration without the 'default' modifier must have a name." },
+ Identifier_expected_0_is_a_reserved_word_in_strict_mode: { code: 1212, category: ts.DiagnosticCategory.Error, key: "Identifier_expected_0_is_a_reserved_word_in_strict_mode_1212", message: "Identifier expected. '{0}' is a reserved word in strict mode." },
Identifier_expected_0_is_a_reserved_word_in_strict_mode_Class_definitions_are_automatically_in_strict_mode: { code: 1213, category: ts.DiagnosticCategory.Error, key: "Identifier_expected_0_is_a_reserved_word_in_strict_mode_Class_definitions_are_automatically_in_stric_1213", message: "Identifier expected. '{0}' is a reserved word in strict mode. Class definitions are automatically in strict mode." },
Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode: { code: 1214, category: ts.DiagnosticCategory.Error, key: "Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode_1214", message: "Identifier expected. '{0}' is a reserved word in strict mode. Modules are automatically in strict mode." },
Invalid_use_of_0_Modules_are_automatically_in_strict_mode: { code: 1215, category: ts.DiagnosticCategory.Error, key: "Invalid_use_of_0_Modules_are_automatically_in_strict_mode_1215", message: "Invalid use of '{0}'. Modules are automatically in strict mode." },
+ Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules: { code: 1216, category: ts.DiagnosticCategory.Error, key: "Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules_1216", message: "Identifier expected. '__esModule' is reserved as an exported marker when transforming ECMAScript modules." },
Export_assignment_is_not_supported_when_module_flag_is_system: { code: 1218, category: ts.DiagnosticCategory.Error, key: "Export_assignment_is_not_supported_when_module_flag_is_system_1218", message: "Export assignment is not supported when '--module' flag is 'system'." },
Experimental_support_for_decorators_is_a_feature_that_is_subject_to_change_in_a_future_release_Set_the_experimentalDecorators_option_to_remove_this_warning: { code: 1219, category: ts.DiagnosticCategory.Error, key: "Experimental_support_for_decorators_is_a_feature_that_is_subject_to_change_in_a_future_release_Set_t_1219", message: "Experimental support for decorators is a feature that is subject to change in a future release. Set the 'experimentalDecorators' option to remove this warning." },
Generators_are_only_available_when_targeting_ECMAScript_2015_or_higher: { code: 1220, category: ts.DiagnosticCategory.Error, key: "Generators_are_only_available_when_targeting_ECMAScript_2015_or_higher_1220", message: "Generators are only available when targeting ECMAScript 2015 or higher." },
@@ -2624,6 +2635,11 @@ var ts;
Global_module_exports_may_only_appear_in_declaration_files: { code: 1315, category: ts.DiagnosticCategory.Error, key: "Global_module_exports_may_only_appear_in_declaration_files_1315", message: "Global module exports may only appear in declaration files." },
Global_module_exports_may_only_appear_at_top_level: { code: 1316, category: ts.DiagnosticCategory.Error, key: "Global_module_exports_may_only_appear_at_top_level_1316", message: "Global module exports may only appear at top level." },
A_parameter_property_cannot_be_declared_using_a_rest_parameter: { code: 1317, category: ts.DiagnosticCategory.Error, key: "A_parameter_property_cannot_be_declared_using_a_rest_parameter_1317", message: "A parameter property cannot be declared using a rest parameter." },
+ An_abstract_accessor_cannot_have_an_implementation: { code: 1318, category: ts.DiagnosticCategory.Error, key: "An_abstract_accessor_cannot_have_an_implementation_1318", message: "An abstract accessor cannot have an implementation." },
+ A_default_export_can_only_be_used_in_an_ECMAScript_style_module: { code: 1319, category: ts.DiagnosticCategory.Error, key: "A_default_export_can_only_be_used_in_an_ECMAScript_style_module_1319", message: "A default export can only be used in an ECMAScript-style module." },
+ Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: { code: 1320, category: ts.DiagnosticCategory.Error, key: "Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member_1320", message: "Type of 'await' operand must either be a valid promise or must not contain a callable 'then' member." },
+ Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: { code: 1321, category: ts.DiagnosticCategory.Error, key: "Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_cal_1321", message: "Type of 'yield' operand in an async generator must either be a valid promise or must not contain a callable 'then' member." },
+ Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: { code: 1322, category: ts.DiagnosticCategory.Error, key: "Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_con_1322", message: "Type of iterated elements of a 'yield*' operand must either be a valid promise or must not contain a callable 'then' member." },
Duplicate_identifier_0: { code: 2300, category: ts.DiagnosticCategory.Error, key: "Duplicate_identifier_0_2300", message: "Duplicate identifier '{0}'." },
Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor: { code: 2301, category: ts.DiagnosticCategory.Error, key: "Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor_2301", message: "Initializer of instance member variable '{0}' cannot reference identifier '{1}' declared in the constructor." },
Static_members_cannot_reference_class_type_parameters: { code: 2302, category: ts.DiagnosticCategory.Error, key: "Static_members_cannot_reference_class_type_parameters_2302", message: "Static members cannot reference class type parameters." },
@@ -2667,6 +2683,7 @@ var ts;
Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword: { code: 2340, category: ts.DiagnosticCategory.Error, key: "Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword_2340", message: "Only public and protected methods of the base class are accessible via the 'super' keyword." },
Property_0_is_private_and_only_accessible_within_class_1: { code: 2341, category: ts.DiagnosticCategory.Error, key: "Property_0_is_private_and_only_accessible_within_class_1_2341", message: "Property '{0}' is private and only accessible within class '{1}'." },
An_index_expression_argument_must_be_of_type_string_number_symbol_or_any: { code: 2342, category: ts.DiagnosticCategory.Error, key: "An_index_expression_argument_must_be_of_type_string_number_symbol_or_any_2342", message: "An index expression argument must be of type 'string', 'number', 'symbol', or 'any'." },
+ This_syntax_requires_an_imported_helper_named_1_but_module_0_has_no_exported_member_1: { code: 2343, category: ts.DiagnosticCategory.Error, key: "This_syntax_requires_an_imported_helper_named_1_but_module_0_has_no_exported_member_1_2343", message: "This syntax requires an imported helper named '{1}', but module '{0}' has no exported member '{1}'." },
Type_0_does_not_satisfy_the_constraint_1: { code: 2344, category: ts.DiagnosticCategory.Error, key: "Type_0_does_not_satisfy_the_constraint_1_2344", message: "Type '{0}' does not satisfy the constraint '{1}'." },
Argument_of_type_0_is_not_assignable_to_parameter_of_type_1: { code: 2345, category: ts.DiagnosticCategory.Error, key: "Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_2345", message: "Argument of type '{0}' is not assignable to parameter of type '{1}'." },
Supplied_parameters_do_not_match_any_signature_of_call_target: { code: 2346, category: ts.DiagnosticCategory.Error, key: "Supplied_parameters_do_not_match_any_signature_of_call_target_2346", message: "Supplied parameters do not match any signature of call target." },
@@ -2677,19 +2694,20 @@ var ts;
Cannot_use_new_with_an_expression_whose_type_lacks_a_call_or_construct_signature: { code: 2351, category: ts.DiagnosticCategory.Error, key: "Cannot_use_new_with_an_expression_whose_type_lacks_a_call_or_construct_signature_2351", message: "Cannot use 'new' with an expression whose type lacks a call or construct signature." },
Type_0_cannot_be_converted_to_type_1: { code: 2352, category: ts.DiagnosticCategory.Error, key: "Type_0_cannot_be_converted_to_type_1_2352", message: "Type '{0}' cannot be converted to type '{1}'." },
Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1: { code: 2353, category: ts.DiagnosticCategory.Error, key: "Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1_2353", message: "Object literal may only specify known properties, and '{0}' does not exist in type '{1}'." },
+ This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found: { code: 2354, category: ts.DiagnosticCategory.Error, key: "This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found_2354", message: "This syntax requires an imported helper but module '{0}' cannot be found." },
A_function_whose_declared_type_is_neither_void_nor_any_must_return_a_value: { code: 2355, category: ts.DiagnosticCategory.Error, key: "A_function_whose_declared_type_is_neither_void_nor_any_must_return_a_value_2355", message: "A function whose declared type is neither 'void' nor 'any' must return a value." },
An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type: { code: 2356, category: ts.DiagnosticCategory.Error, key: "An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type_2356", message: "An arithmetic operand must be of type 'any', 'number' or an enum type." },
The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access: { code: 2357, category: ts.DiagnosticCategory.Error, key: "The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access_2357", message: "The operand of an increment or decrement operator must be a variable or a property access." },
The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: { code: 2358, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_paramete_2358", message: "The left-hand side of an 'instanceof' expression must be of type 'any', an object type or a type parameter." },
The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type: { code: 2359, category: ts.DiagnosticCategory.Error, key: "The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_F_2359", message: "The right-hand side of an 'instanceof' expression must be of type 'any' or of a type assignable to the 'Function' interface type." },
The_left_hand_side_of_an_in_expression_must_be_of_type_any_string_number_or_symbol: { code: 2360, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_an_in_expression_must_be_of_type_any_string_number_or_symbol_2360", message: "The left-hand side of an 'in' expression must be of type 'any', 'string', 'number', or 'symbol'." },
- The_right_hand_side_of_an_in_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: { code: 2361, category: ts.DiagnosticCategory.Error, key: "The_right_hand_side_of_an_in_expression_must_be_of_type_any_an_object_type_or_a_type_parameter_2361", message: "The right-hand side of an 'in' expression must be of type 'any', an object type or a type parameter" },
+ The_right_hand_side_of_an_in_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: { code: 2361, category: ts.DiagnosticCategory.Error, key: "The_right_hand_side_of_an_in_expression_must_be_of_type_any_an_object_type_or_a_type_parameter_2361", message: "The right-hand side of an 'in' expression must be of type 'any', an object type or a type parameter." },
The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_or_an_enum_type: { code: 2362, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_or_an_enum_type_2362", message: "The left-hand side of an arithmetic operation must be of type 'any', 'number' or an enum type." },
The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_or_an_enum_type: { code: 2363, category: ts.DiagnosticCategory.Error, key: "The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_or_an_enum_type_2363", message: "The right-hand side of an arithmetic operation must be of type 'any', 'number' or an enum type." },
The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access: { code: 2364, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access_2364", message: "The left-hand side of an assignment expression must be a variable or a property access." },
Operator_0_cannot_be_applied_to_types_1_and_2: { code: 2365, category: ts.DiagnosticCategory.Error, key: "Operator_0_cannot_be_applied_to_types_1_and_2_2365", message: "Operator '{0}' cannot be applied to types '{1}' and '{2}'." },
Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined: { code: 2366, category: ts.DiagnosticCategory.Error, key: "Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined_2366", message: "Function lacks ending return statement and return type does not include 'undefined'." },
- Type_parameter_name_cannot_be_0: { code: 2368, category: ts.DiagnosticCategory.Error, key: "Type_parameter_name_cannot_be_0_2368", message: "Type parameter name cannot be '{0}'" },
+ Type_parameter_name_cannot_be_0: { code: 2368, category: ts.DiagnosticCategory.Error, key: "Type_parameter_name_cannot_be_0_2368", message: "Type parameter name cannot be '{0}'." },
A_parameter_property_is_only_allowed_in_a_constructor_implementation: { code: 2369, category: ts.DiagnosticCategory.Error, key: "A_parameter_property_is_only_allowed_in_a_constructor_implementation_2369", message: "A parameter property is only allowed in a constructor implementation." },
A_rest_parameter_must_be_of_an_array_type: { code: 2370, category: ts.DiagnosticCategory.Error, key: "A_rest_parameter_must_be_of_an_array_type_2370", message: "A rest parameter must be of an array type." },
A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation: { code: 2371, category: ts.DiagnosticCategory.Error, key: "A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation_2371", message: "A parameter initializer is only allowed in a function or constructor implementation." },
@@ -2729,12 +2747,12 @@ var ts;
The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access: { code: 2406, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access_2406", message: "The left-hand side of a 'for...in' statement must be a variable or a property access." },
The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter: { code: 2407, category: ts.DiagnosticCategory.Error, key: "The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_2407", message: "The right-hand side of a 'for...in' statement must be of type 'any', an object type or a type parameter." },
Setters_cannot_return_a_value: { code: 2408, category: ts.DiagnosticCategory.Error, key: "Setters_cannot_return_a_value_2408", message: "Setters cannot return a value." },
- Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class: { code: 2409, category: ts.DiagnosticCategory.Error, key: "Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class_2409", message: "Return type of constructor signature must be assignable to the instance type of the class" },
+ Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class: { code: 2409, category: ts.DiagnosticCategory.Error, key: "Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class_2409", message: "Return type of constructor signature must be assignable to the instance type of the class." },
The_with_statement_is_not_supported_All_symbols_in_a_with_block_will_have_type_any: { code: 2410, category: ts.DiagnosticCategory.Error, key: "The_with_statement_is_not_supported_All_symbols_in_a_with_block_will_have_type_any_2410", message: "The 'with' statement is not supported. All symbols in a 'with' block will have type 'any'." },
Property_0_of_type_1_is_not_assignable_to_string_index_type_2: { code: 2411, category: ts.DiagnosticCategory.Error, key: "Property_0_of_type_1_is_not_assignable_to_string_index_type_2_2411", message: "Property '{0}' of type '{1}' is not assignable to string index type '{2}'." },
Property_0_of_type_1_is_not_assignable_to_numeric_index_type_2: { code: 2412, category: ts.DiagnosticCategory.Error, key: "Property_0_of_type_1_is_not_assignable_to_numeric_index_type_2_2412", message: "Property '{0}' of type '{1}' is not assignable to numeric index type '{2}'." },
Numeric_index_type_0_is_not_assignable_to_string_index_type_1: { code: 2413, category: ts.DiagnosticCategory.Error, key: "Numeric_index_type_0_is_not_assignable_to_string_index_type_1_2413", message: "Numeric index type '{0}' is not assignable to string index type '{1}'." },
- Class_name_cannot_be_0: { code: 2414, category: ts.DiagnosticCategory.Error, key: "Class_name_cannot_be_0_2414", message: "Class name cannot be '{0}'" },
+ Class_name_cannot_be_0: { code: 2414, category: ts.DiagnosticCategory.Error, key: "Class_name_cannot_be_0_2414", message: "Class name cannot be '{0}'." },
Class_0_incorrectly_extends_base_class_1: { code: 2415, category: ts.DiagnosticCategory.Error, key: "Class_0_incorrectly_extends_base_class_1_2415", message: "Class '{0}' incorrectly extends base class '{1}'." },
Class_static_side_0_incorrectly_extends_base_class_static_side_1: { code: 2417, category: ts.DiagnosticCategory.Error, key: "Class_static_side_0_incorrectly_extends_base_class_static_side_1_2417", message: "Class static side '{0}' incorrectly extends base class static side '{1}'." },
Class_0_incorrectly_implements_interface_1: { code: 2420, category: ts.DiagnosticCategory.Error, key: "Class_0_incorrectly_implements_interface_1_2420", message: "Class '{0}' incorrectly implements interface '{1}'." },
@@ -2743,19 +2761,19 @@ var ts;
Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_property: { code: 2424, category: ts.DiagnosticCategory.Error, key: "Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_proper_2424", message: "Class '{0}' defines instance member function '{1}', but extended class '{2}' defines it as instance member property." },
Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function: { code: 2425, category: ts.DiagnosticCategory.Error, key: "Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_functi_2425", message: "Class '{0}' defines instance member property '{1}', but extended class '{2}' defines it as instance member function." },
Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_function: { code: 2426, category: ts.DiagnosticCategory.Error, key: "Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_functi_2426", message: "Class '{0}' defines instance member accessor '{1}', but extended class '{2}' defines it as instance member function." },
- Interface_name_cannot_be_0: { code: 2427, category: ts.DiagnosticCategory.Error, key: "Interface_name_cannot_be_0_2427", message: "Interface name cannot be '{0}'" },
+ Interface_name_cannot_be_0: { code: 2427, category: ts.DiagnosticCategory.Error, key: "Interface_name_cannot_be_0_2427", message: "Interface name cannot be '{0}'." },
All_declarations_of_0_must_have_identical_type_parameters: { code: 2428, category: ts.DiagnosticCategory.Error, key: "All_declarations_of_0_must_have_identical_type_parameters_2428", message: "All declarations of '{0}' must have identical type parameters." },
Interface_0_incorrectly_extends_interface_1: { code: 2430, category: ts.DiagnosticCategory.Error, key: "Interface_0_incorrectly_extends_interface_1_2430", message: "Interface '{0}' incorrectly extends interface '{1}'." },
- Enum_name_cannot_be_0: { code: 2431, category: ts.DiagnosticCategory.Error, key: "Enum_name_cannot_be_0_2431", message: "Enum name cannot be '{0}'" },
+ Enum_name_cannot_be_0: { code: 2431, category: ts.DiagnosticCategory.Error, key: "Enum_name_cannot_be_0_2431", message: "Enum name cannot be '{0}'." },
In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element: { code: 2432, category: ts.DiagnosticCategory.Error, key: "In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enu_2432", message: "In an enum with multiple declarations, only one declaration can omit an initializer for its first enum element." },
- A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged: { code: 2433, category: ts.DiagnosticCategory.Error, key: "A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merg_2433", message: "A namespace declaration cannot be in a different file from a class or function with which it is merged" },
- A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged: { code: 2434, category: ts.DiagnosticCategory.Error, key: "A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged_2434", message: "A namespace declaration cannot be located prior to a class or function with which it is merged" },
+ A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged: { code: 2433, category: ts.DiagnosticCategory.Error, key: "A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merg_2433", message: "A namespace declaration cannot be in a different file from a class or function with which it is merged." },
+ A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged: { code: 2434, category: ts.DiagnosticCategory.Error, key: "A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged_2434", message: "A namespace declaration cannot be located prior to a class or function with which it is merged." },
Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces: { code: 2435, category: ts.DiagnosticCategory.Error, key: "Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces_2435", message: "Ambient modules cannot be nested in other modules or namespaces." },
Ambient_module_declaration_cannot_specify_relative_module_name: { code: 2436, category: ts.DiagnosticCategory.Error, key: "Ambient_module_declaration_cannot_specify_relative_module_name_2436", message: "Ambient module declaration cannot specify relative module name." },
- Module_0_is_hidden_by_a_local_declaration_with_the_same_name: { code: 2437, category: ts.DiagnosticCategory.Error, key: "Module_0_is_hidden_by_a_local_declaration_with_the_same_name_2437", message: "Module '{0}' is hidden by a local declaration with the same name" },
- Import_name_cannot_be_0: { code: 2438, category: ts.DiagnosticCategory.Error, key: "Import_name_cannot_be_0_2438", message: "Import name cannot be '{0}'" },
+ Module_0_is_hidden_by_a_local_declaration_with_the_same_name: { code: 2437, category: ts.DiagnosticCategory.Error, key: "Module_0_is_hidden_by_a_local_declaration_with_the_same_name_2437", message: "Module '{0}' is hidden by a local declaration with the same name." },
+ Import_name_cannot_be_0: { code: 2438, category: ts.DiagnosticCategory.Error, key: "Import_name_cannot_be_0_2438", message: "Import name cannot be '{0}'." },
Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name: { code: 2439, category: ts.DiagnosticCategory.Error, key: "Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relati_2439", message: "Import or export declaration in an ambient module declaration cannot reference module through relative module name." },
- Import_declaration_conflicts_with_local_declaration_of_0: { code: 2440, category: ts.DiagnosticCategory.Error, key: "Import_declaration_conflicts_with_local_declaration_of_0_2440", message: "Import declaration conflicts with local declaration of '{0}'" },
+ Import_declaration_conflicts_with_local_declaration_of_0: { code: 2440, category: ts.DiagnosticCategory.Error, key: "Import_declaration_conflicts_with_local_declaration_of_0_2440", message: "Import declaration conflicts with local declaration of '{0}'." },
Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module: { code: 2441, category: ts.DiagnosticCategory.Error, key: "Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_2441", message: "Duplicate identifier '{0}'. Compiler reserves name '{1}' in top level scope of a module." },
Types_have_separate_declarations_of_a_private_property_0: { code: 2442, category: ts.DiagnosticCategory.Error, key: "Types_have_separate_declarations_of_a_private_property_0_2442", message: "Types have separate declarations of a private property '{0}'." },
Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2: { code: 2443, category: ts.DiagnosticCategory.Error, key: "Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2_2443", message: "Property '{0}' is protected but type '{1}' is not a class derived from '{2}'." },
@@ -2764,18 +2782,20 @@ var ts;
Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1: { code: 2446, category: ts.DiagnosticCategory.Error, key: "Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_2446", message: "Property '{0}' is protected and only accessible through an instance of class '{1}'." },
The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead: { code: 2447, category: ts.DiagnosticCategory.Error, key: "The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead_2447", message: "The '{0}' operator is not allowed for boolean types. Consider using '{1}' instead." },
Block_scoped_variable_0_used_before_its_declaration: { code: 2448, category: ts.DiagnosticCategory.Error, key: "Block_scoped_variable_0_used_before_its_declaration_2448", message: "Block-scoped variable '{0}' used before its declaration." },
+ Class_0_used_before_its_declaration: { code: 2449, category: ts.DiagnosticCategory.Error, key: "Class_0_used_before_its_declaration_2449", message: "Class '{0}' used before its declaration." },
+ Enum_0_used_before_its_declaration: { code: 2450, category: ts.DiagnosticCategory.Error, key: "Enum_0_used_before_its_declaration_2450", message: "Enum '{0}' used before its declaration." },
Cannot_redeclare_block_scoped_variable_0: { code: 2451, category: ts.DiagnosticCategory.Error, key: "Cannot_redeclare_block_scoped_variable_0_2451", message: "Cannot redeclare block-scoped variable '{0}'." },
An_enum_member_cannot_have_a_numeric_name: { code: 2452, category: ts.DiagnosticCategory.Error, key: "An_enum_member_cannot_have_a_numeric_name_2452", message: "An enum member cannot have a numeric name." },
The_type_argument_for_type_parameter_0_cannot_be_inferred_from_the_usage_Consider_specifying_the_type_arguments_explicitly: { code: 2453, category: ts.DiagnosticCategory.Error, key: "The_type_argument_for_type_parameter_0_cannot_be_inferred_from_the_usage_Consider_specifying_the_typ_2453", message: "The type argument for type parameter '{0}' cannot be inferred from the usage. Consider specifying the type arguments explicitly." },
Variable_0_is_used_before_being_assigned: { code: 2454, category: ts.DiagnosticCategory.Error, key: "Variable_0_is_used_before_being_assigned_2454", message: "Variable '{0}' is used before being assigned." },
Type_argument_candidate_1_is_not_a_valid_type_argument_because_it_is_not_a_supertype_of_candidate_0: { code: 2455, category: ts.DiagnosticCategory.Error, key: "Type_argument_candidate_1_is_not_a_valid_type_argument_because_it_is_not_a_supertype_of_candidate_0_2455", message: "Type argument candidate '{1}' is not a valid type argument because it is not a supertype of candidate '{0}'." },
Type_alias_0_circularly_references_itself: { code: 2456, category: ts.DiagnosticCategory.Error, key: "Type_alias_0_circularly_references_itself_2456", message: "Type alias '{0}' circularly references itself." },
- Type_alias_name_cannot_be_0: { code: 2457, category: ts.DiagnosticCategory.Error, key: "Type_alias_name_cannot_be_0_2457", message: "Type alias name cannot be '{0}'" },
+ Type_alias_name_cannot_be_0: { code: 2457, category: ts.DiagnosticCategory.Error, key: "Type_alias_name_cannot_be_0_2457", message: "Type alias name cannot be '{0}'." },
An_AMD_module_cannot_have_multiple_name_assignments: { code: 2458, category: ts.DiagnosticCategory.Error, key: "An_AMD_module_cannot_have_multiple_name_assignments_2458", message: "An AMD module cannot have multiple name assignments." },
Type_0_has_no_property_1_and_no_string_index_signature: { code: 2459, category: ts.DiagnosticCategory.Error, key: "Type_0_has_no_property_1_and_no_string_index_signature_2459", message: "Type '{0}' has no property '{1}' and no string index signature." },
Type_0_has_no_property_1: { code: 2460, category: ts.DiagnosticCategory.Error, key: "Type_0_has_no_property_1_2460", message: "Type '{0}' has no property '{1}'." },
Type_0_is_not_an_array_type: { code: 2461, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_an_array_type_2461", message: "Type '{0}' is not an array type." },
- A_rest_element_must_be_last_in_a_destructuring_pattern: { code: 2462, category: ts.DiagnosticCategory.Error, key: "A_rest_element_must_be_last_in_a_destructuring_pattern_2462", message: "A rest element must be last in a destructuring pattern" },
+ A_rest_element_must_be_last_in_a_destructuring_pattern: { code: 2462, category: ts.DiagnosticCategory.Error, key: "A_rest_element_must_be_last_in_a_destructuring_pattern_2462", message: "A rest element must be last in a destructuring pattern." },
A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature: { code: 2463, category: ts.DiagnosticCategory.Error, key: "A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature_2463", message: "A binding pattern parameter cannot be optional in an implementation signature." },
A_computed_property_name_must_be_of_type_string_number_symbol_or_any: { code: 2464, category: ts.DiagnosticCategory.Error, key: "A_computed_property_name_must_be_of_type_string_number_symbol_or_any_2464", message: "A computed property name must be of type 'string', 'number', 'symbol', or 'any'." },
this_cannot_be_referenced_in_a_computed_property_name: { code: 2465, category: ts.DiagnosticCategory.Error, key: "this_cannot_be_referenced_in_a_computed_property_name_2465", message: "'this' cannot be referenced in a computed property name." },
@@ -2796,13 +2816,13 @@ var ts;
let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations: { code: 2480, category: ts.DiagnosticCategory.Error, key: "let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations_2480", message: "'let' is not allowed to be used as a name in 'let' or 'const' declarations." },
Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1: { code: 2481, category: ts.DiagnosticCategory.Error, key: "Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1_2481", message: "Cannot initialize outer scoped variable '{0}' in the same scope as block scoped declaration '{1}'." },
The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation: { code: 2483, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation_2483", message: "The left-hand side of a 'for...of' statement cannot use a type annotation." },
- Export_declaration_conflicts_with_exported_declaration_of_0: { code: 2484, category: ts.DiagnosticCategory.Error, key: "Export_declaration_conflicts_with_exported_declaration_of_0_2484", message: "Export declaration conflicts with exported declaration of '{0}'" },
+ Export_declaration_conflicts_with_exported_declaration_of_0: { code: 2484, category: ts.DiagnosticCategory.Error, key: "Export_declaration_conflicts_with_exported_declaration_of_0_2484", message: "Export declaration conflicts with exported declaration of '{0}'." },
The_left_hand_side_of_a_for_of_statement_must_be_a_variable_or_a_property_access: { code: 2487, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_a_for_of_statement_must_be_a_variable_or_a_property_access_2487", message: "The left-hand side of a 'for...of' statement must be a variable or a property access." },
Type_must_have_a_Symbol_iterator_method_that_returns_an_iterator: { code: 2488, category: ts.DiagnosticCategory.Error, key: "Type_must_have_a_Symbol_iterator_method_that_returns_an_iterator_2488", message: "Type must have a '[Symbol.iterator]()' method that returns an iterator." },
An_iterator_must_have_a_next_method: { code: 2489, category: ts.DiagnosticCategory.Error, key: "An_iterator_must_have_a_next_method_2489", message: "An iterator must have a 'next()' method." },
The_type_returned_by_the_next_method_of_an_iterator_must_have_a_value_property: { code: 2490, category: ts.DiagnosticCategory.Error, key: "The_type_returned_by_the_next_method_of_an_iterator_must_have_a_value_property_2490", message: "The type returned by the 'next()' method of an iterator must have a 'value' property." },
The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern: { code: 2491, category: ts.DiagnosticCategory.Error, key: "The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern_2491", message: "The left-hand side of a 'for...in' statement cannot be a destructuring pattern." },
- Cannot_redeclare_identifier_0_in_catch_clause: { code: 2492, category: ts.DiagnosticCategory.Error, key: "Cannot_redeclare_identifier_0_in_catch_clause_2492", message: "Cannot redeclare identifier '{0}' in catch clause" },
+ Cannot_redeclare_identifier_0_in_catch_clause: { code: 2492, category: ts.DiagnosticCategory.Error, key: "Cannot_redeclare_identifier_0_in_catch_clause_2492", message: "Cannot redeclare identifier '{0}' in catch clause." },
Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2: { code: 2493, category: ts.DiagnosticCategory.Error, key: "Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2_2493", message: "Tuple type '{0}' with length '{1}' cannot be assigned to tuple with length '{2}'." },
Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher: { code: 2494, category: ts.DiagnosticCategory.Error, key: "Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher_2494", message: "Using a string in a 'for...of' statement is only supported in ECMAScript 5 and higher." },
Type_0_is_not_an_array_type_or_a_string_type: { code: 2495, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_an_array_type_or_a_string_type_2495", message: "Type '{0}' is not an array type or a string type." },
@@ -2814,6 +2834,7 @@ var ts;
A_rest_element_cannot_contain_a_binding_pattern: { code: 2501, category: ts.DiagnosticCategory.Error, key: "A_rest_element_cannot_contain_a_binding_pattern_2501", message: "A rest element cannot contain a binding pattern." },
_0_is_referenced_directly_or_indirectly_in_its_own_type_annotation: { code: 2502, category: ts.DiagnosticCategory.Error, key: "_0_is_referenced_directly_or_indirectly_in_its_own_type_annotation_2502", message: "'{0}' is referenced directly or indirectly in its own type annotation." },
Cannot_find_namespace_0: { code: 2503, category: ts.DiagnosticCategory.Error, key: "Cannot_find_namespace_0_2503", message: "Cannot find namespace '{0}'." },
+ Type_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator: { code: 2504, category: ts.DiagnosticCategory.Error, key: "Type_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator_2504", message: "Type must have a '[Symbol.asyncIterator]()' method that returns an async iterator." },
A_generator_cannot_have_a_void_type_annotation: { code: 2505, category: ts.DiagnosticCategory.Error, key: "A_generator_cannot_have_a_void_type_annotation_2505", message: "A generator cannot have a 'void' type annotation." },
_0_is_referenced_directly_or_indirectly_in_its_own_base_expression: { code: 2506, category: ts.DiagnosticCategory.Error, key: "_0_is_referenced_directly_or_indirectly_in_its_own_base_expression_2506", message: "'{0}' is referenced directly or indirectly in its own base expression." },
Type_0_is_not_a_constructor_function_type: { code: 2507, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_a_constructor_function_type_2507", message: "Type '{0}' is not a constructor function type." },
@@ -2828,6 +2849,7 @@ var ts;
All_declarations_of_an_abstract_method_must_be_consecutive: { code: 2516, category: ts.DiagnosticCategory.Error, key: "All_declarations_of_an_abstract_method_must_be_consecutive_2516", message: "All declarations of an abstract method must be consecutive." },
Cannot_assign_an_abstract_constructor_type_to_a_non_abstract_constructor_type: { code: 2517, category: ts.DiagnosticCategory.Error, key: "Cannot_assign_an_abstract_constructor_type_to_a_non_abstract_constructor_type_2517", message: "Cannot assign an abstract constructor type to a non-abstract constructor type." },
A_this_based_type_guard_is_not_compatible_with_a_parameter_based_type_guard: { code: 2518, category: ts.DiagnosticCategory.Error, key: "A_this_based_type_guard_is_not_compatible_with_a_parameter_based_type_guard_2518", message: "A 'this'-based type guard is not compatible with a parameter-based type guard." },
+ An_async_iterator_must_have_a_next_method: { code: 2519, category: ts.DiagnosticCategory.Error, key: "An_async_iterator_must_have_a_next_method_2519", message: "An async iterator must have a 'next()' method." },
Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions: { code: 2520, category: ts.DiagnosticCategory.Error, key: "Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions_2520", message: "Duplicate identifier '{0}'. Compiler uses declaration '{1}' to support async functions." },
Expression_resolves_to_variable_declaration_0_that_compiler_uses_to_support_async_functions: { code: 2521, category: ts.DiagnosticCategory.Error, key: "Expression_resolves_to_variable_declaration_0_that_compiler_uses_to_support_async_functions_2521", message: "Expression resolves to variable declaration '{0}' that compiler uses to support async functions." },
The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method: { code: 2522, category: ts.DiagnosticCategory.Error, key: "The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_usi_2522", message: "The 'arguments' object cannot be referenced in an async function or method in ES3 and ES5. Consider using a standard function or method." },
@@ -2851,23 +2873,33 @@ var ts;
Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property: { code: 2540, category: ts.DiagnosticCategory.Error, key: "Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property_2540", message: "Cannot assign to '{0}' because it is a constant or a read-only property." },
The_target_of_an_assignment_must_be_a_variable_or_a_property_access: { code: 2541, category: ts.DiagnosticCategory.Error, key: "The_target_of_an_assignment_must_be_a_variable_or_a_property_access_2541", message: "The target of an assignment must be a variable or a property access." },
Index_signature_in_type_0_only_permits_reading: { code: 2542, category: ts.DiagnosticCategory.Error, key: "Index_signature_in_type_0_only_permits_reading_2542", message: "Index signature in type '{0}' only permits reading." },
+ Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference: { code: 2543, category: ts.DiagnosticCategory.Error, key: "Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_me_2543", message: "Duplicate identifier '_newTarget'. Compiler uses variable declaration '_newTarget' to capture 'new.target' meta-property reference." },
+ Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference: { code: 2544, category: ts.DiagnosticCategory.Error, key: "Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta__2544", message: "Expression resolves to variable declaration '_newTarget' that compiler uses to capture 'new.target' meta-property reference." },
+ A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any: { code: 2545, category: ts.DiagnosticCategory.Error, key: "A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any_2545", message: "A mixin class must have a constructor with a single rest parameter of type 'any[]'." },
+ Property_0_has_conflicting_declarations_and_is_inaccessible_in_type_1: { code: 2546, category: ts.DiagnosticCategory.Error, key: "Property_0_has_conflicting_declarations_and_is_inaccessible_in_type_1_2546", message: "Property '{0}' has conflicting declarations and is inaccessible in type '{1}'." },
+ The_type_returned_by_the_next_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_property: { code: 2547, category: ts.DiagnosticCategory.Error, key: "The_type_returned_by_the_next_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value__2547", message: "The type returned by the 'next()' method of an async iterator must be a promise for a type with a 'value' property." },
+ Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator: { code: 2548, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator_2548", message: "Type '{0}' is not an array type or does not have a '[Symbol.iterator]()' method that returns an iterator." },
+ Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator: { code: 2549, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns__2549", message: "Type '{0}' is not an array type or a string type or does not have a '[Symbol.iterator]()' method that returns an iterator." },
+ Generic_type_instantiation_is_excessively_deep_and_possibly_infinite: { code: 2550, category: ts.DiagnosticCategory.Error, key: "Generic_type_instantiation_is_excessively_deep_and_possibly_infinite_2550", message: "Generic type instantiation is excessively deep and possibly infinite." },
JSX_element_attributes_type_0_may_not_be_a_union_type: { code: 2600, category: ts.DiagnosticCategory.Error, key: "JSX_element_attributes_type_0_may_not_be_a_union_type_2600", message: "JSX element attributes type '{0}' may not be a union type." },
The_return_type_of_a_JSX_element_constructor_must_return_an_object_type: { code: 2601, category: ts.DiagnosticCategory.Error, key: "The_return_type_of_a_JSX_element_constructor_must_return_an_object_type_2601", message: "The return type of a JSX element constructor must return an object type." },
JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist: { code: 2602, category: ts.DiagnosticCategory.Error, key: "JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist_2602", message: "JSX element implicitly has type 'any' because the global type 'JSX.Element' does not exist." },
- Property_0_in_type_1_is_not_assignable_to_type_2: { code: 2603, category: ts.DiagnosticCategory.Error, key: "Property_0_in_type_1_is_not_assignable_to_type_2_2603", message: "Property '{0}' in type '{1}' is not assignable to type '{2}'" },
+ Property_0_in_type_1_is_not_assignable_to_type_2: { code: 2603, category: ts.DiagnosticCategory.Error, key: "Property_0_in_type_1_is_not_assignable_to_type_2_2603", message: "Property '{0}' in type '{1}' is not assignable to type '{2}'." },
JSX_element_type_0_does_not_have_any_construct_or_call_signatures: { code: 2604, category: ts.DiagnosticCategory.Error, key: "JSX_element_type_0_does_not_have_any_construct_or_call_signatures_2604", message: "JSX element type '{0}' does not have any construct or call signatures." },
JSX_element_type_0_is_not_a_constructor_function_for_JSX_elements: { code: 2605, category: ts.DiagnosticCategory.Error, key: "JSX_element_type_0_is_not_a_constructor_function_for_JSX_elements_2605", message: "JSX element type '{0}' is not a constructor function for JSX elements." },
Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property: { code: 2606, category: ts.DiagnosticCategory.Error, key: "Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property_2606", message: "Property '{0}' of JSX spread attribute is not assignable to target property." },
- JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property: { code: 2607, category: ts.DiagnosticCategory.Error, key: "JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property_2607", message: "JSX element class does not support attributes because it does not have a '{0}' property" },
- The_global_type_JSX_0_may_not_have_more_than_one_property: { code: 2608, category: ts.DiagnosticCategory.Error, key: "The_global_type_JSX_0_may_not_have_more_than_one_property_2608", message: "The global type 'JSX.{0}' may not have more than one property" },
- Cannot_emit_namespaced_JSX_elements_in_React: { code: 2650, category: ts.DiagnosticCategory.Error, key: "Cannot_emit_namespaced_JSX_elements_in_React_2650", message: "Cannot emit namespaced JSX elements in React" },
+ JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property: { code: 2607, category: ts.DiagnosticCategory.Error, key: "JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property_2607", message: "JSX element class does not support attributes because it does not have a '{0}' property." },
+ The_global_type_JSX_0_may_not_have_more_than_one_property: { code: 2608, category: ts.DiagnosticCategory.Error, key: "The_global_type_JSX_0_may_not_have_more_than_one_property_2608", message: "The global type 'JSX.{0}' may not have more than one property." },
+ JSX_spread_child_must_be_an_array_type: { code: 2609, category: ts.DiagnosticCategory.Error, key: "JSX_spread_child_must_be_an_array_type_2609", message: "JSX spread child must be an array type." },
+ Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity: { code: 2649, category: ts.DiagnosticCategory.Error, key: "Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity_2649", message: "Cannot augment module '{0}' with value exports because it resolves to a non-module entity." },
+ Cannot_emit_namespaced_JSX_elements_in_React: { code: 2650, category: ts.DiagnosticCategory.Error, key: "Cannot_emit_namespaced_JSX_elements_in_React_2650", message: "Cannot emit namespaced JSX elements in React." },
A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums: { code: 2651, category: ts.DiagnosticCategory.Error, key: "A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_memb_2651", message: "A member initializer in a enum declaration cannot reference members declared after it, including members defined in other enums." },
Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead: { code: 2652, category: ts.DiagnosticCategory.Error, key: "Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_d_2652", message: "Merged declaration '{0}' cannot include a default export declaration. Consider adding a separate 'export default {0}' declaration instead." },
Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1: { code: 2653, category: ts.DiagnosticCategory.Error, key: "Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1_2653", message: "Non-abstract class expression does not implement inherited abstract member '{0}' from class '{1}'." },
Exported_external_package_typings_file_cannot_contain_tripleslash_references_Please_contact_the_package_author_to_update_the_package_definition: { code: 2654, category: ts.DiagnosticCategory.Error, key: "Exported_external_package_typings_file_cannot_contain_tripleslash_references_Please_contact_the_pack_2654", message: "Exported external package typings file cannot contain tripleslash references. Please contact the package author to update the package definition." },
Exported_external_package_typings_file_0_is_not_a_module_Please_contact_the_package_author_to_update_the_package_definition: { code: 2656, category: ts.DiagnosticCategory.Error, key: "Exported_external_package_typings_file_0_is_not_a_module_Please_contact_the_package_author_to_update_2656", message: "Exported external package typings file '{0}' is not a module. Please contact the package author to update the package definition." },
- JSX_expressions_must_have_one_parent_element: { code: 2657, category: ts.DiagnosticCategory.Error, key: "JSX_expressions_must_have_one_parent_element_2657", message: "JSX expressions must have one parent element" },
- Type_0_provides_no_match_for_the_signature_1: { code: 2658, category: ts.DiagnosticCategory.Error, key: "Type_0_provides_no_match_for_the_signature_1_2658", message: "Type '{0}' provides no match for the signature '{1}'" },
+ JSX_expressions_must_have_one_parent_element: { code: 2657, category: ts.DiagnosticCategory.Error, key: "JSX_expressions_must_have_one_parent_element_2657", message: "JSX expressions must have one parent element." },
+ Type_0_provides_no_match_for_the_signature_1: { code: 2658, category: ts.DiagnosticCategory.Error, key: "Type_0_provides_no_match_for_the_signature_1_2658", message: "Type '{0}' provides no match for the signature '{1}'." },
super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher: { code: 2659, category: ts.DiagnosticCategory.Error, key: "super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_highe_2659", message: "'super' is only allowed in members of object literal expressions when option 'target' is 'ES2015' or higher." },
super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions: { code: 2660, category: ts.DiagnosticCategory.Error, key: "super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions_2660", message: "'super' can only be referenced in members of derived classes or object literal expressions." },
Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module: { code: 2661, category: ts.DiagnosticCategory.Error, key: "Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module_2661", message: "Cannot export '{0}'. Only local declarations can be exported from a module." },
@@ -2899,7 +2931,6 @@ var ts;
All_declarations_of_0_must_have_identical_modifiers: { code: 2687, category: ts.DiagnosticCategory.Error, key: "All_declarations_of_0_must_have_identical_modifiers_2687", message: "All declarations of '{0}' must have identical modifiers." },
Cannot_find_type_definition_file_for_0: { code: 2688, category: ts.DiagnosticCategory.Error, key: "Cannot_find_type_definition_file_for_0_2688", message: "Cannot find type definition file for '{0}'." },
Cannot_extend_an_interface_0_Did_you_mean_implements: { code: 2689, category: ts.DiagnosticCategory.Error, key: "Cannot_extend_an_interface_0_Did_you_mean_implements_2689", message: "Cannot extend an interface '{0}'. Did you mean 'implements'?" },
- A_class_must_be_declared_after_its_base_class: { code: 2690, category: ts.DiagnosticCategory.Error, key: "A_class_must_be_declared_after_its_base_class_2690", message: "A class must be declared after its base class." },
An_import_path_cannot_end_with_a_0_extension_Consider_importing_1_instead: { code: 2691, category: ts.DiagnosticCategory.Error, key: "An_import_path_cannot_end_with_a_0_extension_Consider_importing_1_instead_2691", message: "An import path cannot end with a '{0}' extension. Consider importing '{1}' instead." },
_0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible: { code: 2692, category: ts.DiagnosticCategory.Error, key: "_0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible_2692", message: "'{0}' is a primitive, but '{1}' is a wrapper object. Prefer using '{0}' when possible." },
_0_only_refers_to_a_type_but_is_being_used_as_a_value_here: { code: 2693, category: ts.DiagnosticCategory.Error, key: "_0_only_refers_to_a_type_but_is_being_used_as_a_value_here_2693", message: "'{0}' only refers to a type, but is being used as a value here." },
@@ -2908,9 +2939,17 @@ var ts;
The_Object_type_is_assignable_to_very_few_other_types_Did_you_mean_to_use_the_any_type_instead: { code: 2696, category: ts.DiagnosticCategory.Error, key: "The_Object_type_is_assignable_to_very_few_other_types_Did_you_mean_to_use_the_any_type_instead_2696", message: "The 'Object' type is assignable to very few other types. Did you mean to use the 'any' type instead?" },
An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option: { code: 2697, category: ts.DiagnosticCategory.Error, key: "An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_in_2697", message: "An async function or method must return a 'Promise'. Make sure you have a declaration for 'Promise' or include 'ES2015' in your `--lib` option." },
Spread_types_may_only_be_created_from_object_types: { code: 2698, category: ts.DiagnosticCategory.Error, key: "Spread_types_may_only_be_created_from_object_types_2698", message: "Spread types may only be created from object types." },
+ Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1: { code: 2699, category: ts.DiagnosticCategory.Error, key: "Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1_2699", message: "Static property '{0}' conflicts with built-in property 'Function.{0}' of constructor function '{1}'." },
Rest_types_may_only_be_created_from_object_types: { code: 2700, category: ts.DiagnosticCategory.Error, key: "Rest_types_may_only_be_created_from_object_types_2700", message: "Rest types may only be created from object types." },
The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access: { code: 2701, category: ts.DiagnosticCategory.Error, key: "The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access_2701", message: "The target of an object rest assignment must be a variable or a property access." },
_0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here: { code: 2702, category: ts.DiagnosticCategory.Error, key: "_0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here_2702", message: "'{0}' only refers to a type, but is being used as a namespace here." },
+ The_operand_of_a_delete_operator_must_be_a_property_reference: { code: 2703, category: ts.DiagnosticCategory.Error, key: "The_operand_of_a_delete_operator_must_be_a_property_reference_2703", message: "The operand of a delete operator must be a property reference." },
+ The_operand_of_a_delete_operator_cannot_be_a_read_only_property: { code: 2704, category: ts.DiagnosticCategory.Error, key: "The_operand_of_a_delete_operator_cannot_be_a_read_only_property_2704", message: "The operand of a delete operator cannot be a read-only property." },
+ An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option: { code: 2705, category: ts.DiagnosticCategory.Error, key: "An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_de_2705", message: "An async function or method in ES5/ES3 requires the 'Promise' constructor. Make sure you have a declaration for the 'Promise' constructor or include 'ES2015' in your `--lib` option." },
+ Required_type_parameters_may_not_follow_optional_type_parameters: { code: 2706, category: ts.DiagnosticCategory.Error, key: "Required_type_parameters_may_not_follow_optional_type_parameters_2706", message: "Required type parameters may not follow optional type parameters." },
+ Generic_type_0_requires_between_1_and_2_type_arguments: { code: 2707, category: ts.DiagnosticCategory.Error, key: "Generic_type_0_requires_between_1_and_2_type_arguments_2707", message: "Generic type '{0}' requires between {1} and {2} type arguments." },
+ Cannot_use_namespace_0_as_a_value: { code: 2708, category: ts.DiagnosticCategory.Error, key: "Cannot_use_namespace_0_as_a_value_2708", message: "Cannot use namespace '{0}' as a value." },
+ Cannot_use_namespace_0_as_a_type: { code: 2709, category: ts.DiagnosticCategory.Error, key: "Cannot_use_namespace_0_as_a_type_2709", message: "Cannot use namespace '{0}' as a type." },
Import_declaration_0_is_using_private_name_1: { code: 4000, category: ts.DiagnosticCategory.Error, key: "Import_declaration_0_is_using_private_name_1_4000", message: "Import declaration '{0}' is using private name '{1}'." },
Type_parameter_0_of_exported_class_has_or_is_using_private_name_1: { code: 4002, category: ts.DiagnosticCategory.Error, key: "Type_parameter_0_of_exported_class_has_or_is_using_private_name_1_4002", message: "Type parameter '{0}' of exported class has or is using private name '{1}'." },
Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1: { code: 4004, category: ts.DiagnosticCategory.Error, key: "Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1_4004", message: "Type parameter '{0}' of exported interface has or is using private name '{1}'." },
@@ -2921,8 +2960,8 @@ var ts;
Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1: { code: 4014, category: ts.DiagnosticCategory.Error, key: "Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1_4014", message: "Type parameter '{0}' of method from exported interface has or is using private name '{1}'." },
Type_parameter_0_of_exported_function_has_or_is_using_private_name_1: { code: 4016, category: ts.DiagnosticCategory.Error, key: "Type_parameter_0_of_exported_function_has_or_is_using_private_name_1_4016", message: "Type parameter '{0}' of exported function has or is using private name '{1}'." },
Implements_clause_of_exported_class_0_has_or_is_using_private_name_1: { code: 4019, category: ts.DiagnosticCategory.Error, key: "Implements_clause_of_exported_class_0_has_or_is_using_private_name_1_4019", message: "Implements clause of exported class '{0}' has or is using private name '{1}'." },
- Extends_clause_of_exported_class_0_has_or_is_using_private_name_1: { code: 4020, category: ts.DiagnosticCategory.Error, key: "Extends_clause_of_exported_class_0_has_or_is_using_private_name_1_4020", message: "Extends clause of exported class '{0}' has or is using private name '{1}'." },
- Extends_clause_of_exported_interface_0_has_or_is_using_private_name_1: { code: 4022, category: ts.DiagnosticCategory.Error, key: "Extends_clause_of_exported_interface_0_has_or_is_using_private_name_1_4022", message: "Extends clause of exported interface '{0}' has or is using private name '{1}'." },
+ extends_clause_of_exported_class_0_has_or_is_using_private_name_1: { code: 4020, category: ts.DiagnosticCategory.Error, key: "extends_clause_of_exported_class_0_has_or_is_using_private_name_1_4020", message: "'extends' clause of exported class '{0}' has or is using private name '{1}'." },
+ extends_clause_of_exported_interface_0_has_or_is_using_private_name_1: { code: 4022, category: ts.DiagnosticCategory.Error, key: "extends_clause_of_exported_interface_0_has_or_is_using_private_name_1_4022", message: "'extends' clause of exported interface '{0}' has or is using private name '{1}'." },
Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: { code: 4023, category: ts.DiagnosticCategory.Error, key: "Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named_4023", message: "Exported variable '{0}' has or is using name '{1}' from external module {2} but cannot be named." },
Exported_variable_0_has_or_is_using_name_1_from_private_module_2: { code: 4024, category: ts.DiagnosticCategory.Error, key: "Exported_variable_0_has_or_is_using_name_1_from_private_module_2_4024", message: "Exported variable '{0}' has or is using name '{1}' from private module '{2}'." },
Exported_variable_0_has_or_is_using_private_name_1: { code: 4025, category: ts.DiagnosticCategory.Error, key: "Exported_variable_0_has_or_is_using_private_name_1_4025", message: "Exported variable '{0}' has or is using private name '{1}'." },
@@ -2983,16 +3022,18 @@ var ts;
Default_export_of_the_module_has_or_is_using_private_name_0: { code: 4082, category: ts.DiagnosticCategory.Error, key: "Default_export_of_the_module_has_or_is_using_private_name_0_4082", message: "Default export of the module has or is using private name '{0}'." },
Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1: { code: 4083, category: ts.DiagnosticCategory.Error, key: "Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1_4083", message: "Type parameter '{0}' of exported type alias has or is using private name '{1}'." },
Conflicting_definitions_for_0_found_at_1_and_2_Consider_installing_a_specific_version_of_this_library_to_resolve_the_conflict: { code: 4090, category: ts.DiagnosticCategory.Message, key: "Conflicting_definitions_for_0_found_at_1_and_2_Consider_installing_a_specific_version_of_this_librar_4090", message: "Conflicting definitions for '{0}' found at '{1}' and '{2}'. Consider installing a specific version of this library to resolve the conflict." },
+ Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2: { code: 4091, category: ts.DiagnosticCategory.Error, key: "Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2_4091", message: "Parameter '{0}' of index signature from exported interface has or is using name '{1}' from private module '{2}'." },
+ Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1: { code: 4092, category: ts.DiagnosticCategory.Error, key: "Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1_4092", message: "Parameter '{0}' of index signature from exported interface has or is using private name '{1}'." },
+ extends_clause_of_exported_class_0_refers_to_a_type_whose_name_cannot_be_referenced: { code: 4093, category: ts.DiagnosticCategory.Error, key: "extends_clause_of_exported_class_0_refers_to_a_type_whose_name_cannot_be_referenced_4093", message: "'extends' clause of exported class '{0}' refers to a type whose name cannot be referenced." },
The_current_host_does_not_support_the_0_option: { code: 5001, category: ts.DiagnosticCategory.Error, key: "The_current_host_does_not_support_the_0_option_5001", message: "The current host does not support the '{0}' option." },
Cannot_find_the_common_subdirectory_path_for_the_input_files: { code: 5009, category: ts.DiagnosticCategory.Error, key: "Cannot_find_the_common_subdirectory_path_for_the_input_files_5009", message: "Cannot find the common subdirectory path for the input files." },
File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: { code: 5010, category: ts.DiagnosticCategory.Error, key: "File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0_5010", message: "File specification cannot end in a recursive directory wildcard ('**'): '{0}'." },
File_specification_cannot_contain_multiple_recursive_directory_wildcards_Asterisk_Asterisk_Colon_0: { code: 5011, category: ts.DiagnosticCategory.Error, key: "File_specification_cannot_contain_multiple_recursive_directory_wildcards_Asterisk_Asterisk_Colon_0_5011", message: "File specification cannot contain multiple recursive directory wildcards ('**'): '{0}'." },
- Cannot_read_file_0_Colon_1: { code: 5012, category: ts.DiagnosticCategory.Error, key: "Cannot_read_file_0_Colon_1_5012", message: "Cannot read file '{0}': {1}" },
- Unsupported_file_encoding: { code: 5013, category: ts.DiagnosticCategory.Error, key: "Unsupported_file_encoding_5013", message: "Unsupported file encoding." },
+ Cannot_read_file_0_Colon_1: { code: 5012, category: ts.DiagnosticCategory.Error, key: "Cannot_read_file_0_Colon_1_5012", message: "Cannot read file '{0}': {1}." },
Failed_to_parse_file_0_Colon_1: { code: 5014, category: ts.DiagnosticCategory.Error, key: "Failed_to_parse_file_0_Colon_1_5014", message: "Failed to parse file '{0}': {1}." },
Unknown_compiler_option_0: { code: 5023, category: ts.DiagnosticCategory.Error, key: "Unknown_compiler_option_0_5023", message: "Unknown compiler option '{0}'." },
Compiler_option_0_requires_a_value_of_type_1: { code: 5024, category: ts.DiagnosticCategory.Error, key: "Compiler_option_0_requires_a_value_of_type_1_5024", message: "Compiler option '{0}' requires a value of type {1}." },
- Could_not_write_file_0_Colon_1: { code: 5033, category: ts.DiagnosticCategory.Error, key: "Could_not_write_file_0_Colon_1_5033", message: "Could not write file '{0}': {1}" },
+ Could_not_write_file_0_Colon_1: { code: 5033, category: ts.DiagnosticCategory.Error, key: "Could_not_write_file_0_Colon_1_5033", message: "Could not write file '{0}': {1}." },
Option_project_cannot_be_mixed_with_source_files_on_a_command_line: { code: 5042, category: ts.DiagnosticCategory.Error, key: "Option_project_cannot_be_mixed_with_source_files_on_a_command_line_5042", message: "Option 'project' cannot be mixed with source files on a command line." },
Option_isolatedModules_can_only_be_used_when_either_option_module_is_provided_or_option_target_is_ES2015_or_higher: { code: 5047, category: ts.DiagnosticCategory.Error, key: "Option_isolatedModules_can_only_be_used_when_either_option_module_is_provided_or_option_target_is_ES_5047", message: "Option 'isolatedModules' can only be used when either option '--module' is provided or option 'target' is 'ES2015' or higher." },
Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided: { code: 5051, category: ts.DiagnosticCategory.Error, key: "Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided_5051", message: "Option '{0} can only be used when either option '--inlineSourceMap' or option '--sourceMap' is provided." },
@@ -3001,12 +3042,12 @@ var ts;
A_tsconfig_json_file_is_already_defined_at_Colon_0: { code: 5054, category: ts.DiagnosticCategory.Error, key: "A_tsconfig_json_file_is_already_defined_at_Colon_0_5054", message: "A 'tsconfig.json' file is already defined at: '{0}'." },
Cannot_write_file_0_because_it_would_overwrite_input_file: { code: 5055, category: ts.DiagnosticCategory.Error, key: "Cannot_write_file_0_because_it_would_overwrite_input_file_5055", message: "Cannot write file '{0}' because it would overwrite input file." },
Cannot_write_file_0_because_it_would_be_overwritten_by_multiple_input_files: { code: 5056, category: ts.DiagnosticCategory.Error, key: "Cannot_write_file_0_because_it_would_be_overwritten_by_multiple_input_files_5056", message: "Cannot write file '{0}' because it would be overwritten by multiple input files." },
- Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0: { code: 5057, category: ts.DiagnosticCategory.Error, key: "Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0_5057", message: "Cannot find a tsconfig.json file at the specified directory: '{0}'" },
- The_specified_path_does_not_exist_Colon_0: { code: 5058, category: ts.DiagnosticCategory.Error, key: "The_specified_path_does_not_exist_Colon_0_5058", message: "The specified path does not exist: '{0}'" },
+ Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0: { code: 5057, category: ts.DiagnosticCategory.Error, key: "Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0_5057", message: "Cannot find a tsconfig.json file at the specified directory: '{0}'." },
+ The_specified_path_does_not_exist_Colon_0: { code: 5058, category: ts.DiagnosticCategory.Error, key: "The_specified_path_does_not_exist_Colon_0_5058", message: "The specified path does not exist: '{0}'." },
Invalid_value_for_reactNamespace_0_is_not_a_valid_identifier: { code: 5059, category: ts.DiagnosticCategory.Error, key: "Invalid_value_for_reactNamespace_0_is_not_a_valid_identifier_5059", message: "Invalid value for '--reactNamespace'. '{0}' is not a valid identifier." },
Option_paths_cannot_be_used_without_specifying_baseUrl_option: { code: 5060, category: ts.DiagnosticCategory.Error, key: "Option_paths_cannot_be_used_without_specifying_baseUrl_option_5060", message: "Option 'paths' cannot be used without specifying '--baseUrl' option." },
- Pattern_0_can_have_at_most_one_Asterisk_character: { code: 5061, category: ts.DiagnosticCategory.Error, key: "Pattern_0_can_have_at_most_one_Asterisk_character_5061", message: "Pattern '{0}' can have at most one '*' character" },
- Substitution_0_in_pattern_1_in_can_have_at_most_one_Asterisk_character: { code: 5062, category: ts.DiagnosticCategory.Error, key: "Substitution_0_in_pattern_1_in_can_have_at_most_one_Asterisk_character_5062", message: "Substitution '{0}' in pattern '{1}' in can have at most one '*' character" },
+ Pattern_0_can_have_at_most_one_Asterisk_character: { code: 5061, category: ts.DiagnosticCategory.Error, key: "Pattern_0_can_have_at_most_one_Asterisk_character_5061", message: "Pattern '{0}' can have at most one '*' character." },
+ Substitution_0_in_pattern_1_in_can_have_at_most_one_Asterisk_character: { code: 5062, category: ts.DiagnosticCategory.Error, key: "Substitution_0_in_pattern_1_in_can_have_at_most_one_Asterisk_character_5062", message: "Substitution '{0}' in pattern '{1}' in can have at most one '*' character." },
Substitutions_for_pattern_0_should_be_an_array: { code: 5063, category: ts.DiagnosticCategory.Error, key: "Substitutions_for_pattern_0_should_be_an_array_5063", message: "Substitutions for pattern '{0}' should be an array." },
Substitution_0_for_pattern_1_has_incorrect_type_expected_string_got_2: { code: 5064, category: ts.DiagnosticCategory.Error, key: "Substitution_0_for_pattern_1_has_incorrect_type_expected_string_got_2_5064", message: "Substitution '{0}' for pattern '{1}' has incorrect type, expected 'string', got '{2}'." },
File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: { code: 5065, category: ts.DiagnosticCategory.Error, key: "File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildca_5065", message: "File specification cannot contain a parent directory ('..') that appears after a recursive directory wildcard ('**'): '{0}'." },
@@ -3024,11 +3065,11 @@ var ts;
Do_not_emit_outputs: { code: 6010, category: ts.DiagnosticCategory.Message, key: "Do_not_emit_outputs_6010", message: "Do not emit outputs." },
Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typechecking: { code: 6011, category: ts.DiagnosticCategory.Message, key: "Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typech_6011", message: "Allow default imports from modules with no default export. This does not affect code emit, just typechecking." },
Skip_type_checking_of_declaration_files: { code: 6012, category: ts.DiagnosticCategory.Message, key: "Skip_type_checking_of_declaration_files_6012", message: "Skip type checking of declaration files." },
- Specify_ECMAScript_target_version_Colon_ES3_default_ES5_or_ES2015: { code: 6015, category: ts.DiagnosticCategory.Message, key: "Specify_ECMAScript_target_version_Colon_ES3_default_ES5_or_ES2015_6015", message: "Specify ECMAScript target version: 'ES3' (default), 'ES5', or 'ES2015'" },
- Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015: { code: 6016, category: ts.DiagnosticCategory.Message, key: "Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015_6016", message: "Specify module code generation: 'commonjs', 'amd', 'system', 'umd' or 'es2015'" },
+ Specify_ECMAScript_target_version_Colon_ES3_default_ES5_ES2015_ES2016_ES2017_or_ESNEXT: { code: 6015, category: ts.DiagnosticCategory.Message, key: "Specify_ECMAScript_target_version_Colon_ES3_default_ES5_ES2015_ES2016_ES2017_or_ESNEXT_6015", message: "Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', or 'ESNEXT'." },
+ Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015: { code: 6016, category: ts.DiagnosticCategory.Message, key: "Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015_6016", message: "Specify module code generation: 'commonjs', 'amd', 'system', 'umd' or 'es2015'." },
Print_this_message: { code: 6017, category: ts.DiagnosticCategory.Message, key: "Print_this_message_6017", message: "Print this message." },
Print_the_compiler_s_version: { code: 6019, category: ts.DiagnosticCategory.Message, key: "Print_the_compiler_s_version_6019", message: "Print the compiler's version." },
- Compile_the_project_in_the_given_directory: { code: 6020, category: ts.DiagnosticCategory.Message, key: "Compile_the_project_in_the_given_directory_6020", message: "Compile the project in the given directory." },
+ Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json: { code: 6020, category: ts.DiagnosticCategory.Message, key: "Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json_6020", message: "Compile the project given the path to its configuration file, or to a folder with a 'tsconfig.json'." },
Syntax_Colon_0: { code: 6023, category: ts.DiagnosticCategory.Message, key: "Syntax_Colon_0_6023", message: "Syntax: {0}" },
options: { code: 6024, category: ts.DiagnosticCategory.Message, key: "options_6024", message: "options" },
file: { code: 6025, category: ts.DiagnosticCategory.Message, key: "file_6025", message: "file" },
@@ -3043,11 +3084,12 @@ var ts;
LOCATION: { code: 6037, category: ts.DiagnosticCategory.Message, key: "LOCATION_6037", message: "LOCATION" },
DIRECTORY: { code: 6038, category: ts.DiagnosticCategory.Message, key: "DIRECTORY_6038", message: "DIRECTORY" },
STRATEGY: { code: 6039, category: ts.DiagnosticCategory.Message, key: "STRATEGY_6039", message: "STRATEGY" },
+ FILE_OR_DIRECTORY: { code: 6040, category: ts.DiagnosticCategory.Message, key: "FILE_OR_DIRECTORY_6040", message: "FILE OR DIRECTORY" },
Compilation_complete_Watching_for_file_changes: { code: 6042, category: ts.DiagnosticCategory.Message, key: "Compilation_complete_Watching_for_file_changes_6042", message: "Compilation complete. Watching for file changes." },
Generates_corresponding_map_file: { code: 6043, category: ts.DiagnosticCategory.Message, key: "Generates_corresponding_map_file_6043", message: "Generates corresponding '.map' file." },
Compiler_option_0_expects_an_argument: { code: 6044, category: ts.DiagnosticCategory.Error, key: "Compiler_option_0_expects_an_argument_6044", message: "Compiler option '{0}' expects an argument." },
Unterminated_quoted_string_in_response_file_0: { code: 6045, category: ts.DiagnosticCategory.Error, key: "Unterminated_quoted_string_in_response_file_0_6045", message: "Unterminated quoted string in response file '{0}'." },
- Argument_for_0_option_must_be_Colon_1: { code: 6046, category: ts.DiagnosticCategory.Error, key: "Argument_for_0_option_must_be_Colon_1_6046", message: "Argument for '{0}' option must be: {1}" },
+ Argument_for_0_option_must_be_Colon_1: { code: 6046, category: ts.DiagnosticCategory.Error, key: "Argument_for_0_option_must_be_Colon_1_6046", message: "Argument for '{0}' option must be: {1}." },
Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1: { code: 6048, category: ts.DiagnosticCategory.Error, key: "Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1_6048", message: "Locale must be of the form <language> or <language>-<territory>. For example '{0}' or '{1}'." },
Unsupported_locale_0: { code: 6049, category: ts.DiagnosticCategory.Error, key: "Unsupported_locale_0_6049", message: "Unsupported locale '{0}'." },
Unable_to_open_file_0: { code: 6050, category: ts.DiagnosticCategory.Error, key: "Unable_to_open_file_0_6050", message: "Unable to open file '{0}'." },
@@ -3069,17 +3111,18 @@ var ts;
Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file: { code: 6070, category: ts.DiagnosticCategory.Message, key: "Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file_6070", message: "Initializes a TypeScript project and creates a tsconfig.json file." },
Successfully_created_a_tsconfig_json_file: { code: 6071, category: ts.DiagnosticCategory.Message, key: "Successfully_created_a_tsconfig_json_file_6071", message: "Successfully created a tsconfig.json file." },
Suppress_excess_property_checks_for_object_literals: { code: 6072, category: ts.DiagnosticCategory.Message, key: "Suppress_excess_property_checks_for_object_literals_6072", message: "Suppress excess property checks for object literals." },
- Stylize_errors_and_messages_using_color_and_context_experimental: { code: 6073, category: ts.DiagnosticCategory.Message, key: "Stylize_errors_and_messages_using_color_and_context_experimental_6073", message: "Stylize errors and messages using color and context. (experimental)" },
+ Stylize_errors_and_messages_using_color_and_context_experimental: { code: 6073, category: ts.DiagnosticCategory.Message, key: "Stylize_errors_and_messages_using_color_and_context_experimental_6073", message: "Stylize errors and messages using color and context (experimental)." },
Do_not_report_errors_on_unused_labels: { code: 6074, category: ts.DiagnosticCategory.Message, key: "Do_not_report_errors_on_unused_labels_6074", message: "Do not report errors on unused labels." },
Report_error_when_not_all_code_paths_in_function_return_a_value: { code: 6075, category: ts.DiagnosticCategory.Message, key: "Report_error_when_not_all_code_paths_in_function_return_a_value_6075", message: "Report error when not all code paths in function return a value." },
Report_errors_for_fallthrough_cases_in_switch_statement: { code: 6076, category: ts.DiagnosticCategory.Message, key: "Report_errors_for_fallthrough_cases_in_switch_statement_6076", message: "Report errors for fallthrough cases in switch statement." },
Do_not_report_errors_on_unreachable_code: { code: 6077, category: ts.DiagnosticCategory.Message, key: "Do_not_report_errors_on_unreachable_code_6077", message: "Do not report errors on unreachable code." },
Disallow_inconsistently_cased_references_to_the_same_file: { code: 6078, category: ts.DiagnosticCategory.Message, key: "Disallow_inconsistently_cased_references_to_the_same_file_6078", message: "Disallow inconsistently-cased references to the same file." },
Specify_library_files_to_be_included_in_the_compilation_Colon: { code: 6079, category: ts.DiagnosticCategory.Message, key: "Specify_library_files_to_be_included_in_the_compilation_Colon_6079", message: "Specify library files to be included in the compilation: " },
- Specify_JSX_code_generation_Colon_preserve_or_react: { code: 6080, category: ts.DiagnosticCategory.Message, key: "Specify_JSX_code_generation_Colon_preserve_or_react_6080", message: "Specify JSX code generation: 'preserve' or 'react'" },
+ Specify_JSX_code_generation_Colon_preserve_react_native_or_react: { code: 6080, category: ts.DiagnosticCategory.Message, key: "Specify_JSX_code_generation_Colon_preserve_react_native_or_react_6080", message: "Specify JSX code generation: 'preserve', 'react-native', or 'react'." },
+ File_0_has_an_unsupported_extension_so_skipping_it: { code: 6081, category: ts.DiagnosticCategory.Message, key: "File_0_has_an_unsupported_extension_so_skipping_it_6081", message: "File '{0}' has an unsupported extension, so skipping it." },
Only_amd_and_system_modules_are_supported_alongside_0: { code: 6082, category: ts.DiagnosticCategory.Error, key: "Only_amd_and_system_modules_are_supported_alongside_0_6082", message: "Only 'amd' and 'system' modules are supported alongside --{0}." },
Base_directory_to_resolve_non_absolute_module_names: { code: 6083, category: ts.DiagnosticCategory.Message, key: "Base_directory_to_resolve_non_absolute_module_names_6083", message: "Base directory to resolve non-absolute module names." },
- Specify_the_object_invoked_for_createElement_and_spread_when_targeting_react_JSX_emit: { code: 6084, category: ts.DiagnosticCategory.Message, key: "Specify_the_object_invoked_for_createElement_and_spread_when_targeting_react_JSX_emit_6084", message: "Specify the object invoked for createElement and __spread when targeting 'react' JSX emit" },
+ Deprecated_Use_jsxFactory_instead_Specify_the_object_invoked_for_createElement_when_targeting_react_JSX_emit: { code: 6084, category: ts.DiagnosticCategory.Message, key: "Deprecated_Use_jsxFactory_instead_Specify_the_object_invoked_for_createElement_when_targeting_react__6084", message: "[Deprecated] Use '--jsxFactory' instead. Specify the object invoked for createElement when targeting 'react' JSX emit" },
Enable_tracing_of_the_name_resolution_process: { code: 6085, category: ts.DiagnosticCategory.Message, key: "Enable_tracing_of_the_name_resolution_process_6085", message: "Enable tracing of the name resolution process." },
Resolving_module_0_from_1: { code: 6086, category: ts.DiagnosticCategory.Message, key: "Resolving_module_0_from_1_6086", message: "======== Resolving module '{0}' from '{1}'. ========" },
Explicitly_specified_module_resolution_kind_Colon_0: { code: 6087, category: ts.DiagnosticCategory.Message, key: "Explicitly_specified_module_resolution_kind_Colon_0_6087", message: "Explicitly specified module resolution kind: '{0}'." },
@@ -3090,23 +3133,23 @@ var ts;
Module_name_0_matched_pattern_1: { code: 6092, category: ts.DiagnosticCategory.Message, key: "Module_name_0_matched_pattern_1_6092", message: "Module name '{0}', matched pattern '{1}'." },
Trying_substitution_0_candidate_module_location_Colon_1: { code: 6093, category: ts.DiagnosticCategory.Message, key: "Trying_substitution_0_candidate_module_location_Colon_1_6093", message: "Trying substitution '{0}', candidate module location: '{1}'." },
Resolving_module_name_0_relative_to_base_url_1_2: { code: 6094, category: ts.DiagnosticCategory.Message, key: "Resolving_module_name_0_relative_to_base_url_1_2_6094", message: "Resolving module name '{0}' relative to base url '{1}' - '{2}'." },
- Loading_module_as_file_Slash_folder_candidate_module_location_0: { code: 6095, category: ts.DiagnosticCategory.Message, key: "Loading_module_as_file_Slash_folder_candidate_module_location_0_6095", message: "Loading module as file / folder, candidate module location '{0}'." },
+ Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_type_1: { code: 6095, category: ts.DiagnosticCategory.Message, key: "Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_type_1_6095", message: "Loading module as file / folder, candidate module location '{0}', target file type '{1}'." },
File_0_does_not_exist: { code: 6096, category: ts.DiagnosticCategory.Message, key: "File_0_does_not_exist_6096", message: "File '{0}' does not exist." },
File_0_exist_use_it_as_a_name_resolution_result: { code: 6097, category: ts.DiagnosticCategory.Message, key: "File_0_exist_use_it_as_a_name_resolution_result_6097", message: "File '{0}' exist - use it as a name resolution result." },
- Loading_module_0_from_node_modules_folder: { code: 6098, category: ts.DiagnosticCategory.Message, key: "Loading_module_0_from_node_modules_folder_6098", message: "Loading module '{0}' from 'node_modules' folder." },
+ Loading_module_0_from_node_modules_folder_target_file_type_1: { code: 6098, category: ts.DiagnosticCategory.Message, key: "Loading_module_0_from_node_modules_folder_target_file_type_1_6098", message: "Loading module '{0}' from 'node_modules' folder, target file type '{1}'." },
Found_package_json_at_0: { code: 6099, category: ts.DiagnosticCategory.Message, key: "Found_package_json_at_0_6099", message: "Found 'package.json' at '{0}'." },
- package_json_does_not_have_a_types_or_main_field: { code: 6100, category: ts.DiagnosticCategory.Message, key: "package_json_does_not_have_a_types_or_main_field_6100", message: "'package.json' does not have a 'types' or 'main' field." },
+ package_json_does_not_have_a_0_field: { code: 6100, category: ts.DiagnosticCategory.Message, key: "package_json_does_not_have_a_0_field_6100", message: "'package.json' does not have a '{0}' field." },
package_json_has_0_field_1_that_references_2: { code: 6101, category: ts.DiagnosticCategory.Message, key: "package_json_has_0_field_1_that_references_2_6101", message: "'package.json' has '{0}' field '{1}' that references '{2}'." },
Allow_javascript_files_to_be_compiled: { code: 6102, category: ts.DiagnosticCategory.Message, key: "Allow_javascript_files_to_be_compiled_6102", message: "Allow javascript files to be compiled." },
Option_0_should_have_array_of_strings_as_a_value: { code: 6103, category: ts.DiagnosticCategory.Error, key: "Option_0_should_have_array_of_strings_as_a_value_6103", message: "Option '{0}' should have array of strings as a value." },
Checking_if_0_is_the_longest_matching_prefix_for_1_2: { code: 6104, category: ts.DiagnosticCategory.Message, key: "Checking_if_0_is_the_longest_matching_prefix_for_1_2_6104", message: "Checking if '{0}' is the longest matching prefix for '{1}' - '{2}'." },
Expected_type_of_0_field_in_package_json_to_be_string_got_1: { code: 6105, category: ts.DiagnosticCategory.Message, key: "Expected_type_of_0_field_in_package_json_to_be_string_got_1_6105", message: "Expected type of '{0}' field in 'package.json' to be 'string', got '{1}'." },
- baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1: { code: 6106, category: ts.DiagnosticCategory.Message, key: "baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1_6106", message: "'baseUrl' option is set to '{0}', using this value to resolve non-relative module name '{1}'" },
- rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0: { code: 6107, category: ts.DiagnosticCategory.Message, key: "rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0_6107", message: "'rootDirs' option is set, using it to resolve relative module name '{0}'" },
- Longest_matching_prefix_for_0_is_1: { code: 6108, category: ts.DiagnosticCategory.Message, key: "Longest_matching_prefix_for_0_is_1_6108", message: "Longest matching prefix for '{0}' is '{1}'" },
- Loading_0_from_the_root_dir_1_candidate_location_2: { code: 6109, category: ts.DiagnosticCategory.Message, key: "Loading_0_from_the_root_dir_1_candidate_location_2_6109", message: "Loading '{0}' from the root dir '{1}', candidate location '{2}'" },
- Trying_other_entries_in_rootDirs: { code: 6110, category: ts.DiagnosticCategory.Message, key: "Trying_other_entries_in_rootDirs_6110", message: "Trying other entries in 'rootDirs'" },
- Module_resolution_using_rootDirs_has_failed: { code: 6111, category: ts.DiagnosticCategory.Message, key: "Module_resolution_using_rootDirs_has_failed_6111", message: "Module resolution using 'rootDirs' has failed" },
+ baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1: { code: 6106, category: ts.DiagnosticCategory.Message, key: "baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1_6106", message: "'baseUrl' option is set to '{0}', using this value to resolve non-relative module name '{1}'." },
+ rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0: { code: 6107, category: ts.DiagnosticCategory.Message, key: "rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0_6107", message: "'rootDirs' option is set, using it to resolve relative module name '{0}'." },
+ Longest_matching_prefix_for_0_is_1: { code: 6108, category: ts.DiagnosticCategory.Message, key: "Longest_matching_prefix_for_0_is_1_6108", message: "Longest matching prefix for '{0}' is '{1}'." },
+ Loading_0_from_the_root_dir_1_candidate_location_2: { code: 6109, category: ts.DiagnosticCategory.Message, key: "Loading_0_from_the_root_dir_1_candidate_location_2_6109", message: "Loading '{0}' from the root dir '{1}', candidate location '{2}'." },
+ Trying_other_entries_in_rootDirs: { code: 6110, category: ts.DiagnosticCategory.Message, key: "Trying_other_entries_in_rootDirs_6110", message: "Trying other entries in 'rootDirs'." },
+ Module_resolution_using_rootDirs_has_failed: { code: 6111, category: ts.DiagnosticCategory.Message, key: "Module_resolution_using_rootDirs_has_failed_6111", message: "Module resolution using 'rootDirs' has failed." },
Do_not_emit_use_strict_directives_in_module_output: { code: 6112, category: ts.DiagnosticCategory.Message, key: "Do_not_emit_use_strict_directives_in_module_output_6112", message: "Do not emit 'use strict' directives in module output." },
Enable_strict_null_checks: { code: 6113, category: ts.DiagnosticCategory.Message, key: "Enable_strict_null_checks_6113", message: "Enable strict null checks." },
Unknown_option_excludes_Did_you_mean_exclude: { code: 6114, category: ts.DiagnosticCategory.Error, key: "Unknown_option_excludes_Did_you_mean_exclude_6114", message: "Unknown option 'excludes'. Did you mean 'exclude'?" },
@@ -3116,32 +3159,67 @@ var ts;
Resolving_from_node_modules_folder: { code: 6118, category: ts.DiagnosticCategory.Message, key: "Resolving_from_node_modules_folder_6118", message: "Resolving from node_modules folder..." },
Type_reference_directive_0_was_successfully_resolved_to_1_primary_Colon_2: { code: 6119, category: ts.DiagnosticCategory.Message, key: "Type_reference_directive_0_was_successfully_resolved_to_1_primary_Colon_2_6119", message: "======== Type reference directive '{0}' was successfully resolved to '{1}', primary: {2}. ========" },
Type_reference_directive_0_was_not_resolved: { code: 6120, category: ts.DiagnosticCategory.Message, key: "Type_reference_directive_0_was_not_resolved_6120", message: "======== Type reference directive '{0}' was not resolved. ========" },
- Resolving_with_primary_search_path_0: { code: 6121, category: ts.DiagnosticCategory.Message, key: "Resolving_with_primary_search_path_0_6121", message: "Resolving with primary search path '{0}'" },
+ Resolving_with_primary_search_path_0: { code: 6121, category: ts.DiagnosticCategory.Message, key: "Resolving_with_primary_search_path_0_6121", message: "Resolving with primary search path '{0}'." },
Root_directory_cannot_be_determined_skipping_primary_search_paths: { code: 6122, category: ts.DiagnosticCategory.Message, key: "Root_directory_cannot_be_determined_skipping_primary_search_paths_6122", message: "Root directory cannot be determined, skipping primary search paths." },
Resolving_type_reference_directive_0_containing_file_1_root_directory_not_set: { code: 6123, category: ts.DiagnosticCategory.Message, key: "Resolving_type_reference_directive_0_containing_file_1_root_directory_not_set_6123", message: "======== Resolving type reference directive '{0}', containing file '{1}', root directory not set. ========" },
Type_declaration_files_to_be_included_in_compilation: { code: 6124, category: ts.DiagnosticCategory.Message, key: "Type_declaration_files_to_be_included_in_compilation_6124", message: "Type declaration files to be included in compilation." },
- Looking_up_in_node_modules_folder_initial_location_0: { code: 6125, category: ts.DiagnosticCategory.Message, key: "Looking_up_in_node_modules_folder_initial_location_0_6125", message: "Looking up in 'node_modules' folder, initial location '{0}'" },
+ Looking_up_in_node_modules_folder_initial_location_0: { code: 6125, category: ts.DiagnosticCategory.Message, key: "Looking_up_in_node_modules_folder_initial_location_0_6125", message: "Looking up in 'node_modules' folder, initial location '{0}'." },
Containing_file_is_not_specified_and_root_directory_cannot_be_determined_skipping_lookup_in_node_modules_folder: { code: 6126, category: ts.DiagnosticCategory.Message, key: "Containing_file_is_not_specified_and_root_directory_cannot_be_determined_skipping_lookup_in_node_mod_6126", message: "Containing file is not specified and root directory cannot be determined, skipping lookup in 'node_modules' folder." },
Resolving_type_reference_directive_0_containing_file_not_set_root_directory_1: { code: 6127, category: ts.DiagnosticCategory.Message, key: "Resolving_type_reference_directive_0_containing_file_not_set_root_directory_1_6127", message: "======== Resolving type reference directive '{0}', containing file not set, root directory '{1}'. ========" },
Resolving_type_reference_directive_0_containing_file_not_set_root_directory_not_set: { code: 6128, category: ts.DiagnosticCategory.Message, key: "Resolving_type_reference_directive_0_containing_file_not_set_root_directory_not_set_6128", message: "======== Resolving type reference directive '{0}', containing file not set, root directory not set. ========" },
The_config_file_0_found_doesn_t_contain_any_source_files: { code: 6129, category: ts.DiagnosticCategory.Error, key: "The_config_file_0_found_doesn_t_contain_any_source_files_6129", message: "The config file '{0}' found doesn't contain any source files." },
- Resolving_real_path_for_0_result_1: { code: 6130, category: ts.DiagnosticCategory.Message, key: "Resolving_real_path_for_0_result_1_6130", message: "Resolving real path for '{0}', result '{1}'" },
+ Resolving_real_path_for_0_result_1: { code: 6130, category: ts.DiagnosticCategory.Message, key: "Resolving_real_path_for_0_result_1_6130", message: "Resolving real path for '{0}', result '{1}'." },
Cannot_compile_modules_using_option_0_unless_the_module_flag_is_amd_or_system: { code: 6131, category: ts.DiagnosticCategory.Error, key: "Cannot_compile_modules_using_option_0_unless_the_module_flag_is_amd_or_system_6131", message: "Cannot compile modules using option '{0}' unless the '--module' flag is 'amd' or 'system'." },
- File_name_0_has_a_1_extension_stripping_it: { code: 6132, category: ts.DiagnosticCategory.Message, key: "File_name_0_has_a_1_extension_stripping_it_6132", message: "File name '{0}' has a '{1}' extension - stripping it" },
+ File_name_0_has_a_1_extension_stripping_it: { code: 6132, category: ts.DiagnosticCategory.Message, key: "File_name_0_has_a_1_extension_stripping_it_6132", message: "File name '{0}' has a '{1}' extension - stripping it." },
_0_is_declared_but_never_used: { code: 6133, category: ts.DiagnosticCategory.Error, key: "_0_is_declared_but_never_used_6133", message: "'{0}' is declared but never used." },
Report_errors_on_unused_locals: { code: 6134, category: ts.DiagnosticCategory.Message, key: "Report_errors_on_unused_locals_6134", message: "Report errors on unused locals." },
Report_errors_on_unused_parameters: { code: 6135, category: ts.DiagnosticCategory.Message, key: "Report_errors_on_unused_parameters_6135", message: "Report errors on unused parameters." },
- The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files: { code: 6136, category: ts.DiagnosticCategory.Message, key: "The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files_6136", message: "The maximum dependency depth to search under node_modules and load JavaScript files" },
- No_types_specified_in_package_json_so_returning_main_value_of_0: { code: 6137, category: ts.DiagnosticCategory.Message, key: "No_types_specified_in_package_json_so_returning_main_value_of_0_6137", message: "No types specified in 'package.json', so returning 'main' value of '{0}'" },
+ The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files: { code: 6136, category: ts.DiagnosticCategory.Message, key: "The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files_6136", message: "The maximum dependency depth to search under node_modules and load JavaScript files." },
Property_0_is_declared_but_never_used: { code: 6138, category: ts.DiagnosticCategory.Error, key: "Property_0_is_declared_but_never_used_6138", message: "Property '{0}' is declared but never used." },
Import_emit_helpers_from_tslib: { code: 6139, category: ts.DiagnosticCategory.Message, key: "Import_emit_helpers_from_tslib_6139", message: "Import emit helpers from 'tslib'." },
Auto_discovery_for_typings_is_enabled_in_project_0_Running_extra_resolution_pass_for_module_1_using_cache_location_2: { code: 6140, category: ts.DiagnosticCategory.Error, key: "Auto_discovery_for_typings_is_enabled_in_project_0_Running_extra_resolution_pass_for_module_1_using__6140", message: "Auto discovery for typings is enabled in project '{0}'. Running extra resolution pass for module '{1}' using cache location '{2}'." },
- Parse_in_strict_mode_and_emit_use_strict_for_each_source_file: { code: 6141, category: ts.DiagnosticCategory.Message, key: "Parse_in_strict_mode_and_emit_use_strict_for_each_source_file_6141", message: "Parse in strict mode and emit \"use strict\" for each source file" },
+ Parse_in_strict_mode_and_emit_use_strict_for_each_source_file: { code: 6141, category: ts.DiagnosticCategory.Message, key: "Parse_in_strict_mode_and_emit_use_strict_for_each_source_file_6141", message: "Parse in strict mode and emit \"use strict\" for each source file." },
Module_0_was_resolved_to_1_but_jsx_is_not_set: { code: 6142, category: ts.DiagnosticCategory.Error, key: "Module_0_was_resolved_to_1_but_jsx_is_not_set_6142", message: "Module '{0}' was resolved to '{1}', but '--jsx' is not set." },
Module_0_was_resolved_to_1_but_allowJs_is_not_set: { code: 6143, category: ts.DiagnosticCategory.Error, key: "Module_0_was_resolved_to_1_but_allowJs_is_not_set_6143", message: "Module '{0}' was resolved to '{1}', but '--allowJs' is not set." },
Module_0_was_resolved_as_locally_declared_ambient_module_in_file_1: { code: 6144, category: ts.DiagnosticCategory.Message, key: "Module_0_was_resolved_as_locally_declared_ambient_module_in_file_1_6144", message: "Module '{0}' was resolved as locally declared ambient module in file '{1}'." },
Module_0_was_resolved_as_ambient_module_declared_in_1_since_this_file_was_not_modified: { code: 6145, category: ts.DiagnosticCategory.Message, key: "Module_0_was_resolved_as_ambient_module_declared_in_1_since_this_file_was_not_modified_6145", message: "Module '{0}' was resolved as ambient module declared in '{1}' since this file was not modified." },
Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h: { code: 6146, category: ts.DiagnosticCategory.Message, key: "Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h_6146", message: "Specify the JSX factory function to use when targeting 'react' JSX emit, e.g. 'React.createElement' or 'h'." },
+ Resolution_for_module_0_was_found_in_cache: { code: 6147, category: ts.DiagnosticCategory.Message, key: "Resolution_for_module_0_was_found_in_cache_6147", message: "Resolution for module '{0}' was found in cache." },
+ Directory_0_does_not_exist_skipping_all_lookups_in_it: { code: 6148, category: ts.DiagnosticCategory.Message, key: "Directory_0_does_not_exist_skipping_all_lookups_in_it_6148", message: "Directory '{0}' does not exist, skipping all lookups in it." },
+ Show_diagnostic_information: { code: 6149, category: ts.DiagnosticCategory.Message, key: "Show_diagnostic_information_6149", message: "Show diagnostic information." },
+ Show_verbose_diagnostic_information: { code: 6150, category: ts.DiagnosticCategory.Message, key: "Show_verbose_diagnostic_information_6150", message: "Show verbose diagnostic information." },
+ Emit_a_single_file_with_source_maps_instead_of_having_a_separate_file: { code: 6151, category: ts.DiagnosticCategory.Message, key: "Emit_a_single_file_with_source_maps_instead_of_having_a_separate_file_6151", message: "Emit a single file with source maps instead of having a separate file." },
+ Emit_the_source_alongside_the_sourcemaps_within_a_single_file_requires_inlineSourceMap_or_sourceMap_to_be_set: { code: 6152, category: ts.DiagnosticCategory.Message, key: "Emit_the_source_alongside_the_sourcemaps_within_a_single_file_requires_inlineSourceMap_or_sourceMap__6152", message: "Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set." },
+ Transpile_each_file_as_a_separate_module_similar_to_ts_transpileModule: { code: 6153, category: ts.DiagnosticCategory.Message, key: "Transpile_each_file_as_a_separate_module_similar_to_ts_transpileModule_6153", message: "Transpile each file as a separate module (similar to 'ts.transpileModule')." },
+ Print_names_of_generated_files_part_of_the_compilation: { code: 6154, category: ts.DiagnosticCategory.Message, key: "Print_names_of_generated_files_part_of_the_compilation_6154", message: "Print names of generated files part of the compilation." },
+ Print_names_of_files_part_of_the_compilation: { code: 6155, category: ts.DiagnosticCategory.Message, key: "Print_names_of_files_part_of_the_compilation_6155", message: "Print names of files part of the compilation." },
+ The_locale_used_when_displaying_messages_to_the_user_e_g_en_us: { code: 6156, category: ts.DiagnosticCategory.Message, key: "The_locale_used_when_displaying_messages_to_the_user_e_g_en_us_6156", message: "The locale used when displaying messages to the user (e.g. 'en-us')" },
+ Do_not_generate_custom_helper_functions_like_extends_in_compiled_output: { code: 6157, category: ts.DiagnosticCategory.Message, key: "Do_not_generate_custom_helper_functions_like_extends_in_compiled_output_6157", message: "Do not generate custom helper functions like '__extends' in compiled output." },
+ Do_not_include_the_default_library_file_lib_d_ts: { code: 6158, category: ts.DiagnosticCategory.Message, key: "Do_not_include_the_default_library_file_lib_d_ts_6158", message: "Do not include the default library file (lib.d.ts)." },
+ Do_not_add_triple_slash_references_or_imported_modules_to_the_list_of_compiled_files: { code: 6159, category: ts.DiagnosticCategory.Message, key: "Do_not_add_triple_slash_references_or_imported_modules_to_the_list_of_compiled_files_6159", message: "Do not add triple-slash references or imported modules to the list of compiled files." },
+ Deprecated_Use_skipLibCheck_instead_Skip_type_checking_of_default_library_declaration_files: { code: 6160, category: ts.DiagnosticCategory.Message, key: "Deprecated_Use_skipLibCheck_instead_Skip_type_checking_of_default_library_declaration_files_6160", message: "[Deprecated] Use '--skipLibCheck' instead. Skip type checking of default library declaration files." },
+ List_of_folders_to_include_type_definitions_from: { code: 6161, category: ts.DiagnosticCategory.Message, key: "List_of_folders_to_include_type_definitions_from_6161", message: "List of folders to include type definitions from." },
+ Disable_size_limitations_on_JavaScript_projects: { code: 6162, category: ts.DiagnosticCategory.Message, key: "Disable_size_limitations_on_JavaScript_projects_6162", message: "Disable size limitations on JavaScript projects." },
+ The_character_set_of_the_input_files: { code: 6163, category: ts.DiagnosticCategory.Message, key: "The_character_set_of_the_input_files_6163", message: "The character set of the input files." },
+ Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files: { code: 6164, category: ts.DiagnosticCategory.Message, key: "Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files_6164", message: "Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files." },
+ Do_not_truncate_error_messages: { code: 6165, category: ts.DiagnosticCategory.Message, key: "Do_not_truncate_error_messages_6165", message: "Do not truncate error messages." },
+ Output_directory_for_generated_declaration_files: { code: 6166, category: ts.DiagnosticCategory.Message, key: "Output_directory_for_generated_declaration_files_6166", message: "Output directory for generated declaration files." },
+ A_series_of_entries_which_re_map_imports_to_lookup_locations_relative_to_the_baseUrl: { code: 6167, category: ts.DiagnosticCategory.Message, key: "A_series_of_entries_which_re_map_imports_to_lookup_locations_relative_to_the_baseUrl_6167", message: "A series of entries which re-map imports to lookup locations relative to the 'baseUrl'." },
+ List_of_root_folders_whose_combined_content_represents_the_structure_of_the_project_at_runtime: { code: 6168, category: ts.DiagnosticCategory.Message, key: "List_of_root_folders_whose_combined_content_represents_the_structure_of_the_project_at_runtime_6168", message: "List of root folders whose combined content represents the structure of the project at runtime." },
+ Show_all_compiler_options: { code: 6169, category: ts.DiagnosticCategory.Message, key: "Show_all_compiler_options_6169", message: "Show all compiler options." },
+ Deprecated_Use_outFile_instead_Concatenate_and_emit_output_to_single_file: { code: 6170, category: ts.DiagnosticCategory.Message, key: "Deprecated_Use_outFile_instead_Concatenate_and_emit_output_to_single_file_6170", message: "[Deprecated] Use '--outFile' instead. Concatenate and emit output to single file" },
+ Command_line_Options: { code: 6171, category: ts.DiagnosticCategory.Message, key: "Command_line_Options_6171", message: "Command-line Options" },
+ Basic_Options: { code: 6172, category: ts.DiagnosticCategory.Message, key: "Basic_Options_6172", message: "Basic Options" },
+ Strict_Type_Checking_Options: { code: 6173, category: ts.DiagnosticCategory.Message, key: "Strict_Type_Checking_Options_6173", message: "Strict Type-Checking Options" },
+ Module_Resolution_Options: { code: 6174, category: ts.DiagnosticCategory.Message, key: "Module_Resolution_Options_6174", message: "Module Resolution Options" },
+ Source_Map_Options: { code: 6175, category: ts.DiagnosticCategory.Message, key: "Source_Map_Options_6175", message: "Source Map Options" },
+ Additional_Checks: { code: 6176, category: ts.DiagnosticCategory.Message, key: "Additional_Checks_6176", message: "Additional Checks" },
+ Experimental_Options: { code: 6177, category: ts.DiagnosticCategory.Message, key: "Experimental_Options_6177", message: "Experimental Options" },
+ Advanced_Options: { code: 6178, category: ts.DiagnosticCategory.Message, key: "Advanced_Options_6178", message: "Advanced Options" },
+ Provide_full_support_for_iterables_in_for_of_spread_and_destructuring_when_targeting_ES5_or_ES3: { code: 6179, category: ts.DiagnosticCategory.Message, key: "Provide_full_support_for_iterables_in_for_of_spread_and_destructuring_when_targeting_ES5_or_ES3_6179", message: "Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'." },
+ Enable_all_strict_type_checking_options: { code: 6180, category: ts.DiagnosticCategory.Message, key: "Enable_all_strict_type_checking_options_6180", message: "Enable all strict type-checking options." },
+ List_of_language_service_plugins: { code: 6181, category: ts.DiagnosticCategory.Message, key: "List_of_language_service_plugins_6181", message: "List of language service plugins." },
+ Scoped_package_detected_looking_in_0: { code: 6182, category: ts.DiagnosticCategory.Message, key: "Scoped_package_detected_looking_in_0_6182", message: "Scoped package detected, looking in '{0}'" },
Variable_0_implicitly_has_an_1_type: { code: 7005, category: ts.DiagnosticCategory.Error, key: "Variable_0_implicitly_has_an_1_type_7005", message: "Variable '{0}' implicitly has an '{1}' type." },
Parameter_0_implicitly_has_an_1_type: { code: 7006, category: ts.DiagnosticCategory.Error, key: "Parameter_0_implicitly_has_an_1_type_7006", message: "Parameter '{0}' implicitly has an '{1}' type." },
Member_0_implicitly_has_an_1_type: { code: 7008, category: ts.DiagnosticCategory.Error, key: "Member_0_implicitly_has_an_1_type_7008", message: "Member '{0}' implicitly has an '{1}' type." },
@@ -3159,7 +3237,7 @@ var ts;
_0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions: { code: 7023, category: ts.DiagnosticCategory.Error, key: "_0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_reference_7023", message: "'{0}' implicitly has return type 'any' because it does not have a return type annotation and is referenced directly or indirectly in one of its return expressions." },
Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions: { code: 7024, category: ts.DiagnosticCategory.Error, key: "Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_ref_7024", message: "Function implicitly has return type 'any' because it does not have a return type annotation and is referenced directly or indirectly in one of its return expressions." },
Generator_implicitly_has_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type: { code: 7025, category: ts.DiagnosticCategory.Error, key: "Generator_implicitly_has_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_typ_7025", message: "Generator implicitly has type '{0}' because it does not yield any values. Consider supplying a return type." },
- JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists: { code: 7026, category: ts.DiagnosticCategory.Error, key: "JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists_7026", message: "JSX element implicitly has type 'any' because no interface 'JSX.{0}' exists" },
+ JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists: { code: 7026, category: ts.DiagnosticCategory.Error, key: "JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists_7026", message: "JSX element implicitly has type 'any' because no interface 'JSX.{0}' exists." },
Unreachable_code_detected: { code: 7027, category: ts.DiagnosticCategory.Error, key: "Unreachable_code_detected_7027", message: "Unreachable code detected." },
Unused_label: { code: 7028, category: ts.DiagnosticCategory.Error, key: "Unused_label_7028", message: "Unused label." },
Fallthrough_case_in_switch: { code: 7029, category: ts.DiagnosticCategory.Error, key: "Fallthrough_case_in_switch_7029", message: "Fallthrough case in switch." },
@@ -3183,7 +3261,7 @@ var ts;
parameter_modifiers_can_only_be_used_in_a_ts_file: { code: 8012, category: ts.DiagnosticCategory.Error, key: "parameter_modifiers_can_only_be_used_in_a_ts_file_8012", message: "'parameter modifiers' can only be used in a .ts file." },
enum_declarations_can_only_be_used_in_a_ts_file: { code: 8015, category: ts.DiagnosticCategory.Error, key: "enum_declarations_can_only_be_used_in_a_ts_file_8015", message: "'enum declarations' can only be used in a .ts file." },
type_assertion_expressions_can_only_be_used_in_a_ts_file: { code: 8016, category: ts.DiagnosticCategory.Error, key: "type_assertion_expressions_can_only_be_used_in_a_ts_file_8016", message: "'type assertion expressions' can only be used in a .ts file." },
- Only_identifiers_Slashqualified_names_with_optional_type_arguments_are_currently_supported_in_a_class_extends_clauses: { code: 9002, category: ts.DiagnosticCategory.Error, key: "Only_identifiers_Slashqualified_names_with_optional_type_arguments_are_currently_supported_in_a_clas_9002", message: "Only identifiers/qualified-names with optional type arguments are currently supported in a class 'extends' clauses." },
+ Only_identifiers_Slashqualified_names_with_optional_type_arguments_are_currently_supported_in_a_class_extends_clause: { code: 9002, category: ts.DiagnosticCategory.Error, key: "Only_identifiers_Slashqualified_names_with_optional_type_arguments_are_currently_supported_in_a_clas_9002", message: "Only identifiers/qualified-names with optional type arguments are currently supported in a class 'extends' clause." },
class_expressions_are_not_currently_supported: { code: 9003, category: ts.DiagnosticCategory.Error, key: "class_expressions_are_not_currently_supported_9003", message: "'class' expressions are not currently supported." },
Language_service_is_disabled: { code: 9004, category: ts.DiagnosticCategory.Error, key: "Language_service_is_disabled_9004", message: "Language service is disabled." },
JSX_attributes_must_only_be_assigned_a_non_empty_expression: { code: 17000, category: ts.DiagnosticCategory.Error, key: "JSX_attributes_must_only_be_assigned_a_non_empty_expression_17000", message: "JSX attributes must only be assigned a non-empty 'expression'." },
@@ -3191,28 +3269,40 @@ var ts;
Expected_corresponding_JSX_closing_tag_for_0: { code: 17002, category: ts.DiagnosticCategory.Error, key: "Expected_corresponding_JSX_closing_tag_for_0_17002", message: "Expected corresponding JSX closing tag for '{0}'." },
JSX_attribute_expected: { code: 17003, category: ts.DiagnosticCategory.Error, key: "JSX_attribute_expected_17003", message: "JSX attribute expected." },
Cannot_use_JSX_unless_the_jsx_flag_is_provided: { code: 17004, category: ts.DiagnosticCategory.Error, key: "Cannot_use_JSX_unless_the_jsx_flag_is_provided_17004", message: "Cannot use JSX unless the '--jsx' flag is provided." },
- A_constructor_cannot_contain_a_super_call_when_its_class_extends_null: { code: 17005, category: ts.DiagnosticCategory.Error, key: "A_constructor_cannot_contain_a_super_call_when_its_class_extends_null_17005", message: "A constructor cannot contain a 'super' call when its class extends 'null'" },
+ A_constructor_cannot_contain_a_super_call_when_its_class_extends_null: { code: 17005, category: ts.DiagnosticCategory.Error, key: "A_constructor_cannot_contain_a_super_call_when_its_class_extends_null_17005", message: "A constructor cannot contain a 'super' call when its class extends 'null'." },
An_unary_expression_with_the_0_operator_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses: { code: 17006, category: ts.DiagnosticCategory.Error, key: "An_unary_expression_with_the_0_operator_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_ex_17006", message: "An unary expression with the '{0}' operator is not allowed in the left-hand side of an exponentiation expression. Consider enclosing the expression in parentheses." },
A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses: { code: 17007, category: ts.DiagnosticCategory.Error, key: "A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Con_17007", message: "A type assertion expression is not allowed in the left-hand side of an exponentiation expression. Consider enclosing the expression in parentheses." },
JSX_element_0_has_no_corresponding_closing_tag: { code: 17008, category: ts.DiagnosticCategory.Error, key: "JSX_element_0_has_no_corresponding_closing_tag_17008", message: "JSX element '{0}' has no corresponding closing tag." },
super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class: { code: 17009, category: ts.DiagnosticCategory.Error, key: "super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class_17009", message: "'super' must be called before accessing 'this' in the constructor of a derived class." },
Unknown_type_acquisition_option_0: { code: 17010, category: ts.DiagnosticCategory.Error, key: "Unknown_type_acquisition_option_0_17010", message: "Unknown type acquisition option '{0}'." },
+ super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class: { code: 17011, category: ts.DiagnosticCategory.Error, key: "super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class_17011", message: "'super' must be called before accessing a property of 'super' in the constructor of a derived class." },
+ _0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2: { code: 17012, category: ts.DiagnosticCategory.Error, key: "_0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2_17012", message: "'{0}' is not a valid meta-property for keyword '{1}'. Did you mean '{2}'?" },
+ Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor: { code: 17013, category: ts.DiagnosticCategory.Error, key: "Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constru_17013", message: "Meta-property '{0}' is only allowed in the body of a function declaration, function expression, or constructor." },
Circularity_detected_while_resolving_configuration_Colon_0: { code: 18000, category: ts.DiagnosticCategory.Error, key: "Circularity_detected_while_resolving_configuration_Colon_0_18000", message: "Circularity detected while resolving configuration: {0}" },
A_path_in_an_extends_option_must_be_relative_or_rooted_but_0_is_not: { code: 18001, category: ts.DiagnosticCategory.Error, key: "A_path_in_an_extends_option_must_be_relative_or_rooted_but_0_is_not_18001", message: "A path in an 'extends' option must be relative or rooted, but '{0}' is not." },
The_files_list_in_config_file_0_is_empty: { code: 18002, category: ts.DiagnosticCategory.Error, key: "The_files_list_in_config_file_0_is_empty_18002", message: "The 'files' list in config file '{0}' is empty." },
No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2: { code: 18003, category: ts.DiagnosticCategory.Error, key: "No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2_18003", message: "No inputs were found in config file '{0}'. Specified 'include' paths were '{1}' and 'exclude' paths were '{2}'." },
Add_missing_super_call: { code: 90001, category: ts.DiagnosticCategory.Message, key: "Add_missing_super_call_90001", message: "Add missing 'super()' call." },
Make_super_call_the_first_statement_in_the_constructor: { code: 90002, category: ts.DiagnosticCategory.Message, key: "Make_super_call_the_first_statement_in_the_constructor_90002", message: "Make 'super()' call the first statement in the constructor." },
- Change_extends_to_implements: { code: 90003, category: ts.DiagnosticCategory.Message, key: "Change_extends_to_implements_90003", message: "Change 'extends' to 'implements'" },
- Remove_unused_identifiers: { code: 90004, category: ts.DiagnosticCategory.Message, key: "Remove_unused_identifiers_90004", message: "Remove unused identifiers" },
- Implement_interface_on_reference: { code: 90005, category: ts.DiagnosticCategory.Message, key: "Implement_interface_on_reference_90005", message: "Implement interface on reference" },
- Implement_interface_on_class: { code: 90006, category: ts.DiagnosticCategory.Message, key: "Implement_interface_on_class_90006", message: "Implement interface on class" },
- Implement_inherited_abstract_class: { code: 90007, category: ts.DiagnosticCategory.Message, key: "Implement_inherited_abstract_class_90007", message: "Implement inherited abstract class" },
- Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript_files_Learn_more_at_https_Colon_Slash_Slashaka_ms_Slashtsconfig: { code: 90009, category: ts.DiagnosticCategory.Error, key: "Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript__90009", message: "Adding a tsconfig.json file will help organize projects that contain both TypeScript and JavaScript files. Learn more at https://aka.ms/tsconfig" },
+ Change_extends_to_implements: { code: 90003, category: ts.DiagnosticCategory.Message, key: "Change_extends_to_implements_90003", message: "Change 'extends' to 'implements'." },
+ Remove_declaration_for_Colon_0: { code: 90004, category: ts.DiagnosticCategory.Message, key: "Remove_declaration_for_Colon_0_90004", message: "Remove declaration for: '{0}'." },
+ Implement_interface_0: { code: 90006, category: ts.DiagnosticCategory.Message, key: "Implement_interface_0_90006", message: "Implement interface '{0}'." },
+ Implement_inherited_abstract_class: { code: 90007, category: ts.DiagnosticCategory.Message, key: "Implement_inherited_abstract_class_90007", message: "Implement inherited abstract class." },
+ Add_this_to_unresolved_variable: { code: 90008, category: ts.DiagnosticCategory.Message, key: "Add_this_to_unresolved_variable_90008", message: "Add 'this.' to unresolved variable." },
+ Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript_files_Learn_more_at_https_Colon_Slash_Slashaka_ms_Slashtsconfig: { code: 90009, category: ts.DiagnosticCategory.Error, key: "Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript__90009", message: "Adding a tsconfig.json file will help organize projects that contain both TypeScript and JavaScript files. Learn more at https://aka.ms/tsconfig." },
Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated: { code: 90010, category: ts.DiagnosticCategory.Error, key: "Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated_90010", message: "Type '{0}' is not assignable to type '{1}'. Two different types with this name exist, but they are unrelated." },
- Import_0_from_1: { code: 90013, category: ts.DiagnosticCategory.Message, key: "Import_0_from_1_90013", message: "Import {0} from {1}" },
- Change_0_to_1: { code: 90014, category: ts.DiagnosticCategory.Message, key: "Change_0_to_1_90014", message: "Change {0} to {1}" },
- Add_0_to_existing_import_declaration_from_1: { code: 90015, category: ts.DiagnosticCategory.Message, key: "Add_0_to_existing_import_declaration_from_1_90015", message: "Add {0} to existing import declaration from {1}" },
+ Import_0_from_1: { code: 90013, category: ts.DiagnosticCategory.Message, key: "Import_0_from_1_90013", message: "Import {0} from {1}." },
+ Change_0_to_1: { code: 90014, category: ts.DiagnosticCategory.Message, key: "Change_0_to_1_90014", message: "Change {0} to {1}." },
+ Add_0_to_existing_import_declaration_from_1: { code: 90015, category: ts.DiagnosticCategory.Message, key: "Add_0_to_existing_import_declaration_from_1_90015", message: "Add {0} to existing import declaration from {1}." },
+ Add_declaration_for_missing_property_0: { code: 90016, category: ts.DiagnosticCategory.Message, key: "Add_declaration_for_missing_property_0_90016", message: "Add declaration for missing property '{0}'." },
+ Add_index_signature_for_missing_property_0: { code: 90017, category: ts.DiagnosticCategory.Message, key: "Add_index_signature_for_missing_property_0_90017", message: "Add index signature for missing property '{0}'." },
+ Disable_checking_for_this_file: { code: 90018, category: ts.DiagnosticCategory.Message, key: "Disable_checking_for_this_file_90018", message: "Disable checking for this file." },
+ Ignore_this_error_message: { code: 90019, category: ts.DiagnosticCategory.Message, key: "Ignore_this_error_message_90019", message: "Ignore this error message." },
+ Initialize_property_0_in_the_constructor: { code: 90020, category: ts.DiagnosticCategory.Message, key: "Initialize_property_0_in_the_constructor_90020", message: "Initialize property '{0}' in the constructor." },
+ Initialize_static_property_0: { code: 90021, category: ts.DiagnosticCategory.Message, key: "Initialize_static_property_0_90021", message: "Initialize static property '{0}'." },
+ Octal_literal_types_must_use_ES2015_syntax_Use_the_syntax_0: { code: 8017, category: ts.DiagnosticCategory.Error, key: "Octal_literal_types_must_use_ES2015_syntax_Use_the_syntax_0_8017", message: "Octal literal types must use ES2015 syntax. Use the syntax '{0}'." },
+ Octal_literals_are_not_allowed_in_enums_members_initializer_Use_the_syntax_0: { code: 8018, category: ts.DiagnosticCategory.Error, key: "Octal_literals_are_not_allowed_in_enums_members_initializer_Use_the_syntax_0_8018", message: "Octal literals are not allowed in enums members initializer. Use the syntax '{0}'." },
+ Report_errors_in_js_files: { code: 8019, category: ts.DiagnosticCategory.Message, key: "Report_errors_in_js_files_8019", message: "Report errors in .js files." },
};
})(ts || (ts = {}));
var ts;
@@ -3221,7 +3311,7 @@ var ts;
return token >= 70;
}
ts.tokenIsIdentifierOrKeyword = tokenIsIdentifierOrKeyword;
- var textToToken = ts.createMap({
+ var textToToken = ts.createMapFromTemplate({
"abstract": 116,
"any": 118,
"as": 117,
@@ -3245,7 +3335,7 @@ var ts;
"false": 85,
"finally": 86,
"for": 87,
- "from": 138,
+ "from": 139,
"function": 88,
"get": 124,
"if": 89,
@@ -3263,27 +3353,28 @@ var ts;
"new": 93,
"null": 94,
"number": 132,
+ "object": 133,
"package": 110,
"private": 111,
"protected": 112,
"public": 113,
"readonly": 130,
"require": 131,
- "global": 139,
+ "global": 140,
"return": 95,
- "set": 133,
+ "set": 134,
"static": 114,
- "string": 134,
+ "string": 135,
"super": 96,
"switch": 97,
- "symbol": 135,
+ "symbol": 136,
"this": 98,
"throw": 99,
"true": 100,
"try": 101,
- "type": 136,
+ "type": 137,
"typeof": 102,
- "undefined": 137,
+ "undefined": 138,
"var": 103,
"void": 104,
"while": 105,
@@ -3291,7 +3382,7 @@ var ts;
"yield": 115,
"async": 119,
"await": 120,
- "of": 140,
+ "of": 141,
"{": 16,
"}": 17,
"(": 18,
@@ -3386,9 +3477,9 @@ var ts;
}
function makeReverseMap(source) {
var result = [];
- for (var name_4 in source) {
- result[source[name_4]] = name_4;
- }
+ source.forEach(function (value, name) {
+ result[value] = name;
+ });
return result;
}
var tokenStrings = makeReverseMap(textToToken);
@@ -3397,7 +3488,7 @@ var ts;
}
ts.tokenToString = tokenToString;
function stringToToken(s) {
- return textToToken[s];
+ return textToToken.get(s);
}
ts.stringToToken = stringToToken;
function computeLineStarts(text) {
@@ -3457,7 +3548,6 @@ var ts;
return computeLineAndCharacterOfPosition(getLineStarts(sourceFile), position);
}
ts.getLineAndCharacterOfPosition = getLineAndCharacterOfPosition;
- var hasOwnProperty = Object.prototype.hasOwnProperty;
function isWhiteSpace(ch) {
return isWhiteSpaceSingleLine(ch) || isLineBreak(ch);
}
@@ -3593,7 +3683,7 @@ var ts;
if (pos === 0 || isLineBreak(text.charCodeAt(pos - 1))) {
var ch = text.charCodeAt(pos);
if ((pos + mergeConflictMarkerLength) < text.length) {
- for (var i = 0, n = mergeConflictMarkerLength; i < n; i++) {
+ for (var i = 0; i < mergeConflictMarkerLength; i++) {
if (text.charCodeAt(pos + i) !== ch) {
return false;
}
@@ -3746,7 +3836,7 @@ var ts;
if (!comments) {
comments = [];
}
- comments.push({ pos: pos, end: end, hasTrailingNewLine: hasTrailingNewLine, kind: kind });
+ comments.push({ kind: kind, pos: pos, end: end, hasTrailingNewLine: hasTrailingNewLine });
return comments;
}
function getLeadingCommentRanges(text, pos) {
@@ -3779,7 +3869,7 @@ var ts;
if (!isIdentifierStart(name.charCodeAt(0), languageVersion)) {
return false;
}
- for (var i = 1, n = name.length; i < n; i++) {
+ for (var i = 1; i < name.length; i++) {
if (!isIdentifierPart(name.charCodeAt(i), languageVersion)) {
return false;
}
@@ -3798,6 +3888,7 @@ var ts;
var precedingLineBreak;
var hasExtendedUnicodeEscape;
var tokenIsUnterminated;
+ var numericLiteralFlags;
setText(text, start, length);
return {
getStartPos: function () { return startPos; },
@@ -3811,6 +3902,7 @@ var ts;
isIdentifier: function () { return token === 70 || token > 106; },
isReservedWord: function () { return token >= 71 && token <= 106; },
isUnterminated: function () { return tokenIsUnterminated; },
+ getNumericLiteralFlags: function () { return numericLiteralFlags; },
reScanGreaterToken: reScanGreaterToken,
reScanSlashToken: reScanSlashToken,
reScanTemplateToken: reScanTemplateToken,
@@ -3847,6 +3939,7 @@ var ts;
var end = pos;
if (text.charCodeAt(pos) === 69 || text.charCodeAt(pos) === 101) {
pos++;
+ numericLiteralFlags = 2;
if (text.charCodeAt(pos) === 43 || text.charCodeAt(pos) === 45)
pos++;
if (isDigit(text.charCodeAt(pos))) {
@@ -4116,8 +4209,11 @@ var ts;
var len = tokenValue.length;
if (len >= 2 && len <= 11) {
var ch = tokenValue.charCodeAt(0);
- if (ch >= 97 && ch <= 122 && hasOwnProperty.call(textToToken, tokenValue)) {
- return token = textToToken[tokenValue];
+ if (ch >= 97 && ch <= 122) {
+ token = textToToken.get(tokenValue);
+ if (token !== undefined) {
+ return token;
+ }
}
}
return token = 70;
@@ -4146,6 +4242,7 @@ var ts;
hasExtendedUnicodeEscape = false;
precedingLineBreak = false;
tokenIsUnterminated = false;
+ numericLiteralFlags = 0;
while (true) {
tokenPos = pos;
if (pos >= end) {
@@ -4327,6 +4424,7 @@ var ts;
value = 0;
}
tokenValue = "" + value;
+ numericLiteralFlags = 8;
return token = 8;
}
else if (pos + 2 < end && (text.charCodeAt(pos + 1) === 66 || text.charCodeAt(pos + 1) === 98)) {
@@ -4337,6 +4435,7 @@ var ts;
value = 0;
}
tokenValue = "" + value;
+ numericLiteralFlags = 16;
return token = 8;
}
else if (pos + 2 < end && (text.charCodeAt(pos + 1) === 79 || text.charCodeAt(pos + 1) === 111)) {
@@ -4347,10 +4446,12 @@ var ts;
value = 0;
}
tokenValue = "" + value;
+ numericLiteralFlags = 32;
return token = 8;
}
if (pos + 1 < end && isOctalDigit(text.charCodeAt(pos + 1))) {
tokenValue = "" + scanOctalDigits();
+ numericLiteralFlags = 4;
return token = 8;
}
case 49:
@@ -4597,7 +4698,14 @@ var ts;
while (pos < end) {
pos++;
char = text.charCodeAt(pos);
- if ((char === 123) || (char === 60)) {
+ if (char === 123) {
+ break;
+ }
+ if (char === 60) {
+ if (isConflictMarkerTrivia(text, pos)) {
+ pos = scanConflictMarkerTrivia(text, pos, error);
+ return token = 7;
+ }
break;
}
}
@@ -4783,6 +4891,19 @@ var ts;
return undefined;
}
ts.getDeclarationOfKind = getDeclarationOfKind;
+ function findDeclaration(symbol, predicate) {
+ var declarations = symbol.declarations;
+ if (declarations) {
+ for (var _i = 0, declarations_2 = declarations; _i < declarations_2.length; _i++) {
+ var declaration = declarations_2[_i];
+ if (predicate(declaration)) {
+ return declaration;
+ }
+ }
+ }
+ return undefined;
+ }
+ ts.findDeclaration = findDeclaration;
var stringWriters = [];
function getSingleLineStringWriter() {
if (stringWriters.length === 0) {
@@ -4796,13 +4917,15 @@ var ts;
writeSpace: writeText,
writeStringLiteral: writeText,
writeParameter: writeText,
+ writeProperty: writeText,
writeSymbol: writeText,
writeLine: function () { return str_1 += " "; },
increaseIndent: ts.noop,
decreaseIndent: ts.noop,
clear: function () { return str_1 = ""; },
trackSymbol: ts.noop,
- reportInaccessibleThisError: ts.noop
+ reportInaccessibleThisError: ts.noop,
+ reportIllegalExtends: ts.noop
};
}
return stringWriters.pop();
@@ -4818,25 +4941,25 @@ var ts;
}
ts.getFullWidth = getFullWidth;
function hasResolvedModule(sourceFile, moduleNameText) {
- return !!(sourceFile && sourceFile.resolvedModules && sourceFile.resolvedModules[moduleNameText]);
+ return !!(sourceFile && sourceFile.resolvedModules && sourceFile.resolvedModules.get(moduleNameText));
}
ts.hasResolvedModule = hasResolvedModule;
function getResolvedModule(sourceFile, moduleNameText) {
- return hasResolvedModule(sourceFile, moduleNameText) ? sourceFile.resolvedModules[moduleNameText] : undefined;
+ return hasResolvedModule(sourceFile, moduleNameText) ? sourceFile.resolvedModules.get(moduleNameText) : undefined;
}
ts.getResolvedModule = getResolvedModule;
function setResolvedModule(sourceFile, moduleNameText, resolvedModule) {
if (!sourceFile.resolvedModules) {
sourceFile.resolvedModules = ts.createMap();
}
- sourceFile.resolvedModules[moduleNameText] = resolvedModule;
+ sourceFile.resolvedModules.set(moduleNameText, resolvedModule);
}
ts.setResolvedModule = setResolvedModule;
function setResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, resolvedTypeReferenceDirective) {
if (!sourceFile.resolvedTypeReferenceDirectiveNames) {
sourceFile.resolvedTypeReferenceDirectiveNames = ts.createMap();
}
- sourceFile.resolvedTypeReferenceDirectiveNames[typeReferenceDirectiveName] = resolvedTypeReferenceDirective;
+ sourceFile.resolvedTypeReferenceDirectiveNames.set(typeReferenceDirectiveName, resolvedTypeReferenceDirective);
}
ts.setResolvedTypeReferenceDirective = setResolvedTypeReferenceDirective;
function moduleResolutionIsEqualTo(oldResolution, newResolution) {
@@ -4855,7 +4978,7 @@ var ts;
}
for (var i = 0; i < names.length; i++) {
var newResolution = newResolutions[i];
- var oldResolution = oldResolutions && oldResolutions[names[i]];
+ var oldResolution = oldResolutions && oldResolutions.get(names[i]);
var changed = oldResolution
? !newResolution || !comparer(oldResolution, newResolution)
: newResolution;
@@ -4868,21 +4991,21 @@ var ts;
ts.hasChangesInResolutions = hasChangesInResolutions;
function containsParseError(node) {
aggregateChildData(node);
- return (node.flags & 4194304) !== 0;
+ return (node.flags & 131072) !== 0;
}
ts.containsParseError = containsParseError;
function aggregateChildData(node) {
- if (!(node.flags & 8388608)) {
- var thisNodeOrAnySubNodesHasError = ((node.flags & 1048576) !== 0) ||
+ if (!(node.flags & 262144)) {
+ var thisNodeOrAnySubNodesHasError = ((node.flags & 32768) !== 0) ||
ts.forEachChild(node, containsParseError);
if (thisNodeOrAnySubNodesHasError) {
- node.flags |= 4194304;
+ node.flags |= 131072;
}
- node.flags |= 8388608;
+ node.flags |= 262144;
}
}
function getSourceFileOfNode(node) {
- while (node && node.kind !== 261) {
+ while (node && node.kind !== 264) {
node = node.parent;
}
return node;
@@ -4890,11 +5013,11 @@ var ts;
ts.getSourceFileOfNode = getSourceFileOfNode;
function isStatementWithLocals(node) {
switch (node.kind) {
- case 204:
- case 232:
- case 211:
- case 212:
+ case 206:
+ case 234:
case 213:
+ case 214:
+ case 215:
return true;
}
return false;
@@ -4949,6 +5072,10 @@ var ts;
return !nodeIsMissing(node);
}
ts.nodeIsPresent = nodeIsPresent;
+ function isToken(n) {
+ return n.kind >= 0 && n.kind <= 141;
+ }
+ ts.isToken = isToken;
function getTokenPosOfNode(node, sourceFile, includeJsDoc) {
if (nodeIsMissing(node)) {
return node.pos;
@@ -4959,18 +5086,18 @@ var ts;
if (includeJsDoc && node.jsDoc && node.jsDoc.length > 0) {
return getTokenPosOfNode(node.jsDoc[0]);
}
- if (node.kind === 292 && node._children.length > 0) {
+ if (node.kind === 293 && node._children.length > 0) {
return getTokenPosOfNode(node._children[0], sourceFile, includeJsDoc);
}
return ts.skipTrivia((sourceFile || getSourceFileOfNode(node)).text, node.pos);
}
ts.getTokenPosOfNode = getTokenPosOfNode;
function isJSDocNode(node) {
- return node.kind >= 262 && node.kind <= 288;
+ return node.kind >= 266 && node.kind <= 292;
}
ts.isJSDocNode = isJSDocNode;
function isJSDocTag(node) {
- return node.kind >= 278 && node.kind <= 291;
+ return node.kind >= 282 && node.kind <= 292;
}
ts.isJSDocTag = isJSDocTag;
function getNonDecoratorTokenPosOfNode(node, sourceFile) {
@@ -5001,16 +5128,9 @@ var ts;
return getSourceTextOfNodeFromSourceFile(getSourceFileOfNode(node), node, includeTrivia);
}
ts.getTextOfNode = getTextOfNode;
- function getLiteralText(node, sourceFile, languageVersion) {
- if (languageVersion < 2 && (isTemplateLiteralKind(node.kind) || node.hasExtendedUnicodeEscape)) {
- return getQuotedEscapedLiteralText('"', node.text, '"');
- }
+ function getLiteralText(node, sourceFile) {
if (!nodeIsSynthesized(node) && node.parent) {
- var text = getSourceTextOfNodeFromSourceFile(sourceFile, node);
- if (languageVersion < 2 && isBinaryOrOctalIntegerLiteral(node, text)) {
- return node.text;
- }
- return text;
+ return getSourceTextOfNodeFromSourceFile(sourceFile, node);
}
switch (node.kind) {
case 9:
@@ -5029,19 +5149,6 @@ var ts;
ts.Debug.fail("Literal kind '" + node.kind + "' not accounted for.");
}
ts.getLiteralText = getLiteralText;
- function isBinaryOrOctalIntegerLiteral(node, text) {
- if (node.kind === 8 && text.length > 1) {
- switch (text.charCodeAt(1)) {
- case 98:
- case 66:
- case 111:
- case 79:
- return true;
- }
- }
- return false;
- }
- ts.isBinaryOrOctalIntegerLiteral = isBinaryOrOctalIntegerLiteral;
function getQuotedEscapedLiteralText(leftQuote, text, rightQuote) {
return leftQuote + escapeNonAsciiCharacters(escapeString(text)) + rightQuote;
}
@@ -5049,10 +5156,6 @@ var ts;
return identifier.length >= 2 && identifier.charCodeAt(0) === 95 && identifier.charCodeAt(1) === 95 ? "_" + identifier : identifier;
}
ts.escapeIdentifier = escapeIdentifier;
- function unescapeIdentifier(identifier) {
- return identifier.length >= 3 && identifier.charCodeAt(0) === 95 && identifier.charCodeAt(1) === 95 && identifier.charCodeAt(2) === 95 ? identifier.substr(1) : identifier;
- }
- ts.unescapeIdentifier = unescapeIdentifier;
function makeIdentifierFromModuleName(moduleName) {
return ts.getBaseFileName(moduleName).replace(/^(\d)/, "_$1").replace(/\W/g, "_");
}
@@ -5064,11 +5167,11 @@ var ts;
ts.isBlockOrCatchScoped = isBlockOrCatchScoped;
function isCatchClauseVariableDeclarationOrBindingElement(declaration) {
var node = getRootDeclaration(declaration);
- return node.kind === 223 && node.parent.kind === 256;
+ return node.kind === 225 && node.parent.kind === 259;
}
ts.isCatchClauseVariableDeclarationOrBindingElement = isCatchClauseVariableDeclarationOrBindingElement;
function isAmbientModule(node) {
- return node && node.kind === 230 &&
+ return node && node.kind === 232 &&
(node.name.kind === 9 || isGlobalScopeAugmentation(node));
}
ts.isAmbientModule = isAmbientModule;
@@ -5077,11 +5180,11 @@ var ts;
}
ts.isShorthandAmbientModuleSymbol = isShorthandAmbientModuleSymbol;
function isShorthandAmbientModule(node) {
- return node.kind === 230 && (!node.body);
+ return node && node.kind === 232 && (!node.body);
}
function isBlockScopedContainerTopLevel(node) {
- return node.kind === 261 ||
- node.kind === 230 ||
+ return node.kind === 264 ||
+ node.kind === 232 ||
isFunctionLike(node);
}
ts.isBlockScopedContainerTopLevel = isBlockScopedContainerTopLevel;
@@ -5094,32 +5197,36 @@ var ts;
return false;
}
switch (node.parent.kind) {
- case 261:
+ case 264:
return ts.isExternalModule(node.parent);
- case 231:
+ case 233:
return isAmbientModule(node.parent.parent) && !ts.isExternalModule(node.parent.parent.parent);
}
return false;
}
ts.isExternalModuleAugmentation = isExternalModuleAugmentation;
+ function isEffectiveExternalModule(node, compilerOptions) {
+ return ts.isExternalModule(node) || compilerOptions.isolatedModules;
+ }
+ ts.isEffectiveExternalModule = isEffectiveExternalModule;
function isBlockScope(node, parentNode) {
switch (node.kind) {
- case 261:
+ case 264:
+ case 234:
+ case 259:
case 232:
- case 256:
- case 230:
- case 211:
- case 212:
case 213:
- case 150:
- case 149:
+ case 214:
+ case 215:
case 151:
+ case 150:
case 152:
- case 225:
- case 184:
+ case 153:
+ case 227:
case 185:
+ case 186:
return true;
- case 204:
+ case 206:
return parentNode && !isFunctionLike(parentNode);
}
return false;
@@ -5139,6 +5246,10 @@ var ts;
return getFullWidth(name) === 0 ? "(Missing)" : getTextOfNode(name);
}
ts.declarationNameToString = declarationNameToString;
+ function getNameFromIndexInfo(info) {
+ return info.declaration ? declarationNameToString(info.declaration.parameters[0].name) : undefined;
+ }
+ ts.getNameFromIndexInfo = getNameFromIndexInfo;
function getTextOfPropertyName(name) {
switch (name.kind) {
case 70:
@@ -5146,7 +5257,7 @@ var ts;
case 9:
case 8:
return name.text;
- case 142:
+ case 143:
if (isStringOrNumericLiteral(name.expression)) {
return name.expression.text;
}
@@ -5157,10 +5268,10 @@ var ts;
function entityNameToString(name) {
switch (name.kind) {
case 70:
- return getFullWidth(name) === 0 ? unescapeIdentifier(name.text) : getTextOfNode(name);
- case 141:
+ return getFullWidth(name) === 0 ? ts.unescapeIdentifier(name.text) : getTextOfNode(name);
+ case 142:
return entityNameToString(name.left) + "." + entityNameToString(name.right);
- case 177:
+ case 178:
return entityNameToString(name.expression) + "." + entityNameToString(name.name);
}
}
@@ -5197,7 +5308,7 @@ var ts;
ts.getSpanOfTokenAtPosition = getSpanOfTokenAtPosition;
function getErrorSpanForArrowFunction(sourceFile, node) {
var pos = ts.skipTrivia(sourceFile.text, node.pos);
- if (node.body && node.body.kind === 204) {
+ if (node.body && node.body.kind === 206) {
var startLine = ts.getLineAndCharacterOfPosition(sourceFile, node.body.pos).line;
var endLine = ts.getLineAndCharacterOfPosition(sourceFile, node.body.end).line;
if (startLine < endLine) {
@@ -5209,29 +5320,29 @@ var ts;
function getErrorSpanForNode(sourceFile, node) {
var errorNode = node;
switch (node.kind) {
- case 261:
+ case 264:
var pos_1 = ts.skipTrivia(sourceFile.text, 0, false);
if (pos_1 === sourceFile.text.length) {
return ts.createTextSpan(0, 0);
}
return getSpanOfTokenAtPosition(sourceFile, pos_1);
- case 223:
- case 174:
- case 226:
- case 197:
- case 227:
- case 230:
- case 229:
- case 260:
case 225:
- case 184:
- case 149:
- case 151:
- case 152:
+ case 175:
case 228:
+ case 198:
+ case 229:
+ case 232:
+ case 231:
+ case 263:
+ case 227:
+ case 185:
+ case 150:
+ case 152:
+ case 153:
+ case 230:
errorNode = node.name;
break;
- case 185:
+ case 186:
return getErrorSpanForArrowFunction(sourceFile, node);
}
if (errorNode === undefined) {
@@ -5252,7 +5363,7 @@ var ts;
}
ts.isDeclarationFile = isDeclarationFile;
function isConstEnumDeclaration(node) {
- return node.kind === 229 && isConst(node);
+ return node.kind === 231 && isConst(node);
}
ts.isConstEnumDeclaration = isConstEnumDeclaration;
function isConst(node) {
@@ -5265,11 +5376,11 @@ var ts;
}
ts.isLet = isLet;
function isSuperCall(n) {
- return n.kind === 179 && n.expression.kind === 96;
+ return n.kind === 180 && n.expression.kind === 96;
}
ts.isSuperCall = isSuperCall;
function isPrologueDirective(node) {
- return node.kind === 207
+ return node.kind === 209
&& node.expression.kind === 9;
}
ts.isPrologueDirective = isPrologueDirective;
@@ -5282,10 +5393,10 @@ var ts;
}
ts.getLeadingCommentRangesOfNodeFromText = getLeadingCommentRangesOfNodeFromText;
function getJSDocCommentRanges(node, text) {
- var commentRanges = (node.kind === 144 ||
- node.kind === 143 ||
- node.kind === 184 ||
- node.kind === 185) ?
+ var commentRanges = (node.kind === 145 ||
+ node.kind === 144 ||
+ node.kind === 185 ||
+ node.kind === 186) ?
ts.concatenate(ts.getTrailingCommentRanges(text, node.pos), ts.getLeadingCommentRanges(text, node.pos)) :
getLeadingCommentRangesOfNodeFromText(node, text);
return ts.filter(commentRanges, function (comment) {
@@ -5299,96 +5410,110 @@ var ts;
ts.fullTripleSlashReferenceTypeReferenceDirectiveRegEx = /^(\/\/\/\s*<reference\s+types\s*=\s*)('|")(.+?)\2.*?\/>/;
ts.fullTripleSlashAMDReferencePathRegEx = /^(\/\/\/\s*<amd-dependency\s+path\s*=\s*)('|")(.+?)\2.*?\/>/;
function isPartOfTypeNode(node) {
- if (156 <= node.kind && node.kind <= 171) {
+ if (157 <= node.kind && node.kind <= 172) {
return true;
}
switch (node.kind) {
case 118:
case 132:
- case 134:
- case 121:
case 135:
- case 137:
+ case 121:
+ case 136:
+ case 138:
case 129:
return true;
case 104:
- return node.parent.kind !== 188;
- case 199:
+ return node.parent.kind !== 189;
+ case 200:
return !isExpressionWithTypeArgumentsInClassExtendsClause(node);
case 70:
- if (node.parent.kind === 141 && node.parent.right === node) {
+ if (node.parent.kind === 142 && node.parent.right === node) {
node = node.parent;
}
- else if (node.parent.kind === 177 && node.parent.name === node) {
+ else if (node.parent.kind === 178 && node.parent.name === node) {
node = node.parent;
}
- ts.Debug.assert(node.kind === 70 || node.kind === 141 || node.kind === 177, "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'.");
- case 141:
- case 177:
+ ts.Debug.assert(node.kind === 70 || node.kind === 142 || node.kind === 178, "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'.");
+ case 142:
+ case 178:
case 98:
- var parent_1 = node.parent;
- if (parent_1.kind === 160) {
+ var parent = node.parent;
+ if (parent.kind === 161) {
return false;
}
- if (156 <= parent_1.kind && parent_1.kind <= 171) {
+ if (157 <= parent.kind && parent.kind <= 172) {
return true;
}
- switch (parent_1.kind) {
- case 199:
- return !isExpressionWithTypeArgumentsInClassExtendsClause(parent_1);
- case 143:
- return node === parent_1.constraint;
- case 147:
- case 146:
+ switch (parent.kind) {
+ case 200:
+ return !isExpressionWithTypeArgumentsInClassExtendsClause(parent);
case 144:
- case 223:
- return node === parent_1.type;
+ return node === parent.constraint;
+ case 148:
+ case 147:
+ case 145:
case 225:
- case 184:
+ return node === parent.type;
+ case 227:
case 185:
+ case 186:
+ case 151:
case 150:
case 149:
- case 148:
- case 151:
case 152:
- return node === parent_1.type;
case 153:
+ return node === parent.type;
case 154:
case 155:
- return node === parent_1.type;
- case 182:
- return node === parent_1.type;
- case 179:
+ case 156:
+ return node === parent.type;
+ case 183:
+ return node === parent.type;
case 180:
- return parent_1.typeArguments && ts.indexOf(parent_1.typeArguments, node) >= 0;
case 181:
+ return parent.typeArguments && ts.indexOf(parent.typeArguments, node) >= 0;
+ case 182:
return false;
}
}
return false;
}
ts.isPartOfTypeNode = isPartOfTypeNode;
+ function isChildOfNodeWithKind(node, kind) {
+ while (node) {
+ if (node.kind === kind) {
+ return true;
+ }
+ node = node.parent;
+ }
+ return false;
+ }
+ ts.isChildOfNodeWithKind = isChildOfNodeWithKind;
+ function isPrefixUnaryExpression(node) {
+ return node.kind === 191;
+ }
+ ts.isPrefixUnaryExpression = isPrefixUnaryExpression;
function forEachReturnStatement(body, visitor) {
return traverse(body);
function traverse(node) {
switch (node.kind) {
- case 216:
+ case 218:
return visitor(node);
- case 232:
- case 204:
- case 208:
- case 209:
+ case 234:
+ case 206:
case 210:
case 211:
case 212:
case 213:
- case 217:
- case 218:
- case 253:
- case 254:
+ case 214:
+ case 215:
case 219:
- case 221:
+ case 220:
case 256:
+ case 257:
+ case 221:
+ case 223:
+ case 259:
return ts.forEachChild(node, traverse);
}
}
@@ -5398,24 +5523,25 @@ var ts;
return traverse(body);
function traverse(node) {
switch (node.kind) {
- case 195:
+ case 196:
visitor(node);
var operand = node.expression;
if (operand) {
traverse(operand);
}
+ return;
+ case 231:
case 229:
- case 227:
+ case 232:
case 230:
case 228:
- case 226:
- case 197:
+ case 198:
return;
default:
if (isFunctionLike(node)) {
- var name_5 = node.name;
- if (name_5 && name_5.kind === 142) {
- traverse(name_5.expression);
+ var name = node.name;
+ if (name && name.kind === 143) {
+ traverse(name.expression);
return;
}
}
@@ -5426,17 +5552,29 @@ var ts;
}
}
ts.forEachYieldExpression = forEachYieldExpression;
+ function getRestParameterElementType(node) {
+ if (node && node.kind === 163) {
+ return node.elementType;
+ }
+ else if (node && node.kind === 158) {
+ return ts.singleOrUndefined(node.typeArguments);
+ }
+ else {
+ return undefined;
+ }
+ }
+ ts.getRestParameterElementType = getRestParameterElementType;
function isVariableLike(node) {
if (node) {
switch (node.kind) {
- case 174:
+ case 175:
+ case 263:
+ case 145:
case 260:
- case 144:
- case 257:
+ case 148:
case 147:
- case 146:
- case 258:
- case 223:
+ case 261:
+ case 225:
return true;
}
}
@@ -5444,11 +5582,11 @@ var ts;
}
ts.isVariableLike = isVariableLike;
function isAccessor(node) {
- return node && (node.kind === 151 || node.kind === 152);
+ return node && (node.kind === 152 || node.kind === 153);
}
ts.isAccessor = isAccessor;
function isClassLike(node) {
- return node && (node.kind === 226 || node.kind === 197);
+ return node && (node.kind === 228 || node.kind === 198);
}
ts.isClassLike = isClassLike;
function isFunctionLike(node) {
@@ -5457,19 +5595,19 @@ var ts;
ts.isFunctionLike = isFunctionLike;
function isFunctionLikeKind(kind) {
switch (kind) {
- case 150:
- case 184:
- case 225:
+ case 151:
case 185:
+ case 227:
+ case 186:
+ case 150:
case 149:
- case 148:
- case 151:
case 152:
case 153:
case 154:
case 155:
- case 158:
+ case 156:
case 159:
+ case 160:
return true;
}
return false;
@@ -5477,13 +5615,13 @@ var ts;
ts.isFunctionLikeKind = isFunctionLikeKind;
function introducesArgumentsExoticObject(node) {
switch (node.kind) {
- case 149:
- case 148:
case 150:
+ case 149:
case 151:
case 152:
- case 225:
- case 184:
+ case 153:
+ case 227:
+ case 185:
return true;
}
return false;
@@ -5491,30 +5629,42 @@ var ts;
ts.introducesArgumentsExoticObject = introducesArgumentsExoticObject;
function isIterationStatement(node, lookInLabeledStatements) {
switch (node.kind) {
+ case 213:
+ case 214:
+ case 215:
case 211:
case 212:
- case 213:
- case 209:
- case 210:
return true;
- case 219:
+ case 221:
return lookInLabeledStatements && isIterationStatement(node.statement, lookInLabeledStatements);
}
return false;
}
ts.isIterationStatement = isIterationStatement;
+ function unwrapInnermostStatementOfLabel(node, beforeUnwrapLabelCallback) {
+ while (true) {
+ if (beforeUnwrapLabelCallback) {
+ beforeUnwrapLabelCallback(node);
+ }
+ if (node.statement.kind !== 221) {
+ return node.statement;
+ }
+ node = node.statement;
+ }
+ }
+ ts.unwrapInnermostStatementOfLabel = unwrapInnermostStatementOfLabel;
function isFunctionBlock(node) {
- return node && node.kind === 204 && isFunctionLike(node.parent);
+ return node && node.kind === 206 && isFunctionLike(node.parent);
}
ts.isFunctionBlock = isFunctionBlock;
function isObjectLiteralMethod(node) {
- return node && node.kind === 149 && node.parent.kind === 176;
+ return node && node.kind === 150 && node.parent.kind === 177;
}
ts.isObjectLiteralMethod = isObjectLiteralMethod;
function isObjectLiteralOrClassExpressionMethod(node) {
- return node.kind === 149 &&
- (node.parent.kind === 176 ||
- node.parent.kind === 197);
+ return node.kind === 150 &&
+ (node.parent.kind === 177 ||
+ node.parent.kind === 198);
}
ts.isObjectLiteralOrClassExpressionMethod = isObjectLiteralOrClassExpressionMethod;
function isIdentifierTypePredicate(predicate) {
@@ -5550,44 +5700,57 @@ var ts;
return undefined;
}
switch (node.kind) {
- case 142:
+ case 143:
if (isClassLike(node.parent.parent)) {
return node;
}
node = node.parent;
break;
- case 145:
- if (node.parent.kind === 144 && isClassElement(node.parent.parent)) {
+ case 146:
+ if (node.parent.kind === 145 && isClassElement(node.parent.parent)) {
node = node.parent.parent;
}
else if (isClassElement(node.parent)) {
node = node.parent;
}
break;
- case 185:
+ case 186:
if (!includeArrowFunctions) {
continue;
}
- case 225:
- case 184:
- case 230:
- case 147:
- case 146:
- case 149:
+ case 227:
+ case 185:
+ case 232:
case 148:
+ case 147:
case 150:
+ case 149:
case 151:
case 152:
case 153:
case 154:
case 155:
- case 229:
- case 261:
+ case 156:
+ case 231:
+ case 264:
return node;
}
}
}
ts.getThisContainer = getThisContainer;
+ function getNewTargetContainer(node) {
+ var container = getThisContainer(node, false);
+ if (container) {
+ switch (container.kind) {
+ case 151:
+ case 227:
+ case 185:
+ return container;
+ }
+ }
+ return undefined;
+ }
+ ts.getNewTargetContainer = getNewTargetContainer;
function getSuperContainer(node, stopOnFunctions) {
while (true) {
node = node.parent;
@@ -5595,25 +5758,25 @@ var ts;
return node;
}
switch (node.kind) {
- case 142:
+ case 143:
node = node.parent;
break;
- case 225:
- case 184:
+ case 227:
case 185:
+ case 186:
if (!stopOnFunctions) {
continue;
}
- case 147:
- case 146:
- case 149:
case 148:
+ case 147:
case 150:
+ case 149:
case 151:
case 152:
+ case 153:
return node;
- case 145:
- if (node.parent.kind === 144 && isClassElement(node.parent.parent)) {
+ case 146:
+ if (node.parent.kind === 145 && isClassElement(node.parent.parent)) {
node = node.parent.parent;
}
else if (isClassElement(node.parent)) {
@@ -5625,36 +5788,36 @@ var ts;
}
ts.getSuperContainer = getSuperContainer;
function getImmediatelyInvokedFunctionExpression(func) {
- if (func.kind === 184 || func.kind === 185) {
+ if (func.kind === 185 || func.kind === 186) {
var prev = func;
- var parent_2 = func.parent;
- while (parent_2.kind === 183) {
- prev = parent_2;
- parent_2 = parent_2.parent;
+ var parent = func.parent;
+ while (parent.kind === 184) {
+ prev = parent;
+ parent = parent.parent;
}
- if (parent_2.kind === 179 && parent_2.expression === prev) {
- return parent_2;
+ if (parent.kind === 180 && parent.expression === prev) {
+ return parent;
}
}
}
ts.getImmediatelyInvokedFunctionExpression = getImmediatelyInvokedFunctionExpression;
function isSuperProperty(node) {
var kind = node.kind;
- return (kind === 177 || kind === 178)
+ return (kind === 178 || kind === 179)
&& node.expression.kind === 96;
}
ts.isSuperProperty = isSuperProperty;
function getEntityNameFromTypeNode(node) {
switch (node.kind) {
- case 157:
- case 272:
+ case 158:
+ case 276:
return node.typeName;
- case 199:
+ case 200:
return isEntityNameExpression(node.expression)
? node.expression
: undefined;
case 70:
- case 141:
+ case 142:
return node;
}
return undefined;
@@ -5662,10 +5825,12 @@ var ts;
ts.getEntityNameFromTypeNode = getEntityNameFromTypeNode;
function isCallLikeExpression(node) {
switch (node.kind) {
- case 179:
+ case 250:
+ case 249:
case 180:
case 181:
- case 145:
+ case 182:
+ case 146:
return true;
default:
return false;
@@ -5673,29 +5838,32 @@ var ts;
}
ts.isCallLikeExpression = isCallLikeExpression;
function getInvokedExpression(node) {
- if (node.kind === 181) {
+ if (node.kind === 182) {
return node.tag;
}
+ else if (isJsxOpeningLikeElement(node)) {
+ return node.tagName;
+ }
return node.expression;
}
ts.getInvokedExpression = getInvokedExpression;
function nodeCanBeDecorated(node) {
switch (node.kind) {
- case 226:
+ case 228:
return true;
- case 147:
- return node.parent.kind === 226;
- case 151:
+ case 148:
+ return node.parent.kind === 228;
case 152:
- case 149:
+ case 153:
+ case 150:
return node.body !== undefined
- && node.parent.kind === 226;
- case 144:
+ && node.parent.kind === 228;
+ case 145:
return node.parent.body !== undefined
- && (node.parent.kind === 150
- || node.parent.kind === 149
- || node.parent.kind === 152)
- && node.parent.parent.kind === 226;
+ && (node.parent.kind === 151
+ || node.parent.kind === 150
+ || node.parent.kind === 153)
+ && node.parent.parent.kind === 228;
}
return false;
}
@@ -5711,19 +5879,19 @@ var ts;
ts.nodeOrChildIsDecorated = nodeOrChildIsDecorated;
function childIsDecorated(node) {
switch (node.kind) {
- case 226:
+ case 228:
return ts.forEach(node.members, nodeOrChildIsDecorated);
- case 149:
- case 152:
+ case 150:
+ case 153:
return ts.forEach(node.parameters, nodeIsDecorated);
}
}
ts.childIsDecorated = childIsDecorated;
function isJSXTagName(node) {
var parent = node.parent;
- if (parent.kind === 248 ||
- parent.kind === 247 ||
- parent.kind === 249) {
+ if (parent.kind === 250 ||
+ parent.kind === 249 ||
+ parent.kind === 251) {
return parent.tagName === node;
}
return false;
@@ -5737,95 +5905,96 @@ var ts;
case 100:
case 85:
case 11:
- case 175:
case 176:
case 177:
case 178:
case 179:
case 180:
case 181:
- case 200:
case 182:
case 201:
case 183:
+ case 202:
case 184:
- case 197:
case 185:
- case 188:
+ case 198:
case 186:
+ case 189:
case 187:
- case 190:
+ case 188:
case 191:
case 192:
case 193:
- case 196:
case 194:
- case 12:
- case 198:
- case 246:
- case 247:
+ case 197:
case 195:
- case 189:
+ case 12:
+ case 199:
+ case 248:
+ case 249:
+ case 196:
+ case 190:
+ case 203:
return true;
- case 141:
- while (node.parent.kind === 141) {
+ case 142:
+ while (node.parent.kind === 142) {
node = node.parent;
}
- return node.parent.kind === 160 || isJSXTagName(node);
+ return node.parent.kind === 161 || isJSXTagName(node);
case 70:
- if (node.parent.kind === 160 || isJSXTagName(node)) {
+ if (node.parent.kind === 161 || isJSXTagName(node)) {
return true;
}
case 8:
case 9:
case 98:
- var parent_3 = node.parent;
- switch (parent_3.kind) {
- case 223:
- case 144:
+ var parent = node.parent;
+ switch (parent.kind) {
+ case 225:
+ case 145:
+ case 148:
case 147:
- case 146:
+ case 263:
case 260:
- case 257:
- case 174:
- return parent_3.initializer === node;
- case 207:
- case 208:
+ case 175:
+ return parent.initializer === node;
case 209:
case 210:
- case 216:
- case 217:
+ case 211:
+ case 212:
case 218:
- case 253:
+ case 219:
case 220:
- case 218:
- return parent_3.expression === node;
- case 211:
- var forStatement = parent_3;
- return (forStatement.initializer === node && forStatement.initializer.kind !== 224) ||
+ case 256:
+ case 222:
+ case 220:
+ return parent.expression === node;
+ case 213:
+ var forStatement = parent;
+ return (forStatement.initializer === node && forStatement.initializer.kind !== 226) ||
forStatement.condition === node ||
forStatement.incrementor === node;
- case 212:
- case 213:
- var forInStatement = parent_3;
- return (forInStatement.initializer === node && forInStatement.initializer.kind !== 224) ||
+ case 214:
+ case 215:
+ var forInStatement = parent;
+ return (forInStatement.initializer === node && forInStatement.initializer.kind !== 226) ||
forInStatement.expression === node;
- case 182:
- case 200:
- return node === parent_3.expression;
- case 202:
- return node === parent_3.expression;
- case 142:
- return node === parent_3.expression;
- case 145:
- case 252:
- case 251:
- case 259:
+ case 183:
+ case 201:
+ return node === parent.expression;
+ case 204:
+ return node === parent.expression;
+ case 143:
+ return node === parent.expression;
+ case 146:
+ case 255:
+ case 254:
+ case 262:
return true;
- case 199:
- return parent_3.expression === node && isExpressionWithTypeArgumentsInClassExtendsClause(parent_3);
+ case 200:
+ return parent.expression === node && isExpressionWithTypeArgumentsInClassExtendsClause(parent);
default:
- if (isPartOfExpression(parent_3)) {
+ if (isPartOfExpression(parent)) {
return true;
}
}
@@ -5840,7 +6009,7 @@ var ts;
}
ts.isInstantiatedModule = isInstantiatedModule;
function isExternalModuleImportEqualsDeclaration(node) {
- return node.kind === 234 && node.moduleReference.kind === 245;
+ return node.kind === 236 && node.moduleReference.kind === 247;
}
ts.isExternalModuleImportEqualsDeclaration = isExternalModuleImportEqualsDeclaration;
function getExternalModuleImportEqualsDeclarationExpression(node) {
@@ -5849,7 +6018,7 @@ var ts;
}
ts.getExternalModuleImportEqualsDeclarationExpression = getExternalModuleImportEqualsDeclarationExpression;
function isInternalModuleImportEqualsDeclaration(node) {
- return node.kind === 234 && node.moduleReference.kind !== 245;
+ return node.kind === 236 && node.moduleReference.kind !== 247;
}
ts.isInternalModuleImportEqualsDeclaration = isInternalModuleImportEqualsDeclaration;
function isSourceFileJavaScript(file) {
@@ -5857,38 +6026,57 @@ var ts;
}
ts.isSourceFileJavaScript = isSourceFileJavaScript;
function isInJavaScriptFile(node) {
- return node && !!(node.flags & 2097152);
+ return node && !!(node.flags & 65536);
}
ts.isInJavaScriptFile = isInJavaScriptFile;
- function isRequireCall(expression, checkArgumentIsStringLiteral) {
- var isRequire = expression.kind === 179 &&
- expression.expression.kind === 70 &&
- expression.expression.text === "require" &&
- expression.arguments.length === 1;
- return isRequire && (!checkArgumentIsStringLiteral || expression.arguments[0].kind === 9);
+ function isRequireCall(callExpression, checkArgumentIsStringLiteral) {
+ if (callExpression.kind !== 180) {
+ return false;
+ }
+ var _a = callExpression, expression = _a.expression, args = _a.arguments;
+ if (expression.kind !== 70 || expression.text !== "require") {
+ return false;
+ }
+ if (args.length !== 1) {
+ return false;
+ }
+ var arg = args[0];
+ return !checkArgumentIsStringLiteral || arg.kind === 9 || arg.kind === 12;
}
ts.isRequireCall = isRequireCall;
function isSingleOrDoubleQuote(charCode) {
return charCode === 39 || charCode === 34;
}
ts.isSingleOrDoubleQuote = isSingleOrDoubleQuote;
- function isDeclarationOfFunctionExpression(s) {
- if (s.valueDeclaration && s.valueDeclaration.kind === 223) {
+ function isDeclarationOfFunctionOrClassExpression(s) {
+ if (s.valueDeclaration && s.valueDeclaration.kind === 225) {
var declaration = s.valueDeclaration;
- return declaration.initializer && declaration.initializer.kind === 184;
+ return declaration.initializer && (declaration.initializer.kind === 185 || declaration.initializer.kind === 198);
}
return false;
}
- ts.isDeclarationOfFunctionExpression = isDeclarationOfFunctionExpression;
+ ts.isDeclarationOfFunctionOrClassExpression = isDeclarationOfFunctionOrClassExpression;
+ function getRightMostAssignedExpression(node) {
+ while (isAssignmentExpression(node, true)) {
+ node = node.right;
+ }
+ return node;
+ }
+ ts.getRightMostAssignedExpression = getRightMostAssignedExpression;
+ function isExportsIdentifier(node) {
+ return isIdentifier(node) && node.text === "exports";
+ }
+ ts.isExportsIdentifier = isExportsIdentifier;
+ function isModuleExportsPropertyAccessExpression(node) {
+ return isPropertyAccessExpression(node) && isIdentifier(node.expression) && node.expression.text === "module" && node.name.text === "exports";
+ }
+ ts.isModuleExportsPropertyAccessExpression = isModuleExportsPropertyAccessExpression;
function getSpecialPropertyAssignmentKind(expression) {
if (!isInJavaScriptFile(expression)) {
return 0;
}
- if (expression.kind !== 192) {
- return 0;
- }
var expr = expression;
- if (expr.operatorToken.kind !== 57 || expr.left.kind !== 177) {
+ if (expr.operatorToken.kind !== 57 || expr.left.kind !== 178) {
return 0;
}
var lhs = expr.left;
@@ -5900,11 +6088,14 @@ var ts;
else if (lhsId.text === "module" && lhs.name.text === "exports") {
return 2;
}
+ else {
+ return 5;
+ }
}
else if (lhs.expression.kind === 98) {
return 4;
}
- else if (lhs.expression.kind === 177) {
+ else if (lhs.expression.kind === 178) {
var innerPropertyAccess = lhs.expression;
if (innerPropertyAccess.expression.kind === 70) {
var innerPropertyAccessIdentifier = innerPropertyAccess.expression;
@@ -5920,35 +6111,35 @@ var ts;
}
ts.getSpecialPropertyAssignmentKind = getSpecialPropertyAssignmentKind;
function getExternalModuleName(node) {
- if (node.kind === 235) {
+ if (node.kind === 237) {
return node.moduleSpecifier;
}
- if (node.kind === 234) {
+ if (node.kind === 236) {
var reference = node.moduleReference;
- if (reference.kind === 245) {
+ if (reference.kind === 247) {
return reference.expression;
}
}
- if (node.kind === 241) {
+ if (node.kind === 243) {
return node.moduleSpecifier;
}
- if (node.kind === 230 && node.name.kind === 9) {
+ if (node.kind === 232 && node.name.kind === 9) {
return node.name;
}
}
ts.getExternalModuleName = getExternalModuleName;
function getNamespaceDeclarationNode(node) {
- if (node.kind === 234) {
+ if (node.kind === 236) {
return node;
}
var importClause = node.importClause;
- if (importClause && importClause.namedBindings && importClause.namedBindings.kind === 237) {
+ if (importClause && importClause.namedBindings && importClause.namedBindings.kind === 239) {
return importClause.namedBindings;
}
}
ts.getNamespaceDeclarationNode = getNamespaceDeclarationNode;
function isDefaultImport(node) {
- return node.kind === 235
+ return node.kind === 237
&& node.importClause
&& !!node.importClause.name;
}
@@ -5956,13 +6147,13 @@ var ts;
function hasQuestionToken(node) {
if (node) {
switch (node.kind) {
- case 144:
+ case 145:
+ case 150:
case 149:
+ case 261:
+ case 260:
case 148:
- case 258:
- case 257:
case 147:
- case 146:
return node.questionToken !== undefined;
}
}
@@ -5970,28 +6161,36 @@ var ts;
}
ts.hasQuestionToken = hasQuestionToken;
function isJSDocConstructSignature(node) {
- return node.kind === 274 &&
+ return node.kind === 278 &&
node.parameters.length > 0 &&
- node.parameters[0].type.kind === 276;
+ node.parameters[0].type.kind === 280;
}
ts.isJSDocConstructSignature = isJSDocConstructSignature;
function getCommentsFromJSDoc(node) {
return ts.map(getJSDocs(node), function (doc) { return doc.comment; });
}
ts.getCommentsFromJSDoc = getCommentsFromJSDoc;
+ function hasJSDocParameterTags(node) {
+ var parameterTags = getJSDocTags(node, 285);
+ return parameterTags && parameterTags.length > 0;
+ }
+ ts.hasJSDocParameterTags = hasJSDocParameterTags;
function getJSDocTags(node, kind) {
var docs = getJSDocs(node);
if (docs) {
var result = [];
for (var _i = 0, docs_1 = docs; _i < docs_1.length; _i++) {
var doc = docs_1[_i];
- if (doc.kind === 281) {
+ if (doc.kind === 285) {
if (doc.kind === kind) {
result.push(doc);
}
}
else {
- result.push.apply(result, ts.filter(doc.tags, function (tag) { return tag.kind === kind; }));
+ var tags = doc.tags;
+ if (tags) {
+ result.push.apply(result, ts.filter(tags, function (tag) { return tag.kind === kind; }));
+ }
}
}
return result;
@@ -6011,9 +6210,9 @@ var ts;
var parent = node.parent;
var isInitializerOfVariableDeclarationInStatement = isVariableLike(parent) &&
parent.initializer === node &&
- parent.parent.parent.kind === 205;
+ parent.parent.parent.kind === 207;
var isVariableOfVariableDeclarationStatement = isVariableLike(node) &&
- parent.parent.kind === 205;
+ parent.parent.kind === 207;
var variableStatementNode = isInitializerOfVariableDeclarationInStatement ? parent.parent.parent :
isVariableOfVariableDeclarationStatement ? parent.parent :
undefined;
@@ -6021,19 +6220,19 @@ var ts;
getJSDocsWorker(variableStatementNode);
}
var isSourceOfAssignmentExpressionStatement = parent && parent.parent &&
- parent.kind === 192 &&
+ parent.kind === 193 &&
parent.operatorToken.kind === 57 &&
- parent.parent.kind === 207;
+ parent.parent.kind === 209;
if (isSourceOfAssignmentExpressionStatement) {
getJSDocsWorker(parent.parent);
}
- var isModuleDeclaration = node.kind === 230 &&
- parent && parent.kind === 230;
- var isPropertyAssignmentExpression = parent && parent.kind === 257;
+ var isModuleDeclaration = node.kind === 232 &&
+ parent && parent.kind === 232;
+ var isPropertyAssignmentExpression = parent && parent.kind === 260;
if (isModuleDeclaration || isPropertyAssignmentExpression) {
getJSDocsWorker(parent);
}
- if (node.kind === 144) {
+ if (node.kind === 145) {
cache = ts.concatenate(cache, getJSDocParameterTags(node));
}
if (isVariableLike(node) && node.initializer) {
@@ -6042,22 +6241,23 @@ var ts;
cache = ts.concatenate(cache, node.jsDoc);
}
}
+ ts.getJSDocs = getJSDocs;
function getJSDocParameterTags(param) {
if (!isParameter(param)) {
return undefined;
}
var func = param.parent;
- var tags = getJSDocTags(func, 281);
+ var tags = getJSDocTags(func, 285);
if (!param.name) {
var i = func.parameters.indexOf(param);
- var paramTags = ts.filter(tags, function (tag) { return tag.kind === 281; });
+ var paramTags = ts.filter(tags, function (tag) { return tag.kind === 285; });
if (paramTags && 0 <= i && i < paramTags.length) {
return [paramTags[i]];
}
}
else if (param.name.kind === 70) {
- var name_6 = param.name.text;
- return ts.filter(tags, function (tag) { return tag.kind === 281 && tag.parameterName.text === name_6; });
+ var name_1 = param.name.text;
+ return ts.filter(tags, function (tag) { return tag.kind === 285 && tag.parameterName.text === name_1; });
}
else {
return undefined;
@@ -6065,8 +6265,8 @@ var ts;
}
ts.getJSDocParameterTags = getJSDocParameterTags;
function getJSDocType(node) {
- var tag = getFirstJSDocTag(node, 283);
- if (!tag && node.kind === 144) {
+ var tag = getFirstJSDocTag(node, 287);
+ if (!tag && node.kind === 145) {
var paramTags = getJSDocParameterTags(node);
if (paramTags) {
tag = ts.find(paramTags, function (tag) { return !!tag.typeExpression; });
@@ -6076,15 +6276,15 @@ var ts;
}
ts.getJSDocType = getJSDocType;
function getJSDocAugmentsTag(node) {
- return getFirstJSDocTag(node, 280);
+ return getFirstJSDocTag(node, 284);
}
ts.getJSDocAugmentsTag = getJSDocAugmentsTag;
function getJSDocReturnTag(node) {
- return getFirstJSDocTag(node, 282);
+ return getFirstJSDocTag(node, 286);
}
ts.getJSDocReturnTag = getJSDocReturnTag;
function getJSDocTemplateTag(node) {
- return getFirstJSDocTag(node, 284);
+ return getFirstJSDocTag(node, 288);
}
ts.getJSDocTemplateTag = getJSDocTemplateTag;
function hasRestParameter(s) {
@@ -6096,9 +6296,9 @@ var ts;
}
ts.hasDeclaredRestParameter = hasDeclaredRestParameter;
function isRestParameter(node) {
- if (node && (node.flags & 2097152)) {
- if (node.type && node.type.kind === 275 ||
- ts.forEach(getJSDocParameterTags(node), function (t) { return t.typeExpression && t.typeExpression.type.kind === 275; })) {
+ if (node && (node.flags & 65536)) {
+ if (node.type && node.type.kind === 279 ||
+ ts.forEach(getJSDocParameterTags(node), function (t) { return t.typeExpression && t.typeExpression.type.kind === 279; })) {
return true;
}
}
@@ -6113,28 +6313,33 @@ var ts;
var parent = node.parent;
while (true) {
switch (parent.kind) {
- case 192:
+ case 193:
var binaryOperator = parent.operatorToken.kind;
return isAssignmentOperator(binaryOperator) && parent.left === node ?
binaryOperator === 57 ? 1 : 2 :
0;
- case 190:
case 191:
+ case 192:
var unaryOperator = parent.operator;
return unaryOperator === 42 || unaryOperator === 43 ? 2 : 0;
- case 212:
- case 213:
+ case 214:
+ case 215:
return parent.initializer === node ? 1 : 0;
- case 183:
- case 175:
- case 196:
+ case 184:
+ case 176:
+ case 197:
node = parent;
break;
- case 258:
+ case 261:
if (parent.name !== node) {
return 0;
}
- case 257:
+ node = parent.parent;
+ break;
+ case 260:
+ if (parent.name === node) {
+ return 0;
+ }
node = parent.parent;
break;
default:
@@ -6148,6 +6353,17 @@ var ts;
return getAssignmentTargetKind(node) !== 0;
}
ts.isAssignmentTarget = isAssignmentTarget;
+ function isDeleteTarget(node) {
+ if (node.kind !== 178 && node.kind !== 179) {
+ return false;
+ }
+ node = node.parent;
+ while (node && node.kind === 184) {
+ node = node.parent;
+ }
+ return node && node.kind === 187;
+ }
+ ts.isDeleteTarget = isDeleteTarget;
function isNodeDescendantOf(node, ancestor) {
while (node) {
if (node === ancestor)
@@ -6159,7 +6375,7 @@ var ts;
ts.isNodeDescendantOf = isNodeDescendantOf;
function isInAmbientContext(node) {
while (node) {
- if (hasModifier(node, 2) || (node.kind === 261 && node.isDeclarationFile)) {
+ if (hasModifier(node, 2) || (node.kind === 264 && node.isDeclarationFile)) {
return true;
}
node = node.parent;
@@ -6172,7 +6388,7 @@ var ts;
return false;
}
var parent = name.parent;
- if (parent.kind === 239 || parent.kind === 243) {
+ if (parent.kind === 241 || parent.kind === 245) {
if (parent.propertyName) {
return true;
}
@@ -6185,48 +6401,48 @@ var ts;
ts.isDeclarationName = isDeclarationName;
function isLiteralComputedPropertyDeclarationName(node) {
return (node.kind === 9 || node.kind === 8) &&
- node.parent.kind === 142 &&
+ node.parent.kind === 143 &&
isDeclaration(node.parent.parent);
}
ts.isLiteralComputedPropertyDeclarationName = isLiteralComputedPropertyDeclarationName;
function isIdentifierName(node) {
var parent = node.parent;
switch (parent.kind) {
+ case 148:
case 147:
- case 146:
+ case 150:
case 149:
- case 148:
- case 151:
case 152:
+ case 153:
+ case 263:
case 260:
- case 257:
- case 177:
+ case 178:
return parent.name === node;
- case 141:
+ case 142:
if (parent.right === node) {
- while (parent.kind === 141) {
+ while (parent.kind === 142) {
parent = parent.parent;
}
- return parent.kind === 160;
+ return parent.kind === 161;
}
return false;
- case 174:
- case 239:
+ case 175:
+ case 241:
return parent.propertyName === node;
- case 243:
+ case 245:
return true;
}
return false;
}
ts.isIdentifierName = isIdentifierName;
function isAliasSymbolDeclaration(node) {
- return node.kind === 234 ||
- node.kind === 233 ||
- node.kind === 236 && !!node.name ||
- node.kind === 237 ||
+ return node.kind === 236 ||
+ node.kind === 235 ||
+ node.kind === 238 && !!node.name ||
node.kind === 239 ||
- node.kind === 243 ||
- node.kind === 240 && exportAssignmentIsAlias(node);
+ node.kind === 241 ||
+ node.kind === 245 ||
+ node.kind === 242 && exportAssignmentIsAlias(node);
}
ts.isAliasSymbolDeclaration = isAliasSymbolDeclaration;
function exportAssignmentIsAlias(node) {
@@ -6312,17 +6528,51 @@ var ts;
}
ts.getFileReferenceFromReferencePath = getFileReferenceFromReferencePath;
function isKeyword(token) {
- return 71 <= token && token <= 140;
+ return 71 <= token && token <= 141;
}
ts.isKeyword = isKeyword;
function isTrivia(token) {
return 2 <= token && token <= 7;
}
ts.isTrivia = isTrivia;
- function isAsyncFunctionLike(node) {
- return isFunctionLike(node) && hasModifier(node, 256) && !isAccessor(node);
+ function getFunctionFlags(node) {
+ var flags = 0;
+ switch (node.kind) {
+ case 227:
+ case 185:
+ case 150:
+ if (node.asteriskToken) {
+ flags |= 1;
+ }
+ case 186:
+ if (hasModifier(node, 256)) {
+ flags |= 2;
+ }
+ break;
+ }
+ if (!node.body) {
+ flags |= 4;
+ }
+ return flags;
+ }
+ ts.getFunctionFlags = getFunctionFlags;
+ function isAsyncFunction(node) {
+ switch (node.kind) {
+ case 227:
+ case 185:
+ case 186:
+ case 150:
+ return node.body !== undefined
+ && node.asteriskToken === undefined
+ && hasModifier(node, 256);
+ }
+ return false;
}
- ts.isAsyncFunctionLike = isAsyncFunctionLike;
+ ts.isAsyncFunction = isAsyncFunction;
+ function isNumericLiteral(node) {
+ return node.kind === 8;
+ }
+ ts.isNumericLiteral = isNumericLiteral;
function isStringOrNumericLiteral(node) {
var kind = node.kind;
return kind === 9
@@ -6334,7 +6584,7 @@ var ts;
}
ts.hasDynamicName = hasDynamicName;
function isDynamicName(name) {
- return name.kind === 142 &&
+ return name.kind === 143 &&
!isStringOrNumericLiteral(name.expression) &&
!isWellKnownSymbolSyntactically(name.expression);
}
@@ -6344,10 +6594,10 @@ var ts;
}
ts.isWellKnownSymbolSyntactically = isWellKnownSymbolSyntactically;
function getPropertyNameForPropertyNameNode(name) {
- if (name.kind === 70 || name.kind === 9 || name.kind === 8 || name.kind === 144) {
+ if (name.kind === 70 || name.kind === 9 || name.kind === 8 || name.kind === 145) {
return name.text;
}
- if (name.kind === 142) {
+ if (name.kind === 143) {
var nameExpression = name.expression;
if (isWellKnownSymbolSyntactically(nameExpression)) {
var rightHandSideName = nameExpression.name.text;
@@ -6392,11 +6642,11 @@ var ts;
ts.isModifierKind = isModifierKind;
function isParameterDeclaration(node) {
var root = getRootDeclaration(node);
- return root.kind === 144;
+ return root.kind === 145;
}
ts.isParameterDeclaration = isParameterDeclaration;
function getRootDeclaration(node) {
- while (node.kind === 174) {
+ while (node.kind === 175) {
node = node.parent.parent;
}
return node;
@@ -6404,15 +6654,15 @@ var ts;
ts.getRootDeclaration = getRootDeclaration;
function nodeStartsNewLexicalEnvironment(node) {
var kind = node.kind;
- return kind === 150
- || kind === 184
- || kind === 225
+ return kind === 151
|| kind === 185
- || kind === 149
- || kind === 151
+ || kind === 227
+ || kind === 186
+ || kind === 150
|| kind === 152
- || kind === 230
- || kind === 261;
+ || kind === 153
+ || kind === 232
+ || kind === 264;
}
ts.nodeStartsNewLexicalEnvironment = nodeStartsNewLexicalEnvironment;
function nodeIsSynthesized(node) {
@@ -6420,66 +6670,44 @@ var ts;
|| ts.positionIsSynthesized(node.end);
}
ts.nodeIsSynthesized = nodeIsSynthesized;
- function getOriginalNode(node, nodeTest) {
- if (node) {
- while (node.original !== undefined) {
- node = node.original;
- }
+ function getOriginalSourceFileOrBundle(sourceFileOrBundle) {
+ if (sourceFileOrBundle.kind === 265) {
+ return ts.updateBundle(sourceFileOrBundle, ts.sameMap(sourceFileOrBundle.sourceFiles, getOriginalSourceFile));
}
- return !nodeTest || nodeTest(node) ? node : undefined;
+ return getOriginalSourceFile(sourceFileOrBundle);
}
- ts.getOriginalNode = getOriginalNode;
- function isParseTreeNode(node) {
- return (node.flags & 8) === 0;
+ ts.getOriginalSourceFileOrBundle = getOriginalSourceFileOrBundle;
+ function getOriginalSourceFile(sourceFile) {
+ return ts.getParseTreeNode(sourceFile, isSourceFile) || sourceFile;
}
- ts.isParseTreeNode = isParseTreeNode;
- function getParseTreeNode(node, nodeTest) {
- if (isParseTreeNode(node)) {
- return node;
- }
- node = getOriginalNode(node);
- if (isParseTreeNode(node) && (!nodeTest || nodeTest(node))) {
- return node;
- }
- return undefined;
- }
- ts.getParseTreeNode = getParseTreeNode;
function getOriginalSourceFiles(sourceFiles) {
- var originalSourceFiles = [];
- for (var _i = 0, sourceFiles_1 = sourceFiles; _i < sourceFiles_1.length; _i++) {
- var sourceFile = sourceFiles_1[_i];
- var originalSourceFile = getParseTreeNode(sourceFile, isSourceFile);
- if (originalSourceFile) {
- originalSourceFiles.push(originalSourceFile);
- }
- }
- return originalSourceFiles;
+ return ts.sameMap(sourceFiles, getOriginalSourceFile);
}
ts.getOriginalSourceFiles = getOriginalSourceFiles;
function getOriginalNodeId(node) {
- node = getOriginalNode(node);
+ node = ts.getOriginalNode(node);
return node ? ts.getNodeId(node) : 0;
}
ts.getOriginalNodeId = getOriginalNodeId;
function getExpressionAssociativity(expression) {
var operator = getOperator(expression);
- var hasArguments = expression.kind === 180 && expression.arguments !== undefined;
+ var hasArguments = expression.kind === 181 && expression.arguments !== undefined;
return getOperatorAssociativity(expression.kind, operator, hasArguments);
}
ts.getExpressionAssociativity = getExpressionAssociativity;
function getOperatorAssociativity(kind, operator, hasArguments) {
switch (kind) {
- case 180:
+ case 181:
return hasArguments ? 0 : 1;
- case 190:
- case 187:
+ case 191:
case 188:
- case 186:
case 189:
- case 193:
- case 195:
+ case 187:
+ case 190:
+ case 194:
+ case 196:
return 1;
- case 192:
+ case 193:
switch (operator) {
case 39:
case 57:
@@ -6503,15 +6731,15 @@ var ts;
ts.getOperatorAssociativity = getOperatorAssociativity;
function getExpressionPrecedence(expression) {
var operator = getOperator(expression);
- var hasArguments = expression.kind === 180 && expression.arguments !== undefined;
+ var hasArguments = expression.kind === 181 && expression.arguments !== undefined;
return getOperatorPrecedence(expression.kind, operator, hasArguments);
}
ts.getExpressionPrecedence = getExpressionPrecedence;
function getOperator(expression) {
- if (expression.kind === 192) {
+ if (expression.kind === 193) {
return expression.operatorToken.kind;
}
- else if (expression.kind === 190 || expression.kind === 191) {
+ else if (expression.kind === 191 || expression.kind === 192) {
return expression.operator;
}
else {
@@ -6529,37 +6757,36 @@ var ts;
case 85:
case 8:
case 9:
- case 175:
case 176:
- case 184:
+ case 177:
case 185:
- case 197:
- case 246:
- case 247:
+ case 186:
+ case 198:
+ case 248:
+ case 249:
case 11:
case 12:
- case 194:
- case 183:
- case 198:
- case 297:
+ case 195:
+ case 184:
+ case 199:
return 19;
- case 181:
- case 177:
+ case 182:
case 178:
+ case 179:
return 18;
- case 180:
+ case 181:
return hasArguments ? 18 : 17;
- case 179:
+ case 180:
return 17;
- case 191:
+ case 192:
return 16;
- case 190:
- case 187:
+ case 191:
case 188:
- case 186:
case 189:
+ case 187:
+ case 190:
return 15;
- case 192:
+ case 193:
switch (operatorKind) {
case 50:
case 51:
@@ -6617,11 +6844,11 @@ var ts;
default:
return -1;
}
- case 193:
+ case 194:
return 4;
- case 195:
- return 2;
case 196:
+ return 2;
+ case 197:
return 1;
default:
return -1;
@@ -6644,21 +6871,15 @@ var ts;
return modificationCount;
}
function reattachFileDiagnostics(newFile) {
- if (!ts.hasProperty(fileDiagnostics, newFile.fileName)) {
- return;
- }
- for (var _i = 0, _a = fileDiagnostics[newFile.fileName]; _i < _a.length; _i++) {
- var diagnostic = _a[_i];
- diagnostic.file = newFile;
- }
+ ts.forEach(fileDiagnostics.get(newFile.fileName), function (diagnostic) { return diagnostic.file = newFile; });
}
function add(diagnostic) {
var diagnostics;
if (diagnostic.file) {
- diagnostics = fileDiagnostics[diagnostic.file.fileName];
+ diagnostics = fileDiagnostics.get(diagnostic.file.fileName);
if (!diagnostics) {
diagnostics = [];
- fileDiagnostics[diagnostic.file.fileName] = diagnostics;
+ fileDiagnostics.set(diagnostic.file.fileName, diagnostics);
}
}
else {
@@ -6675,16 +6896,16 @@ var ts;
function getDiagnostics(fileName) {
sortAndDeduplicate();
if (fileName) {
- return fileDiagnostics[fileName] || [];
+ return fileDiagnostics.get(fileName) || [];
}
var allDiagnostics = [];
function pushDiagnostic(d) {
allDiagnostics.push(d);
}
ts.forEach(nonFileDiagnostics, pushDiagnostic);
- for (var key in fileDiagnostics) {
- ts.forEach(fileDiagnostics[key], pushDiagnostic);
- }
+ fileDiagnostics.forEach(function (diagnostics) {
+ ts.forEach(diagnostics, pushDiagnostic);
+ });
return ts.sortAndDeduplicateDiagnostics(allDiagnostics);
}
function sortAndDeduplicate() {
@@ -6693,14 +6914,14 @@ var ts;
}
diagnosticsModified = false;
nonFileDiagnostics = ts.sortAndDeduplicateDiagnostics(nonFileDiagnostics);
- for (var key in fileDiagnostics) {
- fileDiagnostics[key] = ts.sortAndDeduplicateDiagnostics(fileDiagnostics[key]);
- }
+ fileDiagnostics.forEach(function (diagnostics, key) {
+ fileDiagnostics.set(key, ts.sortAndDeduplicateDiagnostics(diagnostics));
+ });
}
}
ts.createDiagnosticCollection = createDiagnosticCollection;
var escapedCharsRegExp = /[\\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
- var escapedCharsMap = ts.createMap({
+ var escapedCharsMap = ts.createMapFromTemplate({
"\0": "\\0",
"\t": "\\t",
"\v": "\\v",
@@ -6715,13 +6936,12 @@ var ts;
"\u0085": "\\u0085"
});
function escapeString(s) {
- s = escapedCharsRegExp.test(s) ? s.replace(escapedCharsRegExp, getReplacement) : s;
- return s;
- function getReplacement(c) {
- return escapedCharsMap[c] || get16BitUnicodeEscapeSequence(c.charCodeAt(0));
- }
+ return s.replace(escapedCharsRegExp, getReplacement);
}
ts.escapeString = escapeString;
+ function getReplacement(c) {
+ return escapedCharsMap.get(c) || get16BitUnicodeEscapeSequence(c.charCodeAt(0));
+ }
function isIntrinsicJsxName(name) {
var ch = name.substr(0, 1);
return ch.toLowerCase() === ch;
@@ -6864,129 +7084,62 @@ var ts;
ts.getDeclarationEmitOutputFilePath = getDeclarationEmitOutputFilePath;
function getSourceFilesToEmit(host, targetSourceFile) {
var options = host.getCompilerOptions();
+ var isSourceFileFromExternalLibrary = function (file) { return host.isSourceFileFromExternalLibrary(file); };
if (options.outFile || options.out) {
var moduleKind = ts.getEmitModuleKind(options);
- var moduleEmitEnabled = moduleKind === ts.ModuleKind.AMD || moduleKind === ts.ModuleKind.System;
- var sourceFiles = getAllEmittableSourceFiles();
- return ts.filter(sourceFiles, moduleEmitEnabled ? isNonDeclarationFile : isBundleEmitNonExternalModule);
+ var moduleEmitEnabled_1 = moduleKind === ts.ModuleKind.AMD || moduleKind === ts.ModuleKind.System;
+ return ts.filter(host.getSourceFiles(), function (sourceFile) {
+ return (moduleEmitEnabled_1 || !ts.isExternalModule(sourceFile)) && sourceFileMayBeEmitted(sourceFile, options, isSourceFileFromExternalLibrary);
+ });
}
else {
- var sourceFiles = targetSourceFile === undefined ? getAllEmittableSourceFiles() : [targetSourceFile];
- return filterSourceFilesInDirectory(sourceFiles, function (file) { return host.isSourceFileFromExternalLibrary(file); });
- }
- function getAllEmittableSourceFiles() {
- return options.noEmitForJsFiles ? ts.filter(host.getSourceFiles(), function (sourceFile) { return !isSourceFileJavaScript(sourceFile); }) : host.getSourceFiles();
+ var sourceFiles = targetSourceFile === undefined ? host.getSourceFiles() : [targetSourceFile];
+ return ts.filter(sourceFiles, function (sourceFile) { return sourceFileMayBeEmitted(sourceFile, options, isSourceFileFromExternalLibrary); });
}
}
ts.getSourceFilesToEmit = getSourceFilesToEmit;
- function filterSourceFilesInDirectory(sourceFiles, isSourceFileFromExternalLibrary) {
- return ts.filter(sourceFiles, function (file) { return shouldEmitInDirectory(file, isSourceFileFromExternalLibrary); });
- }
- ts.filterSourceFilesInDirectory = filterSourceFilesInDirectory;
- function isNonDeclarationFile(sourceFile) {
- return !isDeclarationFile(sourceFile);
- }
- function shouldEmitInDirectory(sourceFile, isSourceFileFromExternalLibrary) {
- return isNonDeclarationFile(sourceFile) && !isSourceFileFromExternalLibrary(sourceFile);
+ function sourceFileMayBeEmitted(sourceFile, options, isSourceFileFromExternalLibrary) {
+ return !(options.noEmitForJsFiles && isSourceFileJavaScript(sourceFile)) && !isDeclarationFile(sourceFile) && !isSourceFileFromExternalLibrary(sourceFile);
}
- function isBundleEmitNonExternalModule(sourceFile) {
- return isNonDeclarationFile(sourceFile) && !ts.isExternalModule(sourceFile);
- }
- function forEachTransformedEmitFile(host, sourceFiles, action, emitOnlyDtsFiles) {
+ ts.sourceFileMayBeEmitted = sourceFileMayBeEmitted;
+ function forEachEmittedFile(host, action, sourceFilesOrTargetSourceFile, emitOnlyDtsFiles) {
+ var sourceFiles = ts.isArray(sourceFilesOrTargetSourceFile) ? sourceFilesOrTargetSourceFile : getSourceFilesToEmit(host, sourceFilesOrTargetSourceFile);
var options = host.getCompilerOptions();
if (options.outFile || options.out) {
- onBundledEmit(sourceFiles);
- }
- else {
- for (var _i = 0, sourceFiles_2 = sourceFiles; _i < sourceFiles_2.length; _i++) {
- var sourceFile = sourceFiles_2[_i];
- if (!isDeclarationFile(sourceFile) && !host.isSourceFileFromExternalLibrary(sourceFile)) {
- onSingleFileEmit(host, sourceFile);
- }
- }
- }
- function onSingleFileEmit(host, sourceFile) {
- var extension = ".js";
- if (options.jsx === 1) {
- if (isSourceFileJavaScript(sourceFile)) {
- if (ts.fileExtensionIs(sourceFile.fileName, ".jsx")) {
- extension = ".jsx";
- }
- }
- else if (sourceFile.languageVariant === 1) {
- extension = ".jsx";
- }
- }
- var jsFilePath = getOwnEmitOutputFilePath(sourceFile, host, extension);
- var sourceMapFilePath = getSourceMapFilePath(jsFilePath, options);
- var declarationFilePath = !isSourceFileJavaScript(sourceFile) && (options.declaration || emitOnlyDtsFiles) ? getDeclarationEmitOutputFilePath(sourceFile, host) : undefined;
- action(jsFilePath, sourceMapFilePath, declarationFilePath, [sourceFile], false);
- }
- function onBundledEmit(sourceFiles) {
if (sourceFiles.length) {
var jsFilePath = options.outFile || options.out;
var sourceMapFilePath = getSourceMapFilePath(jsFilePath, options);
- var declarationFilePath = options.declaration ? ts.removeFileExtension(jsFilePath) + ".d.ts" : undefined;
- action(jsFilePath, sourceMapFilePath, declarationFilePath, sourceFiles, true);
+ var declarationFilePath = options.declaration ? ts.removeFileExtension(jsFilePath) + ".d.ts" : "";
+ action({ jsFilePath: jsFilePath, sourceMapFilePath: sourceMapFilePath, declarationFilePath: declarationFilePath }, ts.createBundle(sourceFiles), emitOnlyDtsFiles);
+ }
+ }
+ else {
+ for (var _i = 0, sourceFiles_1 = sourceFiles; _i < sourceFiles_1.length; _i++) {
+ var sourceFile = sourceFiles_1[_i];
+ var jsFilePath = getOwnEmitOutputFilePath(sourceFile, host, getOutputExtension(sourceFile, options));
+ var sourceMapFilePath = getSourceMapFilePath(jsFilePath, options);
+ var declarationFilePath = !isSourceFileJavaScript(sourceFile) && (emitOnlyDtsFiles || options.declaration) ? getDeclarationEmitOutputFilePath(sourceFile, host) : undefined;
+ action({ jsFilePath: jsFilePath, sourceMapFilePath: sourceMapFilePath, declarationFilePath: declarationFilePath }, sourceFile, emitOnlyDtsFiles);
}
}
}
- ts.forEachTransformedEmitFile = forEachTransformedEmitFile;
+ ts.forEachEmittedFile = forEachEmittedFile;
function getSourceMapFilePath(jsFilePath, options) {
return options.sourceMap ? jsFilePath + ".map" : undefined;
}
- function forEachExpectedEmitFile(host, action, targetSourceFile, emitOnlyDtsFiles) {
- var options = host.getCompilerOptions();
- if (options.outFile || options.out) {
- onBundledEmit(host);
- }
- else {
- var sourceFiles = targetSourceFile === undefined ? getSourceFilesToEmit(host) : [targetSourceFile];
- for (var _i = 0, sourceFiles_3 = sourceFiles; _i < sourceFiles_3.length; _i++) {
- var sourceFile = sourceFiles_3[_i];
- if (shouldEmitInDirectory(sourceFile, function (file) { return host.isSourceFileFromExternalLibrary(file); })) {
- onSingleFileEmit(host, sourceFile);
+ function getOutputExtension(sourceFile, options) {
+ if (options.jsx === 1) {
+ if (isSourceFileJavaScript(sourceFile)) {
+ if (ts.fileExtensionIs(sourceFile.fileName, ".jsx")) {
+ return ".jsx";
}
}
- }
- function onSingleFileEmit(host, sourceFile) {
- var extension = ".js";
- if (options.jsx === 1) {
- if (isSourceFileJavaScript(sourceFile)) {
- if (ts.fileExtensionIs(sourceFile.fileName, ".jsx")) {
- extension = ".jsx";
- }
- }
- else if (sourceFile.languageVariant === 1) {
- extension = ".jsx";
- }
- }
- var jsFilePath = getOwnEmitOutputFilePath(sourceFile, host, extension);
- var declarationFilePath = !isSourceFileJavaScript(sourceFile) && (emitOnlyDtsFiles || options.declaration) ? getDeclarationEmitOutputFilePath(sourceFile, host) : undefined;
- var emitFileNames = {
- jsFilePath: jsFilePath,
- sourceMapFilePath: getSourceMapFilePath(jsFilePath, options),
- declarationFilePath: declarationFilePath
- };
- action(emitFileNames, [sourceFile], false, emitOnlyDtsFiles);
- }
- function onBundledEmit(host) {
- var bundledSources = ts.filter(getSourceFilesToEmit(host), function (sourceFile) { return !isDeclarationFile(sourceFile) &&
- !host.isSourceFileFromExternalLibrary(sourceFile) &&
- (!ts.isExternalModule(sourceFile) ||
- !!ts.getEmitModuleKind(options)); });
- if (bundledSources.length) {
- var jsFilePath = options.outFile || options.out;
- var emitFileNames = {
- jsFilePath: jsFilePath,
- sourceMapFilePath: getSourceMapFilePath(jsFilePath, options),
- declarationFilePath: options.declaration ? ts.removeFileExtension(jsFilePath) + ".d.ts" : undefined
- };
- action(emitFileNames, bundledSources, true, emitOnlyDtsFiles);
+ else if (sourceFile.languageVariant === 1) {
+ return ".jsx";
}
}
+ return ".js";
}
- ts.forEachExpectedEmitFile = forEachExpectedEmitFile;
function getSourceFilePathInNewDir(sourceFile, host, newDirPath) {
var sourceFilePath = ts.getNormalizedAbsolutePath(sourceFile.fileName, host.getCurrentDirectory());
var commonSourceDirectory = host.getCommonSourceDirectory();
@@ -7011,7 +7164,7 @@ var ts;
ts.getLineOfLocalPositionFromLineMap = getLineOfLocalPositionFromLineMap;
function getFirstConstructorWithBody(node) {
return ts.forEach(node.members, function (member) {
- if (member.kind === 150 && nodeIsPresent(member.body)) {
+ if (member.kind === 151 && nodeIsPresent(member.body)) {
return member;
}
});
@@ -7052,10 +7205,10 @@ var ts;
var setAccessor;
if (hasDynamicName(accessor)) {
firstAccessor = accessor;
- if (accessor.kind === 151) {
+ if (accessor.kind === 152) {
getAccessor = accessor;
}
- else if (accessor.kind === 152) {
+ else if (accessor.kind === 153) {
setAccessor = accessor;
}
else {
@@ -7064,7 +7217,7 @@ var ts;
}
else {
ts.forEach(declarations, function (member) {
- if ((member.kind === 151 || member.kind === 152)
+ if ((member.kind === 152 || member.kind === 153)
&& hasModifier(member, 32) === hasModifier(accessor, 32)) {
var memberName = getPropertyNameForPropertyNameNode(member.name);
var accessorName = getPropertyNameForPropertyNameNode(accessor.name);
@@ -7075,10 +7228,10 @@ var ts;
else if (!secondAccessor) {
secondAccessor = member;
}
- if (member.kind === 151 && !getAccessor) {
+ if (member.kind === 152 && !getAccessor) {
getAccessor = member;
}
- if (member.kind === 152 && !setAccessor) {
+ if (member.kind === 153 && !setAccessor) {
setAccessor = member;
}
}
@@ -7296,7 +7449,7 @@ var ts;
}
ts.isAssignmentOperator = isAssignmentOperator;
function tryGetClassExtendingExpressionWithTypeArguments(node) {
- if (node.kind === 199 &&
+ if (node.kind === 200 &&
node.parent.token === 84 &&
isClassLike(node.parent.parent)) {
return node.parent.parent;
@@ -7314,8 +7467,8 @@ var ts;
function isDestructuringAssignment(node) {
if (isAssignmentExpression(node, true)) {
var kind = node.left.kind;
- return kind === 176
- || kind === 175;
+ return kind === 177
+ || kind === 176;
}
return false;
}
@@ -7339,31 +7492,42 @@ var ts;
return tryGetClassExtendingExpressionWithTypeArguments(node) !== undefined;
}
ts.isExpressionWithTypeArgumentsInClassExtendsClause = isExpressionWithTypeArgumentsInClassExtendsClause;
+ function isExpressionWithTypeArgumentsInClassImplementsClause(node) {
+ return node.kind === 200
+ && isEntityNameExpression(node.expression)
+ && node.parent
+ && node.parent.token === 107
+ && node.parent.parent
+ && isClassLike(node.parent.parent);
+ }
+ ts.isExpressionWithTypeArgumentsInClassImplementsClause = isExpressionWithTypeArgumentsInClassImplementsClause;
function isEntityNameExpression(node) {
return node.kind === 70 ||
- node.kind === 177 && isEntityNameExpression(node.expression);
+ node.kind === 178 && isEntityNameExpression(node.expression);
}
ts.isEntityNameExpression = isEntityNameExpression;
function isRightSideOfQualifiedNameOrPropertyAccess(node) {
- return (node.parent.kind === 141 && node.parent.right === node) ||
- (node.parent.kind === 177 && node.parent.name === node);
+ return (node.parent.kind === 142 && node.parent.right === node) ||
+ (node.parent.kind === 178 && node.parent.name === node);
}
ts.isRightSideOfQualifiedNameOrPropertyAccess = isRightSideOfQualifiedNameOrPropertyAccess;
- function isEmptyObjectLiteralOrArrayLiteral(expression) {
- var kind = expression.kind;
- if (kind === 176) {
- return expression.properties.length === 0;
- }
- if (kind === 175) {
- return expression.elements.length === 0;
- }
- return false;
+ function isEmptyObjectLiteral(expression) {
+ return expression.kind === 177 &&
+ expression.properties.length === 0;
+ }
+ ts.isEmptyObjectLiteral = isEmptyObjectLiteral;
+ function isEmptyArrayLiteral(expression) {
+ return expression.kind === 176 &&
+ expression.elements.length === 0;
}
- ts.isEmptyObjectLiteralOrArrayLiteral = isEmptyObjectLiteralOrArrayLiteral;
+ ts.isEmptyArrayLiteral = isEmptyArrayLiteral;
function getLocalSymbolForExportDefault(symbol) {
- return symbol && symbol.valueDeclaration && hasModifier(symbol.valueDeclaration, 512) ? symbol.valueDeclaration.localSymbol : undefined;
+ return isExportDefaultSymbol(symbol) ? symbol.valueDeclaration.localSymbol : undefined;
}
ts.getLocalSymbolForExportDefault = getLocalSymbolForExportDefault;
+ function isExportDefaultSymbol(symbol) {
+ return symbol && symbol.valueDeclaration && hasModifier(symbol.valueDeclaration, 512);
+ }
function tryExtractTypeScriptExtension(fileName) {
return ts.find(ts.supportedTypescriptExtensionsForExtractExtension, function (extension) { return ts.fileExtensionIs(fileName, extension); });
}
@@ -7397,39 +7561,6 @@ var ts;
}
return output;
}
- ts.stringify = typeof JSON !== "undefined" && JSON.stringify
- ? JSON.stringify
- : stringifyFallback;
- function stringifyFallback(value) {
- return value === undefined ? undefined : stringifyValue(value);
- }
- function stringifyValue(value) {
- return typeof value === "string" ? "\"" + escapeString(value) + "\""
- : typeof value === "number" ? isFinite(value) ? String(value) : "null"
- : typeof value === "boolean" ? value ? "true" : "false"
- : typeof value === "object" && value ? ts.isArray(value) ? cycleCheck(stringifyArray, value) : cycleCheck(stringifyObject, value)
- : "null";
- }
- function cycleCheck(cb, value) {
- ts.Debug.assert(!value.hasOwnProperty("__cycle"), "Converting circular structure to JSON");
- value.__cycle = true;
- var result = cb(value);
- delete value.__cycle;
- return result;
- }
- function stringifyArray(value) {
- return "[" + ts.reduceLeft(value, stringifyElement, "") + "]";
- }
- function stringifyElement(memo, value) {
- return (memo ? memo + "," : memo) + stringifyValue(value);
- }
- function stringifyObject(value) {
- return "{" + ts.reduceOwnProperties(value, stringifyProperty, "") + "}";
- }
- function stringifyProperty(memo, value, key) {
- return value === undefined || typeof value === "function" || key === "__cycle" ? memo
- : (memo ? memo + "," : memo) + ("\"" + escapeString(key) + "\":" + stringifyValue(value));
- }
var base64Digits = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
function convertToBase64(input) {
var result = "";
@@ -7488,39 +7619,39 @@ var ts;
|| kind === 94) {
return true;
}
- else if (kind === 177) {
+ else if (kind === 178) {
return isSimpleExpressionWorker(node.expression, depth + 1);
}
- else if (kind === 178) {
+ else if (kind === 179) {
return isSimpleExpressionWorker(node.expression, depth + 1)
&& isSimpleExpressionWorker(node.argumentExpression, depth + 1);
}
- else if (kind === 190
- || kind === 191) {
+ else if (kind === 191
+ || kind === 192) {
return isSimpleExpressionWorker(node.operand, depth + 1);
}
- else if (kind === 192) {
+ else if (kind === 193) {
return node.operatorToken.kind !== 39
&& isSimpleExpressionWorker(node.left, depth + 1)
&& isSimpleExpressionWorker(node.right, depth + 1);
}
- else if (kind === 193) {
+ else if (kind === 194) {
return isSimpleExpressionWorker(node.condition, depth + 1)
&& isSimpleExpressionWorker(node.whenTrue, depth + 1)
&& isSimpleExpressionWorker(node.whenFalse, depth + 1);
}
- else if (kind === 188
- || kind === 187
- || kind === 186) {
+ else if (kind === 189
+ || kind === 188
+ || kind === 187) {
return isSimpleExpressionWorker(node.expression, depth + 1);
}
- else if (kind === 175) {
+ else if (kind === 176) {
return node.elements.length === 0;
}
- else if (kind === 176) {
+ else if (kind === 177) {
return node.properties.length === 0;
}
- else if (kind === 179) {
+ else if (kind === 180) {
if (!isSimpleExpressionWorker(node.expression, depth + 1)) {
return false;
}
@@ -7535,16 +7666,19 @@ var ts;
}
return false;
}
- var syntaxKindCache = ts.createMap();
+ var syntaxKindCache = [];
function formatSyntaxKind(kind) {
var syntaxKindEnum = ts.SyntaxKind;
if (syntaxKindEnum) {
- if (syntaxKindCache[kind]) {
- return syntaxKindCache[kind];
+ var cached = syntaxKindCache[kind];
+ if (cached !== undefined) {
+ return cached;
}
- for (var name_7 in syntaxKindEnum) {
- if (syntaxKindEnum[name_7] === kind) {
- return syntaxKindCache[kind] = kind.toString() + " (" + name_7 + ")";
+ for (var name in syntaxKindEnum) {
+ if (syntaxKindEnum[name] === kind) {
+ var result = kind + " (" + name + ")";
+ syntaxKindCache[kind] = result;
+ return result;
}
}
}
@@ -7553,6 +7687,14 @@ var ts;
}
}
ts.formatSyntaxKind = formatSyntaxKind;
+ function getRangePos(range) {
+ return range ? range.pos : -1;
+ }
+ ts.getRangePos = getRangePos;
+ function getRangeEnd(range) {
+ return range ? range.end : -1;
+ }
+ ts.getRangeEnd = getRangeEnd;
function movePos(pos, value) {
return ts.positionIsSynthesized(pos) ? -1 : pos + value;
}
@@ -7627,11 +7769,11 @@ var ts;
}
ts.getStartPositionOfRange = getStartPositionOfRange;
function isDeclarationNameOfEnumOrNamespace(node) {
- var parseNode = getParseTreeNode(node);
+ var parseNode = ts.getParseTreeNode(node);
if (parseNode) {
switch (parseNode.parent.kind) {
- case 229:
- case 230:
+ case 231:
+ case 232:
return parseNode === parseNode.parent.name;
}
}
@@ -7649,7 +7791,7 @@ var ts;
if (node.symbol) {
for (var _i = 0, _a = node.symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
- if (declaration.kind === 226 && declaration !== node) {
+ if (declaration.kind === 228 && declaration !== node) {
return true;
}
}
@@ -7700,6 +7842,10 @@ var ts;
return node.kind === 70;
}
ts.isIdentifier = isIdentifier;
+ function isVoidExpression(node) {
+ return node.kind === 189;
+ }
+ ts.isVoidExpression = isVoidExpression;
function isGeneratedIdentifier(node) {
return isIdentifier(node) && node.autoGenerateKind > 0;
}
@@ -7709,16 +7855,16 @@ var ts;
}
ts.isModifier = isModifier;
function isQualifiedName(node) {
- return node.kind === 141;
+ return node.kind === 142;
}
ts.isQualifiedName = isQualifiedName;
function isComputedPropertyName(node) {
- return node.kind === 142;
+ return node.kind === 143;
}
ts.isComputedPropertyName = isComputedPropertyName;
function isEntityName(node) {
var kind = node.kind;
- return kind === 141
+ return kind === 142
|| kind === 70;
}
ts.isEntityName = isEntityName;
@@ -7727,7 +7873,7 @@ var ts;
return kind === 70
|| kind === 9
|| kind === 8
- || kind === 142;
+ || kind === 143;
}
ts.isPropertyName = isPropertyName;
function isModuleName(node) {
@@ -7739,101 +7885,105 @@ var ts;
function isBindingName(node) {
var kind = node.kind;
return kind === 70
- || kind === 172
- || kind === 173;
+ || kind === 173
+ || kind === 174;
}
ts.isBindingName = isBindingName;
function isTypeParameter(node) {
- return node.kind === 143;
+ return node.kind === 144;
}
ts.isTypeParameter = isTypeParameter;
function isParameter(node) {
- return node.kind === 144;
+ return node.kind === 145;
}
ts.isParameter = isParameter;
function isDecorator(node) {
- return node.kind === 145;
+ return node.kind === 146;
}
ts.isDecorator = isDecorator;
function isMethodDeclaration(node) {
- return node.kind === 149;
+ return node.kind === 150;
}
ts.isMethodDeclaration = isMethodDeclaration;
function isClassElement(node) {
var kind = node.kind;
- return kind === 150
- || kind === 147
- || kind === 149
- || kind === 151
+ return kind === 151
+ || kind === 148
+ || kind === 150
|| kind === 152
- || kind === 155
- || kind === 203;
+ || kind === 153
+ || kind === 156
+ || kind === 205;
}
ts.isClassElement = isClassElement;
function isObjectLiteralElementLike(node) {
var kind = node.kind;
- return kind === 257
- || kind === 258
- || kind === 259
- || kind === 149
- || kind === 151
+ return kind === 260
+ || kind === 261
+ || kind === 262
+ || kind === 150
|| kind === 152
- || kind === 244;
+ || kind === 153
+ || kind === 246;
}
ts.isObjectLiteralElementLike = isObjectLiteralElementLike;
function isTypeNodeKind(kind) {
- return (kind >= 156 && kind <= 171)
+ return (kind >= 157 && kind <= 172)
|| kind === 118
|| kind === 132
+ || kind === 133
|| kind === 121
- || kind === 134
|| kind === 135
+ || kind === 136
+ || kind === 98
|| kind === 104
+ || kind === 138
+ || kind === 94
|| kind === 129
- || kind === 199;
+ || kind === 200;
}
function isTypeNode(node) {
return isTypeNodeKind(node.kind);
}
ts.isTypeNode = isTypeNode;
function isArrayBindingPattern(node) {
- return node.kind === 173;
+ return node.kind === 174;
}
ts.isArrayBindingPattern = isArrayBindingPattern;
function isObjectBindingPattern(node) {
- return node.kind === 172;
+ return node.kind === 173;
}
ts.isObjectBindingPattern = isObjectBindingPattern;
function isBindingPattern(node) {
if (node) {
var kind = node.kind;
- return kind === 173
- || kind === 172;
+ return kind === 174
+ || kind === 173;
}
return false;
}
ts.isBindingPattern = isBindingPattern;
function isAssignmentPattern(node) {
var kind = node.kind;
- return kind === 175
- || kind === 176;
+ return kind === 176
+ || kind === 177;
}
ts.isAssignmentPattern = isAssignmentPattern;
function isBindingElement(node) {
- return node.kind === 174;
+ return node.kind === 175;
}
ts.isBindingElement = isBindingElement;
function isArrayBindingElement(node) {
var kind = node.kind;
- return kind === 174
- || kind === 198;
+ return kind === 175
+ || kind === 199;
}
ts.isArrayBindingElement = isArrayBindingElement;
function isDeclarationBindingElement(bindingElement) {
switch (bindingElement.kind) {
- case 223:
- case 144:
- case 174:
+ case 225:
+ case 145:
+ case 175:
return true;
}
return false;
@@ -7846,8 +7996,8 @@ var ts;
ts.isBindingOrAssignmentPattern = isBindingOrAssignmentPattern;
function isObjectBindingOrAssignmentPattern(node) {
switch (node.kind) {
- case 172:
- case 176:
+ case 173:
+ case 177:
return true;
}
return false;
@@ -7855,94 +8005,100 @@ var ts;
ts.isObjectBindingOrAssignmentPattern = isObjectBindingOrAssignmentPattern;
function isArrayBindingOrAssignmentPattern(node) {
switch (node.kind) {
- case 173:
- case 175:
+ case 174:
+ case 176:
return true;
}
return false;
}
ts.isArrayBindingOrAssignmentPattern = isArrayBindingOrAssignmentPattern;
function isArrayLiteralExpression(node) {
- return node.kind === 175;
+ return node.kind === 176;
}
ts.isArrayLiteralExpression = isArrayLiteralExpression;
function isObjectLiteralExpression(node) {
- return node.kind === 176;
+ return node.kind === 177;
}
ts.isObjectLiteralExpression = isObjectLiteralExpression;
function isPropertyAccessExpression(node) {
- return node.kind === 177;
+ return node.kind === 178;
}
ts.isPropertyAccessExpression = isPropertyAccessExpression;
+ function isPropertyAccessOrQualifiedName(node) {
+ var kind = node.kind;
+ return kind === 178
+ || kind === 142;
+ }
+ ts.isPropertyAccessOrQualifiedName = isPropertyAccessOrQualifiedName;
function isElementAccessExpression(node) {
- return node.kind === 178;
+ return node.kind === 179;
}
ts.isElementAccessExpression = isElementAccessExpression;
function isBinaryExpression(node) {
- return node.kind === 192;
+ return node.kind === 193;
}
ts.isBinaryExpression = isBinaryExpression;
function isConditionalExpression(node) {
- return node.kind === 193;
+ return node.kind === 194;
}
ts.isConditionalExpression = isConditionalExpression;
function isCallExpression(node) {
- return node.kind === 179;
+ return node.kind === 180;
}
ts.isCallExpression = isCallExpression;
function isTemplateLiteral(node) {
var kind = node.kind;
- return kind === 194
+ return kind === 195
|| kind === 12;
}
ts.isTemplateLiteral = isTemplateLiteral;
function isSpreadExpression(node) {
- return node.kind === 196;
+ return node.kind === 197;
}
ts.isSpreadExpression = isSpreadExpression;
function isExpressionWithTypeArguments(node) {
- return node.kind === 199;
+ return node.kind === 200;
}
ts.isExpressionWithTypeArguments = isExpressionWithTypeArguments;
function isLeftHandSideExpressionKind(kind) {
- return kind === 177
- || kind === 178
- || kind === 180
+ return kind === 178
|| kind === 179
- || kind === 246
- || kind === 247
|| kind === 181
- || kind === 175
- || kind === 183
+ || kind === 180
+ || kind === 248
+ || kind === 249
+ || kind === 182
|| kind === 176
- || kind === 197
|| kind === 184
+ || kind === 177
+ || kind === 198
+ || kind === 185
|| kind === 70
|| kind === 11
|| kind === 8
|| kind === 9
|| kind === 12
- || kind === 194
+ || kind === 195
|| kind === 85
|| kind === 94
|| kind === 98
|| kind === 100
|| kind === 96
- || kind === 201
- || kind === 297;
+ || kind === 202
+ || kind === 203;
}
function isLeftHandSideExpression(node) {
return isLeftHandSideExpressionKind(ts.skipPartiallyEmittedExpressions(node).kind);
}
ts.isLeftHandSideExpression = isLeftHandSideExpression;
function isUnaryExpressionKind(kind) {
- return kind === 190
- || kind === 191
- || kind === 186
+ return kind === 191
+ || kind === 192
|| kind === 187
|| kind === 188
|| kind === 189
- || kind === 182
+ || kind === 190
+ || kind === 183
|| isLeftHandSideExpressionKind(kind);
}
function isUnaryExpression(node) {
@@ -7950,14 +8106,13 @@ var ts;
}
ts.isUnaryExpression = isUnaryExpression;
function isExpressionKind(kind) {
- return kind === 193
- || kind === 195
- || kind === 185
- || kind === 192
+ return kind === 194
|| kind === 196
- || kind === 200
- || kind === 198
- || kind === 297
+ || kind === 186
+ || kind === 193
+ || kind === 197
+ || kind === 201
+ || kind === 199
|| isUnaryExpressionKind(kind);
}
function isExpression(node) {
@@ -7966,16 +8121,16 @@ var ts;
ts.isExpression = isExpression;
function isAssertionExpression(node) {
var kind = node.kind;
- return kind === 182
- || kind === 200;
+ return kind === 183
+ || kind === 201;
}
ts.isAssertionExpression = isAssertionExpression;
function isPartiallyEmittedExpression(node) {
- return node.kind === 294;
+ return node.kind === 295;
}
ts.isPartiallyEmittedExpression = isPartiallyEmittedExpression;
function isNotEmittedStatement(node) {
- return node.kind === 293;
+ return node.kind === 294;
}
ts.isNotEmittedStatement = isNotEmittedStatement;
function isNotEmittedOrPartiallyEmittedNode(node) {
@@ -7984,15 +8139,15 @@ var ts;
}
ts.isNotEmittedOrPartiallyEmittedNode = isNotEmittedOrPartiallyEmittedNode;
function isOmittedExpression(node) {
- return node.kind === 198;
+ return node.kind === 199;
}
ts.isOmittedExpression = isOmittedExpression;
function isTemplateSpan(node) {
- return node.kind === 202;
+ return node.kind === 204;
}
ts.isTemplateSpan = isTemplateSpan;
function isBlock(node) {
- return node.kind === 204;
+ return node.kind === 206;
}
ts.isBlock = isBlock;
function isConciseBody(node) {
@@ -8010,121 +8165,135 @@ var ts;
}
ts.isForInitializer = isForInitializer;
function isVariableDeclaration(node) {
- return node.kind === 223;
+ return node.kind === 225;
}
ts.isVariableDeclaration = isVariableDeclaration;
function isVariableDeclarationList(node) {
- return node.kind === 224;
+ return node.kind === 226;
}
ts.isVariableDeclarationList = isVariableDeclarationList;
function isCaseBlock(node) {
- return node.kind === 232;
+ return node.kind === 234;
}
ts.isCaseBlock = isCaseBlock;
function isModuleBody(node) {
var kind = node.kind;
- return kind === 231
- || kind === 230;
+ return kind === 233
+ || kind === 232
+ || kind === 70;
}
ts.isModuleBody = isModuleBody;
+ function isNamespaceBody(node) {
+ var kind = node.kind;
+ return kind === 233
+ || kind === 232;
+ }
+ ts.isNamespaceBody = isNamespaceBody;
+ function isJSDocNamespaceBody(node) {
+ var kind = node.kind;
+ return kind === 70
+ || kind === 232;
+ }
+ ts.isJSDocNamespaceBody = isJSDocNamespaceBody;
function isImportEqualsDeclaration(node) {
- return node.kind === 234;
+ return node.kind === 236;
}
ts.isImportEqualsDeclaration = isImportEqualsDeclaration;
function isImportClause(node) {
- return node.kind === 236;
+ return node.kind === 238;
}
ts.isImportClause = isImportClause;
function isNamedImportBindings(node) {
var kind = node.kind;
- return kind === 238
- || kind === 237;
+ return kind === 240
+ || kind === 239;
}
ts.isNamedImportBindings = isNamedImportBindings;
function isImportSpecifier(node) {
- return node.kind === 239;
+ return node.kind === 241;
}
ts.isImportSpecifier = isImportSpecifier;
function isNamedExports(node) {
- return node.kind === 242;
+ return node.kind === 244;
}
ts.isNamedExports = isNamedExports;
function isExportSpecifier(node) {
- return node.kind === 243;
+ return node.kind === 245;
}
ts.isExportSpecifier = isExportSpecifier;
function isModuleOrEnumDeclaration(node) {
- return node.kind === 230 || node.kind === 229;
+ return node.kind === 232 || node.kind === 231;
}
ts.isModuleOrEnumDeclaration = isModuleOrEnumDeclaration;
function isDeclarationKind(kind) {
- return kind === 185
- || kind === 174
- || kind === 226
- || kind === 197
- || kind === 150
- || kind === 229
- || kind === 260
- || kind === 243
- || kind === 225
- || kind === 184
+ return kind === 186
+ || kind === 175
+ || kind === 228
+ || kind === 198
|| kind === 151
- || kind === 236
- || kind === 234
- || kind === 239
+ || kind === 231
+ || kind === 263
+ || kind === 245
|| kind === 227
+ || kind === 185
+ || kind === 152
+ || kind === 238
+ || kind === 236
+ || kind === 241
+ || kind === 229
+ || kind === 252
+ || kind === 150
|| kind === 149
+ || kind === 232
+ || kind === 235
+ || kind === 239
+ || kind === 145
+ || kind === 260
|| kind === 148
+ || kind === 147
+ || kind === 153
+ || kind === 261
|| kind === 230
- || kind === 233
- || kind === 237
|| kind === 144
- || kind === 257
- || kind === 147
- || kind === 146
- || kind === 152
- || kind === 258
- || kind === 228
- || kind === 143
- || kind === 223
- || kind === 285;
+ || kind === 225
+ || kind === 289;
}
function isDeclarationStatementKind(kind) {
- return kind === 225
- || kind === 244
- || kind === 226
- || kind === 227
+ return kind === 227
+ || kind === 246
|| kind === 228
|| kind === 229
|| kind === 230
- || kind === 235
- || kind === 234
- || kind === 241
- || kind === 240
- || kind === 233;
+ || kind === 231
+ || kind === 232
+ || kind === 237
+ || kind === 236
+ || kind === 243
+ || kind === 242
+ || kind === 235;
}
function isStatementKindButNotDeclarationKind(kind) {
- return kind === 215
+ return kind === 217
+ || kind === 216
+ || kind === 224
+ || kind === 211
+ || kind === 209
+ || kind === 208
|| kind === 214
+ || kind === 215
+ || kind === 213
+ || kind === 210
+ || kind === 221
+ || kind === 218
+ || kind === 220
|| kind === 222
- || kind === 209
+ || kind === 223
|| kind === 207
- || kind === 206
|| kind === 212
- || kind === 213
- || kind === 211
- || kind === 208
|| kind === 219
- || kind === 216
- || kind === 218
- || kind === 220
- || kind === 221
- || kind === 205
- || kind === 210
- || kind === 217
- || kind === 293
- || kind === 296
- || kind === 295;
+ || kind === 294
+ || kind === 297
+ || kind === 296;
}
function isDeclaration(node) {
return isDeclarationKind(node.kind);
@@ -8142,87 +8311,98 @@ var ts;
var kind = node.kind;
return isStatementKindButNotDeclarationKind(kind)
|| isDeclarationStatementKind(kind)
- || kind === 204;
+ || kind === 206;
}
ts.isStatement = isStatement;
function isModuleReference(node) {
var kind = node.kind;
- return kind === 245
- || kind === 141
+ return kind === 247
+ || kind === 142
|| kind === 70;
}
ts.isModuleReference = isModuleReference;
function isJsxOpeningElement(node) {
- return node.kind === 248;
+ return node.kind === 250;
}
ts.isJsxOpeningElement = isJsxOpeningElement;
function isJsxClosingElement(node) {
- return node.kind === 249;
+ return node.kind === 251;
}
ts.isJsxClosingElement = isJsxClosingElement;
function isJsxTagNameExpression(node) {
var kind = node.kind;
return kind === 98
|| kind === 70
- || kind === 177;
+ || kind === 178;
}
ts.isJsxTagNameExpression = isJsxTagNameExpression;
function isJsxChild(node) {
var kind = node.kind;
- return kind === 246
- || kind === 252
- || kind === 247
+ return kind === 248
+ || kind === 255
+ || kind === 249
|| kind === 10;
}
ts.isJsxChild = isJsxChild;
+ function isJsxAttributes(node) {
+ var kind = node.kind;
+ return kind === 253;
+ }
+ ts.isJsxAttributes = isJsxAttributes;
function isJsxAttributeLike(node) {
var kind = node.kind;
- return kind === 250
- || kind === 251;
+ return kind === 252
+ || kind === 254;
}
ts.isJsxAttributeLike = isJsxAttributeLike;
function isJsxSpreadAttribute(node) {
- return node.kind === 251;
+ return node.kind === 254;
}
ts.isJsxSpreadAttribute = isJsxSpreadAttribute;
function isJsxAttribute(node) {
- return node.kind === 250;
+ return node.kind === 252;
}
ts.isJsxAttribute = isJsxAttribute;
function isStringLiteralOrJsxExpression(node) {
var kind = node.kind;
return kind === 9
- || kind === 252;
+ || kind === 255;
}
ts.isStringLiteralOrJsxExpression = isStringLiteralOrJsxExpression;
+ function isJsxOpeningLikeElement(node) {
+ var kind = node.kind;
+ return kind === 250
+ || kind === 249;
+ }
+ ts.isJsxOpeningLikeElement = isJsxOpeningLikeElement;
function isCaseOrDefaultClause(node) {
var kind = node.kind;
- return kind === 253
- || kind === 254;
+ return kind === 256
+ || kind === 257;
}
ts.isCaseOrDefaultClause = isCaseOrDefaultClause;
function isHeritageClause(node) {
- return node.kind === 255;
+ return node.kind === 258;
}
ts.isHeritageClause = isHeritageClause;
function isCatchClause(node) {
- return node.kind === 256;
+ return node.kind === 259;
}
ts.isCatchClause = isCatchClause;
function isPropertyAssignment(node) {
- return node.kind === 257;
+ return node.kind === 260;
}
ts.isPropertyAssignment = isPropertyAssignment;
function isShorthandPropertyAssignment(node) {
- return node.kind === 258;
+ return node.kind === 261;
}
ts.isShorthandPropertyAssignment = isShorthandPropertyAssignment;
function isEnumMember(node) {
- return node.kind === 260;
+ return node.kind === 263;
}
ts.isEnumMember = isEnumMember;
function isSourceFile(node) {
- return node.kind === 261;
+ return node.kind === 264;
}
ts.isSourceFile = isSourceFile;
function isWatchSet(options) {
@@ -8234,10 +8414,11 @@ var ts;
function getDefaultLibFileName(options) {
switch (options.target) {
case 5:
+ return "lib.esnext.full.d.ts";
case 4:
- return "lib.es2017.d.ts";
+ return "lib.es2017.full.d.ts";
case 3:
- return "lib.es2016.d.ts";
+ return "lib.es2016.full.d.ts";
case 2:
return "lib.es6.d.ts";
default:
@@ -8361,9 +8542,9 @@ var ts;
}
ts.collapseTextChangeRangesAcrossMultipleVersions = collapseTextChangeRangesAcrossMultipleVersions;
function getTypeParameterOwner(d) {
- if (d && d.kind === 143) {
+ if (d && d.kind === 144) {
for (var current = d; current; current = current.parent) {
- if (ts.isFunctionLike(current) || ts.isClassLike(current) || current.kind === 227) {
+ if (ts.isFunctionLike(current) || ts.isClassLike(current) || current.kind === 229) {
return current;
}
}
@@ -8371,11 +8552,11 @@ var ts;
}
ts.getTypeParameterOwner = getTypeParameterOwner;
function isParameterPropertyDeclaration(node) {
- return ts.hasModifier(node, 92) && node.parent.kind === 150 && ts.isClassLike(node.parent.parent);
+ return ts.hasModifier(node, 92) && node.parent.kind === 151 && ts.isClassLike(node.parent.parent);
}
ts.isParameterPropertyDeclaration = isParameterPropertyDeclaration;
function walkUpBindingElementsAndPatterns(node) {
- while (node && (node.kind === 174 || ts.isBindingPattern(node))) {
+ while (node && (node.kind === 175 || ts.isBindingPattern(node))) {
node = node.parent;
}
return node;
@@ -8383,14 +8564,14 @@ var ts;
function getCombinedModifierFlags(node) {
node = walkUpBindingElementsAndPatterns(node);
var flags = ts.getModifierFlags(node);
- if (node.kind === 223) {
+ if (node.kind === 225) {
node = node.parent;
}
- if (node && node.kind === 224) {
+ if (node && node.kind === 226) {
flags |= ts.getModifierFlags(node);
node = node.parent;
}
- if (node && node.kind === 205) {
+ if (node && node.kind === 207) {
flags |= ts.getModifierFlags(node);
}
return flags;
@@ -8399,14 +8580,14 @@ var ts;
function getCombinedNodeFlags(node) {
node = walkUpBindingElementsAndPatterns(node);
var flags = node.flags;
- if (node.kind === 223) {
+ if (node.kind === 225) {
node = node.parent;
}
- if (node && node.kind === 224) {
+ if (node && node.kind === 226) {
flags |= node.flags;
node = node.parent;
}
- if (node && node.kind === 205) {
+ if (node && node.kind === 207) {
flags |= node.flags;
}
return flags;
@@ -8459,24 +8640,46 @@ var ts;
}
}
ts.validateLocaleAndSetLanguage = validateLocaleAndSetLanguage;
+ function getOriginalNode(node, nodeTest) {
+ if (node) {
+ while (node.original !== undefined) {
+ node = node.original;
+ }
+ }
+ return !nodeTest || nodeTest(node) ? node : undefined;
+ }
+ ts.getOriginalNode = getOriginalNode;
+ function isParseTreeNode(node) {
+ return (node.flags & 8) === 0;
+ }
+ ts.isParseTreeNode = isParseTreeNode;
+ function getParseTreeNode(node, nodeTest) {
+ if (node === undefined || isParseTreeNode(node)) {
+ return node;
+ }
+ node = getOriginalNode(node);
+ if (isParseTreeNode(node) && (!nodeTest || nodeTest(node))) {
+ return node;
+ }
+ return undefined;
+ }
+ ts.getParseTreeNode = getParseTreeNode;
+ function unescapeIdentifier(identifier) {
+ return identifier.length >= 3 && identifier.charCodeAt(0) === 95 && identifier.charCodeAt(1) === 95 && identifier.charCodeAt(2) === 95 ? identifier.substr(1) : identifier;
+ }
+ ts.unescapeIdentifier = unescapeIdentifier;
})(ts || (ts = {}));
var ts;
(function (ts) {
- var NodeConstructor;
- var SourceFileConstructor;
- function createNode(kind, location, flags) {
- var ConstructorForKind = kind === 261
- ? (SourceFileConstructor || (SourceFileConstructor = ts.objectAllocator.getSourceFileConstructor()))
- : (NodeConstructor || (NodeConstructor = ts.objectAllocator.getNodeConstructor()));
- var node = location
- ? new ConstructorForKind(kind, location.pos, location.end)
- : new ConstructorForKind(kind, -1, -1);
- node.flags = flags | 8;
+ function createSynthesizedNode(kind) {
+ var node = ts.createNode(kind, -1, -1);
+ node.flags |= 8;
return node;
}
function updateNode(updated, original) {
if (updated !== original) {
setOriginalNode(updated, original);
+ setTextRange(updated, original);
if (original.startsOnNewLine) {
updated.startsOnNewLine = true;
}
@@ -8485,7 +8688,7 @@ var ts;
return updated;
}
ts.updateNode = updateNode;
- function createNodeArray(elements, location, hasTrailingComma) {
+ function createNodeArray(elements, hasTrailingComma) {
if (elements) {
if (ts.isNodeArray(elements)) {
return elements;
@@ -8495,32 +8698,15 @@ var ts;
elements = [];
}
var array = elements;
- if (location) {
- array.pos = location.pos;
- array.end = location.end;
- }
- else {
- array.pos = -1;
- array.end = -1;
- }
- if (hasTrailingComma) {
- array.hasTrailingComma = true;
- }
+ array.pos = -1;
+ array.end = -1;
+ array.hasTrailingComma = hasTrailingComma;
return array;
}
ts.createNodeArray = createNodeArray;
- function createSynthesizedNode(kind, startsOnNewLine) {
- var node = createNode(kind, undefined);
- node.startsOnNewLine = startsOnNewLine;
- return node;
- }
- ts.createSynthesizedNode = createSynthesizedNode;
- function createSynthesizedNodeArray(elements) {
- return createNodeArray(elements, undefined);
- }
- ts.createSynthesizedNodeArray = createSynthesizedNodeArray;
function getSynthesizedClone(node) {
- var clone = createNode(node.kind, undefined, node.flags);
+ var clone = createSynthesizedNode(node.kind);
+ clone.flags |= node.flags;
setOriginalNode(clone, node);
for (var key in node) {
if (clone.hasOwnProperty(key) || !node.hasOwnProperty(key)) {
@@ -8531,50 +8717,48 @@ var ts;
return clone;
}
ts.getSynthesizedClone = getSynthesizedClone;
- function getMutableClone(node) {
- var clone = getSynthesizedClone(node);
- clone.pos = node.pos;
- clone.end = node.end;
- clone.parent = node.parent;
- return clone;
- }
- ts.getMutableClone = getMutableClone;
- function createLiteral(value, location) {
+ function createLiteral(value) {
if (typeof value === "number") {
- var node = createNode(8, location, undefined);
- node.text = value.toString();
- return node;
+ return createNumericLiteral(value + "");
}
- else if (typeof value === "boolean") {
- return createNode(value ? 100 : 85, location, undefined);
+ if (typeof value === "boolean") {
+ return value ? createTrue() : createFalse();
}
- else if (typeof value === "string") {
- var node = createNode(9, location, undefined);
- node.text = value;
- return node;
- }
- else if (value) {
- var node = createNode(9, location, undefined);
- node.textSourceNode = value;
- node.text = value.text;
- return node;
+ if (typeof value === "string") {
+ return createStringLiteral(value);
}
+ return createLiteralFromNode(value);
}
ts.createLiteral = createLiteral;
- var nextAutoGenerateId = 0;
- function createIdentifier(text, location) {
- var node = createNode(70, location);
+ function createNumericLiteral(value) {
+ var node = createSynthesizedNode(8);
+ node.text = value;
+ node.numericLiteralFlags = 0;
+ return node;
+ }
+ ts.createNumericLiteral = createNumericLiteral;
+ function createStringLiteral(text) {
+ var node = createSynthesizedNode(9);
+ node.text = text;
+ return node;
+ }
+ function createLiteralFromNode(sourceNode) {
+ var node = createStringLiteral(sourceNode.text);
+ node.textSourceNode = sourceNode;
+ return node;
+ }
+ function createIdentifier(text) {
+ var node = createSynthesizedNode(70);
node.text = ts.escapeIdentifier(text);
- node.originalKeywordKind = ts.stringToToken(text);
+ node.originalKeywordKind = text ? ts.stringToToken(text) : 0;
node.autoGenerateKind = 0;
node.autoGenerateId = 0;
return node;
}
ts.createIdentifier = createIdentifier;
- function createTempVariable(recordTempVariable, location) {
- var name = createNode(70, location);
- name.text = "";
- name.originalKeywordKind = 0;
+ var nextAutoGenerateId = 0;
+ function createTempVariable(recordTempVariable) {
+ var name = createIdentifier("");
name.autoGenerateKind = 1;
name.autoGenerateId = nextAutoGenerateId;
nextAutoGenerateId++;
@@ -8584,93 +8768,387 @@ var ts;
return name;
}
ts.createTempVariable = createTempVariable;
- function createLoopVariable(location) {
- var name = createNode(70, location);
- name.text = "";
- name.originalKeywordKind = 0;
+ function createLoopVariable() {
+ var name = createIdentifier("");
name.autoGenerateKind = 2;
name.autoGenerateId = nextAutoGenerateId;
nextAutoGenerateId++;
return name;
}
ts.createLoopVariable = createLoopVariable;
- function createUniqueName(text, location) {
- var name = createNode(70, location);
- name.text = text;
- name.originalKeywordKind = 0;
+ function createUniqueName(text) {
+ var name = createIdentifier(text);
name.autoGenerateKind = 3;
name.autoGenerateId = nextAutoGenerateId;
nextAutoGenerateId++;
return name;
}
ts.createUniqueName = createUniqueName;
- function getGeneratedNameForNode(node, location) {
- var name = createNode(70, location);
- name.original = node;
- name.text = "";
- name.originalKeywordKind = 0;
+ function getGeneratedNameForNode(node) {
+ var name = createIdentifier("");
name.autoGenerateKind = 4;
name.autoGenerateId = nextAutoGenerateId;
+ name.original = node;
nextAutoGenerateId++;
return name;
}
ts.getGeneratedNameForNode = getGeneratedNameForNode;
function createToken(token) {
- return createNode(token);
+ return createSynthesizedNode(token);
}
ts.createToken = createToken;
function createSuper() {
- var node = createNode(96);
- return node;
+ return createSynthesizedNode(96);
}
ts.createSuper = createSuper;
- function createThis(location) {
- var node = createNode(98, location);
- return node;
+ function createThis() {
+ return createSynthesizedNode(98);
}
ts.createThis = createThis;
function createNull() {
- var node = createNode(94);
- return node;
+ return createSynthesizedNode(94);
}
ts.createNull = createNull;
- function createComputedPropertyName(expression, location) {
- var node = createNode(142, location);
+ function createTrue() {
+ return createSynthesizedNode(100);
+ }
+ ts.createTrue = createTrue;
+ function createFalse() {
+ return createSynthesizedNode(85);
+ }
+ ts.createFalse = createFalse;
+ function createQualifiedName(left, right) {
+ var node = createSynthesizedNode(142);
+ node.left = left;
+ node.right = asName(right);
+ return node;
+ }
+ ts.createQualifiedName = createQualifiedName;
+ function updateQualifiedName(node, left, right) {
+ return node.left !== left
+ || node.right !== right
+ ? updateNode(createQualifiedName(left, right), node)
+ : node;
+ }
+ ts.updateQualifiedName = updateQualifiedName;
+ function createComputedPropertyName(expression) {
+ var node = createSynthesizedNode(143);
node.expression = expression;
return node;
}
ts.createComputedPropertyName = createComputedPropertyName;
function updateComputedPropertyName(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createComputedPropertyName(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createComputedPropertyName(expression), node)
+ : node;
}
ts.updateComputedPropertyName = updateComputedPropertyName;
- function createParameter(decorators, modifiers, dotDotDotToken, name, questionToken, type, initializer, location, flags) {
- var node = createNode(144, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createSignatureDeclaration(kind, typeParameters, parameters, type) {
+ var signatureDeclaration = createSynthesizedNode(kind);
+ signatureDeclaration.typeParameters = asNodeArray(typeParameters);
+ signatureDeclaration.parameters = asNodeArray(parameters);
+ signatureDeclaration.type = type;
+ return signatureDeclaration;
+ }
+ ts.createSignatureDeclaration = createSignatureDeclaration;
+ function updateSignatureDeclaration(node, typeParameters, parameters, type) {
+ return node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ ? updateNode(createSignatureDeclaration(node.kind, typeParameters, parameters, type), node)
+ : node;
+ }
+ function createFunctionTypeNode(typeParameters, parameters, type) {
+ return createSignatureDeclaration(159, typeParameters, parameters, type);
+ }
+ ts.createFunctionTypeNode = createFunctionTypeNode;
+ function updateFunctionTypeNode(node, typeParameters, parameters, type) {
+ return updateSignatureDeclaration(node, typeParameters, parameters, type);
+ }
+ ts.updateFunctionTypeNode = updateFunctionTypeNode;
+ function createConstructorTypeNode(typeParameters, parameters, type) {
+ return createSignatureDeclaration(160, typeParameters, parameters, type);
+ }
+ ts.createConstructorTypeNode = createConstructorTypeNode;
+ function updateConstructorTypeNode(node, typeParameters, parameters, type) {
+ return updateSignatureDeclaration(node, typeParameters, parameters, type);
+ }
+ ts.updateConstructorTypeNode = updateConstructorTypeNode;
+ function createCallSignatureDeclaration(typeParameters, parameters, type) {
+ return createSignatureDeclaration(154, typeParameters, parameters, type);
+ }
+ ts.createCallSignatureDeclaration = createCallSignatureDeclaration;
+ function updateCallSignatureDeclaration(node, typeParameters, parameters, type) {
+ return updateSignatureDeclaration(node, typeParameters, parameters, type);
+ }
+ ts.updateCallSignatureDeclaration = updateCallSignatureDeclaration;
+ function createConstructSignatureDeclaration(typeParameters, parameters, type) {
+ return createSignatureDeclaration(155, typeParameters, parameters, type);
+ }
+ ts.createConstructSignatureDeclaration = createConstructSignatureDeclaration;
+ function updateConstructSignatureDeclaration(node, typeParameters, parameters, type) {
+ return updateSignatureDeclaration(node, typeParameters, parameters, type);
+ }
+ ts.updateConstructSignatureDeclaration = updateConstructSignatureDeclaration;
+ function createMethodSignature(typeParameters, parameters, type, name, questionToken) {
+ var methodSignature = createSignatureDeclaration(149, typeParameters, parameters, type);
+ methodSignature.name = asName(name);
+ methodSignature.questionToken = questionToken;
+ return methodSignature;
+ }
+ ts.createMethodSignature = createMethodSignature;
+ function updateMethodSignature(node, typeParameters, parameters, type, name, questionToken) {
+ return node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.name !== name
+ || node.questionToken !== questionToken
+ ? updateNode(createMethodSignature(typeParameters, parameters, type, name, questionToken), node)
+ : node;
+ }
+ ts.updateMethodSignature = updateMethodSignature;
+ function createKeywordTypeNode(kind) {
+ return createSynthesizedNode(kind);
+ }
+ ts.createKeywordTypeNode = createKeywordTypeNode;
+ function createThisTypeNode() {
+ return createSynthesizedNode(168);
+ }
+ ts.createThisTypeNode = createThisTypeNode;
+ function createLiteralTypeNode(literal) {
+ var literalTypeNode = createSynthesizedNode(172);
+ literalTypeNode.literal = literal;
+ return literalTypeNode;
+ }
+ ts.createLiteralTypeNode = createLiteralTypeNode;
+ function updateLiteralTypeNode(node, literal) {
+ return node.literal !== literal
+ ? updateNode(createLiteralTypeNode(literal), node)
+ : node;
+ }
+ ts.updateLiteralTypeNode = updateLiteralTypeNode;
+ function createTypeReferenceNode(typeName, typeArguments) {
+ var typeReference = createSynthesizedNode(158);
+ typeReference.typeName = asName(typeName);
+ typeReference.typeArguments = asNodeArray(typeArguments);
+ return typeReference;
+ }
+ ts.createTypeReferenceNode = createTypeReferenceNode;
+ function updateTypeReferenceNode(node, typeName, typeArguments) {
+ return node.typeName !== typeName
+ || node.typeArguments !== typeArguments
+ ? updateNode(createTypeReferenceNode(typeName, typeArguments), node)
+ : node;
+ }
+ ts.updateTypeReferenceNode = updateTypeReferenceNode;
+ function createTypePredicateNode(parameterName, type) {
+ var typePredicateNode = createSynthesizedNode(157);
+ typePredicateNode.parameterName = asName(parameterName);
+ typePredicateNode.type = type;
+ return typePredicateNode;
+ }
+ ts.createTypePredicateNode = createTypePredicateNode;
+ function updateTypePredicateNode(node, parameterName, type) {
+ return node.parameterName !== parameterName
+ || node.type !== type
+ ? updateNode(createTypePredicateNode(parameterName, type), node)
+ : node;
+ }
+ ts.updateTypePredicateNode = updateTypePredicateNode;
+ function createTypeQueryNode(exprName) {
+ var typeQueryNode = createSynthesizedNode(161);
+ typeQueryNode.exprName = exprName;
+ return typeQueryNode;
+ }
+ ts.createTypeQueryNode = createTypeQueryNode;
+ function updateTypeQueryNode(node, exprName) {
+ return node.exprName !== exprName ? updateNode(createTypeQueryNode(exprName), node) : node;
+ }
+ ts.updateTypeQueryNode = updateTypeQueryNode;
+ function createArrayTypeNode(elementType) {
+ var arrayTypeNode = createSynthesizedNode(163);
+ arrayTypeNode.elementType = elementType;
+ return arrayTypeNode;
+ }
+ ts.createArrayTypeNode = createArrayTypeNode;
+ function updateArrayTypeNode(node, elementType) {
+ return node.elementType !== elementType
+ ? updateNode(createArrayTypeNode(elementType), node)
+ : node;
+ }
+ ts.updateArrayTypeNode = updateArrayTypeNode;
+ function createUnionOrIntersectionTypeNode(kind, types) {
+ var unionTypeNode = createSynthesizedNode(kind);
+ unionTypeNode.types = createNodeArray(types);
+ return unionTypeNode;
+ }
+ ts.createUnionOrIntersectionTypeNode = createUnionOrIntersectionTypeNode;
+ function updateUnionOrIntersectionTypeNode(node, types) {
+ return node.types !== types
+ ? updateNode(createUnionOrIntersectionTypeNode(node.kind, types), node)
+ : node;
+ }
+ ts.updateUnionOrIntersectionTypeNode = updateUnionOrIntersectionTypeNode;
+ function createTypeLiteralNode(members) {
+ var typeLiteralNode = createSynthesizedNode(162);
+ typeLiteralNode.members = createNodeArray(members);
+ return typeLiteralNode;
+ }
+ ts.createTypeLiteralNode = createTypeLiteralNode;
+ function updateTypeLiteralNode(node, members) {
+ return node.members !== members
+ ? updateNode(createTypeLiteralNode(members), node)
+ : node;
+ }
+ ts.updateTypeLiteralNode = updateTypeLiteralNode;
+ function createTupleTypeNode(elementTypes) {
+ var tupleTypeNode = createSynthesizedNode(164);
+ tupleTypeNode.elementTypes = createNodeArray(elementTypes);
+ return tupleTypeNode;
+ }
+ ts.createTupleTypeNode = createTupleTypeNode;
+ function updateTypleTypeNode(node, elementTypes) {
+ return node.elementTypes !== elementTypes
+ ? updateNode(createTupleTypeNode(elementTypes), node)
+ : node;
+ }
+ ts.updateTypleTypeNode = updateTypleTypeNode;
+ function createMappedTypeNode(readonlyToken, typeParameter, questionToken, type) {
+ var mappedTypeNode = createSynthesizedNode(171);
+ mappedTypeNode.readonlyToken = readonlyToken;
+ mappedTypeNode.typeParameter = typeParameter;
+ mappedTypeNode.questionToken = questionToken;
+ mappedTypeNode.type = type;
+ return mappedTypeNode;
+ }
+ ts.createMappedTypeNode = createMappedTypeNode;
+ function updateMappedTypeNode(node, readonlyToken, typeParameter, questionToken, type) {
+ return node.readonlyToken !== readonlyToken
+ || node.typeParameter !== typeParameter
+ || node.questionToken !== questionToken
+ || node.type !== type
+ ? updateNode(createMappedTypeNode(readonlyToken, typeParameter, questionToken, type), node)
+ : node;
+ }
+ ts.updateMappedTypeNode = updateMappedTypeNode;
+ function createTypeOperatorNode(type) {
+ var typeOperatorNode = createSynthesizedNode(169);
+ typeOperatorNode.operator = 126;
+ typeOperatorNode.type = type;
+ return typeOperatorNode;
+ }
+ ts.createTypeOperatorNode = createTypeOperatorNode;
+ function updateTypeOperatorNode(node, type) {
+ return node.type !== type ? updateNode(createTypeOperatorNode(type), node) : node;
+ }
+ ts.updateTypeOperatorNode = updateTypeOperatorNode;
+ function createIndexedAccessTypeNode(objectType, indexType) {
+ var indexedAccessTypeNode = createSynthesizedNode(170);
+ indexedAccessTypeNode.objectType = objectType;
+ indexedAccessTypeNode.indexType = indexType;
+ return indexedAccessTypeNode;
+ }
+ ts.createIndexedAccessTypeNode = createIndexedAccessTypeNode;
+ function updateIndexedAccessTypeNode(node, objectType, indexType) {
+ return node.objectType !== objectType
+ || node.indexType !== indexType
+ ? updateNode(createIndexedAccessTypeNode(objectType, indexType), node)
+ : node;
+ }
+ ts.updateIndexedAccessTypeNode = updateIndexedAccessTypeNode;
+ function createTypeParameterDeclaration(name, constraint, defaultType) {
+ var typeParameter = createSynthesizedNode(144);
+ typeParameter.name = asName(name);
+ typeParameter.constraint = constraint;
+ typeParameter.default = defaultType;
+ return typeParameter;
+ }
+ ts.createTypeParameterDeclaration = createTypeParameterDeclaration;
+ function updateTypeParameterDeclaration(node, name, constraint, defaultType) {
+ return node.name !== name
+ || node.constraint !== constraint
+ || node.default !== defaultType
+ ? updateNode(createTypeParameterDeclaration(name, constraint, defaultType), node)
+ : node;
+ }
+ ts.updateTypeParameterDeclaration = updateTypeParameterDeclaration;
+ function createPropertySignature(name, questionToken, type, initializer) {
+ var propertySignature = createSynthesizedNode(147);
+ propertySignature.name = asName(name);
+ propertySignature.questionToken = questionToken;
+ propertySignature.type = type;
+ propertySignature.initializer = initializer;
+ return propertySignature;
+ }
+ ts.createPropertySignature = createPropertySignature;
+ function updatePropertySignature(node, name, questionToken, type, initializer) {
+ return node.name !== name
+ || node.questionToken !== questionToken
+ || node.type !== type
+ || node.initializer !== initializer
+ ? updateNode(createPropertySignature(name, questionToken, type, initializer), node)
+ : node;
+ }
+ ts.updatePropertySignature = updatePropertySignature;
+ function createIndexSignatureDeclaration(decorators, modifiers, parameters, type) {
+ var indexSignature = createSynthesizedNode(156);
+ indexSignature.decorators = asNodeArray(decorators);
+ indexSignature.modifiers = asNodeArray(modifiers);
+ indexSignature.parameters = createNodeArray(parameters);
+ indexSignature.type = type;
+ return indexSignature;
+ }
+ ts.createIndexSignatureDeclaration = createIndexSignatureDeclaration;
+ function updateIndexSignatureDeclaration(node, decorators, modifiers, parameters, type) {
+ return node.parameters !== parameters
+ || node.type !== type
+ || node.decorators !== decorators
+ || node.modifiers !== modifiers
+ ? updateNode(createIndexSignatureDeclaration(decorators, modifiers, parameters, type), node)
+ : node;
+ }
+ ts.updateIndexSignatureDeclaration = updateIndexSignatureDeclaration;
+ function createParameter(decorators, modifiers, dotDotDotToken, name, questionToken, type, initializer) {
+ var node = createSynthesizedNode(145);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.dotDotDotToken = dotDotDotToken;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ node.name = asName(name);
node.questionToken = questionToken;
node.type = type;
- node.initializer = initializer ? parenthesizeExpressionForList(initializer) : undefined;
+ node.initializer = initializer ? ts.parenthesizeExpressionForList(initializer) : undefined;
return node;
}
ts.createParameter = createParameter;
- function updateParameter(node, decorators, modifiers, dotDotDotToken, name, type, initializer) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.type !== type || node.initializer !== initializer) {
- return updateNode(createParameter(decorators, modifiers, dotDotDotToken, name, node.questionToken, type, initializer, node, node.flags), node);
- }
- return node;
+ function updateParameter(node, decorators, modifiers, dotDotDotToken, name, questionToken, type, initializer) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.dotDotDotToken !== dotDotDotToken
+ || node.name !== name
+ || node.questionToken !== questionToken
+ || node.type !== type
+ || node.initializer !== initializer
+ ? updateNode(createParameter(decorators, modifiers, dotDotDotToken, name, node.questionToken, type, initializer), node)
+ : node;
}
ts.updateParameter = updateParameter;
- function createProperty(decorators, modifiers, name, questionToken, type, initializer, location) {
- var node = createNode(147, location);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createDecorator(expression) {
+ var node = createSynthesizedNode(146);
+ node.expression = ts.parenthesizeForAccess(expression);
+ return node;
+ }
+ ts.createDecorator = createDecorator;
+ function updateDecorator(node, expression) {
+ return node.expression !== expression
+ ? updateNode(createDecorator(expression), node)
+ : node;
+ }
+ ts.updateDecorator = updateDecorator;
+ function createProperty(decorators, modifiers, name, questionToken, type, initializer) {
+ var node = createSynthesizedNode(148);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
node.questionToken = questionToken;
node.type = type;
node.initializer = initializer;
@@ -8678,36 +9156,46 @@ var ts;
}
ts.createProperty = createProperty;
function updateProperty(node, decorators, modifiers, name, type, initializer) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.type !== type || node.initializer !== initializer) {
- return updateNode(createProperty(decorators, modifiers, name, node.questionToken, type, initializer, node), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.type !== type
+ || node.initializer !== initializer
+ ? updateNode(createProperty(decorators, modifiers, name, node.questionToken, type, initializer), node)
+ : node;
}
ts.updateProperty = updateProperty;
- function createMethod(decorators, modifiers, asteriskToken, name, typeParameters, parameters, type, body, location, flags) {
- var node = createNode(149, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createMethodDeclaration(decorators, modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) {
+ var node = createSynthesizedNode(150);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.asteriskToken = asteriskToken;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
+ node.name = asName(name);
+ node.questionToken = questionToken;
+ node.typeParameters = asNodeArray(typeParameters);
node.parameters = createNodeArray(parameters);
node.type = type;
node.body = body;
return node;
}
- ts.createMethod = createMethod;
- function updateMethod(node, decorators, modifiers, name, typeParameters, parameters, type, body) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body) {
- return updateNode(createMethod(decorators, modifiers, node.asteriskToken, name, typeParameters, parameters, type, body, node, node.flags), node);
- }
- return node;
+ ts.createMethodDeclaration = createMethodDeclaration;
+ function updateMethod(node, decorators, modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.asteriskToken !== asteriskToken
+ || node.name !== name
+ || node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.body !== body
+ ? updateNode(createMethodDeclaration(decorators, modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body), node)
+ : node;
}
ts.updateMethod = updateMethod;
- function createConstructor(decorators, modifiers, parameters, body, location, flags) {
- var node = createNode(150, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createConstructor(decorators, modifiers, parameters, body) {
+ var node = createSynthesizedNode(151);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.typeParameters = undefined;
node.parameters = createNodeArray(parameters);
node.type = undefined;
@@ -8716,17 +9204,19 @@ var ts;
}
ts.createConstructor = createConstructor;
function updateConstructor(node, decorators, modifiers, parameters, body) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.parameters !== parameters || node.body !== body) {
- return updateNode(createConstructor(decorators, modifiers, parameters, body, node, node.flags), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.parameters !== parameters
+ || node.body !== body
+ ? updateNode(createConstructor(decorators, modifiers, parameters, body), node)
+ : node;
}
ts.updateConstructor = updateConstructor;
- function createGetAccessor(decorators, modifiers, name, parameters, type, body, location, flags) {
- var node = createNode(151, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createGetAccessor(decorators, modifiers, name, parameters, type, body) {
+ var node = createSynthesizedNode(152);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
node.typeParameters = undefined;
node.parameters = createNodeArray(parameters);
node.type = type;
@@ -8735,17 +9225,21 @@ var ts;
}
ts.createGetAccessor = createGetAccessor;
function updateGetAccessor(node, decorators, modifiers, name, parameters, type, body) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.parameters !== parameters || node.type !== type || node.body !== body) {
- return updateNode(createGetAccessor(decorators, modifiers, name, parameters, type, body, node, node.flags), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.body !== body
+ ? updateNode(createGetAccessor(decorators, modifiers, name, parameters, type, body), node)
+ : node;
}
ts.updateGetAccessor = updateGetAccessor;
- function createSetAccessor(decorators, modifiers, name, parameters, body, location, flags) {
- var node = createNode(152, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createSetAccessor(decorators, modifiers, name, parameters, body) {
+ var node = createSynthesizedNode(153);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
node.typeParameters = undefined;
node.parameters = createNodeArray(parameters);
node.body = body;
@@ -8753,57 +9247,60 @@ var ts;
}
ts.createSetAccessor = createSetAccessor;
function updateSetAccessor(node, decorators, modifiers, name, parameters, body) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.parameters !== parameters || node.body !== body) {
- return updateNode(createSetAccessor(decorators, modifiers, name, parameters, body, node, node.flags), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.parameters !== parameters
+ || node.body !== body
+ ? updateNode(createSetAccessor(decorators, modifiers, name, parameters, body), node)
+ : node;
}
ts.updateSetAccessor = updateSetAccessor;
- function createObjectBindingPattern(elements, location) {
- var node = createNode(172, location);
+ function createObjectBindingPattern(elements) {
+ var node = createSynthesizedNode(173);
node.elements = createNodeArray(elements);
return node;
}
ts.createObjectBindingPattern = createObjectBindingPattern;
function updateObjectBindingPattern(node, elements) {
- if (node.elements !== elements) {
- return updateNode(createObjectBindingPattern(elements, node), node);
- }
- return node;
+ return node.elements !== elements
+ ? updateNode(createObjectBindingPattern(elements), node)
+ : node;
}
ts.updateObjectBindingPattern = updateObjectBindingPattern;
- function createArrayBindingPattern(elements, location) {
- var node = createNode(173, location);
+ function createArrayBindingPattern(elements) {
+ var node = createSynthesizedNode(174);
node.elements = createNodeArray(elements);
return node;
}
ts.createArrayBindingPattern = createArrayBindingPattern;
function updateArrayBindingPattern(node, elements) {
- if (node.elements !== elements) {
- return updateNode(createArrayBindingPattern(elements, node), node);
- }
- return node;
+ return node.elements !== elements
+ ? updateNode(createArrayBindingPattern(elements), node)
+ : node;
}
ts.updateArrayBindingPattern = updateArrayBindingPattern;
- function createBindingElement(propertyName, dotDotDotToken, name, initializer, location) {
- var node = createNode(174, location);
- node.propertyName = typeof propertyName === "string" ? createIdentifier(propertyName) : propertyName;
+ function createBindingElement(dotDotDotToken, propertyName, name, initializer) {
+ var node = createSynthesizedNode(175);
node.dotDotDotToken = dotDotDotToken;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ node.propertyName = asName(propertyName);
+ node.name = asName(name);
node.initializer = initializer;
return node;
}
ts.createBindingElement = createBindingElement;
function updateBindingElement(node, dotDotDotToken, propertyName, name, initializer) {
- if (node.propertyName !== propertyName || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.initializer !== initializer) {
- return updateNode(createBindingElement(propertyName, dotDotDotToken, name, initializer, node), node);
- }
- return node;
+ return node.propertyName !== propertyName
+ || node.dotDotDotToken !== dotDotDotToken
+ || node.name !== name
+ || node.initializer !== initializer
+ ? updateNode(createBindingElement(dotDotDotToken, propertyName, name, initializer), node)
+ : node;
}
ts.updateBindingElement = updateBindingElement;
- function createArrayLiteral(elements, location, multiLine) {
- var node = createNode(175, location);
- node.elements = parenthesizeListElements(createNodeArray(elements));
+ function createArrayLiteral(elements, multiLine) {
+ var node = createSynthesizedNode(176);
+ node.elements = ts.parenthesizeListElements(createNodeArray(elements));
if (multiLine) {
node.multiLine = true;
}
@@ -8811,14 +9308,13 @@ var ts;
}
ts.createArrayLiteral = createArrayLiteral;
function updateArrayLiteral(node, elements) {
- if (node.elements !== elements) {
- return updateNode(createArrayLiteral(elements, node, node.multiLine), node);
- }
- return node;
+ return node.elements !== elements
+ ? updateNode(createArrayLiteral(elements, node.multiLine), node)
+ : node;
}
ts.updateArrayLiteral = updateArrayLiteral;
- function createObjectLiteral(properties, location, multiLine) {
- var node = createNode(176, location);
+ function createObjectLiteral(properties, multiLine) {
+ var node = createSynthesizedNode(177);
node.properties = createNodeArray(properties);
if (multiLine) {
node.multiLine = true;
@@ -8827,431 +9323,461 @@ var ts;
}
ts.createObjectLiteral = createObjectLiteral;
function updateObjectLiteral(node, properties) {
- if (node.properties !== properties) {
- return updateNode(createObjectLiteral(properties, node, node.multiLine), node);
- }
- return node;
+ return node.properties !== properties
+ ? updateNode(createObjectLiteral(properties, node.multiLine), node)
+ : node;
}
ts.updateObjectLiteral = updateObjectLiteral;
- function createPropertyAccess(expression, name, location, flags) {
- var node = createNode(177, location, flags);
- node.expression = parenthesizeForAccess(expression);
- (node.emitNode || (node.emitNode = {})).flags |= 65536;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createPropertyAccess(expression, name) {
+ var node = createSynthesizedNode(178);
+ node.expression = ts.parenthesizeForAccess(expression);
+ node.name = asName(name);
+ setEmitFlags(node, 65536);
return node;
}
ts.createPropertyAccess = createPropertyAccess;
function updatePropertyAccess(node, expression, name) {
- if (node.expression !== expression || node.name !== name) {
- var propertyAccess = createPropertyAccess(expression, name, node, node.flags);
- (propertyAccess.emitNode || (propertyAccess.emitNode = {})).flags = getEmitFlags(node);
- return updateNode(propertyAccess, node);
- }
- return node;
+ return node.expression !== expression
+ || node.name !== name
+ ? updateNode(setEmitFlags(createPropertyAccess(expression, name), getEmitFlags(node)), node)
+ : node;
}
ts.updatePropertyAccess = updatePropertyAccess;
- function createElementAccess(expression, index, location) {
- var node = createNode(178, location);
- node.expression = parenthesizeForAccess(expression);
- node.argumentExpression = typeof index === "number" ? createLiteral(index) : index;
+ function createElementAccess(expression, index) {
+ var node = createSynthesizedNode(179);
+ node.expression = ts.parenthesizeForAccess(expression);
+ node.argumentExpression = asExpression(index);
return node;
}
ts.createElementAccess = createElementAccess;
function updateElementAccess(node, expression, argumentExpression) {
- if (node.expression !== expression || node.argumentExpression !== argumentExpression) {
- return updateNode(createElementAccess(expression, argumentExpression, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.argumentExpression !== argumentExpression
+ ? updateNode(createElementAccess(expression, argumentExpression), node)
+ : node;
}
ts.updateElementAccess = updateElementAccess;
- function createCall(expression, typeArguments, argumentsArray, location, flags) {
- var node = createNode(179, location, flags);
- node.expression = parenthesizeForAccess(expression);
- if (typeArguments) {
- node.typeArguments = createNodeArray(typeArguments);
- }
- node.arguments = parenthesizeListElements(createNodeArray(argumentsArray));
+ function createCall(expression, typeArguments, argumentsArray) {
+ var node = createSynthesizedNode(180);
+ node.expression = ts.parenthesizeForAccess(expression);
+ node.typeArguments = asNodeArray(typeArguments);
+ node.arguments = ts.parenthesizeListElements(createNodeArray(argumentsArray));
return node;
}
ts.createCall = createCall;
function updateCall(node, expression, typeArguments, argumentsArray) {
- if (expression !== node.expression || typeArguments !== node.typeArguments || argumentsArray !== node.arguments) {
- return updateNode(createCall(expression, typeArguments, argumentsArray, node, node.flags), node);
- }
- return node;
+ return expression !== node.expression
+ || typeArguments !== node.typeArguments
+ || argumentsArray !== node.arguments
+ ? updateNode(createCall(expression, typeArguments, argumentsArray), node)
+ : node;
}
ts.updateCall = updateCall;
- function createNew(expression, typeArguments, argumentsArray, location, flags) {
- var node = createNode(180, location, flags);
- node.expression = parenthesizeForNew(expression);
- node.typeArguments = typeArguments ? createNodeArray(typeArguments) : undefined;
- node.arguments = argumentsArray ? parenthesizeListElements(createNodeArray(argumentsArray)) : undefined;
+ function createNew(expression, typeArguments, argumentsArray) {
+ var node = createSynthesizedNode(181);
+ node.expression = ts.parenthesizeForNew(expression);
+ node.typeArguments = asNodeArray(typeArguments);
+ node.arguments = argumentsArray ? ts.parenthesizeListElements(createNodeArray(argumentsArray)) : undefined;
return node;
}
ts.createNew = createNew;
function updateNew(node, expression, typeArguments, argumentsArray) {
- if (node.expression !== expression || node.typeArguments !== typeArguments || node.arguments !== argumentsArray) {
- return updateNode(createNew(expression, typeArguments, argumentsArray, node, node.flags), node);
- }
- return node;
+ return node.expression !== expression
+ || node.typeArguments !== typeArguments
+ || node.arguments !== argumentsArray
+ ? updateNode(createNew(expression, typeArguments, argumentsArray), node)
+ : node;
}
ts.updateNew = updateNew;
- function createTaggedTemplate(tag, template, location) {
- var node = createNode(181, location);
- node.tag = parenthesizeForAccess(tag);
+ function createTaggedTemplate(tag, template) {
+ var node = createSynthesizedNode(182);
+ node.tag = ts.parenthesizeForAccess(tag);
node.template = template;
return node;
}
ts.createTaggedTemplate = createTaggedTemplate;
function updateTaggedTemplate(node, tag, template) {
- if (node.tag !== tag || node.template !== template) {
- return updateNode(createTaggedTemplate(tag, template, node), node);
- }
- return node;
+ return node.tag !== tag
+ || node.template !== template
+ ? updateNode(createTaggedTemplate(tag, template), node)
+ : node;
}
ts.updateTaggedTemplate = updateTaggedTemplate;
- function createParen(expression, location) {
- var node = createNode(183, location);
+ function createTypeAssertion(type, expression) {
+ var node = createSynthesizedNode(183);
+ node.type = type;
+ node.expression = ts.parenthesizePrefixOperand(expression);
+ return node;
+ }
+ ts.createTypeAssertion = createTypeAssertion;
+ function updateTypeAssertion(node, type, expression) {
+ return node.type !== type
+ || node.expression !== expression
+ ? updateNode(createTypeAssertion(type, expression), node)
+ : node;
+ }
+ ts.updateTypeAssertion = updateTypeAssertion;
+ function createParen(expression) {
+ var node = createSynthesizedNode(184);
node.expression = expression;
return node;
}
ts.createParen = createParen;
function updateParen(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createParen(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createParen(expression), node)
+ : node;
}
ts.updateParen = updateParen;
- function createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body, location, flags) {
- var node = createNode(184, location, flags);
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
+ var node = createSynthesizedNode(185);
+ node.modifiers = asNodeArray(modifiers);
node.asteriskToken = asteriskToken;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
+ node.name = asName(name);
+ node.typeParameters = asNodeArray(typeParameters);
node.parameters = createNodeArray(parameters);
node.type = type;
node.body = body;
return node;
}
ts.createFunctionExpression = createFunctionExpression;
- function updateFunctionExpression(node, modifiers, name, typeParameters, parameters, type, body) {
- if (node.name !== name || node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body) {
- return updateNode(createFunctionExpression(modifiers, node.asteriskToken, name, typeParameters, parameters, type, body, node, node.flags), node);
- }
- return node;
+ function updateFunctionExpression(node, modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
+ return node.name !== name
+ || node.modifiers !== modifiers
+ || node.asteriskToken !== asteriskToken
+ || node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.body !== body
+ ? updateNode(createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body), node)
+ : node;
}
ts.updateFunctionExpression = updateFunctionExpression;
- function createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body, location, flags) {
- var node = createNode(185, location, flags);
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
+ function createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body) {
+ var node = createSynthesizedNode(186);
+ node.modifiers = asNodeArray(modifiers);
+ node.typeParameters = asNodeArray(typeParameters);
node.parameters = createNodeArray(parameters);
node.type = type;
node.equalsGreaterThanToken = equalsGreaterThanToken || createToken(35);
- node.body = parenthesizeConciseBody(body);
+ node.body = ts.parenthesizeConciseBody(body);
return node;
}
ts.createArrowFunction = createArrowFunction;
function updateArrowFunction(node, modifiers, typeParameters, parameters, type, body) {
- if (node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body) {
- return updateNode(createArrowFunction(modifiers, typeParameters, parameters, type, node.equalsGreaterThanToken, body, node, node.flags), node);
- }
- return node;
+ return node.modifiers !== modifiers
+ || node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.body !== body
+ ? updateNode(createArrowFunction(modifiers, typeParameters, parameters, type, node.equalsGreaterThanToken, body), node)
+ : node;
}
ts.updateArrowFunction = updateArrowFunction;
- function createDelete(expression, location) {
- var node = createNode(186, location);
- node.expression = parenthesizePrefixOperand(expression);
+ function createDelete(expression) {
+ var node = createSynthesizedNode(187);
+ node.expression = ts.parenthesizePrefixOperand(expression);
return node;
}
ts.createDelete = createDelete;
function updateDelete(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createDelete(expression, node), expression);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createDelete(expression), node)
+ : node;
}
ts.updateDelete = updateDelete;
- function createTypeOf(expression, location) {
- var node = createNode(187, location);
- node.expression = parenthesizePrefixOperand(expression);
+ function createTypeOf(expression) {
+ var node = createSynthesizedNode(188);
+ node.expression = ts.parenthesizePrefixOperand(expression);
return node;
}
ts.createTypeOf = createTypeOf;
function updateTypeOf(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createTypeOf(expression, node), expression);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createTypeOf(expression), node)
+ : node;
}
ts.updateTypeOf = updateTypeOf;
- function createVoid(expression, location) {
- var node = createNode(188, location);
- node.expression = parenthesizePrefixOperand(expression);
+ function createVoid(expression) {
+ var node = createSynthesizedNode(189);
+ node.expression = ts.parenthesizePrefixOperand(expression);
return node;
}
ts.createVoid = createVoid;
function updateVoid(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createVoid(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createVoid(expression), node)
+ : node;
}
ts.updateVoid = updateVoid;
- function createAwait(expression, location) {
- var node = createNode(189, location);
- node.expression = parenthesizePrefixOperand(expression);
+ function createAwait(expression) {
+ var node = createSynthesizedNode(190);
+ node.expression = ts.parenthesizePrefixOperand(expression);
return node;
}
ts.createAwait = createAwait;
function updateAwait(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createAwait(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createAwait(expression), node)
+ : node;
}
ts.updateAwait = updateAwait;
- function createPrefix(operator, operand, location) {
- var node = createNode(190, location);
+ function createPrefix(operator, operand) {
+ var node = createSynthesizedNode(191);
node.operator = operator;
- node.operand = parenthesizePrefixOperand(operand);
+ node.operand = ts.parenthesizePrefixOperand(operand);
return node;
}
ts.createPrefix = createPrefix;
function updatePrefix(node, operand) {
- if (node.operand !== operand) {
- return updateNode(createPrefix(node.operator, operand, node), node);
- }
- return node;
+ return node.operand !== operand
+ ? updateNode(createPrefix(node.operator, operand), node)
+ : node;
}
ts.updatePrefix = updatePrefix;
- function createPostfix(operand, operator, location) {
- var node = createNode(191, location);
- node.operand = parenthesizePostfixOperand(operand);
+ function createPostfix(operand, operator) {
+ var node = createSynthesizedNode(192);
+ node.operand = ts.parenthesizePostfixOperand(operand);
node.operator = operator;
return node;
}
ts.createPostfix = createPostfix;
function updatePostfix(node, operand) {
- if (node.operand !== operand) {
- return updateNode(createPostfix(operand, node.operator, node), node);
- }
- return node;
+ return node.operand !== operand
+ ? updateNode(createPostfix(operand, node.operator), node)
+ : node;
}
ts.updatePostfix = updatePostfix;
- function createBinary(left, operator, right, location) {
- var operatorToken = typeof operator === "number" ? createToken(operator) : operator;
+ function createBinary(left, operator, right) {
+ var node = createSynthesizedNode(193);
+ var operatorToken = asToken(operator);
var operatorKind = operatorToken.kind;
- var node = createNode(192, location);
- node.left = parenthesizeBinaryOperand(operatorKind, left, true, undefined);
+ node.left = ts.parenthesizeBinaryOperand(operatorKind, left, true, undefined);
node.operatorToken = operatorToken;
- node.right = parenthesizeBinaryOperand(operatorKind, right, false, node.left);
+ node.right = ts.parenthesizeBinaryOperand(operatorKind, right, false, node.left);
return node;
}
ts.createBinary = createBinary;
function updateBinary(node, left, right) {
- if (node.left !== left || node.right !== right) {
- return updateNode(createBinary(left, node.operatorToken, right, node), node);
- }
- return node;
+ return node.left !== left
+ || node.right !== right
+ ? updateNode(createBinary(left, node.operatorToken, right), node)
+ : node;
}
ts.updateBinary = updateBinary;
- function createConditional(condition, questionTokenOrWhenTrue, whenTrueOrWhenFalse, colonTokenOrLocation, whenFalse, location) {
- var node = createNode(193, whenFalse ? location : colonTokenOrLocation);
- node.condition = parenthesizeForConditionalHead(condition);
- if (whenFalse) {
- node.questionToken = questionTokenOrWhenTrue;
- node.whenTrue = parenthesizeSubexpressionOfConditionalExpression(whenTrueOrWhenFalse);
- node.colonToken = colonTokenOrLocation;
- node.whenFalse = parenthesizeSubexpressionOfConditionalExpression(whenFalse);
- }
- else {
- node.questionToken = createToken(54);
- node.whenTrue = parenthesizeSubexpressionOfConditionalExpression(questionTokenOrWhenTrue);
- node.colonToken = createToken(55);
- node.whenFalse = parenthesizeSubexpressionOfConditionalExpression(whenTrueOrWhenFalse);
- }
+ function createConditional(condition, questionTokenOrWhenTrue, whenTrueOrWhenFalse, colonToken, whenFalse) {
+ var node = createSynthesizedNode(194);
+ node.condition = ts.parenthesizeForConditionalHead(condition);
+ node.questionToken = whenFalse ? questionTokenOrWhenTrue : createToken(54);
+ node.whenTrue = ts.parenthesizeSubexpressionOfConditionalExpression(whenFalse ? whenTrueOrWhenFalse : questionTokenOrWhenTrue);
+ node.colonToken = whenFalse ? colonToken : createToken(55);
+ node.whenFalse = ts.parenthesizeSubexpressionOfConditionalExpression(whenFalse ? whenFalse : whenTrueOrWhenFalse);
return node;
}
ts.createConditional = createConditional;
function updateConditional(node, condition, whenTrue, whenFalse) {
- if (node.condition !== condition || node.whenTrue !== whenTrue || node.whenFalse !== whenFalse) {
- return updateNode(createConditional(condition, node.questionToken, whenTrue, node.colonToken, whenFalse, node), node);
- }
- return node;
+ return node.condition !== condition
+ || node.whenTrue !== whenTrue
+ || node.whenFalse !== whenFalse
+ ? updateNode(createConditional(condition, node.questionToken, whenTrue, node.colonToken, whenFalse), node)
+ : node;
}
ts.updateConditional = updateConditional;
- function createTemplateExpression(head, templateSpans, location) {
- var node = createNode(194, location);
+ function createTemplateExpression(head, templateSpans) {
+ var node = createSynthesizedNode(195);
node.head = head;
node.templateSpans = createNodeArray(templateSpans);
return node;
}
ts.createTemplateExpression = createTemplateExpression;
function updateTemplateExpression(node, head, templateSpans) {
- if (node.head !== head || node.templateSpans !== templateSpans) {
- return updateNode(createTemplateExpression(head, templateSpans, node), node);
- }
- return node;
+ return node.head !== head
+ || node.templateSpans !== templateSpans
+ ? updateNode(createTemplateExpression(head, templateSpans), node)
+ : node;
}
ts.updateTemplateExpression = updateTemplateExpression;
- function createYield(asteriskToken, expression, location) {
- var node = createNode(195, location);
- node.asteriskToken = asteriskToken;
- node.expression = expression;
+ function createYield(asteriskTokenOrExpression, expression) {
+ var node = createSynthesizedNode(196);
+ node.asteriskToken = asteriskTokenOrExpression && asteriskTokenOrExpression.kind === 38 ? asteriskTokenOrExpression : undefined;
+ node.expression = asteriskTokenOrExpression && asteriskTokenOrExpression.kind !== 38 ? asteriskTokenOrExpression : expression;
return node;
}
ts.createYield = createYield;
- function updateYield(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createYield(node.asteriskToken, expression, node), node);
- }
- return node;
+ function updateYield(node, asteriskToken, expression) {
+ return node.expression !== expression
+ || node.asteriskToken !== asteriskToken
+ ? updateNode(createYield(asteriskToken, expression), node)
+ : node;
}
ts.updateYield = updateYield;
- function createSpread(expression, location) {
- var node = createNode(196, location);
- node.expression = parenthesizeExpressionForList(expression);
+ function createSpread(expression) {
+ var node = createSynthesizedNode(197);
+ node.expression = ts.parenthesizeExpressionForList(expression);
return node;
}
ts.createSpread = createSpread;
function updateSpread(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createSpread(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createSpread(expression), node)
+ : node;
}
ts.updateSpread = updateSpread;
- function createClassExpression(modifiers, name, typeParameters, heritageClauses, members, location) {
- var node = createNode(197, location);
+ function createClassExpression(modifiers, name, typeParameters, heritageClauses, members) {
+ var node = createSynthesizedNode(198);
node.decorators = undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.name = name;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
- node.heritageClauses = createNodeArray(heritageClauses);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
+ node.typeParameters = asNodeArray(typeParameters);
+ node.heritageClauses = asNodeArray(heritageClauses);
node.members = createNodeArray(members);
return node;
}
ts.createClassExpression = createClassExpression;
function updateClassExpression(node, modifiers, name, typeParameters, heritageClauses, members) {
- if (node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members) {
- return updateNode(createClassExpression(modifiers, name, typeParameters, heritageClauses, members, node), node);
- }
- return node;
+ return node.modifiers !== modifiers
+ || node.name !== name
+ || node.typeParameters !== typeParameters
+ || node.heritageClauses !== heritageClauses
+ || node.members !== members
+ ? updateNode(createClassExpression(modifiers, name, typeParameters, heritageClauses, members), node)
+ : node;
}
ts.updateClassExpression = updateClassExpression;
- function createOmittedExpression(location) {
- var node = createNode(198, location);
- return node;
+ function createOmittedExpression() {
+ return createSynthesizedNode(199);
}
ts.createOmittedExpression = createOmittedExpression;
- function createExpressionWithTypeArguments(typeArguments, expression, location) {
- var node = createNode(199, location);
- node.typeArguments = typeArguments ? createNodeArray(typeArguments) : undefined;
- node.expression = parenthesizeForAccess(expression);
+ function createExpressionWithTypeArguments(typeArguments, expression) {
+ var node = createSynthesizedNode(200);
+ node.expression = ts.parenthesizeForAccess(expression);
+ node.typeArguments = asNodeArray(typeArguments);
return node;
}
ts.createExpressionWithTypeArguments = createExpressionWithTypeArguments;
function updateExpressionWithTypeArguments(node, typeArguments, expression) {
- if (node.typeArguments !== typeArguments || node.expression !== expression) {
- return updateNode(createExpressionWithTypeArguments(typeArguments, expression, node), node);
- }
- return node;
+ return node.typeArguments !== typeArguments
+ || node.expression !== expression
+ ? updateNode(createExpressionWithTypeArguments(typeArguments, expression), node)
+ : node;
}
ts.updateExpressionWithTypeArguments = updateExpressionWithTypeArguments;
- function createTemplateSpan(expression, literal, location) {
- var node = createNode(202, location);
+ function createAsExpression(expression, type) {
+ var node = createSynthesizedNode(201);
+ node.expression = expression;
+ node.type = type;
+ return node;
+ }
+ ts.createAsExpression = createAsExpression;
+ function updateAsExpression(node, expression, type) {
+ return node.expression !== expression
+ || node.type !== type
+ ? updateNode(createAsExpression(expression, type), node)
+ : node;
+ }
+ ts.updateAsExpression = updateAsExpression;
+ function createNonNullExpression(expression) {
+ var node = createSynthesizedNode(202);
+ node.expression = ts.parenthesizeForAccess(expression);
+ return node;
+ }
+ ts.createNonNullExpression = createNonNullExpression;
+ function updateNonNullExpression(node, expression) {
+ return node.expression !== expression
+ ? updateNode(createNonNullExpression(expression), node)
+ : node;
+ }
+ ts.updateNonNullExpression = updateNonNullExpression;
+ function createTemplateSpan(expression, literal) {
+ var node = createSynthesizedNode(204);
node.expression = expression;
node.literal = literal;
return node;
}
ts.createTemplateSpan = createTemplateSpan;
function updateTemplateSpan(node, expression, literal) {
- if (node.expression !== expression || node.literal !== literal) {
- return updateNode(createTemplateSpan(expression, literal, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.literal !== literal
+ ? updateNode(createTemplateSpan(expression, literal), node)
+ : node;
}
ts.updateTemplateSpan = updateTemplateSpan;
- function createBlock(statements, location, multiLine, flags) {
- var block = createNode(204, location, flags);
+ function createBlock(statements, multiLine) {
+ var block = createSynthesizedNode(206);
block.statements = createNodeArray(statements);
- if (multiLine) {
- block.multiLine = true;
- }
+ if (multiLine)
+ block.multiLine = multiLine;
return block;
}
ts.createBlock = createBlock;
function updateBlock(node, statements) {
- if (statements !== node.statements) {
- return updateNode(createBlock(statements, node, node.multiLine, node.flags), node);
- }
- return node;
+ return statements !== node.statements
+ ? updateNode(createBlock(statements, node.multiLine), node)
+ : node;
}
ts.updateBlock = updateBlock;
- function createVariableStatement(modifiers, declarationList, location, flags) {
- var node = createNode(205, location, flags);
+ function createVariableStatement(modifiers, declarationList) {
+ var node = createSynthesizedNode(207);
node.decorators = undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ node.modifiers = asNodeArray(modifiers);
node.declarationList = ts.isArray(declarationList) ? createVariableDeclarationList(declarationList) : declarationList;
return node;
}
ts.createVariableStatement = createVariableStatement;
function updateVariableStatement(node, modifiers, declarationList) {
- if (node.modifiers !== modifiers || node.declarationList !== declarationList) {
- return updateNode(createVariableStatement(modifiers, declarationList, node, node.flags), node);
- }
- return node;
+ return node.modifiers !== modifiers
+ || node.declarationList !== declarationList
+ ? updateNode(createVariableStatement(modifiers, declarationList), node)
+ : node;
}
ts.updateVariableStatement = updateVariableStatement;
- function createVariableDeclarationList(declarations, location, flags) {
- var node = createNode(224, location, flags);
+ function createVariableDeclarationList(declarations, flags) {
+ var node = createSynthesizedNode(226);
+ node.flags |= flags;
node.declarations = createNodeArray(declarations);
return node;
}
ts.createVariableDeclarationList = createVariableDeclarationList;
function updateVariableDeclarationList(node, declarations) {
- if (node.declarations !== declarations) {
- return updateNode(createVariableDeclarationList(declarations, node, node.flags), node);
- }
- return node;
+ return node.declarations !== declarations
+ ? updateNode(createVariableDeclarationList(declarations, node.flags), node)
+ : node;
}
ts.updateVariableDeclarationList = updateVariableDeclarationList;
- function createVariableDeclaration(name, type, initializer, location, flags) {
- var node = createNode(223, location, flags);
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createVariableDeclaration(name, type, initializer) {
+ var node = createSynthesizedNode(225);
+ node.name = asName(name);
node.type = type;
- node.initializer = initializer !== undefined ? parenthesizeExpressionForList(initializer) : undefined;
+ node.initializer = initializer !== undefined ? ts.parenthesizeExpressionForList(initializer) : undefined;
return node;
}
ts.createVariableDeclaration = createVariableDeclaration;
function updateVariableDeclaration(node, name, type, initializer) {
- if (node.name !== name || node.type !== type || node.initializer !== initializer) {
- return updateNode(createVariableDeclaration(name, type, initializer, node, node.flags), node);
- }
- return node;
+ return node.name !== name
+ || node.type !== type
+ || node.initializer !== initializer
+ ? updateNode(createVariableDeclaration(name, type, initializer), node)
+ : node;
}
ts.updateVariableDeclaration = updateVariableDeclaration;
- function createEmptyStatement(location) {
- return createNode(206, location);
+ function createEmptyStatement() {
+ return createSynthesizedNode(208);
}
ts.createEmptyStatement = createEmptyStatement;
- function createStatement(expression, location, flags) {
- var node = createNode(207, location, flags);
- node.expression = parenthesizeExpressionForExpressionStatement(expression);
+ function createStatement(expression) {
+ var node = createSynthesizedNode(209);
+ node.expression = ts.parenthesizeExpressionForExpressionStatement(expression);
return node;
}
ts.createStatement = createStatement;
function updateStatement(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createStatement(expression, node, node.flags), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createStatement(expression), node)
+ : node;
}
ts.updateStatement = updateStatement;
- function createIf(expression, thenStatement, elseStatement, location) {
- var node = createNode(208, location);
+ function createIf(expression, thenStatement, elseStatement) {
+ var node = createSynthesizedNode(210);
node.expression = expression;
node.thenStatement = thenStatement;
node.elseStatement = elseStatement;
@@ -9259,42 +9785,43 @@ var ts;
}
ts.createIf = createIf;
function updateIf(node, expression, thenStatement, elseStatement) {
- if (node.expression !== expression || node.thenStatement !== thenStatement || node.elseStatement !== elseStatement) {
- return updateNode(createIf(expression, thenStatement, elseStatement, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.thenStatement !== thenStatement
+ || node.elseStatement !== elseStatement
+ ? updateNode(createIf(expression, thenStatement, elseStatement), node)
+ : node;
}
ts.updateIf = updateIf;
- function createDo(statement, expression, location) {
- var node = createNode(209, location);
+ function createDo(statement, expression) {
+ var node = createSynthesizedNode(211);
node.statement = statement;
node.expression = expression;
return node;
}
ts.createDo = createDo;
function updateDo(node, statement, expression) {
- if (node.statement !== statement || node.expression !== expression) {
- return updateNode(createDo(statement, expression, node), node);
- }
- return node;
+ return node.statement !== statement
+ || node.expression !== expression
+ ? updateNode(createDo(statement, expression), node)
+ : node;
}
ts.updateDo = updateDo;
- function createWhile(expression, statement, location) {
- var node = createNode(210, location);
+ function createWhile(expression, statement) {
+ var node = createSynthesizedNode(212);
node.expression = expression;
node.statement = statement;
return node;
}
ts.createWhile = createWhile;
function updateWhile(node, expression, statement) {
- if (node.expression !== expression || node.statement !== statement) {
- return updateNode(createWhile(expression, statement, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.statement !== statement
+ ? updateNode(createWhile(expression, statement), node)
+ : node;
}
ts.updateWhile = updateWhile;
- function createFor(initializer, condition, incrementor, statement, location) {
- var node = createNode(211, location, undefined);
+ function createFor(initializer, condition, incrementor, statement) {
+ var node = createSynthesizedNode(213);
node.initializer = initializer;
node.condition = condition;
node.incrementor = incrementor;
@@ -9303,14 +9830,16 @@ var ts;
}
ts.createFor = createFor;
function updateFor(node, initializer, condition, incrementor, statement) {
- if (node.initializer !== initializer || node.condition !== condition || node.incrementor !== incrementor || node.statement !== statement) {
- return updateNode(createFor(initializer, condition, incrementor, statement, node), node);
- }
- return node;
+ return node.initializer !== initializer
+ || node.condition !== condition
+ || node.incrementor !== incrementor
+ || node.statement !== statement
+ ? updateNode(createFor(initializer, condition, incrementor, statement), node)
+ : node;
}
ts.updateFor = updateFor;
- function createForIn(initializer, expression, statement, location) {
- var node = createNode(212, location);
+ function createForIn(initializer, expression, statement) {
+ var node = createSynthesizedNode(214);
node.initializer = initializer;
node.expression = expression;
node.statement = statement;
@@ -9318,127 +9847,123 @@ var ts;
}
ts.createForIn = createForIn;
function updateForIn(node, initializer, expression, statement) {
- if (node.initializer !== initializer || node.expression !== expression || node.statement !== statement) {
- return updateNode(createForIn(initializer, expression, statement, node), node);
- }
- return node;
+ return node.initializer !== initializer
+ || node.expression !== expression
+ || node.statement !== statement
+ ? updateNode(createForIn(initializer, expression, statement), node)
+ : node;
}
ts.updateForIn = updateForIn;
- function createForOf(initializer, expression, statement, location) {
- var node = createNode(213, location);
+ function createForOf(awaitModifier, initializer, expression, statement) {
+ var node = createSynthesizedNode(215);
+ node.awaitModifier = awaitModifier;
node.initializer = initializer;
node.expression = expression;
node.statement = statement;
return node;
}
ts.createForOf = createForOf;
- function updateForOf(node, initializer, expression, statement) {
- if (node.initializer !== initializer || node.expression !== expression || node.statement !== statement) {
- return updateNode(createForOf(initializer, expression, statement, node), node);
- }
- return node;
+ function updateForOf(node, awaitModifier, initializer, expression, statement) {
+ return node.awaitModifier !== awaitModifier
+ || node.initializer !== initializer
+ || node.expression !== expression
+ || node.statement !== statement
+ ? updateNode(createForOf(awaitModifier, initializer, expression, statement), node)
+ : node;
}
ts.updateForOf = updateForOf;
- function createContinue(label, location) {
- var node = createNode(214, location);
- if (label) {
- node.label = label;
- }
+ function createContinue(label) {
+ var node = createSynthesizedNode(216);
+ node.label = asName(label);
return node;
}
ts.createContinue = createContinue;
function updateContinue(node, label) {
- if (node.label !== label) {
- return updateNode(createContinue(label, node), node);
- }
- return node;
+ return node.label !== label
+ ? updateNode(createContinue(label), node)
+ : node;
}
ts.updateContinue = updateContinue;
- function createBreak(label, location) {
- var node = createNode(215, location);
- if (label) {
- node.label = label;
- }
+ function createBreak(label) {
+ var node = createSynthesizedNode(217);
+ node.label = asName(label);
return node;
}
ts.createBreak = createBreak;
function updateBreak(node, label) {
- if (node.label !== label) {
- return updateNode(createBreak(label, node), node);
- }
- return node;
+ return node.label !== label
+ ? updateNode(createBreak(label), node)
+ : node;
}
ts.updateBreak = updateBreak;
- function createReturn(expression, location) {
- var node = createNode(216, location);
+ function createReturn(expression) {
+ var node = createSynthesizedNode(218);
node.expression = expression;
return node;
}
ts.createReturn = createReturn;
function updateReturn(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createReturn(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createReturn(expression), node)
+ : node;
}
ts.updateReturn = updateReturn;
- function createWith(expression, statement, location) {
- var node = createNode(217, location);
+ function createWith(expression, statement) {
+ var node = createSynthesizedNode(219);
node.expression = expression;
node.statement = statement;
return node;
}
ts.createWith = createWith;
function updateWith(node, expression, statement) {
- if (node.expression !== expression || node.statement !== statement) {
- return updateNode(createWith(expression, statement, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.statement !== statement
+ ? updateNode(createWith(expression, statement), node)
+ : node;
}
ts.updateWith = updateWith;
- function createSwitch(expression, caseBlock, location) {
- var node = createNode(218, location);
- node.expression = parenthesizeExpressionForList(expression);
+ function createSwitch(expression, caseBlock) {
+ var node = createSynthesizedNode(220);
+ node.expression = ts.parenthesizeExpressionForList(expression);
node.caseBlock = caseBlock;
return node;
}
ts.createSwitch = createSwitch;
function updateSwitch(node, expression, caseBlock) {
- if (node.expression !== expression || node.caseBlock !== caseBlock) {
- return updateNode(createSwitch(expression, caseBlock, node), node);
- }
- return node;
+ return node.expression !== expression
+ || node.caseBlock !== caseBlock
+ ? updateNode(createSwitch(expression, caseBlock), node)
+ : node;
}
ts.updateSwitch = updateSwitch;
- function createLabel(label, statement, location) {
- var node = createNode(219, location);
- node.label = typeof label === "string" ? createIdentifier(label) : label;
+ function createLabel(label, statement) {
+ var node = createSynthesizedNode(221);
+ node.label = asName(label);
node.statement = statement;
return node;
}
ts.createLabel = createLabel;
function updateLabel(node, label, statement) {
- if (node.label !== label || node.statement !== statement) {
- return updateNode(createLabel(label, statement, node), node);
- }
- return node;
+ return node.label !== label
+ || node.statement !== statement
+ ? updateNode(createLabel(label, statement), node)
+ : node;
}
ts.updateLabel = updateLabel;
- function createThrow(expression, location) {
- var node = createNode(220, location);
+ function createThrow(expression) {
+ var node = createSynthesizedNode(222);
node.expression = expression;
return node;
}
ts.createThrow = createThrow;
function updateThrow(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createThrow(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createThrow(expression), node)
+ : node;
}
ts.updateThrow = updateThrow;
- function createTry(tryBlock, catchClause, finallyBlock, location) {
- var node = createNode(221, location);
+ function createTry(tryBlock, catchClause, finallyBlock) {
+ var node = createSynthesizedNode(223);
node.tryBlock = tryBlock;
node.catchClause = catchClause;
node.finallyBlock = finallyBlock;
@@ -9446,194 +9971,284 @@ var ts;
}
ts.createTry = createTry;
function updateTry(node, tryBlock, catchClause, finallyBlock) {
- if (node.tryBlock !== tryBlock || node.catchClause !== catchClause || node.finallyBlock !== finallyBlock) {
- return updateNode(createTry(tryBlock, catchClause, finallyBlock, node), node);
- }
- return node;
+ return node.tryBlock !== tryBlock
+ || node.catchClause !== catchClause
+ || node.finallyBlock !== finallyBlock
+ ? updateNode(createTry(tryBlock, catchClause, finallyBlock), node)
+ : node;
}
ts.updateTry = updateTry;
- function createCaseBlock(clauses, location) {
- var node = createNode(232, location);
- node.clauses = createNodeArray(clauses);
- return node;
- }
- ts.createCaseBlock = createCaseBlock;
- function updateCaseBlock(node, clauses) {
- if (node.clauses !== clauses) {
- return updateNode(createCaseBlock(clauses, node), node);
- }
- return node;
- }
- ts.updateCaseBlock = updateCaseBlock;
- function createFunctionDeclaration(decorators, modifiers, asteriskToken, name, typeParameters, parameters, type, body, location, flags) {
- var node = createNode(225, location, flags);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createFunctionDeclaration(decorators, modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
+ var node = createSynthesizedNode(227);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.asteriskToken = asteriskToken;
- node.name = typeof name === "string" ? createIdentifier(name) : name;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
+ node.name = asName(name);
+ node.typeParameters = asNodeArray(typeParameters);
node.parameters = createNodeArray(parameters);
node.type = type;
node.body = body;
return node;
}
ts.createFunctionDeclaration = createFunctionDeclaration;
- function updateFunctionDeclaration(node, decorators, modifiers, name, typeParameters, parameters, type, body) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body) {
- return updateNode(createFunctionDeclaration(decorators, modifiers, node.asteriskToken, name, typeParameters, parameters, type, body, node, node.flags), node);
- }
- return node;
+ function updateFunctionDeclaration(node, decorators, modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.asteriskToken !== asteriskToken
+ || node.name !== name
+ || node.typeParameters !== typeParameters
+ || node.parameters !== parameters
+ || node.type !== type
+ || node.body !== body
+ ? updateNode(createFunctionDeclaration(decorators, modifiers, asteriskToken, name, typeParameters, parameters, type, body), node)
+ : node;
}
ts.updateFunctionDeclaration = updateFunctionDeclaration;
- function createClassDeclaration(decorators, modifiers, name, typeParameters, heritageClauses, members, location) {
- var node = createNode(226, location);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
- node.name = name;
- node.typeParameters = typeParameters ? createNodeArray(typeParameters) : undefined;
- node.heritageClauses = createNodeArray(heritageClauses);
+ function createClassDeclaration(decorators, modifiers, name, typeParameters, heritageClauses, members) {
+ var node = createSynthesizedNode(228);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
+ node.typeParameters = asNodeArray(typeParameters);
+ node.heritageClauses = asNodeArray(heritageClauses);
node.members = createNodeArray(members);
return node;
}
ts.createClassDeclaration = createClassDeclaration;
function updateClassDeclaration(node, decorators, modifiers, name, typeParameters, heritageClauses, members) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members) {
- return updateNode(createClassDeclaration(decorators, modifiers, name, typeParameters, heritageClauses, members, node), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.typeParameters !== typeParameters
+ || node.heritageClauses !== heritageClauses
+ || node.members !== members
+ ? updateNode(createClassDeclaration(decorators, modifiers, name, typeParameters, heritageClauses, members), node)
+ : node;
}
ts.updateClassDeclaration = updateClassDeclaration;
- function createImportDeclaration(decorators, modifiers, importClause, moduleSpecifier, location) {
- var node = createNode(235, location);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createEnumDeclaration(decorators, modifiers, name, members) {
+ var node = createSynthesizedNode(231);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
+ node.members = createNodeArray(members);
+ return node;
+ }
+ ts.createEnumDeclaration = createEnumDeclaration;
+ function updateEnumDeclaration(node, decorators, modifiers, name, members) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.members !== members
+ ? updateNode(createEnumDeclaration(decorators, modifiers, name, members), node)
+ : node;
+ }
+ ts.updateEnumDeclaration = updateEnumDeclaration;
+ function createModuleDeclaration(decorators, modifiers, name, body, flags) {
+ var node = createSynthesizedNode(232);
+ node.flags |= flags;
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = name;
+ node.body = body;
+ return node;
+ }
+ ts.createModuleDeclaration = createModuleDeclaration;
+ function updateModuleDeclaration(node, decorators, modifiers, name, body) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.body !== body
+ ? updateNode(createModuleDeclaration(decorators, modifiers, name, body, node.flags), node)
+ : node;
+ }
+ ts.updateModuleDeclaration = updateModuleDeclaration;
+ function createModuleBlock(statements) {
+ var node = createSynthesizedNode(233);
+ node.statements = createNodeArray(statements);
+ return node;
+ }
+ ts.createModuleBlock = createModuleBlock;
+ function updateModuleBlock(node, statements) {
+ return node.statements !== statements
+ ? updateNode(createModuleBlock(statements), node)
+ : node;
+ }
+ ts.updateModuleBlock = updateModuleBlock;
+ function createCaseBlock(clauses) {
+ var node = createSynthesizedNode(234);
+ node.clauses = createNodeArray(clauses);
+ return node;
+ }
+ ts.createCaseBlock = createCaseBlock;
+ function updateCaseBlock(node, clauses) {
+ return node.clauses !== clauses
+ ? updateNode(createCaseBlock(clauses), node)
+ : node;
+ }
+ ts.updateCaseBlock = updateCaseBlock;
+ function createImportEqualsDeclaration(decorators, modifiers, name, moduleReference) {
+ var node = createSynthesizedNode(236);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
+ node.name = asName(name);
+ node.moduleReference = moduleReference;
+ return node;
+ }
+ ts.createImportEqualsDeclaration = createImportEqualsDeclaration;
+ function updateImportEqualsDeclaration(node, decorators, modifiers, name, moduleReference) {
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.name !== name
+ || node.moduleReference !== moduleReference
+ ? updateNode(createImportEqualsDeclaration(decorators, modifiers, name, moduleReference), node)
+ : node;
+ }
+ ts.updateImportEqualsDeclaration = updateImportEqualsDeclaration;
+ function createImportDeclaration(decorators, modifiers, importClause, moduleSpecifier) {
+ var node = createSynthesizedNode(237);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.importClause = importClause;
node.moduleSpecifier = moduleSpecifier;
return node;
}
ts.createImportDeclaration = createImportDeclaration;
function updateImportDeclaration(node, decorators, modifiers, importClause, moduleSpecifier) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier) {
- return updateNode(createImportDeclaration(decorators, modifiers, importClause, moduleSpecifier, node), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier
+ ? updateNode(createImportDeclaration(decorators, modifiers, importClause, moduleSpecifier), node)
+ : node;
}
ts.updateImportDeclaration = updateImportDeclaration;
- function createImportClause(name, namedBindings, location) {
- var node = createNode(236, location);
+ function createImportClause(name, namedBindings) {
+ var node = createSynthesizedNode(238);
node.name = name;
node.namedBindings = namedBindings;
return node;
}
ts.createImportClause = createImportClause;
function updateImportClause(node, name, namedBindings) {
- if (node.name !== name || node.namedBindings !== namedBindings) {
- return updateNode(createImportClause(name, namedBindings, node), node);
- }
- return node;
+ return node.name !== name
+ || node.namedBindings !== namedBindings
+ ? updateNode(createImportClause(name, namedBindings), node)
+ : node;
}
ts.updateImportClause = updateImportClause;
- function createNamespaceImport(name, location) {
- var node = createNode(237, location);
+ function createNamespaceImport(name) {
+ var node = createSynthesizedNode(239);
node.name = name;
return node;
}
ts.createNamespaceImport = createNamespaceImport;
function updateNamespaceImport(node, name) {
- if (node.name !== name) {
- return updateNode(createNamespaceImport(name, node), node);
- }
- return node;
+ return node.name !== name
+ ? updateNode(createNamespaceImport(name), node)
+ : node;
}
ts.updateNamespaceImport = updateNamespaceImport;
- function createNamedImports(elements, location) {
- var node = createNode(238, location);
+ function createNamedImports(elements) {
+ var node = createSynthesizedNode(240);
node.elements = createNodeArray(elements);
return node;
}
ts.createNamedImports = createNamedImports;
function updateNamedImports(node, elements) {
- if (node.elements !== elements) {
- return updateNode(createNamedImports(elements, node), node);
- }
- return node;
+ return node.elements !== elements
+ ? updateNode(createNamedImports(elements), node)
+ : node;
}
ts.updateNamedImports = updateNamedImports;
- function createImportSpecifier(propertyName, name, location) {
- var node = createNode(239, location);
+ function createImportSpecifier(propertyName, name) {
+ var node = createSynthesizedNode(241);
node.propertyName = propertyName;
node.name = name;
return node;
}
ts.createImportSpecifier = createImportSpecifier;
function updateImportSpecifier(node, propertyName, name) {
- if (node.propertyName !== propertyName || node.name !== name) {
- return updateNode(createImportSpecifier(propertyName, name, node), node);
- }
- return node;
+ return node.propertyName !== propertyName
+ || node.name !== name
+ ? updateNode(createImportSpecifier(propertyName, name), node)
+ : node;
}
ts.updateImportSpecifier = updateImportSpecifier;
- function createExportAssignment(decorators, modifiers, isExportEquals, expression, location) {
- var node = createNode(240, location);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createExportAssignment(decorators, modifiers, isExportEquals, expression) {
+ var node = createSynthesizedNode(242);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.isExportEquals = isExportEquals;
node.expression = expression;
return node;
}
ts.createExportAssignment = createExportAssignment;
function updateExportAssignment(node, decorators, modifiers, expression) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.expression !== expression) {
- return updateNode(createExportAssignment(decorators, modifiers, node.isExportEquals, expression, node), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.expression !== expression
+ ? updateNode(createExportAssignment(decorators, modifiers, node.isExportEquals, expression), node)
+ : node;
}
ts.updateExportAssignment = updateExportAssignment;
- function createExportDeclaration(decorators, modifiers, exportClause, moduleSpecifier, location) {
- var node = createNode(241, location);
- node.decorators = decorators ? createNodeArray(decorators) : undefined;
- node.modifiers = modifiers ? createNodeArray(modifiers) : undefined;
+ function createExportDeclaration(decorators, modifiers, exportClause, moduleSpecifier) {
+ var node = createSynthesizedNode(243);
+ node.decorators = asNodeArray(decorators);
+ node.modifiers = asNodeArray(modifiers);
node.exportClause = exportClause;
node.moduleSpecifier = moduleSpecifier;
return node;
}
ts.createExportDeclaration = createExportDeclaration;
function updateExportDeclaration(node, decorators, modifiers, exportClause, moduleSpecifier) {
- if (node.decorators !== decorators || node.modifiers !== modifiers || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier) {
- return updateNode(createExportDeclaration(decorators, modifiers, exportClause, moduleSpecifier, node), node);
- }
- return node;
+ return node.decorators !== decorators
+ || node.modifiers !== modifiers
+ || node.exportClause !== exportClause
+ || node.moduleSpecifier !== moduleSpecifier
+ ? updateNode(createExportDeclaration(decorators, modifiers, exportClause, moduleSpecifier), node)
+ : node;
}
ts.updateExportDeclaration = updateExportDeclaration;
- function createNamedExports(elements, location) {
- var node = createNode(242, location);
+ function createNamedExports(elements) {
+ var node = createSynthesizedNode(244);
node.elements = createNodeArray(elements);
return node;
}
ts.createNamedExports = createNamedExports;
function updateNamedExports(node, elements) {
- if (node.elements !== elements) {
- return updateNode(createNamedExports(elements, node), node);
- }
- return node;
+ return node.elements !== elements
+ ? updateNode(createNamedExports(elements), node)
+ : node;
}
ts.updateNamedExports = updateNamedExports;
- function createExportSpecifier(name, propertyName, location) {
- var node = createNode(243, location);
- node.name = typeof name === "string" ? createIdentifier(name) : name;
- node.propertyName = typeof propertyName === "string" ? createIdentifier(propertyName) : propertyName;
+ function createExportSpecifier(propertyName, name) {
+ var node = createSynthesizedNode(245);
+ node.propertyName = asName(propertyName);
+ node.name = asName(name);
return node;
}
ts.createExportSpecifier = createExportSpecifier;
- function updateExportSpecifier(node, name, propertyName) {
- if (node.name !== name || node.propertyName !== propertyName) {
- return updateNode(createExportSpecifier(name, propertyName, node), node);
- }
- return node;
+ function updateExportSpecifier(node, propertyName, name) {
+ return node.propertyName !== propertyName
+ || node.name !== name
+ ? updateNode(createExportSpecifier(propertyName, name), node)
+ : node;
}
ts.updateExportSpecifier = updateExportSpecifier;
- function createJsxElement(openingElement, children, closingElement, location) {
- var node = createNode(246, location);
+ function createExternalModuleReference(expression) {
+ var node = createSynthesizedNode(247);
+ node.expression = expression;
+ return node;
+ }
+ ts.createExternalModuleReference = createExternalModuleReference;
+ function updateExternalModuleReference(node, expression) {
+ return node.expression !== expression
+ ? updateNode(createExternalModuleReference(expression), node)
+ : node;
+ }
+ ts.updateExternalModuleReference = updateExternalModuleReference;
+ function createJsxElement(openingElement, children, closingElement) {
+ var node = createSynthesizedNode(248);
node.openingElement = openingElement;
node.children = createNodeArray(children);
node.closingElement = closingElement;
@@ -9641,95 +10256,107 @@ var ts;
}
ts.createJsxElement = createJsxElement;
function updateJsxElement(node, openingElement, children, closingElement) {
- if (node.openingElement !== openingElement || node.children !== children || node.closingElement !== closingElement) {
- return updateNode(createJsxElement(openingElement, children, closingElement, node), node);
- }
- return node;
+ return node.openingElement !== openingElement
+ || node.children !== children
+ || node.closingElement !== closingElement
+ ? updateNode(createJsxElement(openingElement, children, closingElement), node)
+ : node;
}
ts.updateJsxElement = updateJsxElement;
- function createJsxSelfClosingElement(tagName, attributes, location) {
- var node = createNode(247, location);
+ function createJsxSelfClosingElement(tagName, attributes) {
+ var node = createSynthesizedNode(249);
node.tagName = tagName;
- node.attributes = createNodeArray(attributes);
+ node.attributes = attributes;
return node;
}
ts.createJsxSelfClosingElement = createJsxSelfClosingElement;
function updateJsxSelfClosingElement(node, tagName, attributes) {
- if (node.tagName !== tagName || node.attributes !== attributes) {
- return updateNode(createJsxSelfClosingElement(tagName, attributes, node), node);
- }
- return node;
+ return node.tagName !== tagName
+ || node.attributes !== attributes
+ ? updateNode(createJsxSelfClosingElement(tagName, attributes), node)
+ : node;
}
ts.updateJsxSelfClosingElement = updateJsxSelfClosingElement;
- function createJsxOpeningElement(tagName, attributes, location) {
- var node = createNode(248, location);
+ function createJsxOpeningElement(tagName, attributes) {
+ var node = createSynthesizedNode(250);
node.tagName = tagName;
- node.attributes = createNodeArray(attributes);
+ node.attributes = attributes;
return node;
}
ts.createJsxOpeningElement = createJsxOpeningElement;
function updateJsxOpeningElement(node, tagName, attributes) {
- if (node.tagName !== tagName || node.attributes !== attributes) {
- return updateNode(createJsxOpeningElement(tagName, attributes, node), node);
- }
- return node;
+ return node.tagName !== tagName
+ || node.attributes !== attributes
+ ? updateNode(createJsxOpeningElement(tagName, attributes), node)
+ : node;
}
ts.updateJsxOpeningElement = updateJsxOpeningElement;
- function createJsxClosingElement(tagName, location) {
- var node = createNode(249, location);
+ function createJsxClosingElement(tagName) {
+ var node = createSynthesizedNode(251);
node.tagName = tagName;
return node;
}
ts.createJsxClosingElement = createJsxClosingElement;
function updateJsxClosingElement(node, tagName) {
- if (node.tagName !== tagName) {
- return updateNode(createJsxClosingElement(tagName, node), node);
- }
- return node;
+ return node.tagName !== tagName
+ ? updateNode(createJsxClosingElement(tagName), node)
+ : node;
}
ts.updateJsxClosingElement = updateJsxClosingElement;
- function createJsxAttribute(name, initializer, location) {
- var node = createNode(250, location);
+ function createJsxAttributes(properties) {
+ var jsxAttributes = createSynthesizedNode(253);
+ jsxAttributes.properties = createNodeArray(properties);
+ return jsxAttributes;
+ }
+ ts.createJsxAttributes = createJsxAttributes;
+ function updateJsxAttributes(jsxAttributes, properties) {
+ if (jsxAttributes.properties !== properties) {
+ return updateNode(createJsxAttributes(properties), jsxAttributes);
+ }
+ return jsxAttributes;
+ }
+ ts.updateJsxAttributes = updateJsxAttributes;
+ function createJsxAttribute(name, initializer) {
+ var node = createSynthesizedNode(252);
node.name = name;
node.initializer = initializer;
return node;
}
ts.createJsxAttribute = createJsxAttribute;
function updateJsxAttribute(node, name, initializer) {
- if (node.name !== name || node.initializer !== initializer) {
- return updateNode(createJsxAttribute(name, initializer, node), node);
- }
- return node;
+ return node.name !== name
+ || node.initializer !== initializer
+ ? updateNode(createJsxAttribute(name, initializer), node)
+ : node;
}
ts.updateJsxAttribute = updateJsxAttribute;
- function createJsxSpreadAttribute(expression, location) {
- var node = createNode(251, location);
+ function createJsxSpreadAttribute(expression) {
+ var node = createSynthesizedNode(254);
node.expression = expression;
return node;
}
ts.createJsxSpreadAttribute = createJsxSpreadAttribute;
function updateJsxSpreadAttribute(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createJsxSpreadAttribute(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createJsxSpreadAttribute(expression), node)
+ : node;
}
ts.updateJsxSpreadAttribute = updateJsxSpreadAttribute;
- function createJsxExpression(expression, location) {
- var node = createNode(252, location);
+ function createJsxExpression(dotDotDotToken, expression) {
+ var node = createSynthesizedNode(255);
+ node.dotDotDotToken = dotDotDotToken;
node.expression = expression;
return node;
}
ts.createJsxExpression = createJsxExpression;
function updateJsxExpression(node, expression) {
- if (node.expression !== expression) {
- return updateNode(createJsxExpression(expression, node), node);
- }
- return node;
+ return node.expression !== expression
+ ? updateNode(createJsxExpression(node.dotDotDotToken, expression), node)
+ : node;
}
ts.updateJsxExpression = updateJsxExpression;
- function createHeritageClause(token, types, location) {
- var node = createNode(255, location);
+ function createHeritageClause(token, types) {
+ var node = createSynthesizedNode(258);
node.token = token;
node.types = createNodeArray(types);
return node;
@@ -9737,40 +10364,40 @@ var ts;
ts.createHeritageClause = createHeritageClause;
function updateHeritageClause(node, types) {
if (node.types !== types) {
- return updateNode(createHeritageClause(node.token, types, node), node);
+ return updateNode(createHeritageClause(node.token, types), node);
}
return node;
}
ts.updateHeritageClause = updateHeritageClause;
- function createCaseClause(expression, statements, location) {
- var node = createNode(253, location);
- node.expression = parenthesizeExpressionForList(expression);
+ function createCaseClause(expression, statements) {
+ var node = createSynthesizedNode(256);
+ node.expression = ts.parenthesizeExpressionForList(expression);
node.statements = createNodeArray(statements);
return node;
}
ts.createCaseClause = createCaseClause;
function updateCaseClause(node, expression, statements) {
if (node.expression !== expression || node.statements !== statements) {
- return updateNode(createCaseClause(expression, statements, node), node);
+ return updateNode(createCaseClause(expression, statements), node);
}
return node;
}
ts.updateCaseClause = updateCaseClause;
- function createDefaultClause(statements, location) {
- var node = createNode(254, location);
+ function createDefaultClause(statements) {
+ var node = createSynthesizedNode(257);
node.statements = createNodeArray(statements);
return node;
}
ts.createDefaultClause = createDefaultClause;
function updateDefaultClause(node, statements) {
if (node.statements !== statements) {
- return updateNode(createDefaultClause(statements, node), node);
+ return updateNode(createDefaultClause(statements), node);
}
return node;
}
ts.updateDefaultClause = updateDefaultClause;
- function createCatchClause(variableDeclaration, block, location) {
- var node = createNode(256, location);
+ function createCatchClause(variableDeclaration, block) {
+ var node = createSynthesizedNode(259);
node.variableDeclaration = typeof variableDeclaration === "string" ? createVariableDeclaration(variableDeclaration) : variableDeclaration;
node.block = block;
return node;
@@ -9778,56 +10405,71 @@ var ts;
ts.createCatchClause = createCatchClause;
function updateCatchClause(node, variableDeclaration, block) {
if (node.variableDeclaration !== variableDeclaration || node.block !== block) {
- return updateNode(createCatchClause(variableDeclaration, block, node), node);
+ return updateNode(createCatchClause(variableDeclaration, block), node);
}
return node;
}
ts.updateCatchClause = updateCatchClause;
- function createPropertyAssignment(name, initializer, location) {
- var node = createNode(257, location);
- node.name = typeof name === "string" ? createIdentifier(name) : name;
+ function createPropertyAssignment(name, initializer) {
+ var node = createSynthesizedNode(260);
+ node.name = asName(name);
node.questionToken = undefined;
- node.initializer = initializer !== undefined ? parenthesizeExpressionForList(initializer) : undefined;
+ node.initializer = initializer !== undefined ? ts.parenthesizeExpressionForList(initializer) : undefined;
return node;
}
ts.createPropertyAssignment = createPropertyAssignment;
function updatePropertyAssignment(node, name, initializer) {
if (node.name !== name || node.initializer !== initializer) {
- return updateNode(createPropertyAssignment(name, initializer, node), node);
+ return updateNode(createPropertyAssignment(name, initializer), node);
}
return node;
}
ts.updatePropertyAssignment = updatePropertyAssignment;
- function createShorthandPropertyAssignment(name, objectAssignmentInitializer, location) {
- var node = createNode(258, location);
- node.name = typeof name === "string" ? createIdentifier(name) : name;
- node.objectAssignmentInitializer = objectAssignmentInitializer !== undefined ? parenthesizeExpressionForList(objectAssignmentInitializer) : undefined;
+ function createShorthandPropertyAssignment(name, objectAssignmentInitializer) {
+ var node = createSynthesizedNode(261);
+ node.name = asName(name);
+ node.objectAssignmentInitializer = objectAssignmentInitializer !== undefined ? ts.parenthesizeExpressionForList(objectAssignmentInitializer) : undefined;
return node;
}
ts.createShorthandPropertyAssignment = createShorthandPropertyAssignment;
- function createSpreadAssignment(expression, location) {
- var node = createNode(259, location);
- node.expression = expression !== undefined ? parenthesizeExpressionForList(expression) : undefined;
- return node;
- }
- ts.createSpreadAssignment = createSpreadAssignment;
function updateShorthandPropertyAssignment(node, name, objectAssignmentInitializer) {
if (node.name !== name || node.objectAssignmentInitializer !== objectAssignmentInitializer) {
- return updateNode(createShorthandPropertyAssignment(name, objectAssignmentInitializer, node), node);
+ return updateNode(createShorthandPropertyAssignment(name, objectAssignmentInitializer), node);
}
return node;
}
ts.updateShorthandPropertyAssignment = updateShorthandPropertyAssignment;
+ function createSpreadAssignment(expression) {
+ var node = createSynthesizedNode(262);
+ node.expression = expression !== undefined ? ts.parenthesizeExpressionForList(expression) : undefined;
+ return node;
+ }
+ ts.createSpreadAssignment = createSpreadAssignment;
function updateSpreadAssignment(node, expression) {
if (node.expression !== expression) {
- return updateNode(createSpreadAssignment(expression, node), node);
+ return updateNode(createSpreadAssignment(expression), node);
}
return node;
}
ts.updateSpreadAssignment = updateSpreadAssignment;
+ function createEnumMember(name, initializer) {
+ var node = createSynthesizedNode(263);
+ node.name = asName(name);
+ node.initializer = initializer && ts.parenthesizeExpressionForList(initializer);
+ return node;
+ }
+ ts.createEnumMember = createEnumMember;
+ function updateEnumMember(node, name, initializer) {
+ return node.name !== name
+ || node.initializer !== initializer
+ ? updateNode(createEnumMember(name, initializer), node)
+ : node;
+ }
+ ts.updateEnumMember = updateEnumMember;
function updateSourceFileNode(node, statements) {
if (node.statements !== statements) {
- var updated = createNode(261, node, node.flags);
+ var updated = createSynthesizedNode(264);
+ updated.flags |= node.flags;
updated.statements = createNodeArray(statements);
updated.endOfFileToken = node.endOfFileToken;
updated.fileName = node.fileName;
@@ -9886,56 +10528,73 @@ var ts;
return node;
}
ts.updateSourceFileNode = updateSourceFileNode;
+ function getMutableClone(node) {
+ var clone = getSynthesizedClone(node);
+ clone.pos = node.pos;
+ clone.end = node.end;
+ clone.parent = node.parent;
+ return clone;
+ }
+ ts.getMutableClone = getMutableClone;
function createNotEmittedStatement(original) {
- var node = createNode(293, original);
+ var node = createSynthesizedNode(294);
node.original = original;
+ setTextRange(node, original);
return node;
}
ts.createNotEmittedStatement = createNotEmittedStatement;
function createEndOfDeclarationMarker(original) {
- var node = createNode(296);
+ var node = createSynthesizedNode(297);
node.emitNode = {};
node.original = original;
return node;
}
ts.createEndOfDeclarationMarker = createEndOfDeclarationMarker;
function createMergeDeclarationMarker(original) {
- var node = createNode(295);
+ var node = createSynthesizedNode(296);
node.emitNode = {};
node.original = original;
return node;
}
ts.createMergeDeclarationMarker = createMergeDeclarationMarker;
- function createPartiallyEmittedExpression(expression, original, location) {
- var node = createNode(294, location || original);
+ function createPartiallyEmittedExpression(expression, original) {
+ var node = createSynthesizedNode(295);
node.expression = expression;
node.original = original;
+ setTextRange(node, original);
return node;
}
ts.createPartiallyEmittedExpression = createPartiallyEmittedExpression;
function updatePartiallyEmittedExpression(node, expression) {
if (node.expression !== expression) {
- return updateNode(createPartiallyEmittedExpression(expression, node.original, node), node);
+ return updateNode(createPartiallyEmittedExpression(expression, node.original), node);
}
return node;
}
ts.updatePartiallyEmittedExpression = updatePartiallyEmittedExpression;
- function createRawExpression(text) {
- var node = createNode(297);
- node.text = text;
+ function createBundle(sourceFiles) {
+ var node = ts.createNode(265);
+ node.sourceFiles = sourceFiles;
+ return node;
+ }
+ ts.createBundle = createBundle;
+ function updateBundle(node, sourceFiles) {
+ if (node.sourceFiles !== sourceFiles) {
+ return createBundle(sourceFiles);
+ }
return node;
}
- ts.createRawExpression = createRawExpression;
+ ts.updateBundle = updateBundle;
function createComma(left, right) {
return createBinary(left, 25, right);
}
ts.createComma = createComma;
- function createLessThan(left, right, location) {
- return createBinary(left, 26, right, location);
+ function createLessThan(left, right) {
+ return createBinary(left, 26, right);
}
ts.createLessThan = createLessThan;
- function createAssignment(left, right, location) {
- return createBinary(left, 57, right, location);
+ function createAssignment(left, right) {
+ return createBinary(left, 57, right);
}
ts.createAssignment = createAssignment;
function createStrictEquality(left, right) {
@@ -9954,8 +10613,8 @@ var ts;
return createBinary(left, 37, right);
}
ts.createSubtract = createSubtract;
- function createPostfixIncrement(operand, location) {
- return createPostfix(operand, 42, location);
+ function createPostfixIncrement(operand) {
+ return createPostfix(operand, 42);
}
ts.createPostfixIncrement = createPostfixIncrement;
function createLogicalAnd(left, right) {
@@ -9974,54 +10633,305 @@ var ts;
return createVoid(createLiteral(0));
}
ts.createVoidZero = createVoidZero;
+ function createExportDefault(expression) {
+ return createExportAssignment(undefined, undefined, false, expression);
+ }
+ ts.createExportDefault = createExportDefault;
+ function createExternalModuleExport(exportName) {
+ return createExportDeclaration(undefined, undefined, createNamedExports([createExportSpecifier(undefined, exportName)]));
+ }
+ ts.createExternalModuleExport = createExternalModuleExport;
+ function asName(name) {
+ return typeof name === "string" ? createIdentifier(name) : name;
+ }
+ function asExpression(value) {
+ return typeof value === "string" || typeof value === "number" ? createLiteral(value) : value;
+ }
+ function asNodeArray(array) {
+ return array ? createNodeArray(array) : undefined;
+ }
+ function asToken(value) {
+ return typeof value === "number" ? createToken(value) : value;
+ }
+ function disposeEmitNodes(sourceFile) {
+ sourceFile = ts.getSourceFileOfNode(ts.getParseTreeNode(sourceFile));
+ var emitNode = sourceFile && sourceFile.emitNode;
+ var annotatedNodes = emitNode && emitNode.annotatedNodes;
+ if (annotatedNodes) {
+ for (var _i = 0, annotatedNodes_1 = annotatedNodes; _i < annotatedNodes_1.length; _i++) {
+ var node = annotatedNodes_1[_i];
+ node.emitNode = undefined;
+ }
+ }
+ }
+ ts.disposeEmitNodes = disposeEmitNodes;
+ function getOrCreateEmitNode(node) {
+ if (!node.emitNode) {
+ if (ts.isParseTreeNode(node)) {
+ if (node.kind === 264) {
+ return node.emitNode = { annotatedNodes: [node] };
+ }
+ var sourceFile = ts.getSourceFileOfNode(node);
+ getOrCreateEmitNode(sourceFile).annotatedNodes.push(node);
+ }
+ node.emitNode = {};
+ }
+ return node.emitNode;
+ }
+ ts.getOrCreateEmitNode = getOrCreateEmitNode;
+ function setTextRange(range, location) {
+ if (location) {
+ range.pos = location.pos;
+ range.end = location.end;
+ }
+ return range;
+ }
+ ts.setTextRange = setTextRange;
+ function getEmitFlags(node) {
+ var emitNode = node.emitNode;
+ return emitNode && emitNode.flags;
+ }
+ ts.getEmitFlags = getEmitFlags;
+ function setEmitFlags(node, emitFlags) {
+ getOrCreateEmitNode(node).flags = emitFlags;
+ return node;
+ }
+ ts.setEmitFlags = setEmitFlags;
+ function getSourceMapRange(node) {
+ var emitNode = node.emitNode;
+ return (emitNode && emitNode.sourceMapRange) || node;
+ }
+ ts.getSourceMapRange = getSourceMapRange;
+ function setSourceMapRange(node, range) {
+ getOrCreateEmitNode(node).sourceMapRange = range;
+ return node;
+ }
+ ts.setSourceMapRange = setSourceMapRange;
+ function getTokenSourceMapRange(node, token) {
+ var emitNode = node.emitNode;
+ var tokenSourceMapRanges = emitNode && emitNode.tokenSourceMapRanges;
+ return tokenSourceMapRanges && tokenSourceMapRanges[token];
+ }
+ ts.getTokenSourceMapRange = getTokenSourceMapRange;
+ function setTokenSourceMapRange(node, token, range) {
+ var emitNode = getOrCreateEmitNode(node);
+ var tokenSourceMapRanges = emitNode.tokenSourceMapRanges || (emitNode.tokenSourceMapRanges = []);
+ tokenSourceMapRanges[token] = range;
+ return node;
+ }
+ ts.setTokenSourceMapRange = setTokenSourceMapRange;
+ function getCommentRange(node) {
+ var emitNode = node.emitNode;
+ return (emitNode && emitNode.commentRange) || node;
+ }
+ ts.getCommentRange = getCommentRange;
+ function setCommentRange(node, range) {
+ getOrCreateEmitNode(node).commentRange = range;
+ return node;
+ }
+ ts.setCommentRange = setCommentRange;
+ function getSyntheticLeadingComments(node) {
+ var emitNode = node.emitNode;
+ return emitNode && emitNode.leadingComments;
+ }
+ ts.getSyntheticLeadingComments = getSyntheticLeadingComments;
+ function setSyntheticLeadingComments(node, comments) {
+ getOrCreateEmitNode(node).leadingComments = comments;
+ return node;
+ }
+ ts.setSyntheticLeadingComments = setSyntheticLeadingComments;
+ function addSyntheticLeadingComment(node, kind, text, hasTrailingNewLine) {
+ return setSyntheticLeadingComments(node, ts.append(getSyntheticLeadingComments(node), { kind: kind, pos: -1, end: -1, hasTrailingNewLine: hasTrailingNewLine, text: text }));
+ }
+ ts.addSyntheticLeadingComment = addSyntheticLeadingComment;
+ function getSyntheticTrailingComments(node) {
+ var emitNode = node.emitNode;
+ return emitNode && emitNode.trailingComments;
+ }
+ ts.getSyntheticTrailingComments = getSyntheticTrailingComments;
+ function setSyntheticTrailingComments(node, comments) {
+ getOrCreateEmitNode(node).trailingComments = comments;
+ return node;
+ }
+ ts.setSyntheticTrailingComments = setSyntheticTrailingComments;
+ function addSyntheticTrailingComment(node, kind, text, hasTrailingNewLine) {
+ return setSyntheticTrailingComments(node, ts.append(getSyntheticTrailingComments(node), { kind: kind, pos: -1, end: -1, hasTrailingNewLine: hasTrailingNewLine, text: text }));
+ }
+ ts.addSyntheticTrailingComment = addSyntheticTrailingComment;
+ function getConstantValue(node) {
+ var emitNode = node.emitNode;
+ return emitNode && emitNode.constantValue;
+ }
+ ts.getConstantValue = getConstantValue;
+ function setConstantValue(node, value) {
+ var emitNode = getOrCreateEmitNode(node);
+ emitNode.constantValue = value;
+ return node;
+ }
+ ts.setConstantValue = setConstantValue;
+ function addEmitHelper(node, helper) {
+ var emitNode = getOrCreateEmitNode(node);
+ emitNode.helpers = ts.append(emitNode.helpers, helper);
+ return node;
+ }
+ ts.addEmitHelper = addEmitHelper;
+ function addEmitHelpers(node, helpers) {
+ if (ts.some(helpers)) {
+ var emitNode = getOrCreateEmitNode(node);
+ for (var _i = 0, helpers_1 = helpers; _i < helpers_1.length; _i++) {
+ var helper = helpers_1[_i];
+ if (!ts.contains(emitNode.helpers, helper)) {
+ emitNode.helpers = ts.append(emitNode.helpers, helper);
+ }
+ }
+ }
+ return node;
+ }
+ ts.addEmitHelpers = addEmitHelpers;
+ function removeEmitHelper(node, helper) {
+ var emitNode = node.emitNode;
+ if (emitNode) {
+ var helpers = emitNode.helpers;
+ if (helpers) {
+ return ts.orderedRemoveItem(helpers, helper);
+ }
+ }
+ return false;
+ }
+ ts.removeEmitHelper = removeEmitHelper;
+ function getEmitHelpers(node) {
+ var emitNode = node.emitNode;
+ return emitNode && emitNode.helpers;
+ }
+ ts.getEmitHelpers = getEmitHelpers;
+ function moveEmitHelpers(source, target, predicate) {
+ var sourceEmitNode = source.emitNode;
+ var sourceEmitHelpers = sourceEmitNode && sourceEmitNode.helpers;
+ if (!ts.some(sourceEmitHelpers))
+ return;
+ var targetEmitNode = getOrCreateEmitNode(target);
+ var helpersRemoved = 0;
+ for (var i = 0; i < sourceEmitHelpers.length; i++) {
+ var helper = sourceEmitHelpers[i];
+ if (predicate(helper)) {
+ helpersRemoved++;
+ if (!ts.contains(targetEmitNode.helpers, helper)) {
+ targetEmitNode.helpers = ts.append(targetEmitNode.helpers, helper);
+ }
+ }
+ else if (helpersRemoved > 0) {
+ sourceEmitHelpers[i - helpersRemoved] = helper;
+ }
+ }
+ if (helpersRemoved > 0) {
+ sourceEmitHelpers.length -= helpersRemoved;
+ }
+ }
+ ts.moveEmitHelpers = moveEmitHelpers;
+ function compareEmitHelpers(x, y) {
+ if (x === y)
+ return 0;
+ if (x.priority === y.priority)
+ return 0;
+ if (x.priority === undefined)
+ return 1;
+ if (y.priority === undefined)
+ return -1;
+ return ts.compareValues(x.priority, y.priority);
+ }
+ ts.compareEmitHelpers = compareEmitHelpers;
+ function setOriginalNode(node, original) {
+ node.original = original;
+ if (original) {
+ var emitNode = original.emitNode;
+ if (emitNode)
+ node.emitNode = mergeEmitNode(emitNode, node.emitNode);
+ }
+ return node;
+ }
+ ts.setOriginalNode = setOriginalNode;
+ function mergeEmitNode(sourceEmitNode, destEmitNode) {
+ var flags = sourceEmitNode.flags, leadingComments = sourceEmitNode.leadingComments, trailingComments = sourceEmitNode.trailingComments, commentRange = sourceEmitNode.commentRange, sourceMapRange = sourceEmitNode.sourceMapRange, tokenSourceMapRanges = sourceEmitNode.tokenSourceMapRanges, constantValue = sourceEmitNode.constantValue, helpers = sourceEmitNode.helpers;
+ if (!destEmitNode)
+ destEmitNode = {};
+ if (leadingComments)
+ destEmitNode.leadingComments = ts.addRange(leadingComments.slice(), destEmitNode.leadingComments);
+ if (trailingComments)
+ destEmitNode.trailingComments = ts.addRange(trailingComments.slice(), destEmitNode.trailingComments);
+ if (flags)
+ destEmitNode.flags = flags;
+ if (commentRange)
+ destEmitNode.commentRange = commentRange;
+ if (sourceMapRange)
+ destEmitNode.sourceMapRange = sourceMapRange;
+ if (tokenSourceMapRanges)
+ destEmitNode.tokenSourceMapRanges = mergeTokenSourceMapRanges(tokenSourceMapRanges, destEmitNode.tokenSourceMapRanges);
+ if (constantValue !== undefined)
+ destEmitNode.constantValue = constantValue;
+ if (helpers)
+ destEmitNode.helpers = ts.addRange(destEmitNode.helpers, helpers);
+ return destEmitNode;
+ }
+ function mergeTokenSourceMapRanges(sourceRanges, destRanges) {
+ if (!destRanges)
+ destRanges = [];
+ for (var key in sourceRanges) {
+ destRanges[key] = sourceRanges[key];
+ }
+ return destRanges;
+ }
+})(ts || (ts = {}));
+(function (ts) {
function createTypeCheck(value, tag) {
return tag === "undefined"
- ? createStrictEquality(value, createVoidZero())
- : createStrictEquality(createTypeOf(value), createLiteral(tag));
+ ? ts.createStrictEquality(value, ts.createVoidZero())
+ : ts.createStrictEquality(ts.createTypeOf(value), ts.createLiteral(tag));
}
ts.createTypeCheck = createTypeCheck;
function createMemberAccessForPropertyName(target, memberName, location) {
if (ts.isComputedPropertyName(memberName)) {
- return createElementAccess(target, memberName.expression, location);
+ return ts.setTextRange(ts.createElementAccess(target, memberName.expression), location);
}
else {
- var expression = ts.isIdentifier(memberName) ? createPropertyAccess(target, memberName, location) : createElementAccess(target, memberName, location);
- (expression.emitNode || (expression.emitNode = {})).flags |= 64;
+ var expression = ts.setTextRange(ts.isIdentifier(memberName)
+ ? ts.createPropertyAccess(target, memberName)
+ : ts.createElementAccess(target, memberName), memberName);
+ ts.getOrCreateEmitNode(expression).flags |= 64;
return expression;
}
}
ts.createMemberAccessForPropertyName = createMemberAccessForPropertyName;
function createFunctionCall(func, thisArg, argumentsList, location) {
- return createCall(createPropertyAccess(func, "call"), undefined, [
+ return ts.setTextRange(ts.createCall(ts.createPropertyAccess(func, "call"), undefined, [
thisArg
- ].concat(argumentsList), location);
+ ].concat(argumentsList)), location);
}
ts.createFunctionCall = createFunctionCall;
function createFunctionApply(func, thisArg, argumentsExpression, location) {
- return createCall(createPropertyAccess(func, "apply"), undefined, [
+ return ts.setTextRange(ts.createCall(ts.createPropertyAccess(func, "apply"), undefined, [
thisArg,
argumentsExpression
- ], location);
+ ]), location);
}
ts.createFunctionApply = createFunctionApply;
function createArraySlice(array, start) {
var argumentsList = [];
if (start !== undefined) {
- argumentsList.push(typeof start === "number" ? createLiteral(start) : start);
+ argumentsList.push(typeof start === "number" ? ts.createLiteral(start) : start);
}
- return createCall(createPropertyAccess(array, "slice"), undefined, argumentsList);
+ return ts.createCall(ts.createPropertyAccess(array, "slice"), undefined, argumentsList);
}
ts.createArraySlice = createArraySlice;
function createArrayConcat(array, values) {
- return createCall(createPropertyAccess(array, "concat"), undefined, values);
+ return ts.createCall(ts.createPropertyAccess(array, "concat"), undefined, values);
}
ts.createArrayConcat = createArrayConcat;
function createMathPow(left, right, location) {
- return createCall(createPropertyAccess(createIdentifier("Math"), "pow"), undefined, [left, right], location);
+ return ts.setTextRange(ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Math"), "pow"), undefined, [left, right]), location);
}
ts.createMathPow = createMathPow;
function createReactNamespace(reactNamespace, parent) {
- var react = createIdentifier(reactNamespace || "React");
+ var react = ts.createIdentifier(reactNamespace || "React");
react.flags &= ~8;
react.parent = ts.getParseTreeNode(parent);
return react;
@@ -10029,9 +10939,9 @@ var ts;
function createJsxFactoryExpressionFromEntityName(jsxFactory, parent) {
if (ts.isQualifiedName(jsxFactory)) {
var left = createJsxFactoryExpressionFromEntityName(jsxFactory.left, parent);
- var right = createSynthesizedNode(70);
+ var right = ts.createIdentifier(jsxFactory.right.text);
right.text = jsxFactory.right.text;
- return createPropertyAccess(left, right);
+ return ts.createPropertyAccess(left, right);
}
else {
return createReactNamespace(jsxFactory.text, parent);
@@ -10040,7 +10950,7 @@ var ts;
function createJsxFactoryExpression(jsxFactoryEntity, reactNamespace, parent) {
return jsxFactoryEntity ?
createJsxFactoryExpressionFromEntityName(jsxFactoryEntity, parent) :
- createPropertyAccess(createReactNamespace(reactNamespace, parent), "createElement");
+ ts.createPropertyAccess(createReactNamespace(reactNamespace, parent), "createElement");
}
function createExpressionForJsxElement(jsxFactoryEntity, reactNamespace, tagName, props, children, parentElement, location) {
var argumentsList = [tagName];
@@ -10049,7 +10959,7 @@ var ts;
}
if (children && children.length > 0) {
if (!props) {
- argumentsList.push(createNull());
+ argumentsList.push(ts.createNull());
}
if (children.length > 1) {
for (var _i = 0, children_1 = children; _i < children_1.length; _i++) {
@@ -10062,33 +10972,80 @@ var ts;
argumentsList.push(children[0]);
}
}
- return createCall(createJsxFactoryExpression(jsxFactoryEntity, reactNamespace, parentElement), undefined, argumentsList, location);
+ return ts.setTextRange(ts.createCall(createJsxFactoryExpression(jsxFactoryEntity, reactNamespace, parentElement), undefined, argumentsList), location);
}
ts.createExpressionForJsxElement = createExpressionForJsxElement;
- function createExportDefault(expression) {
- return createExportAssignment(undefined, undefined, false, expression);
- }
- ts.createExportDefault = createExportDefault;
- function createExternalModuleExport(exportName) {
- return createExportDeclaration(undefined, undefined, createNamedExports([createExportSpecifier(exportName)]));
+ function getHelperName(name) {
+ return ts.setEmitFlags(ts.createIdentifier(name), 4096 | 2);
}
- ts.createExternalModuleExport = createExternalModuleExport;
- function createLetStatement(name, initializer, location) {
- return createVariableStatement(undefined, createLetDeclarationList([createVariableDeclaration(name, undefined, initializer)]), location);
+ ts.getHelperName = getHelperName;
+ var valuesHelper = {
+ name: "typescript:values",
+ scoped: false,
+ text: "\n var __values = (this && this.__values) || function (o) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\n if (m) return m.call(o);\n return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n };\n "
+ };
+ function createValuesHelper(context, expression, location) {
+ context.requestEmitHelper(valuesHelper);
+ return ts.setTextRange(ts.createCall(getHelperName("__values"), undefined, [expression]), location);
}
- ts.createLetStatement = createLetStatement;
- function createLetDeclarationList(declarations, location) {
- return createVariableDeclarationList(declarations, location, 1);
+ ts.createValuesHelper = createValuesHelper;
+ var readHelper = {
+ name: "typescript:read",
+ scoped: false,
+ text: "\n var __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n };\n "
+ };
+ function createReadHelper(context, iteratorRecord, count, location) {
+ context.requestEmitHelper(readHelper);
+ return ts.setTextRange(ts.createCall(getHelperName("__read"), undefined, count !== undefined
+ ? [iteratorRecord, ts.createLiteral(count)]
+ : [iteratorRecord]), location);
+ }
+ ts.createReadHelper = createReadHelper;
+ var spreadHelper = {
+ name: "typescript:spread",
+ scoped: false,
+ text: "\n var __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n };"
+ };
+ function createSpreadHelper(context, argumentList, location) {
+ context.requestEmitHelper(readHelper);
+ context.requestEmitHelper(spreadHelper);
+ return ts.setTextRange(ts.createCall(getHelperName("__spread"), undefined, argumentList), location);
+ }
+ ts.createSpreadHelper = createSpreadHelper;
+ function createForOfBindingStatement(node, boundValue) {
+ if (ts.isVariableDeclarationList(node)) {
+ var firstDeclaration = ts.firstOrUndefined(node.declarations);
+ var updatedDeclaration = ts.updateVariableDeclaration(firstDeclaration, firstDeclaration.name, undefined, boundValue);
+ return ts.setTextRange(ts.createVariableStatement(undefined, ts.updateVariableDeclarationList(node, [updatedDeclaration])), node);
+ }
+ else {
+ var updatedExpression = ts.setTextRange(ts.createAssignment(node, boundValue), node);
+ return ts.setTextRange(ts.createStatement(updatedExpression), node);
+ }
}
- ts.createLetDeclarationList = createLetDeclarationList;
- function createConstDeclarationList(declarations, location) {
- return createVariableDeclarationList(declarations, location, 2);
+ ts.createForOfBindingStatement = createForOfBindingStatement;
+ function insertLeadingStatement(dest, source) {
+ if (ts.isBlock(dest)) {
+ return ts.updateBlock(dest, ts.setTextRange(ts.createNodeArray([source].concat(dest.statements)), dest.statements));
+ }
+ else {
+ return ts.createBlock(ts.createNodeArray([dest, source]), true);
+ }
}
- ts.createConstDeclarationList = createConstDeclarationList;
- function getHelperName(name) {
- return setEmitFlags(createIdentifier(name), 4096 | 2);
+ ts.insertLeadingStatement = insertLeadingStatement;
+ function restoreEnclosingLabel(node, outermostLabeledStatement, afterRestoreLabelCallback) {
+ if (!outermostLabeledStatement) {
+ return node;
+ }
+ var updated = ts.updateLabel(outermostLabeledStatement, outermostLabeledStatement.label, outermostLabeledStatement.statement.kind === 221
+ ? restoreEnclosingLabel(node, outermostLabeledStatement.statement)
+ : node);
+ if (afterRestoreLabelCallback) {
+ afterRestoreLabelCallback(outermostLabeledStatement);
+ }
+ return updated;
}
- ts.getHelperName = getHelperName;
+ ts.restoreEnclosingLabel = restoreEnclosingLabel;
function shouldBeCapturedInTempVariable(node, cacheIdentifiers) {
var target = skipParentheses(node);
switch (target.kind) {
@@ -10098,13 +11055,13 @@ var ts;
case 8:
case 9:
return false;
- case 175:
+ case 176:
var elements = target.elements;
if (elements.length === 0) {
return false;
}
return true;
- case 176:
+ case 177:
return target.properties.length > 0;
default:
return true;
@@ -10115,19 +11072,26 @@ var ts;
var thisArg;
var target;
if (ts.isSuperProperty(callee)) {
- thisArg = createThis();
+ thisArg = ts.createThis();
target = callee;
}
else if (callee.kind === 96) {
- thisArg = createThis();
- target = languageVersion < 2 ? createIdentifier("_super", callee) : callee;
+ thisArg = ts.createThis();
+ target = languageVersion < 2
+ ? ts.setTextRange(ts.createIdentifier("_super"), callee)
+ : callee;
+ }
+ else if (ts.getEmitFlags(callee) & 4096) {
+ thisArg = ts.createVoidZero();
+ target = parenthesizeForAccess(callee);
}
else {
switch (callee.kind) {
- case 177: {
+ case 178: {
if (shouldBeCapturedInTempVariable(callee.expression, cacheIdentifiers)) {
- thisArg = createTempVariable(recordTempVariable);
- target = createPropertyAccess(createAssignment(thisArg, callee.expression, callee.expression), callee.name, callee);
+ thisArg = ts.createTempVariable(recordTempVariable);
+ target = ts.createPropertyAccess(ts.setTextRange(ts.createAssignment(thisArg, callee.expression), callee.expression), callee.name);
+ ts.setTextRange(target, callee);
}
else {
thisArg = callee.expression;
@@ -10135,10 +11099,11 @@ var ts;
}
break;
}
- case 178: {
+ case 179: {
if (shouldBeCapturedInTempVariable(callee.expression, cacheIdentifiers)) {
- thisArg = createTempVariable(recordTempVariable);
- target = createElementAccess(createAssignment(thisArg, callee.expression, callee.expression), callee.argumentExpression, callee);
+ thisArg = ts.createTempVariable(recordTempVariable);
+ target = ts.createElementAccess(ts.setTextRange(ts.createAssignment(thisArg, callee.expression), callee.expression), callee.argumentExpression);
+ ts.setTextRange(target, callee);
}
else {
thisArg = callee.expression;
@@ -10147,7 +11112,7 @@ var ts;
break;
}
default: {
- thisArg = createVoidZero();
+ thisArg = ts.createVoidZero();
target = parenthesizeForAccess(expression);
break;
}
@@ -10157,42 +11122,42 @@ var ts;
}
ts.createCallBinding = createCallBinding;
function inlineExpressions(expressions) {
- return ts.reduceLeft(expressions, createComma);
+ return ts.reduceLeft(expressions, ts.createComma);
}
ts.inlineExpressions = inlineExpressions;
function createExpressionFromEntityName(node) {
if (ts.isQualifiedName(node)) {
var left = createExpressionFromEntityName(node.left);
- var right = getMutableClone(node.right);
- return createPropertyAccess(left, right, node);
+ var right = ts.getMutableClone(node.right);
+ return ts.setTextRange(ts.createPropertyAccess(left, right), node);
}
else {
- return getMutableClone(node);
+ return ts.getMutableClone(node);
}
}
ts.createExpressionFromEntityName = createExpressionFromEntityName;
function createExpressionForPropertyName(memberName) {
if (ts.isIdentifier(memberName)) {
- return createLiteral(memberName, undefined);
+ return ts.createLiteral(memberName);
}
else if (ts.isComputedPropertyName(memberName)) {
- return getMutableClone(memberName.expression);
+ return ts.getMutableClone(memberName.expression);
}
else {
- return getMutableClone(memberName);
+ return ts.getMutableClone(memberName);
}
}
ts.createExpressionForPropertyName = createExpressionForPropertyName;
function createExpressionForObjectLiteralElementLike(node, property, receiver) {
switch (property.kind) {
- case 151:
case 152:
+ case 153:
return createExpressionForAccessorDeclaration(node.properties, property, receiver, node.multiLine);
- case 257:
+ case 260:
return createExpressionForPropertyAssignment(property, receiver);
- case 258:
+ case 261:
return createExpressionForShorthandPropertyAssignment(property, receiver);
- case 149:
+ case 150:
return createExpressionForMethodDeclaration(property, receiver);
}
}
@@ -10202,43 +11167,45 @@ var ts;
if (property === firstAccessor) {
var properties_1 = [];
if (getAccessor) {
- var getterFunction = createFunctionExpression(getAccessor.modifiers, undefined, undefined, undefined, getAccessor.parameters, undefined, getAccessor.body, getAccessor);
- setOriginalNode(getterFunction, getAccessor);
- var getter = createPropertyAssignment("get", getterFunction);
+ var getterFunction = ts.createFunctionExpression(getAccessor.modifiers, undefined, undefined, undefined, getAccessor.parameters, undefined, getAccessor.body);
+ ts.setTextRange(getterFunction, getAccessor);
+ ts.setOriginalNode(getterFunction, getAccessor);
+ var getter = ts.createPropertyAssignment("get", getterFunction);
properties_1.push(getter);
}
if (setAccessor) {
- var setterFunction = createFunctionExpression(setAccessor.modifiers, undefined, undefined, undefined, setAccessor.parameters, undefined, setAccessor.body, setAccessor);
- setOriginalNode(setterFunction, setAccessor);
- var setter = createPropertyAssignment("set", setterFunction);
+ var setterFunction = ts.createFunctionExpression(setAccessor.modifiers, undefined, undefined, undefined, setAccessor.parameters, undefined, setAccessor.body);
+ ts.setTextRange(setterFunction, setAccessor);
+ ts.setOriginalNode(setterFunction, setAccessor);
+ var setter = ts.createPropertyAssignment("set", setterFunction);
properties_1.push(setter);
}
- properties_1.push(createPropertyAssignment("enumerable", createLiteral(true)));
- properties_1.push(createPropertyAssignment("configurable", createLiteral(true)));
- var expression = createCall(createPropertyAccess(createIdentifier("Object"), "defineProperty"), undefined, [
+ properties_1.push(ts.createPropertyAssignment("enumerable", ts.createTrue()));
+ properties_1.push(ts.createPropertyAssignment("configurable", ts.createTrue()));
+ var expression = ts.setTextRange(ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Object"), "defineProperty"), undefined, [
receiver,
createExpressionForPropertyName(property.name),
- createObjectLiteral(properties_1, undefined, multiLine)
- ], firstAccessor);
+ ts.createObjectLiteral(properties_1, multiLine)
+ ]), firstAccessor);
return ts.aggregateTransformFlags(expression);
}
return undefined;
}
function createExpressionForPropertyAssignment(property, receiver) {
- return ts.aggregateTransformFlags(setOriginalNode(createAssignment(createMemberAccessForPropertyName(receiver, property.name, property.name), property.initializer, property), property));
+ return ts.aggregateTransformFlags(ts.setOriginalNode(ts.setTextRange(ts.createAssignment(createMemberAccessForPropertyName(receiver, property.name, property.name), property.initializer), property), property));
}
function createExpressionForShorthandPropertyAssignment(property, receiver) {
- return ts.aggregateTransformFlags(setOriginalNode(createAssignment(createMemberAccessForPropertyName(receiver, property.name, property.name), getSynthesizedClone(property.name), property), property));
+ return ts.aggregateTransformFlags(ts.setOriginalNode(ts.setTextRange(ts.createAssignment(createMemberAccessForPropertyName(receiver, property.name, property.name), ts.getSynthesizedClone(property.name)), property), property));
}
function createExpressionForMethodDeclaration(method, receiver) {
- return ts.aggregateTransformFlags(setOriginalNode(createAssignment(createMemberAccessForPropertyName(receiver, method.name, method.name), setOriginalNode(createFunctionExpression(method.modifiers, method.asteriskToken, undefined, undefined, method.parameters, undefined, method.body, method), method), method), method));
+ return ts.aggregateTransformFlags(ts.setOriginalNode(ts.setTextRange(ts.createAssignment(createMemberAccessForPropertyName(receiver, method.name, method.name), ts.setOriginalNode(ts.setTextRange(ts.createFunctionExpression(method.modifiers, method.asteriskToken, undefined, undefined, method.parameters, undefined, method.body), method), method)), method), method));
}
function getLocalName(node, allowComments, allowSourceMaps) {
return getName(node, allowComments, allowSourceMaps, 16384);
}
ts.getLocalName = getLocalName;
function isLocalName(node) {
- return (getEmitFlags(node) & 16384) !== 0;
+ return (ts.getEmitFlags(node) & 16384) !== 0;
}
ts.isLocalName = isLocalName;
function getExportName(node, allowComments, allowSourceMaps) {
@@ -10246,7 +11213,7 @@ var ts;
}
ts.getExportName = getExportName;
function isExportName(node) {
- return (getEmitFlags(node) & 8192) !== 0;
+ return (ts.getEmitFlags(node) & 8192) !== 0;
}
ts.isExportName = isExportName;
function getDeclarationName(node, allowComments, allowSourceMaps) {
@@ -10255,17 +11222,17 @@ var ts;
ts.getDeclarationName = getDeclarationName;
function getName(node, allowComments, allowSourceMaps, emitFlags) {
if (node.name && ts.isIdentifier(node.name) && !ts.isGeneratedIdentifier(node.name)) {
- var name_8 = getMutableClone(node.name);
- emitFlags |= getEmitFlags(node.name);
+ var name = ts.getMutableClone(node.name);
+ emitFlags |= ts.getEmitFlags(node.name);
if (!allowSourceMaps)
emitFlags |= 48;
if (!allowComments)
emitFlags |= 1536;
if (emitFlags)
- setEmitFlags(name_8, emitFlags);
- return name_8;
+ ts.setEmitFlags(name, emitFlags);
+ return name;
}
- return getGeneratedNameForNode(node);
+ return ts.getGeneratedNameForNode(node);
}
function getExternalModuleOrNamespaceExportName(ns, node, allowComments, allowSourceMaps) {
if (ns && ts.hasModifier(node, 1)) {
@@ -10275,25 +11242,31 @@ var ts;
}
ts.getExternalModuleOrNamespaceExportName = getExternalModuleOrNamespaceExportName;
function getNamespaceMemberName(ns, name, allowComments, allowSourceMaps) {
- var qualifiedName = createPropertyAccess(ns, ts.nodeIsSynthesized(name) ? name : getSynthesizedClone(name), name);
+ var qualifiedName = ts.createPropertyAccess(ns, ts.nodeIsSynthesized(name) ? name : ts.getSynthesizedClone(name));
+ ts.setTextRange(qualifiedName, name);
var emitFlags;
if (!allowSourceMaps)
emitFlags |= 48;
if (!allowComments)
emitFlags |= 1536;
if (emitFlags)
- setEmitFlags(qualifiedName, emitFlags);
+ ts.setEmitFlags(qualifiedName, emitFlags);
return qualifiedName;
}
ts.getNamespaceMemberName = getNamespaceMemberName;
function convertToFunctionBody(node, multiLine) {
- return ts.isBlock(node) ? node : createBlock([createReturn(node, node)], node, multiLine);
+ return ts.isBlock(node) ? node : ts.setTextRange(ts.createBlock([ts.setTextRange(ts.createReturn(node), node)], multiLine), node);
}
ts.convertToFunctionBody = convertToFunctionBody;
function isUseStrictPrologue(node) {
return node.expression.text === "use strict";
}
- function addPrologueDirectives(target, source, ensureUseStrict, visitor) {
+ function addPrologue(target, source, ensureUseStrict, visitor) {
+ var offset = addStandardPrologue(target, source, ensureUseStrict);
+ return addCustomPrologue(target, source, offset, visitor);
+ }
+ ts.addPrologue = addPrologue;
+ function addStandardPrologue(target, source, ensureUseStrict) {
ts.Debug.assert(target.length === 0, "Prologue directives should be at the first statement in the target statements array");
var foundUseStrict = false;
var statementOffset = 0;
@@ -10312,11 +11285,16 @@ var ts;
statementOffset++;
}
if (ensureUseStrict && !foundUseStrict) {
- target.push(startOnNewLine(createStatement(createLiteral("use strict"))));
+ target.push(startOnNewLine(ts.createStatement(ts.createLiteral("use strict"))));
}
+ return statementOffset;
+ }
+ ts.addStandardPrologue = addStandardPrologue;
+ function addCustomPrologue(target, source, statementOffset, visitor) {
+ var numStatements = source.length;
while (statementOffset < numStatements) {
var statement = source[statementOffset];
- if (getEmitFlags(statement) & 524288) {
+ if (ts.getEmitFlags(statement) & 524288) {
target.push(visitor ? ts.visitNode(statement, visitor, ts.isStatement) : statement);
}
else {
@@ -10326,7 +11304,7 @@ var ts;
}
return statementOffset;
}
- ts.addPrologueDirectives = addPrologueDirectives;
+ ts.addCustomPrologue = addCustomPrologue;
function startsWithUseStrict(statements) {
var firstStatement = ts.firstOrUndefined(statements);
return firstStatement !== undefined
@@ -10349,33 +11327,43 @@ var ts;
}
}
if (!foundUseStrict) {
- return createNodeArray([
- startOnNewLine(createStatement(createLiteral("use strict")))
- ].concat(statements), statements);
+ return ts.setTextRange(ts.createNodeArray([
+ startOnNewLine(ts.createStatement(ts.createLiteral("use strict")))
+ ].concat(statements)), statements);
}
return statements;
}
ts.ensureUseStrict = ensureUseStrict;
+ function parenthesizeConditionalHead(condition) {
+ var conditionalPrecedence = ts.getOperatorPrecedence(194, 54);
+ var emittedCondition = skipPartiallyEmittedExpressions(condition);
+ var conditionPrecedence = ts.getExpressionPrecedence(emittedCondition);
+ if (ts.compareValues(conditionPrecedence, conditionalPrecedence) === -1) {
+ return ts.createParen(condition);
+ }
+ return condition;
+ }
+ ts.parenthesizeConditionalHead = parenthesizeConditionalHead;
function parenthesizeBinaryOperand(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
var skipped = skipPartiallyEmittedExpressions(operand);
- if (skipped.kind === 183) {
+ if (skipped.kind === 184) {
return operand;
}
return binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand)
- ? createParen(operand)
+ ? ts.createParen(operand)
: operand;
}
ts.parenthesizeBinaryOperand = parenthesizeBinaryOperand;
function binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
- var binaryOperatorPrecedence = ts.getOperatorPrecedence(192, binaryOperator);
- var binaryOperatorAssociativity = ts.getOperatorAssociativity(192, binaryOperator);
+ var binaryOperatorPrecedence = ts.getOperatorPrecedence(193, binaryOperator);
+ var binaryOperatorAssociativity = ts.getOperatorAssociativity(193, binaryOperator);
var emittedOperand = skipPartiallyEmittedExpressions(operand);
var operandPrecedence = ts.getExpressionPrecedence(emittedOperand);
switch (ts.compareValues(operandPrecedence, binaryOperatorPrecedence)) {
case -1:
if (!isLeftSideOfBinary
&& binaryOperatorAssociativity === 1
- && operand.kind === 195) {
+ && operand.kind === 196) {
return false;
}
return true;
@@ -10414,7 +11402,7 @@ var ts;
if (ts.isLiteralKind(node.kind)) {
return node.kind;
}
- if (node.kind === 192 && node.operatorToken.kind === 36) {
+ if (node.kind === 193 && node.operatorToken.kind === 36) {
if (node.cachedLiteralKind !== undefined) {
return node.cachedLiteralKind;
}
@@ -10429,29 +11417,30 @@ var ts;
return 0;
}
function parenthesizeForConditionalHead(condition) {
- var conditionalPrecedence = ts.getOperatorPrecedence(193, 54);
+ var conditionalPrecedence = ts.getOperatorPrecedence(194, 54);
var emittedCondition = skipPartiallyEmittedExpressions(condition);
var conditionPrecedence = ts.getExpressionPrecedence(emittedCondition);
if (ts.compareValues(conditionPrecedence, conditionalPrecedence) === -1) {
- return createParen(condition);
+ return ts.createParen(condition);
}
return condition;
}
ts.parenthesizeForConditionalHead = parenthesizeForConditionalHead;
function parenthesizeSubexpressionOfConditionalExpression(e) {
- return e.kind === 192 && e.operatorToken.kind === 25
- ? createParen(e)
+ return e.kind === 193 && e.operatorToken.kind === 25
+ ? ts.createParen(e)
: e;
}
+ ts.parenthesizeSubexpressionOfConditionalExpression = parenthesizeSubexpressionOfConditionalExpression;
function parenthesizeForNew(expression) {
var emittedExpression = skipPartiallyEmittedExpressions(expression);
switch (emittedExpression.kind) {
- case 179:
- return createParen(expression);
case 180:
+ return ts.createParen(expression);
+ case 181:
return emittedExpression.arguments
? expression
- : createParen(expression);
+ : ts.createParen(expression);
}
return parenthesizeForAccess(expression);
}
@@ -10459,23 +11448,22 @@ var ts;
function parenthesizeForAccess(expression) {
var emittedExpression = skipPartiallyEmittedExpressions(expression);
if (ts.isLeftHandSideExpression(emittedExpression)
- && (emittedExpression.kind !== 180 || emittedExpression.arguments)
- && emittedExpression.kind !== 8) {
+ && (emittedExpression.kind !== 181 || emittedExpression.arguments)) {
return expression;
}
- return createParen(expression, expression);
+ return ts.setTextRange(ts.createParen(expression), expression);
}
ts.parenthesizeForAccess = parenthesizeForAccess;
function parenthesizePostfixOperand(operand) {
return ts.isLeftHandSideExpression(operand)
? operand
- : createParen(operand, operand);
+ : ts.setTextRange(ts.createParen(operand), operand);
}
ts.parenthesizePostfixOperand = parenthesizePostfixOperand;
function parenthesizePrefixOperand(operand) {
return ts.isUnaryExpression(operand)
? operand
- : createParen(operand, operand);
+ : ts.setTextRange(ts.createParen(operand), operand);
}
ts.parenthesizePrefixOperand = parenthesizePrefixOperand;
function parenthesizeListElements(elements) {
@@ -10490,17 +11478,18 @@ var ts;
}
}
if (result !== undefined) {
- return createNodeArray(result, elements, elements.hasTrailingComma);
+ return ts.setTextRange(ts.createNodeArray(result, elements.hasTrailingComma), elements);
}
return elements;
}
+ ts.parenthesizeListElements = parenthesizeListElements;
function parenthesizeExpressionForList(expression) {
var emittedExpression = skipPartiallyEmittedExpressions(expression);
var expressionPrecedence = ts.getExpressionPrecedence(emittedExpression);
- var commaPrecedence = ts.getOperatorPrecedence(192, 25);
+ var commaPrecedence = ts.getOperatorPrecedence(193, 25);
return expressionPrecedence > commaPrecedence
? expression
- : createParen(expression, expression);
+ : ts.setTextRange(ts.createParen(expression), expression);
}
ts.parenthesizeExpressionForList = parenthesizeExpressionForList;
function parenthesizeExpressionForExpressionStatement(expression) {
@@ -10508,16 +11497,16 @@ var ts;
if (ts.isCallExpression(emittedExpression)) {
var callee = emittedExpression.expression;
var kind = skipPartiallyEmittedExpressions(callee).kind;
- if (kind === 184 || kind === 185) {
- var mutableCall = getMutableClone(emittedExpression);
- mutableCall.expression = createParen(callee, callee);
+ if (kind === 185 || kind === 186) {
+ var mutableCall = ts.getMutableClone(emittedExpression);
+ mutableCall.expression = ts.setTextRange(ts.createParen(callee), callee);
return recreatePartiallyEmittedExpressions(expression, mutableCall);
}
}
else {
var leftmostExpressionKind = getLeftmostExpression(emittedExpression).kind;
- if (leftmostExpressionKind === 176 || leftmostExpressionKind === 184) {
- return createParen(expression, expression);
+ if (leftmostExpressionKind === 177 || leftmostExpressionKind === 185) {
+ return ts.setTextRange(ts.createParen(expression), expression);
}
}
return expression;
@@ -10525,7 +11514,7 @@ var ts;
ts.parenthesizeExpressionForExpressionStatement = parenthesizeExpressionForExpressionStatement;
function recreatePartiallyEmittedExpressions(originalOuterExpression, newInnerExpression) {
if (ts.isPartiallyEmittedExpression(originalOuterExpression)) {
- var clone_1 = getMutableClone(originalOuterExpression);
+ var clone_1 = ts.getMutableClone(originalOuterExpression);
clone_1.expression = recreatePartiallyEmittedExpressions(clone_1.expression, newInnerExpression);
return clone_1;
}
@@ -10534,21 +11523,21 @@ var ts;
function getLeftmostExpression(node) {
while (true) {
switch (node.kind) {
- case 191:
+ case 192:
node = node.operand;
continue;
- case 192:
+ case 193:
node = node.left;
continue;
- case 193:
+ case 194:
node = node.condition;
continue;
+ case 180:
case 179:
case 178:
- case 177:
node = node.expression;
continue;
- case 294:
+ case 295:
node = node.expression;
continue;
}
@@ -10556,9 +11545,8 @@ var ts;
}
}
function parenthesizeConciseBody(body) {
- var emittedBody = skipPartiallyEmittedExpressions(body);
- if (emittedBody.kind === 176) {
- return createParen(body, body);
+ if (!ts.isBlock(body) && getLeftmostExpression(body).kind === 177) {
+ return ts.setTextRange(ts.createParen(body), body);
}
return body;
}
@@ -10582,7 +11570,7 @@ var ts;
}
ts.skipOuterExpressions = skipOuterExpressions;
function skipParentheses(node) {
- while (node.kind === 183) {
+ while (node.kind === 184) {
node = node.expression;
}
return node;
@@ -10596,7 +11584,7 @@ var ts;
}
ts.skipAssertions = skipAssertions;
function skipPartiallyEmittedExpressions(node) {
- while (node.kind === 294) {
+ while (node.kind === 295) {
node = node.expression;
}
return node;
@@ -10607,120 +11595,6 @@ var ts;
return node;
}
ts.startOnNewLine = startOnNewLine;
- function setOriginalNode(node, original) {
- node.original = original;
- if (original) {
- var emitNode = original.emitNode;
- if (emitNode)
- node.emitNode = mergeEmitNode(emitNode, node.emitNode);
- }
- return node;
- }
- ts.setOriginalNode = setOriginalNode;
- function mergeEmitNode(sourceEmitNode, destEmitNode) {
- var flags = sourceEmitNode.flags, commentRange = sourceEmitNode.commentRange, sourceMapRange = sourceEmitNode.sourceMapRange, tokenSourceMapRanges = sourceEmitNode.tokenSourceMapRanges, constantValue = sourceEmitNode.constantValue, helpers = sourceEmitNode.helpers;
- if (!destEmitNode)
- destEmitNode = {};
- if (flags)
- destEmitNode.flags = flags;
- if (commentRange)
- destEmitNode.commentRange = commentRange;
- if (sourceMapRange)
- destEmitNode.sourceMapRange = sourceMapRange;
- if (tokenSourceMapRanges)
- destEmitNode.tokenSourceMapRanges = mergeTokenSourceMapRanges(tokenSourceMapRanges, destEmitNode.tokenSourceMapRanges);
- if (constantValue !== undefined)
- destEmitNode.constantValue = constantValue;
- if (helpers)
- destEmitNode.helpers = ts.addRange(destEmitNode.helpers, helpers);
- return destEmitNode;
- }
- function mergeTokenSourceMapRanges(sourceRanges, destRanges) {
- if (!destRanges)
- destRanges = ts.createMap();
- ts.copyProperties(sourceRanges, destRanges);
- return destRanges;
- }
- function disposeEmitNodes(sourceFile) {
- sourceFile = ts.getSourceFileOfNode(ts.getParseTreeNode(sourceFile));
- var emitNode = sourceFile && sourceFile.emitNode;
- var annotatedNodes = emitNode && emitNode.annotatedNodes;
- if (annotatedNodes) {
- for (var _i = 0, annotatedNodes_1 = annotatedNodes; _i < annotatedNodes_1.length; _i++) {
- var node = annotatedNodes_1[_i];
- node.emitNode = undefined;
- }
- }
- }
- ts.disposeEmitNodes = disposeEmitNodes;
- function getOrCreateEmitNode(node) {
- if (!node.emitNode) {
- if (ts.isParseTreeNode(node)) {
- if (node.kind === 261) {
- return node.emitNode = { annotatedNodes: [node] };
- }
- var sourceFile = ts.getSourceFileOfNode(node);
- getOrCreateEmitNode(sourceFile).annotatedNodes.push(node);
- }
- node.emitNode = {};
- }
- return node.emitNode;
- }
- ts.getOrCreateEmitNode = getOrCreateEmitNode;
- function getEmitFlags(node) {
- var emitNode = node.emitNode;
- return emitNode && emitNode.flags;
- }
- ts.getEmitFlags = getEmitFlags;
- function setEmitFlags(node, emitFlags) {
- getOrCreateEmitNode(node).flags = emitFlags;
- return node;
- }
- ts.setEmitFlags = setEmitFlags;
- function getSourceMapRange(node) {
- var emitNode = node.emitNode;
- return (emitNode && emitNode.sourceMapRange) || node;
- }
- ts.getSourceMapRange = getSourceMapRange;
- function setSourceMapRange(node, range) {
- getOrCreateEmitNode(node).sourceMapRange = range;
- return node;
- }
- ts.setSourceMapRange = setSourceMapRange;
- function getTokenSourceMapRange(node, token) {
- var emitNode = node.emitNode;
- var tokenSourceMapRanges = emitNode && emitNode.tokenSourceMapRanges;
- return tokenSourceMapRanges && tokenSourceMapRanges[token];
- }
- ts.getTokenSourceMapRange = getTokenSourceMapRange;
- function setTokenSourceMapRange(node, token, range) {
- var emitNode = getOrCreateEmitNode(node);
- var tokenSourceMapRanges = emitNode.tokenSourceMapRanges || (emitNode.tokenSourceMapRanges = ts.createMap());
- tokenSourceMapRanges[token] = range;
- return node;
- }
- ts.setTokenSourceMapRange = setTokenSourceMapRange;
- function getCommentRange(node) {
- var emitNode = node.emitNode;
- return (emitNode && emitNode.commentRange) || node;
- }
- ts.getCommentRange = getCommentRange;
- function setCommentRange(node, range) {
- getOrCreateEmitNode(node).commentRange = range;
- return node;
- }
- ts.setCommentRange = setCommentRange;
- function getConstantValue(node) {
- var emitNode = node.emitNode;
- return emitNode && emitNode.constantValue;
- }
- ts.getConstantValue = getConstantValue;
- function setConstantValue(node, value) {
- var emitNode = getOrCreateEmitNode(node);
- emitNode.constantValue = value;
- return node;
- }
- ts.setConstantValue = setConstantValue;
function getExternalHelpersModuleName(node) {
var parseNode = ts.getOriginalNode(node, ts.isSourceFile);
var emitNode = parseNode && parseNode.emitNode;
@@ -10733,125 +11607,31 @@ var ts;
if (externalHelpersModuleName) {
return externalHelpersModuleName;
}
- var helpers = getEmitHelpers(node);
+ var helpers = ts.getEmitHelpers(node);
if (helpers) {
- for (var _i = 0, helpers_1 = helpers; _i < helpers_1.length; _i++) {
- var helper = helpers_1[_i];
+ for (var _i = 0, helpers_2 = helpers; _i < helpers_2.length; _i++) {
+ var helper = helpers_2[_i];
if (!helper.scoped) {
var parseNode = ts.getOriginalNode(node, ts.isSourceFile);
- var emitNode = getOrCreateEmitNode(parseNode);
- return emitNode.externalHelpersModuleName || (emitNode.externalHelpersModuleName = createUniqueName(ts.externalHelpersModuleNameText));
+ var emitNode = ts.getOrCreateEmitNode(parseNode);
+ return emitNode.externalHelpersModuleName || (emitNode.externalHelpersModuleName = ts.createUniqueName(ts.externalHelpersModuleNameText));
}
}
}
}
}
ts.getOrCreateExternalHelpersModuleNameIfNeeded = getOrCreateExternalHelpersModuleNameIfNeeded;
- function addEmitHelper(node, helper) {
- var emitNode = getOrCreateEmitNode(node);
- emitNode.helpers = ts.append(emitNode.helpers, helper);
- return node;
- }
- ts.addEmitHelper = addEmitHelper;
- function addEmitHelpers(node, helpers) {
- if (ts.some(helpers)) {
- var emitNode = getOrCreateEmitNode(node);
- for (var _i = 0, helpers_2 = helpers; _i < helpers_2.length; _i++) {
- var helper = helpers_2[_i];
- if (!ts.contains(emitNode.helpers, helper)) {
- emitNode.helpers = ts.append(emitNode.helpers, helper);
- }
- }
- }
- return node;
- }
- ts.addEmitHelpers = addEmitHelpers;
- function removeEmitHelper(node, helper) {
- var emitNode = node.emitNode;
- if (emitNode) {
- var helpers = emitNode.helpers;
- if (helpers) {
- return ts.orderedRemoveItem(helpers, helper);
- }
- }
- return false;
- }
- ts.removeEmitHelper = removeEmitHelper;
- function getEmitHelpers(node) {
- var emitNode = node.emitNode;
- return emitNode && emitNode.helpers;
- }
- ts.getEmitHelpers = getEmitHelpers;
- function moveEmitHelpers(source, target, predicate) {
- var sourceEmitNode = source.emitNode;
- var sourceEmitHelpers = sourceEmitNode && sourceEmitNode.helpers;
- if (!ts.some(sourceEmitHelpers))
- return;
- var targetEmitNode = getOrCreateEmitNode(target);
- var helpersRemoved = 0;
- for (var i = 0; i < sourceEmitHelpers.length; i++) {
- var helper = sourceEmitHelpers[i];
- if (predicate(helper)) {
- helpersRemoved++;
- if (!ts.contains(targetEmitNode.helpers, helper)) {
- targetEmitNode.helpers = ts.append(targetEmitNode.helpers, helper);
- }
- }
- else if (helpersRemoved > 0) {
- sourceEmitHelpers[i - helpersRemoved] = helper;
- }
- }
- if (helpersRemoved > 0) {
- sourceEmitHelpers.length -= helpersRemoved;
- }
- }
- ts.moveEmitHelpers = moveEmitHelpers;
- function compareEmitHelpers(x, y) {
- if (x === y)
- return 0;
- if (x.priority === y.priority)
- return 0;
- if (x.priority === undefined)
- return 1;
- if (y.priority === undefined)
- return -1;
- return ts.compareValues(x.priority, y.priority);
- }
- ts.compareEmitHelpers = compareEmitHelpers;
- function setTextRange(node, location) {
- if (location) {
- node.pos = location.pos;
- node.end = location.end;
- }
- return node;
- }
- ts.setTextRange = setTextRange;
- function setNodeFlags(node, flags) {
- node.flags = flags;
- return node;
- }
- ts.setNodeFlags = setNodeFlags;
- function setMultiLine(node, multiLine) {
- node.multiLine = multiLine;
- return node;
- }
- ts.setMultiLine = setMultiLine;
- function setHasTrailingComma(nodes, hasTrailingComma) {
- nodes.hasTrailingComma = hasTrailingComma;
- return nodes;
- }
- ts.setHasTrailingComma = setHasTrailingComma;
function getLocalNameForExternalImport(node, sourceFile) {
var namespaceDeclaration = ts.getNamespaceDeclarationNode(node);
if (namespaceDeclaration && !ts.isDefaultImport(node)) {
- var name_9 = namespaceDeclaration.name;
- return ts.isGeneratedIdentifier(name_9) ? name_9 : createIdentifier(ts.getSourceTextOfNodeFromSourceFile(sourceFile, namespaceDeclaration.name));
+ var name = namespaceDeclaration.name;
+ return ts.isGeneratedIdentifier(name) ? name : ts.createIdentifier(ts.getSourceTextOfNodeFromSourceFile(sourceFile, namespaceDeclaration.name));
}
- if (node.kind === 235 && node.importClause) {
- return getGeneratedNameForNode(node);
+ if (node.kind === 237 && node.importClause) {
+ return ts.getGeneratedNameForNode(node);
}
- if (node.kind === 241 && node.moduleSpecifier) {
- return getGeneratedNameForNode(node);
+ if (node.kind === 243 && node.moduleSpecifier) {
+ return ts.getGeneratedNameForNode(node);
}
return undefined;
}
@@ -10861,26 +11641,24 @@ var ts;
if (moduleName.kind === 9) {
return tryGetModuleNameFromDeclaration(importNode, host, resolver, compilerOptions)
|| tryRenameExternalModule(moduleName, sourceFile)
- || getSynthesizedClone(moduleName);
+ || ts.getSynthesizedClone(moduleName);
}
return undefined;
}
ts.getExternalModuleNameLiteral = getExternalModuleNameLiteral;
function tryRenameExternalModule(moduleName, sourceFile) {
- if (sourceFile.renamedDependencies && ts.hasProperty(sourceFile.renamedDependencies, moduleName.text)) {
- return createLiteral(sourceFile.renamedDependencies[moduleName.text]);
- }
- return undefined;
+ var rename = sourceFile.renamedDependencies && sourceFile.renamedDependencies.get(moduleName.text);
+ return rename && ts.createLiteral(rename);
}
function tryGetModuleNameFromFile(file, host, options) {
if (!file) {
return undefined;
}
if (file.moduleName) {
- return createLiteral(file.moduleName);
+ return ts.createLiteral(file.moduleName);
}
if (!ts.isDeclarationFile(file) && (options.out || options.outFile)) {
- return createLiteral(ts.getExternalModuleNameFromPath(host, file.fileName));
+ return ts.createLiteral(ts.getExternalModuleNameFromPath(host, file.fileName));
}
return undefined;
}
@@ -10914,11 +11692,11 @@ var ts;
}
if (ts.isObjectLiteralElementLike(bindingElement)) {
switch (bindingElement.kind) {
- case 257:
+ case 260:
return getTargetOfBindingOrAssignmentElement(bindingElement.initializer);
- case 258:
+ case 261:
return bindingElement.name;
- case 259:
+ case 262:
return getTargetOfBindingOrAssignmentElement(bindingElement.expression);
}
return undefined;
@@ -10934,11 +11712,11 @@ var ts;
ts.getTargetOfBindingOrAssignmentElement = getTargetOfBindingOrAssignmentElement;
function getRestIndicatorOfBindingOrAssignmentElement(bindingElement) {
switch (bindingElement.kind) {
- case 144:
- case 174:
+ case 145:
+ case 175:
return bindingElement.dotDotDotToken;
- case 196:
- case 259:
+ case 197:
+ case 262:
return bindingElement;
}
return undefined;
@@ -10946,7 +11724,7 @@ var ts;
ts.getRestIndicatorOfBindingOrAssignmentElement = getRestIndicatorOfBindingOrAssignmentElement;
function getPropertyNameOfBindingOrAssignmentElement(bindingElement) {
switch (bindingElement.kind) {
- case 174:
+ case 175:
if (bindingElement.propertyName) {
var propertyName = bindingElement.propertyName;
return ts.isComputedPropertyName(propertyName) && ts.isStringOrNumericLiteral(propertyName.expression)
@@ -10954,7 +11732,7 @@ var ts;
: propertyName;
}
break;
- case 257:
+ case 260:
if (bindingElement.name) {
var propertyName = bindingElement.name;
return ts.isComputedPropertyName(propertyName) && ts.isStringOrNumericLiteral(propertyName.expression)
@@ -10962,7 +11740,7 @@ var ts;
: propertyName;
}
break;
- case 259:
+ case 262:
return bindingElement.name;
}
var target = getTargetOfBindingOrAssignmentElement(bindingElement);
@@ -10976,11 +11754,11 @@ var ts;
ts.getPropertyNameOfBindingOrAssignmentElement = getPropertyNameOfBindingOrAssignmentElement;
function getElementsOfBindingOrAssignmentPattern(name) {
switch (name.kind) {
- case 172:
case 173:
- case 175:
- return name.elements;
+ case 174:
case 176:
+ return name.elements;
+ case 177:
return name.properties;
}
}
@@ -10989,10 +11767,12 @@ var ts;
if (ts.isBindingElement(element)) {
if (element.dotDotDotToken) {
ts.Debug.assertNode(element.name, ts.isIdentifier);
- return setOriginalNode(createSpread(element.name, element), element);
+ return ts.setOriginalNode(ts.setTextRange(ts.createSpread(element.name), element), element);
}
var expression = convertToAssignmentElementTarget(element.name);
- return element.initializer ? setOriginalNode(createAssignment(expression, element.initializer, element), element) : expression;
+ return element.initializer
+ ? ts.setOriginalNode(ts.setTextRange(ts.createAssignment(expression, element.initializer), element), element)
+ : expression;
}
ts.Debug.assertNode(element, ts.isExpression);
return element;
@@ -11002,14 +11782,14 @@ var ts;
if (ts.isBindingElement(element)) {
if (element.dotDotDotToken) {
ts.Debug.assertNode(element.name, ts.isIdentifier);
- return setOriginalNode(createSpreadAssignment(element.name, element), element);
+ return ts.setOriginalNode(ts.setTextRange(ts.createSpreadAssignment(element.name), element), element);
}
if (element.propertyName) {
var expression = convertToAssignmentElementTarget(element.name);
- return setOriginalNode(createPropertyAssignment(element.propertyName, element.initializer ? createAssignment(expression, element.initializer) : expression, element), element);
+ return ts.setOriginalNode(ts.setTextRange(ts.createPropertyAssignment(element.propertyName, element.initializer ? ts.createAssignment(expression, element.initializer) : expression), element), element);
}
ts.Debug.assertNode(element.name, ts.isIdentifier);
- return setOriginalNode(createShorthandPropertyAssignment(element.name, element.initializer, element), element);
+ return ts.setOriginalNode(ts.setTextRange(ts.createShorthandPropertyAssignment(element.name, element.initializer), element), element);
}
ts.Debug.assertNode(element, ts.isObjectLiteralElementLike);
return element;
@@ -11017,18 +11797,18 @@ var ts;
ts.convertToObjectAssignmentElement = convertToObjectAssignmentElement;
function convertToAssignmentPattern(node) {
switch (node.kind) {
- case 173:
- case 175:
- return convertToArrayAssignmentPattern(node);
- case 172:
+ case 174:
case 176:
+ return convertToArrayAssignmentPattern(node);
+ case 173:
+ case 177:
return convertToObjectAssignmentPattern(node);
}
}
ts.convertToAssignmentPattern = convertToAssignmentPattern;
function convertToObjectAssignmentPattern(node) {
if (ts.isObjectBindingPattern(node)) {
- return setOriginalNode(createObjectLiteral(ts.map(node.elements, convertToObjectAssignmentElement), node), node);
+ return ts.setOriginalNode(ts.setTextRange(ts.createObjectLiteral(ts.map(node.elements, convertToObjectAssignmentElement)), node), node);
}
ts.Debug.assertNode(node, ts.isObjectLiteralExpression);
return node;
@@ -11036,7 +11816,7 @@ var ts;
ts.convertToObjectAssignmentPattern = convertToObjectAssignmentPattern;
function convertToArrayAssignmentPattern(node) {
if (ts.isArrayBindingPattern(node)) {
- return setOriginalNode(createArrayLiteral(ts.map(node.elements, convertToArrayAssignmentElement), node), node);
+ return ts.setOriginalNode(ts.setTextRange(ts.createArrayLiteral(ts.map(node.elements, convertToArrayAssignmentElement)), node), node);
}
ts.Debug.assertNode(node, ts.isArrayLiteralExpression);
return node;
@@ -11052,30 +11832,30 @@ var ts;
ts.convertToAssignmentElementTarget = convertToAssignmentElementTarget;
function collectExternalModuleInfo(sourceFile, resolver, compilerOptions) {
var externalImports = [];
- var exportSpecifiers = ts.createMap();
- var exportedBindings = ts.createMap();
+ var exportSpecifiers = ts.createMultiMap();
+ var exportedBindings = [];
var uniqueExports = ts.createMap();
var exportedNames;
var hasExportDefault = false;
var exportEquals = undefined;
var hasExportStarsToExportValues = false;
var externalHelpersModuleName = getOrCreateExternalHelpersModuleNameIfNeeded(sourceFile, compilerOptions);
- var externalHelpersImportDeclaration = externalHelpersModuleName && createImportDeclaration(undefined, undefined, createImportClause(undefined, createNamespaceImport(externalHelpersModuleName)), createLiteral(ts.externalHelpersModuleNameText));
+ var externalHelpersImportDeclaration = externalHelpersModuleName && ts.createImportDeclaration(undefined, undefined, ts.createImportClause(undefined, ts.createNamespaceImport(externalHelpersModuleName)), ts.createLiteral(ts.externalHelpersModuleNameText));
if (externalHelpersImportDeclaration) {
externalImports.push(externalHelpersImportDeclaration);
}
for (var _i = 0, _a = sourceFile.statements; _i < _a.length; _i++) {
var node = _a[_i];
switch (node.kind) {
- case 235:
+ case 237:
externalImports.push(node);
break;
- case 234:
- if (node.moduleReference.kind === 245) {
+ case 236:
+ if (node.moduleReference.kind === 247) {
externalImports.push(node);
}
break;
- case 241:
+ case 243:
if (node.moduleSpecifier) {
if (!node.exportClause) {
externalImports.push(node);
@@ -11088,26 +11868,26 @@ var ts;
else {
for (var _b = 0, _c = node.exportClause.elements; _b < _c.length; _b++) {
var specifier = _c[_b];
- if (!uniqueExports[specifier.name.text]) {
- var name_10 = specifier.propertyName || specifier.name;
- ts.multiMapAdd(exportSpecifiers, name_10.text, specifier);
- var decl = resolver.getReferencedImportDeclaration(name_10)
- || resolver.getReferencedValueDeclaration(name_10);
+ if (!uniqueExports.get(specifier.name.text)) {
+ var name = specifier.propertyName || specifier.name;
+ exportSpecifiers.add(name.text, specifier);
+ var decl = resolver.getReferencedImportDeclaration(name)
+ || resolver.getReferencedValueDeclaration(name);
if (decl) {
- ts.multiMapAdd(exportedBindings, ts.getOriginalNodeId(decl), specifier.name);
+ multiMapSparseArrayAdd(exportedBindings, ts.getOriginalNodeId(decl), specifier.name);
}
- uniqueExports[specifier.name.text] = true;
+ uniqueExports.set(specifier.name.text, true);
exportedNames = ts.append(exportedNames, specifier.name);
}
}
}
break;
- case 240:
+ case 242:
if (node.isExportEquals && !exportEquals) {
exportEquals = node;
}
break;
- case 205:
+ case 207:
if (ts.hasModifier(node, 1)) {
for (var _d = 0, _e = node.declarationList.declarations; _d < _e.length; _d++) {
var decl = _e[_d];
@@ -11115,38 +11895,38 @@ var ts;
}
}
break;
- case 225:
+ case 227:
if (ts.hasModifier(node, 1)) {
if (ts.hasModifier(node, 512)) {
if (!hasExportDefault) {
- ts.multiMapAdd(exportedBindings, ts.getOriginalNodeId(node), getDeclarationName(node));
+ multiMapSparseArrayAdd(exportedBindings, ts.getOriginalNodeId(node), getDeclarationName(node));
hasExportDefault = true;
}
}
else {
- var name_11 = node.name;
- if (!uniqueExports[name_11.text]) {
- ts.multiMapAdd(exportedBindings, ts.getOriginalNodeId(node), name_11);
- uniqueExports[name_11.text] = true;
- exportedNames = ts.append(exportedNames, name_11);
+ var name = node.name;
+ if (!uniqueExports.get(name.text)) {
+ multiMapSparseArrayAdd(exportedBindings, ts.getOriginalNodeId(node), name);
+ uniqueExports.set(name.text, true);
+ exportedNames = ts.append(exportedNames, name);
}
}
}
break;
- case 226:
+ case 228:
if (ts.hasModifier(node, 1)) {
if (ts.hasModifier(node, 512)) {
if (!hasExportDefault) {
- ts.multiMapAdd(exportedBindings, ts.getOriginalNodeId(node), getDeclarationName(node));
+ multiMapSparseArrayAdd(exportedBindings, ts.getOriginalNodeId(node), getDeclarationName(node));
hasExportDefault = true;
}
}
else {
- var name_12 = node.name;
- if (!uniqueExports[name_12.text]) {
- ts.multiMapAdd(exportedBindings, ts.getOriginalNodeId(node), name_12);
- uniqueExports[name_12.text] = true;
- exportedNames = ts.append(exportedNames, name_12);
+ var name = node.name;
+ if (!uniqueExports.get(name.text)) {
+ multiMapSparseArrayAdd(exportedBindings, ts.getOriginalNodeId(node), name);
+ uniqueExports.set(name.text, true);
+ exportedNames = ts.append(exportedNames, name);
}
}
}
@@ -11166,13 +11946,23 @@ var ts;
}
}
else if (!ts.isGeneratedIdentifier(decl.name)) {
- if (!uniqueExports[decl.name.text]) {
- uniqueExports[decl.name.text] = true;
+ if (!uniqueExports.get(decl.name.text)) {
+ uniqueExports.set(decl.name.text, true);
exportedNames = ts.append(exportedNames, decl.name);
}
}
return exportedNames;
}
+ function multiMapSparseArrayAdd(map, key, value) {
+ var values = map[key];
+ if (values) {
+ values.push(value);
+ }
+ else {
+ map[key] = values = [value];
+ }
+ return values;
+ }
})(ts || (ts = {}));
var ts;
(function (ts) {
@@ -11181,13 +11971,13 @@ var ts;
var IdentifierConstructor;
var SourceFileConstructor;
function createNode(kind, pos, end) {
- if (kind === 261) {
+ if (kind === 264) {
return new (SourceFileConstructor || (SourceFileConstructor = ts.objectAllocator.getSourceFileConstructor()))(kind, pos, end);
}
else if (kind === 70) {
return new (IdentifierConstructor || (IdentifierConstructor = ts.objectAllocator.getIdentifierConstructor()))(kind, pos, end);
}
- else if (kind < 141) {
+ else if (kind < 142) {
return new (TokenConstructor || (TokenConstructor = ts.objectAllocator.getTokenConstructor()))(kind, pos, end);
}
else {
@@ -11223,28 +12013,29 @@ var ts;
var visitNodes = cbNodeArray ? visitNodeArray : visitEachNode;
var cbNodes = cbNodeArray || cbNode;
switch (node.kind) {
- case 141:
+ case 142:
return visitNode(cbNode, node.left) ||
visitNode(cbNode, node.right);
- case 143:
+ case 144:
return visitNode(cbNode, node.name) ||
visitNode(cbNode, node.constraint) ||
+ visitNode(cbNode, node.default) ||
visitNode(cbNode, node.expression);
- case 258:
+ case 261:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNode(cbNode, node.questionToken) ||
visitNode(cbNode, node.equalsToken) ||
visitNode(cbNode, node.objectAssignmentInitializer);
- case 259:
+ case 262:
return visitNode(cbNode, node.expression);
- case 144:
+ case 145:
+ case 148:
case 147:
- case 146:
- case 257:
- case 223:
- case 174:
+ case 260:
+ case 225:
+ case 175:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.propertyName) ||
@@ -11253,24 +12044,24 @@ var ts;
visitNode(cbNode, node.questionToken) ||
visitNode(cbNode, node.type) ||
visitNode(cbNode, node.initializer);
- case 158:
case 159:
- case 153:
+ case 160:
case 154:
case 155:
+ case 156:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNodes(cbNodes, node.typeParameters) ||
visitNodes(cbNodes, node.parameters) ||
visitNode(cbNode, node.type);
- case 149:
- case 148:
case 150:
+ case 149:
case 151:
case 152:
- case 184:
- case 225:
+ case 153:
case 185:
+ case 227:
+ case 186:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.asteriskToken) ||
@@ -11281,320 +12072,326 @@ var ts;
visitNode(cbNode, node.type) ||
visitNode(cbNode, node.equalsGreaterThanToken) ||
visitNode(cbNode, node.body);
- case 157:
+ case 158:
return visitNode(cbNode, node.typeName) ||
visitNodes(cbNodes, node.typeArguments);
- case 156:
+ case 157:
return visitNode(cbNode, node.parameterName) ||
visitNode(cbNode, node.type);
- case 160:
- return visitNode(cbNode, node.exprName);
case 161:
- return visitNodes(cbNodes, node.members);
+ return visitNode(cbNode, node.exprName);
case 162:
- return visitNode(cbNode, node.elementType);
+ return visitNodes(cbNodes, node.members);
case 163:
- return visitNodes(cbNodes, node.elementTypes);
+ return visitNode(cbNode, node.elementType);
case 164:
+ return visitNodes(cbNodes, node.elementTypes);
case 165:
- return visitNodes(cbNodes, node.types);
case 166:
- case 168:
- return visitNode(cbNode, node.type);
+ return visitNodes(cbNodes, node.types);
+ case 167:
case 169:
+ return visitNode(cbNode, node.type);
+ case 170:
return visitNode(cbNode, node.objectType) ||
visitNode(cbNode, node.indexType);
- case 170:
+ case 171:
return visitNode(cbNode, node.readonlyToken) ||
visitNode(cbNode, node.typeParameter) ||
visitNode(cbNode, node.questionToken) ||
visitNode(cbNode, node.type);
- case 171:
- return visitNode(cbNode, node.literal);
case 172:
+ return visitNode(cbNode, node.literal);
case 173:
- return visitNodes(cbNodes, node.elements);
- case 175:
+ case 174:
return visitNodes(cbNodes, node.elements);
case 176:
- return visitNodes(cbNodes, node.properties);
+ return visitNodes(cbNodes, node.elements);
case 177:
+ return visitNodes(cbNodes, node.properties);
+ case 178:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.name);
- case 178:
+ case 179:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.argumentExpression);
- case 179:
case 180:
+ case 181:
return visitNode(cbNode, node.expression) ||
visitNodes(cbNodes, node.typeArguments) ||
visitNodes(cbNodes, node.arguments);
- case 181:
+ case 182:
return visitNode(cbNode, node.tag) ||
visitNode(cbNode, node.template);
- case 182:
+ case 183:
return visitNode(cbNode, node.type) ||
visitNode(cbNode, node.expression);
- case 183:
- return visitNode(cbNode, node.expression);
- case 186:
+ case 184:
return visitNode(cbNode, node.expression);
case 187:
return visitNode(cbNode, node.expression);
case 188:
return visitNode(cbNode, node.expression);
- case 190:
- return visitNode(cbNode, node.operand);
- case 195:
- return visitNode(cbNode, node.asteriskToken) ||
- visitNode(cbNode, node.expression);
case 189:
return visitNode(cbNode, node.expression);
case 191:
return visitNode(cbNode, node.operand);
+ case 196:
+ return visitNode(cbNode, node.asteriskToken) ||
+ visitNode(cbNode, node.expression);
+ case 190:
+ return visitNode(cbNode, node.expression);
case 192:
+ return visitNode(cbNode, node.operand);
+ case 193:
return visitNode(cbNode, node.left) ||
visitNode(cbNode, node.operatorToken) ||
visitNode(cbNode, node.right);
- case 200:
+ case 201:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.type);
- case 201:
+ case 202:
return visitNode(cbNode, node.expression);
- case 193:
+ case 203:
+ return visitNode(cbNode, node.name);
+ case 194:
return visitNode(cbNode, node.condition) ||
visitNode(cbNode, node.questionToken) ||
visitNode(cbNode, node.whenTrue) ||
visitNode(cbNode, node.colonToken) ||
visitNode(cbNode, node.whenFalse);
- case 196:
+ case 197:
return visitNode(cbNode, node.expression);
- case 204:
- case 231:
+ case 206:
+ case 233:
return visitNodes(cbNodes, node.statements);
- case 261:
+ case 264:
return visitNodes(cbNodes, node.statements) ||
visitNode(cbNode, node.endOfFileToken);
- case 205:
+ case 207:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.declarationList);
- case 224:
+ case 226:
return visitNodes(cbNodes, node.declarations);
- case 207:
+ case 209:
return visitNode(cbNode, node.expression);
- case 208:
+ case 210:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.thenStatement) ||
visitNode(cbNode, node.elseStatement);
- case 209:
+ case 211:
return visitNode(cbNode, node.statement) ||
visitNode(cbNode, node.expression);
- case 210:
+ case 212:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.statement);
- case 211:
+ case 213:
return visitNode(cbNode, node.initializer) ||
visitNode(cbNode, node.condition) ||
visitNode(cbNode, node.incrementor) ||
visitNode(cbNode, node.statement);
- case 212:
+ case 214:
return visitNode(cbNode, node.initializer) ||
visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.statement);
- case 213:
- return visitNode(cbNode, node.initializer) ||
+ case 215:
+ return visitNode(cbNode, node.awaitModifier) ||
+ visitNode(cbNode, node.initializer) ||
visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.statement);
- case 214:
- case 215:
- return visitNode(cbNode, node.label);
case 216:
- return visitNode(cbNode, node.expression);
case 217:
+ return visitNode(cbNode, node.label);
+ case 218:
+ return visitNode(cbNode, node.expression);
+ case 219:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.statement);
- case 218:
+ case 220:
return visitNode(cbNode, node.expression) ||
visitNode(cbNode, node.caseBlock);
- case 232:
+ case 234:
return visitNodes(cbNodes, node.clauses);
- case 253:
+ case 256:
return visitNode(cbNode, node.expression) ||
visitNodes(cbNodes, node.statements);
- case 254:
+ case 257:
return visitNodes(cbNodes, node.statements);
- case 219:
+ case 221:
return visitNode(cbNode, node.label) ||
visitNode(cbNode, node.statement);
- case 220:
+ case 222:
return visitNode(cbNode, node.expression);
- case 221:
+ case 223:
return visitNode(cbNode, node.tryBlock) ||
visitNode(cbNode, node.catchClause) ||
visitNode(cbNode, node.finallyBlock);
- case 256:
+ case 259:
return visitNode(cbNode, node.variableDeclaration) ||
visitNode(cbNode, node.block);
- case 145:
+ case 146:
return visitNode(cbNode, node.expression);
- case 226:
- case 197:
+ case 228:
+ case 198:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNodes(cbNodes, node.typeParameters) ||
visitNodes(cbNodes, node.heritageClauses) ||
visitNodes(cbNodes, node.members);
- case 227:
+ case 229:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNodes(cbNodes, node.typeParameters) ||
visitNodes(cbNodes, node.heritageClauses) ||
visitNodes(cbNodes, node.members);
- case 228:
+ case 230:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNodes(cbNodes, node.typeParameters) ||
visitNode(cbNode, node.type);
- case 229:
+ case 231:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNodes(cbNodes, node.members);
- case 260:
+ case 263:
return visitNode(cbNode, node.name) ||
visitNode(cbNode, node.initializer);
- case 230:
+ case 232:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNode(cbNode, node.body);
- case 234:
+ case 236:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.name) ||
visitNode(cbNode, node.moduleReference);
- case 235:
+ case 237:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.importClause) ||
visitNode(cbNode, node.moduleSpecifier);
- case 236:
+ case 238:
return visitNode(cbNode, node.name) ||
visitNode(cbNode, node.namedBindings);
- case 233:
+ case 235:
return visitNode(cbNode, node.name);
- case 237:
+ case 239:
return visitNode(cbNode, node.name);
- case 238:
- case 242:
+ case 240:
+ case 244:
return visitNodes(cbNodes, node.elements);
- case 241:
+ case 243:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.exportClause) ||
visitNode(cbNode, node.moduleSpecifier);
- case 239:
- case 243:
+ case 241:
+ case 245:
return visitNode(cbNode, node.propertyName) ||
visitNode(cbNode, node.name);
- case 240:
+ case 242:
return visitNodes(cbNodes, node.decorators) ||
visitNodes(cbNodes, node.modifiers) ||
visitNode(cbNode, node.expression);
- case 194:
+ case 195:
return visitNode(cbNode, node.head) || visitNodes(cbNodes, node.templateSpans);
- case 202:
+ case 204:
return visitNode(cbNode, node.expression) || visitNode(cbNode, node.literal);
- case 142:
+ case 143:
return visitNode(cbNode, node.expression);
- case 255:
+ case 258:
return visitNodes(cbNodes, node.types);
- case 199:
+ case 200:
return visitNode(cbNode, node.expression) ||
visitNodes(cbNodes, node.typeArguments);
- case 245:
+ case 247:
return visitNode(cbNode, node.expression);
- case 244:
- return visitNodes(cbNodes, node.decorators);
case 246:
+ return visitNodes(cbNodes, node.decorators);
+ case 248:
return visitNode(cbNode, node.openingElement) ||
visitNodes(cbNodes, node.children) ||
visitNode(cbNode, node.closingElement);
- case 247:
- case 248:
- return visitNode(cbNode, node.tagName) ||
- visitNodes(cbNodes, node.attributes);
+ case 249:
case 250:
+ return visitNode(cbNode, node.tagName) ||
+ visitNode(cbNode, node.attributes);
+ case 253:
+ return visitNodes(cbNodes, node.properties);
+ case 252:
return visitNode(cbNode, node.name) ||
visitNode(cbNode, node.initializer);
- case 251:
- return visitNode(cbNode, node.expression);
- case 252:
+ case 254:
return visitNode(cbNode, node.expression);
- case 249:
+ case 255:
+ return visitNode(cbNode, node.dotDotDotToken) ||
+ visitNode(cbNode, node.expression);
+ case 251:
return visitNode(cbNode, node.tagName);
- case 262:
- return visitNode(cbNode, node.type);
case 266:
+ return visitNode(cbNode, node.type);
+ case 270:
return visitNodes(cbNodes, node.types);
- case 267:
+ case 271:
return visitNodes(cbNodes, node.types);
- case 265:
- return visitNode(cbNode, node.elementType);
case 269:
+ return visitNode(cbNode, node.elementType);
+ case 273:
return visitNode(cbNode, node.type);
- case 268:
+ case 272:
return visitNode(cbNode, node.type);
- case 270:
+ case 274:
return visitNode(cbNode, node.literal);
- case 272:
+ case 276:
return visitNode(cbNode, node.name) ||
visitNodes(cbNodes, node.typeArguments);
- case 273:
+ case 277:
return visitNode(cbNode, node.type);
- case 274:
+ case 278:
return visitNodes(cbNodes, node.parameters) ||
visitNode(cbNode, node.type);
- case 275:
+ case 279:
return visitNode(cbNode, node.type);
- case 276:
+ case 280:
return visitNode(cbNode, node.type);
- case 277:
+ case 281:
return visitNode(cbNode, node.type);
- case 271:
+ case 275:
return visitNode(cbNode, node.name) ||
visitNode(cbNode, node.type);
- case 278:
+ case 282:
return visitNodes(cbNodes, node.tags);
- case 281:
+ case 285:
return visitNode(cbNode, node.preParameterName) ||
visitNode(cbNode, node.typeExpression) ||
visitNode(cbNode, node.postParameterName);
- case 282:
- return visitNode(cbNode, node.typeExpression);
- case 283:
+ case 286:
return visitNode(cbNode, node.typeExpression);
- case 280:
+ case 287:
return visitNode(cbNode, node.typeExpression);
case 284:
+ return visitNode(cbNode, node.typeExpression);
+ case 288:
return visitNodes(cbNodes, node.typeParameters);
- case 285:
+ case 289:
return visitNode(cbNode, node.typeExpression) ||
visitNode(cbNode, node.fullName) ||
visitNode(cbNode, node.name) ||
visitNode(cbNode, node.jsDocTypeLiteral);
- case 287:
+ case 291:
return visitNodes(cbNodes, node.jsDocPropertyTags);
- case 286:
+ case 290:
return visitNode(cbNode, node.typeExpression) ||
visitNode(cbNode, node.name);
- case 294:
+ case 295:
return visitNode(cbNode, node.expression);
- case 288:
+ case 292:
return visitNode(cbNode, node.literal);
}
}
@@ -11635,7 +12432,7 @@ var ts;
var Parser;
(function (Parser) {
var scanner = ts.createScanner(5, true);
- var disallowInAndDecoratorContext = 65536 | 262144;
+ var disallowInAndDecoratorContext = 2048 | 8192;
var NodeConstructor;
var TokenConstructor;
var IdentifierConstructor;
@@ -11683,7 +12480,7 @@ var ts;
identifiers = ts.createMap();
identifierCount = 0;
nodeCount = 0;
- contextFlags = scriptKind === 1 || scriptKind === 2 ? 2097152 : 0;
+ contextFlags = scriptKind === 1 || scriptKind === 2 ? 65536 : 0;
parseErrorBeforeNextFinishedNode = false;
scanner.setText(sourceText);
scanner.setOnError(scanError);
@@ -11758,7 +12555,7 @@ var ts;
}
Parser.fixupParentReferences = fixupParentReferences;
function createSourceFile(fileName, languageVersion, scriptKind) {
- var sourceFile = new SourceFileConstructor(261, 0, sourceText.length);
+ var sourceFile = new SourceFileConstructor(264, 0, sourceText.length);
nodeCount++;
sourceFile.text = sourceText;
sourceFile.bindDiagnostics = [];
@@ -11778,16 +12575,16 @@ var ts;
}
}
function setDisallowInContext(val) {
- setContextFlag(val, 65536);
+ setContextFlag(val, 2048);
}
function setYieldContext(val) {
- setContextFlag(val, 131072);
+ setContextFlag(val, 4096);
}
function setDecoratorContext(val) {
- setContextFlag(val, 262144);
+ setContextFlag(val, 8192);
}
function setAwaitContext(val) {
- setContextFlag(val, 524288);
+ setContextFlag(val, 16384);
}
function doOutsideOfContext(context, func) {
var contextFlagsToClear = context & contextFlags;
@@ -11810,40 +12607,40 @@ var ts;
return func();
}
function allowInAnd(func) {
- return doOutsideOfContext(65536, func);
+ return doOutsideOfContext(2048, func);
}
function disallowInAnd(func) {
- return doInsideOfContext(65536, func);
+ return doInsideOfContext(2048, func);
}
function doInYieldContext(func) {
- return doInsideOfContext(131072, func);
+ return doInsideOfContext(4096, func);
}
function doInDecoratorContext(func) {
- return doInsideOfContext(262144, func);
+ return doInsideOfContext(8192, func);
}
function doInAwaitContext(func) {
- return doInsideOfContext(524288, func);
+ return doInsideOfContext(16384, func);
}
function doOutsideOfAwaitContext(func) {
- return doOutsideOfContext(524288, func);
+ return doOutsideOfContext(16384, func);
}
function doInYieldAndAwaitContext(func) {
- return doInsideOfContext(131072 | 524288, func);
+ return doInsideOfContext(4096 | 16384, func);
}
function inContext(flags) {
return (contextFlags & flags) !== 0;
}
function inYieldContext() {
- return inContext(131072);
+ return inContext(4096);
}
function inDisallowInContext() {
- return inContext(65536);
+ return inContext(2048);
}
function inDecoratorContext() {
- return inContext(262144);
+ return inContext(8192);
}
function inAwaitContext() {
- return inContext(524288);
+ return inContext(16384);
}
function parseErrorAtCurrentToken(message, arg0) {
var start = scanner.getTokenPos();
@@ -11985,7 +12782,7 @@ var ts;
if (!(pos >= 0)) {
pos = scanner.getStartPos();
}
- return kind >= 141 ? new NodeConstructor(kind, pos, pos) :
+ return kind >= 142 ? new NodeConstructor(kind, pos, pos) :
kind === 70 ? new IdentifierConstructor(kind, pos, pos) :
new TokenConstructor(kind, pos, pos);
}
@@ -12005,7 +12802,7 @@ var ts;
}
if (parseErrorBeforeNextFinishedNode) {
parseErrorBeforeNextFinishedNode = false;
- node.flags |= 1048576;
+ node.flags |= 32768;
}
return node;
}
@@ -12022,7 +12819,11 @@ var ts;
}
function internIdentifier(text) {
text = ts.escapeIdentifier(text);
- return identifiers[text] || (identifiers[text] = text);
+ var identifier = identifiers.get(text);
+ if (identifier === undefined) {
+ identifiers.set(text, identifier = text);
+ }
+ return identifier;
}
function createIdentifier(isIdentifier, diagnosticMessage) {
identifierCount++;
@@ -12067,7 +12868,7 @@ var ts;
return token() === 9 || token() === 8 || ts.tokenIsIdentifierOrKeyword(token());
}
function parseComputedPropertyName() {
- var node = createNode(142);
+ var node = createNode(143);
parseExpected(20);
node.expression = allowInAnd(parseExpression);
parseExpected(21);
@@ -12116,6 +12917,7 @@ var ts;
function nextTokenIsClassOrFunctionOrAsync() {
nextToken();
return token() === 74 || token() === 88 ||
+ (token() === 116 && lookAhead(nextTokenIsClassKeywordOnSameLine)) ||
(token() === 119 && lookAhead(nextTokenIsFunctionKeywordOnSameLine));
}
function isListElement(parsingContext, inErrorRecovery) {
@@ -12323,7 +13125,7 @@ var ts;
if (ts.containsParseError(node)) {
return undefined;
}
- var nodeContextFlags = node.flags & 3080192;
+ var nodeContextFlags = node.flags & 96256;
if (nodeContextFlags !== contextFlags) {
return undefined;
}
@@ -12372,14 +13174,14 @@ var ts;
function isReusableClassMember(node) {
if (node) {
switch (node.kind) {
- case 150:
- case 155:
case 151:
+ case 156:
case 152:
- case 147:
- case 203:
+ case 153:
+ case 148:
+ case 205:
return true;
- case 149:
+ case 150:
var methodDeclaration = node;
var nameIsConstructor = methodDeclaration.name.kind === 70 &&
methodDeclaration.name.originalKeywordKind === 122;
@@ -12391,8 +13193,8 @@ var ts;
function isReusableSwitchClause(node) {
if (node) {
switch (node.kind) {
- case 253:
- case 254:
+ case 256:
+ case 257:
return true;
}
}
@@ -12401,65 +13203,65 @@ var ts;
function isReusableStatement(node) {
if (node) {
switch (node.kind) {
- case 225:
- case 205:
- case 204:
- case 208:
+ case 227:
case 207:
+ case 206:
+ case 210:
+ case 209:
+ case 222:
+ case 218:
case 220:
+ case 217:
case 216:
- case 218:
- case 215:
case 214:
- case 212:
+ case 215:
case 213:
- case 211:
- case 210:
- case 217:
- case 206:
- case 221:
+ case 212:
case 219:
- case 209:
- case 222:
- case 235:
- case 234:
- case 241:
- case 240:
- case 230:
- case 226:
- case 227:
- case 229:
+ case 208:
+ case 223:
+ case 221:
+ case 211:
+ case 224:
+ case 237:
+ case 236:
+ case 243:
+ case 242:
+ case 232:
case 228:
+ case 229:
+ case 231:
+ case 230:
return true;
}
}
return false;
}
function isReusableEnumMember(node) {
- return node.kind === 260;
+ return node.kind === 263;
}
function isReusableTypeMember(node) {
if (node) {
switch (node.kind) {
- case 154:
- case 148:
case 155:
- case 146:
- case 153:
+ case 149:
+ case 156:
+ case 147:
+ case 154:
return true;
}
}
return false;
}
function isReusableVariableDeclaration(node) {
- if (node.kind !== 223) {
+ if (node.kind !== 225) {
return false;
}
var variableDeclarator = node;
return variableDeclarator.initializer === undefined;
}
function isReusableParameter(node) {
- if (node.kind !== 144) {
+ if (node.kind !== 145) {
return false;
}
var parameter = node;
@@ -12504,7 +13306,6 @@ var ts;
case 25: return ts.Diagnostics.Property_assignment_expected;
}
}
- ;
function parseDelimitedList(kind, parseElement, considerSemicolonAsDelimiter) {
var saveParsingContext = parsingContext;
parsingContext |= 1 << kind;
@@ -12555,7 +13356,7 @@ var ts;
function parseEntityName(allowReservedWords, diagnosticMessage) {
var entity = parseIdentifier(diagnosticMessage);
while (parseOptional(22)) {
- var node = createNode(141, entity.pos);
+ var node = createNode(142, entity.pos);
node.left = entity;
node.right = parseRightSideOfDot(allowReservedWords);
entity = finishNode(node);
@@ -12572,7 +13373,7 @@ var ts;
return allowIdentifierNames ? parseIdentifierName() : parseIdentifier();
}
function parseTemplateExpression() {
- var template = createNode(194);
+ var template = createNode(195);
template.head = parseTemplateHead();
ts.Debug.assert(template.head.kind === 13, "Template head has wrong token kind");
var templateSpans = createNodeArray();
@@ -12584,7 +13385,7 @@ var ts;
return finishNode(template);
}
function parseTemplateSpan() {
- var span = createNode(202);
+ var span = createNode(204);
span.expression = allowInAnd(parseExpression);
var literal;
if (token() === 17) {
@@ -12620,20 +13421,16 @@ var ts;
if (scanner.isUnterminated()) {
node.isUnterminated = true;
}
- var tokenPos = scanner.getTokenPos();
+ if (node.kind === 8) {
+ node.numericLiteralFlags = scanner.getNumericLiteralFlags();
+ }
nextToken();
finishNode(node);
- if (node.kind === 8
- && sourceText.charCodeAt(tokenPos) === 48
- && ts.isOctalDigit(sourceText.charCodeAt(tokenPos + 1))) {
- node.isOctalLiteral = true;
- }
return node;
}
function parseTypeReference() {
- var typeName = parseEntityName(false, ts.Diagnostics.Type_expected);
- var node = createNode(157, typeName.pos);
- node.typeName = typeName;
+ var node = createNode(158);
+ node.typeName = parseEntityName(false, ts.Diagnostics.Type_expected);
if (!scanner.hasPrecedingLineBreak() && token() === 26) {
node.typeArguments = parseBracketedList(19, parseType, 26, 28);
}
@@ -12641,24 +13438,24 @@ var ts;
}
function parseThisTypePredicate(lhs) {
nextToken();
- var node = createNode(156, lhs.pos);
+ var node = createNode(157, lhs.pos);
node.parameterName = lhs;
node.type = parseType();
return finishNode(node);
}
function parseThisTypeNode() {
- var node = createNode(167);
+ var node = createNode(168);
nextToken();
return finishNode(node);
}
function parseTypeQuery() {
- var node = createNode(160);
+ var node = createNode(161);
parseExpected(102);
node.exprName = parseEntityName(true);
return finishNode(node);
}
function parseTypeParameter() {
- var node = createNode(143);
+ var node = createNode(144);
node.name = parseIdentifier();
if (parseOptional(84)) {
if (isStartOfType() || !isStartOfExpression()) {
@@ -12668,6 +13465,9 @@ var ts;
node.expression = parseUnaryExpressionOrHigher();
}
}
+ if (parseOptional(57)) {
+ node.default = parseType();
+ }
return finishNode(node);
}
function parseTypeParameters() {
@@ -12685,9 +13485,9 @@ var ts;
return token() === 23 || isIdentifierOrPattern() || ts.isModifierKind(token()) || token() === 56 || token() === 98;
}
function parseParameter() {
- var node = createNode(144);
+ var node = createNode(145);
if (token() === 98) {
- node.name = createIdentifier(true, undefined);
+ node.name = createIdentifier(true);
node.type = parseParameterType();
return finishNode(node);
}
@@ -12745,7 +13545,7 @@ var ts;
}
function parseSignatureMember(kind) {
var node = createNode(kind);
- if (kind === 154) {
+ if (kind === 155) {
parseExpected(93);
}
fillSignature(55, false, false, false, node);
@@ -12785,7 +13585,7 @@ var ts;
return token() === 55 || token() === 25 || token() === 21;
}
function parseIndexSignatureDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(155, fullStart);
+ var node = createNode(156, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
node.parameters = parseBracketedList(16, parseParameter, 20, 21);
@@ -12797,7 +13597,7 @@ var ts;
var name = parsePropertyName();
var questionToken = parseOptionalToken(54);
if (token() === 18 || token() === 26) {
- var method = createNode(148, fullStart);
+ var method = createNode(149, fullStart);
method.modifiers = modifiers;
method.name = name;
method.questionToken = questionToken;
@@ -12806,7 +13606,7 @@ var ts;
return addJSDocComment(finishNode(method));
}
else {
- var property = createNode(146, fullStart);
+ var property = createNode(147, fullStart);
property.modifiers = modifiers;
property.name = name;
property.questionToken = questionToken;
@@ -12819,19 +13619,19 @@ var ts;
}
}
function isTypeMemberStart() {
- var idToken;
if (token() === 18 || token() === 26) {
return true;
}
+ var idToken;
while (ts.isModifierKind(token())) {
- idToken = token();
+ idToken = true;
nextToken();
}
if (token() === 20) {
return true;
}
if (isLiteralPropertyName()) {
- idToken = token();
+ idToken = true;
nextToken();
}
if (idToken) {
@@ -12846,10 +13646,10 @@ var ts;
}
function parseTypeMember() {
if (token() === 18 || token() === 26) {
- return parseSignatureMember(153);
+ return parseSignatureMember(154);
}
if (token() === 93 && lookAhead(isStartOfConstructSignature)) {
- return parseSignatureMember(154);
+ return parseSignatureMember(155);
}
var fullStart = getNodePos();
var modifiers = parseModifiers();
@@ -12863,7 +13663,7 @@ var ts;
return token() === 18 || token() === 26;
}
function parseTypeLiteral() {
- var node = createNode(161);
+ var node = createNode(162);
node.members = parseObjectTypeMembers();
return finishNode(node);
}
@@ -12886,14 +13686,14 @@ var ts;
return token() === 20 && nextTokenIsIdentifier() && nextToken() === 91;
}
function parseMappedTypeParameter() {
- var node = createNode(143);
+ var node = createNode(144);
node.name = parseIdentifier();
parseExpected(91);
node.constraint = parseType();
return finishNode(node);
}
function parseMappedType() {
- var node = createNode(170);
+ var node = createNode(171);
parseExpected(16);
node.readonlyToken = parseOptionalToken(130);
parseExpected(20);
@@ -12906,12 +13706,12 @@ var ts;
return finishNode(node);
}
function parseTupleType() {
- var node = createNode(163);
+ var node = createNode(164);
node.elementTypes = parseBracketedList(20, parseType, 20, 21);
return finishNode(node);
}
function parseParenthesizedType() {
- var node = createNode(166);
+ var node = createNode(167);
parseExpected(18);
node.type = parseType();
parseExpected(19);
@@ -12919,7 +13719,7 @@ var ts;
}
function parseFunctionOrConstructorType(kind) {
var node = createNode(kind);
- if (kind === 159) {
+ if (kind === 160) {
parseExpected(93);
}
fillSignature(35, false, false, false, node);
@@ -12930,7 +13730,7 @@ var ts;
return token() === 22 ? undefined : node;
}
function parseLiteralTypeNode() {
- var node = createNode(171);
+ var node = createNode(172);
node.literal = parseSimpleUnaryExpression();
finishNode(node);
return node;
@@ -12941,12 +13741,13 @@ var ts;
function parseNonArrayType() {
switch (token()) {
case 118:
- case 134:
+ case 135:
case 132:
case 121:
- case 135:
- case 137:
+ case 136:
+ case 138:
case 129:
+ case 133:
var node = tryParse(parseKeywordAndNoDot);
return node || parseTypeReference();
case 9:
@@ -12983,12 +13784,12 @@ var ts;
function isStartOfType() {
switch (token()) {
case 118:
- case 134:
+ case 135:
case 132:
case 121:
- case 135:
+ case 136:
case 104:
- case 137:
+ case 138:
case 94:
case 98:
case 102:
@@ -12996,11 +13797,14 @@ var ts;
case 16:
case 20:
case 26:
+ case 48:
+ case 47:
case 93:
case 9:
case 8:
case 100:
case 85:
+ case 133:
return true;
case 37:
return lookAhead(nextTokenIsNumericLiteral);
@@ -13018,14 +13822,14 @@ var ts;
var type = parseNonArrayType();
while (!scanner.hasPrecedingLineBreak() && parseOptional(20)) {
if (isStartOfType()) {
- var node = createNode(169, type.pos);
+ var node = createNode(170, type.pos);
node.objectType = type;
node.indexType = parseType();
parseExpected(21);
type = finishNode(node);
}
else {
- var node = createNode(162, type.pos);
+ var node = createNode(163, type.pos);
node.elementType = type;
parseExpected(21);
type = finishNode(node);
@@ -13034,7 +13838,7 @@ var ts;
return type;
}
function parseTypeOperator(operator) {
- var node = createNode(168);
+ var node = createNode(169);
parseExpected(operator);
node.operator = operator;
node.type = parseTypeOperatorOrHigher();
@@ -13048,6 +13852,7 @@ var ts;
return parseArrayTypeOrHigher();
}
function parseUnionOrIntersectionType(kind, parseConstituentType, operator) {
+ parseOptional(operator);
var type = parseConstituentType();
if (token() === operator) {
var types = createNodeArray([type], type.pos);
@@ -13062,10 +13867,10 @@ var ts;
return type;
}
function parseIntersectionTypeOrHigher() {
- return parseUnionOrIntersectionType(165, parseTypeOperatorOrHigher, 47);
+ return parseUnionOrIntersectionType(166, parseTypeOperatorOrHigher, 47);
}
function parseUnionTypeOrHigher() {
- return parseUnionOrIntersectionType(164, parseIntersectionTypeOrHigher, 48);
+ return parseUnionOrIntersectionType(165, parseIntersectionTypeOrHigher, 48);
}
function isStartOfFunctionType() {
if (token() === 26) {
@@ -13111,7 +13916,7 @@ var ts;
var typePredicateVariable = isIdentifier() && tryParse(parseTypePredicatePrefix);
var type = parseType();
if (typePredicateVariable) {
- var node = createNode(156, typePredicateVariable.pos);
+ var node = createNode(157, typePredicateVariable.pos);
node.parameterName = typePredicateVariable;
node.type = type;
return finishNode(node);
@@ -13128,14 +13933,14 @@ var ts;
}
}
function parseType() {
- return doOutsideOfContext(655360, parseTypeWorker);
+ return doOutsideOfContext(20480, parseTypeWorker);
}
function parseTypeWorker() {
if (isStartOfFunctionType()) {
- return parseFunctionOrConstructorType(158);
+ return parseFunctionOrConstructorType(159);
}
if (token() === 93) {
- return parseFunctionOrConstructorType(159);
+ return parseFunctionOrConstructorType(160);
}
return parseUnionTypeOrHigher();
}
@@ -13254,7 +14059,7 @@ var ts;
return !scanner.hasPrecedingLineBreak() && isIdentifier();
}
function parseYieldExpression() {
- var node = createNode(195);
+ var node = createNode(196);
nextToken();
if (!scanner.hasPrecedingLineBreak() &&
(token() === 38 || isStartOfExpression())) {
@@ -13270,13 +14075,13 @@ var ts;
ts.Debug.assert(token() === 35, "parseSimpleArrowFunctionExpression should only have been called if we had a =>");
var node;
if (asyncModifier) {
- node = createNode(185, asyncModifier.pos);
+ node = createNode(186, asyncModifier.pos);
node.modifiers = asyncModifier;
}
else {
- node = createNode(185, identifier.pos);
+ node = createNode(186, identifier.pos);
}
- var parameter = createNode(144, identifier.pos);
+ var parameter = createNode(145, identifier.pos);
parameter.name = identifier;
finishNode(parameter);
node.parameters = createNodeArray([parameter], parameter.pos);
@@ -13410,7 +14215,7 @@ var ts;
return 0;
}
function parseParenthesizedArrowFunctionExpressionHead(allowAmbiguity) {
- var node = createNode(185);
+ var node = createNode(186);
node.modifiers = parseModifiersForArrowFunction();
var isAsync = !!(ts.getModifierFlags(node) & 256);
fillSignature(55, false, isAsync, !allowAmbiguity, node);
@@ -13442,7 +14247,7 @@ var ts;
if (!questionToken) {
return leftOperand;
}
- var node = createNode(193, leftOperand.pos);
+ var node = createNode(194, leftOperand.pos);
node.condition = leftOperand;
node.questionToken = questionToken;
node.whenTrue = doOutsideOfContext(disallowInAndDecoratorContext, parseAssignmentExpressionOrHigher);
@@ -13455,7 +14260,7 @@ var ts;
return parseBinaryExpressionRest(precedence, leftOperand);
}
function isInOrOfKeyword(t) {
- return t === 91 || t === 140;
+ return t === 91 || t === 141;
}
function parseBinaryExpressionRest(precedence, leftOperand) {
while (true) {
@@ -13533,39 +14338,39 @@ var ts;
return -1;
}
function makeBinaryExpression(left, operatorToken, right) {
- var node = createNode(192, left.pos);
+ var node = createNode(193, left.pos);
node.left = left;
node.operatorToken = operatorToken;
node.right = right;
return finishNode(node);
}
function makeAsExpression(left, right) {
- var node = createNode(200, left.pos);
+ var node = createNode(201, left.pos);
node.expression = left;
node.type = right;
return finishNode(node);
}
function parsePrefixUnaryExpression() {
- var node = createNode(190);
+ var node = createNode(191);
node.operator = token();
nextToken();
node.operand = parseSimpleUnaryExpression();
return finishNode(node);
}
function parseDeleteExpression() {
- var node = createNode(186);
+ var node = createNode(187);
nextToken();
node.expression = parseSimpleUnaryExpression();
return finishNode(node);
}
function parseTypeOfExpression() {
- var node = createNode(187);
+ var node = createNode(188);
nextToken();
node.expression = parseSimpleUnaryExpression();
return finishNode(node);
}
function parseVoidExpression() {
- var node = createNode(188);
+ var node = createNode(189);
nextToken();
node.expression = parseSimpleUnaryExpression();
return finishNode(node);
@@ -13580,7 +14385,7 @@ var ts;
return false;
}
function parseAwaitExpression() {
- var node = createNode(189);
+ var node = createNode(190);
nextToken();
node.expression = parseSimpleUnaryExpression();
return finishNode(node);
@@ -13596,7 +14401,7 @@ var ts;
var simpleUnaryExpression = parseSimpleUnaryExpression();
if (token() === 39) {
var start = ts.skipTrivia(sourceText, simpleUnaryExpression.pos);
- if (simpleUnaryExpression.kind === 182) {
+ if (simpleUnaryExpression.kind === 183) {
parseErrorAtPosition(start, simpleUnaryExpression.end - start, ts.Diagnostics.A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses);
}
else {
@@ -13649,7 +14454,7 @@ var ts;
}
function parseIncrementExpression() {
if (token() === 42 || token() === 43) {
- var node = createNode(190);
+ var node = createNode(191);
node.operator = token();
nextToken();
node.operand = parseLeftHandSideExpressionOrHigher();
@@ -13661,7 +14466,7 @@ var ts;
var expression = parseLeftHandSideExpressionOrHigher();
ts.Debug.assert(ts.isLeftHandSideExpression(expression));
if ((token() === 42 || token() === 43) && !scanner.hasPrecedingLineBreak()) {
- var node = createNode(191, expression.pos);
+ var node = createNode(192, expression.pos);
node.operand = expression;
node.operator = token();
nextToken();
@@ -13684,7 +14489,7 @@ var ts;
if (token() === 18 || token() === 22 || token() === 20) {
return expression;
}
- var node = createNode(177, expression.pos);
+ var node = createNode(178, expression.pos);
node.expression = expression;
parseExpectedToken(22, false, ts.Diagnostics.super_must_be_followed_by_an_argument_list_or_member_access);
node.name = parseRightSideOfDot(true);
@@ -13706,8 +14511,8 @@ var ts;
function parseJsxElementOrSelfClosingElement(inExpressionContext) {
var opening = parseJsxOpeningOrSelfClosingElement(inExpressionContext);
var result;
- if (opening.kind === 248) {
- var node = createNode(246, opening.pos);
+ if (opening.kind === 250) {
+ var node = createNode(248, opening.pos);
node.openingElement = opening;
node.children = parseJsxChildren(node.openingElement.tagName);
node.closingElement = parseJsxClosingElement(inExpressionContext);
@@ -13717,14 +14522,14 @@ var ts;
result = finishNode(node);
}
else {
- ts.Debug.assert(opening.kind === 247);
+ ts.Debug.assert(opening.kind === 249);
result = opening;
}
if (inExpressionContext && token() === 26) {
var invalidElement = tryParse(function () { return parseJsxElementOrSelfClosingElement(true); });
if (invalidElement) {
parseErrorAtCurrentToken(ts.Diagnostics.JSX_expressions_must_have_one_parent_element);
- var badNode = createNode(192, result.pos);
+ var badNode = createNode(193, result.pos);
badNode.end = invalidElement.end;
badNode.left = result;
badNode.right = invalidElement;
@@ -13764,20 +14569,28 @@ var ts;
parseErrorAtPosition(openingTagName.pos, openingTagName.end - openingTagName.pos, ts.Diagnostics.JSX_element_0_has_no_corresponding_closing_tag, ts.getTextOfNodeFromSourceText(sourceText, openingTagName));
break;
}
+ else if (token() === 7) {
+ break;
+ }
result.push(parseJsxChild());
}
result.end = scanner.getTokenPos();
parsingContext = saveParsingContext;
return result;
}
+ function parseJsxAttributes() {
+ var jsxAttributes = createNode(253);
+ jsxAttributes.properties = parseList(13, parseJsxAttribute);
+ return finishNode(jsxAttributes);
+ }
function parseJsxOpeningOrSelfClosingElement(inExpressionContext) {
var fullStart = scanner.getStartPos();
parseExpected(26);
var tagName = parseJsxElementName();
- var attributes = parseList(13, parseJsxAttribute);
+ var attributes = parseJsxAttributes();
var node;
if (token() === 28) {
- node = createNode(248, fullStart);
+ node = createNode(250, fullStart);
scanJsxText();
}
else {
@@ -13789,7 +14602,7 @@ var ts;
parseExpected(28, undefined, false);
scanJsxText();
}
- node = createNode(247, fullStart);
+ node = createNode(249, fullStart);
}
node.tagName = tagName;
node.attributes = attributes;
@@ -13800,7 +14613,7 @@ var ts;
var expression = token() === 98 ?
parseTokenNode() : parseIdentifierName();
while (parseOptional(22)) {
- var propertyAccess = createNode(177, expression.pos);
+ var propertyAccess = createNode(178, expression.pos);
propertyAccess.expression = expression;
propertyAccess.name = parseRightSideOfDot(true);
expression = finishNode(propertyAccess);
@@ -13808,9 +14621,10 @@ var ts;
return expression;
}
function parseJsxExpression(inExpressionContext) {
- var node = createNode(252);
+ var node = createNode(255);
parseExpected(16);
if (token() !== 17) {
+ node.dotDotDotToken = parseOptionalToken(23);
node.expression = parseAssignmentExpressionOrHigher();
}
if (inExpressionContext) {
@@ -13827,7 +14641,7 @@ var ts;
return parseJsxSpreadAttribute();
}
scanJsxIdentifier();
- var node = createNode(250);
+ var node = createNode(252);
node.name = parseIdentifierName();
if (token() === 57) {
switch (scanJsxAttributeValue()) {
@@ -13842,7 +14656,7 @@ var ts;
return finishNode(node);
}
function parseJsxSpreadAttribute() {
- var node = createNode(251);
+ var node = createNode(254);
parseExpected(16);
parseExpected(23);
node.expression = parseExpression();
@@ -13850,7 +14664,7 @@ var ts;
return finishNode(node);
}
function parseJsxClosingElement(inExpressionContext) {
- var node = createNode(249);
+ var node = createNode(251);
parseExpected(27);
node.tagName = parseJsxElementName();
if (inExpressionContext) {
@@ -13863,7 +14677,7 @@ var ts;
return finishNode(node);
}
function parseTypeAssertion() {
- var node = createNode(182);
+ var node = createNode(183);
parseExpected(26);
node.type = parseType();
parseExpected(28);
@@ -13874,7 +14688,7 @@ var ts;
while (true) {
var dotToken = parseOptionalToken(22);
if (dotToken) {
- var propertyAccess = createNode(177, expression.pos);
+ var propertyAccess = createNode(178, expression.pos);
propertyAccess.expression = expression;
propertyAccess.name = parseRightSideOfDot(true);
expression = finishNode(propertyAccess);
@@ -13882,13 +14696,13 @@ var ts;
}
if (token() === 50 && !scanner.hasPrecedingLineBreak()) {
nextToken();
- var nonNullExpression = createNode(201, expression.pos);
+ var nonNullExpression = createNode(202, expression.pos);
nonNullExpression.expression = expression;
expression = finishNode(nonNullExpression);
continue;
}
if (!inDecoratorContext() && parseOptional(20)) {
- var indexedAccess = createNode(178, expression.pos);
+ var indexedAccess = createNode(179, expression.pos);
indexedAccess.expression = expression;
if (token() !== 21) {
indexedAccess.argumentExpression = allowInAnd(parseExpression);
@@ -13902,7 +14716,7 @@ var ts;
continue;
}
if (token() === 12 || token() === 13) {
- var tagExpression = createNode(181, expression.pos);
+ var tagExpression = createNode(182, expression.pos);
tagExpression.tag = expression;
tagExpression.template = token() === 12
? parseLiteralNode()
@@ -13921,7 +14735,7 @@ var ts;
if (!typeArguments) {
return expression;
}
- var callExpr = createNode(179, expression.pos);
+ var callExpr = createNode(180, expression.pos);
callExpr.expression = expression;
callExpr.typeArguments = typeArguments;
callExpr.arguments = parseArgumentList();
@@ -13929,7 +14743,7 @@ var ts;
continue;
}
else if (token() === 18) {
- var callExpr = createNode(179, expression.pos);
+ var callExpr = createNode(180, expression.pos);
callExpr.expression = expression;
callExpr.arguments = parseArgumentList();
expression = finishNode(callExpr);
@@ -14024,28 +14838,28 @@ var ts;
return parseIdentifier(ts.Diagnostics.Expression_expected);
}
function parseParenthesizedExpression() {
- var node = createNode(183);
+ var node = createNode(184);
parseExpected(18);
node.expression = allowInAnd(parseExpression);
parseExpected(19);
return finishNode(node);
}
function parseSpreadElement() {
- var node = createNode(196);
+ var node = createNode(197);
parseExpected(23);
node.expression = parseAssignmentExpressionOrHigher();
return finishNode(node);
}
function parseArgumentOrArrayLiteralElement() {
return token() === 23 ? parseSpreadElement() :
- token() === 25 ? createNode(198) :
+ token() === 25 ? createNode(199) :
parseAssignmentExpressionOrHigher();
}
function parseArgumentExpression() {
return doOutsideOfContext(disallowInAndDecoratorContext, parseArgumentOrArrayLiteralElement);
}
function parseArrayLiteralExpression() {
- var node = createNode(175);
+ var node = createNode(176);
parseExpected(20);
if (scanner.hasPrecedingLineBreak()) {
node.multiLine = true;
@@ -14056,18 +14870,18 @@ var ts;
}
function tryParseAccessorDeclaration(fullStart, decorators, modifiers) {
if (parseContextualModifier(124)) {
- return parseAccessorDeclaration(151, fullStart, decorators, modifiers);
- }
- else if (parseContextualModifier(133)) {
return parseAccessorDeclaration(152, fullStart, decorators, modifiers);
}
+ else if (parseContextualModifier(134)) {
+ return parseAccessorDeclaration(153, fullStart, decorators, modifiers);
+ }
return undefined;
}
function parseObjectLiteralElement() {
var fullStart = scanner.getStartPos();
var dotDotDotToken = parseOptionalToken(23);
if (dotDotDotToken) {
- var spreadElement = createNode(259, fullStart);
+ var spreadElement = createNode(262, fullStart);
spreadElement.expression = parseAssignmentExpressionOrHigher();
return addJSDocComment(finishNode(spreadElement));
}
@@ -14086,7 +14900,7 @@ var ts;
}
var isShorthandPropertyAssignment = tokenIsIdentifier && (token() === 25 || token() === 17 || token() === 57);
if (isShorthandPropertyAssignment) {
- var shorthandDeclaration = createNode(258, fullStart);
+ var shorthandDeclaration = createNode(261, fullStart);
shorthandDeclaration.name = propertyName;
shorthandDeclaration.questionToken = questionToken;
var equalsToken = parseOptionalToken(57);
@@ -14097,7 +14911,7 @@ var ts;
return addJSDocComment(finishNode(shorthandDeclaration));
}
else {
- var propertyAssignment = createNode(257, fullStart);
+ var propertyAssignment = createNode(260, fullStart);
propertyAssignment.modifiers = modifiers;
propertyAssignment.name = propertyName;
propertyAssignment.questionToken = questionToken;
@@ -14107,7 +14921,7 @@ var ts;
}
}
function parseObjectLiteralExpression() {
- var node = createNode(176);
+ var node = createNode(177);
parseExpected(16);
if (scanner.hasPrecedingLineBreak()) {
node.multiLine = true;
@@ -14121,7 +14935,7 @@ var ts;
if (saveDecoratorContext) {
setDecoratorContext(false);
}
- var node = createNode(184);
+ var node = createNode(185);
node.modifiers = parseModifiers();
parseExpected(88);
node.asteriskToken = parseOptionalToken(38);
@@ -14143,8 +14957,15 @@ var ts;
return isIdentifier() ? parseIdentifier() : undefined;
}
function parseNewExpression() {
- var node = createNode(180);
+ var fullStart = scanner.getStartPos();
parseExpected(93);
+ if (parseOptional(22)) {
+ var node_1 = createNode(203, fullStart);
+ node_1.keywordToken = 93;
+ node_1.name = parseIdentifierName();
+ return finishNode(node_1);
+ }
+ var node = createNode(181, fullStart);
node.expression = parseMemberExpressionOrHigher();
node.typeArguments = tryParse(parseTypeArgumentsInExpression);
if (node.typeArguments || token() === 18) {
@@ -14153,7 +14974,7 @@ var ts;
return finishNode(node);
}
function parseBlock(ignoreMissingOpenBrace, diagnosticMessage) {
- var node = createNode(204);
+ var node = createNode(206);
if (parseExpected(16, diagnosticMessage) || ignoreMissingOpenBrace) {
if (scanner.hasPrecedingLineBreak()) {
node.multiLine = true;
@@ -14184,12 +15005,12 @@ var ts;
return block;
}
function parseEmptyStatement() {
- var node = createNode(206);
+ var node = createNode(208);
parseExpected(24);
return finishNode(node);
}
function parseIfStatement() {
- var node = createNode(208);
+ var node = createNode(210);
parseExpected(89);
parseExpected(18);
node.expression = allowInAnd(parseExpression);
@@ -14199,7 +15020,7 @@ var ts;
return finishNode(node);
}
function parseDoStatement() {
- var node = createNode(209);
+ var node = createNode(211);
parseExpected(80);
node.statement = parseStatement();
parseExpected(105);
@@ -14210,7 +15031,7 @@ var ts;
return finishNode(node);
}
function parseWhileStatement() {
- var node = createNode(210);
+ var node = createNode(212);
parseExpected(105);
parseExpected(18);
node.expression = allowInAnd(parseExpression);
@@ -14221,6 +15042,7 @@ var ts;
function parseForOrForInOrForOfStatement() {
var pos = getNodePos();
parseExpected(87);
+ var awaitToken = parseOptionalToken(120);
parseExpected(18);
var initializer = undefined;
if (token() !== 24) {
@@ -14232,22 +15054,23 @@ var ts;
}
}
var forOrForInOrForOfStatement;
- if (parseOptional(91)) {
- var forInStatement = createNode(212, pos);
- forInStatement.initializer = initializer;
- forInStatement.expression = allowInAnd(parseExpression);
- parseExpected(19);
- forOrForInOrForOfStatement = forInStatement;
- }
- else if (parseOptional(140)) {
- var forOfStatement = createNode(213, pos);
+ if (awaitToken ? parseExpected(141) : parseOptional(141)) {
+ var forOfStatement = createNode(215, pos);
+ forOfStatement.awaitModifier = awaitToken;
forOfStatement.initializer = initializer;
forOfStatement.expression = allowInAnd(parseAssignmentExpressionOrHigher);
parseExpected(19);
forOrForInOrForOfStatement = forOfStatement;
}
+ else if (parseOptional(91)) {
+ var forInStatement = createNode(214, pos);
+ forInStatement.initializer = initializer;
+ forInStatement.expression = allowInAnd(parseExpression);
+ parseExpected(19);
+ forOrForInOrForOfStatement = forInStatement;
+ }
else {
- var forStatement = createNode(211, pos);
+ var forStatement = createNode(213, pos);
forStatement.initializer = initializer;
parseExpected(24);
if (token() !== 24 && token() !== 19) {
@@ -14265,7 +15088,7 @@ var ts;
}
function parseBreakOrContinueStatement(kind) {
var node = createNode(kind);
- parseExpected(kind === 215 ? 71 : 76);
+ parseExpected(kind === 217 ? 71 : 76);
if (!canParseSemicolon()) {
node.label = parseIdentifier();
}
@@ -14273,7 +15096,7 @@ var ts;
return finishNode(node);
}
function parseReturnStatement() {
- var node = createNode(216);
+ var node = createNode(218);
parseExpected(95);
if (!canParseSemicolon()) {
node.expression = allowInAnd(parseExpression);
@@ -14282,7 +15105,7 @@ var ts;
return finishNode(node);
}
function parseWithStatement() {
- var node = createNode(217);
+ var node = createNode(219);
parseExpected(106);
parseExpected(18);
node.expression = allowInAnd(parseExpression);
@@ -14291,7 +15114,7 @@ var ts;
return finishNode(node);
}
function parseCaseClause() {
- var node = createNode(253);
+ var node = createNode(256);
parseExpected(72);
node.expression = allowInAnd(parseExpression);
parseExpected(55);
@@ -14299,7 +15122,7 @@ var ts;
return finishNode(node);
}
function parseDefaultClause() {
- var node = createNode(254);
+ var node = createNode(257);
parseExpected(78);
parseExpected(55);
node.statements = parseList(3, parseStatement);
@@ -14309,12 +15132,12 @@ var ts;
return token() === 72 ? parseCaseClause() : parseDefaultClause();
}
function parseSwitchStatement() {
- var node = createNode(218);
+ var node = createNode(220);
parseExpected(97);
parseExpected(18);
node.expression = allowInAnd(parseExpression);
parseExpected(19);
- var caseBlock = createNode(232, scanner.getStartPos());
+ var caseBlock = createNode(234, scanner.getStartPos());
parseExpected(16);
caseBlock.clauses = parseList(2, parseCaseOrDefaultClause);
parseExpected(17);
@@ -14322,14 +15145,14 @@ var ts;
return finishNode(node);
}
function parseThrowStatement() {
- var node = createNode(220);
+ var node = createNode(222);
parseExpected(99);
node.expression = scanner.hasPrecedingLineBreak() ? undefined : allowInAnd(parseExpression);
parseSemicolon();
return finishNode(node);
}
function parseTryStatement() {
- var node = createNode(221);
+ var node = createNode(223);
parseExpected(101);
node.tryBlock = parseBlock(false);
node.catchClause = token() === 73 ? parseCatchClause() : undefined;
@@ -14340,7 +15163,7 @@ var ts;
return finishNode(node);
}
function parseCatchClause() {
- var result = createNode(256);
+ var result = createNode(259);
parseExpected(73);
if (parseExpected(18)) {
result.variableDeclaration = parseVariableDeclaration();
@@ -14350,7 +15173,7 @@ var ts;
return finishNode(result);
}
function parseDebuggerStatement() {
- var node = createNode(222);
+ var node = createNode(224);
parseExpected(77);
parseSemicolon();
return finishNode(node);
@@ -14359,13 +15182,13 @@ var ts;
var fullStart = scanner.getStartPos();
var expression = allowInAnd(parseExpression);
if (expression.kind === 70 && parseOptional(55)) {
- var labeledStatement = createNode(219, fullStart);
+ var labeledStatement = createNode(221, fullStart);
labeledStatement.label = expression;
labeledStatement.statement = parseStatement();
return addJSDocComment(finishNode(labeledStatement));
}
else {
- var expressionStatement = createNode(207, fullStart);
+ var expressionStatement = createNode(209, fullStart);
expressionStatement.expression = expression;
parseSemicolon();
return addJSDocComment(finishNode(expressionStatement));
@@ -14375,6 +15198,10 @@ var ts;
nextToken();
return ts.tokenIsIdentifierOrKeyword(token()) && !scanner.hasPrecedingLineBreak();
}
+ function nextTokenIsClassKeywordOnSameLine() {
+ nextToken();
+ return token() === 74 && !scanner.hasPrecedingLineBreak();
+ }
function nextTokenIsFunctionKeywordOnSameLine() {
nextToken();
return token() === 88 && !scanner.hasPrecedingLineBreak();
@@ -14394,7 +15221,7 @@ var ts;
case 82:
return true;
case 108:
- case 136:
+ case 137:
return nextTokenIsIdentifierOnSameLine();
case 127:
case 128:
@@ -14411,7 +15238,7 @@ var ts;
return false;
}
continue;
- case 139:
+ case 140:
nextToken();
return token() === 16 || token() === 70 || token() === 83;
case 90:
@@ -14471,8 +15298,8 @@ var ts;
case 108:
case 127:
case 128:
- case 136:
- case 139:
+ case 137:
+ case 140:
return true;
case 113:
case 111:
@@ -14517,9 +15344,9 @@ var ts;
case 87:
return parseForOrForInOrForOfStatement();
case 76:
- return parseBreakOrContinueStatement(214);
+ return parseBreakOrContinueStatement(216);
case 71:
- return parseBreakOrContinueStatement(215);
+ return parseBreakOrContinueStatement(217);
case 95:
return parseReturnStatement();
case 106:
@@ -14538,7 +15365,7 @@ var ts;
return parseDeclaration();
case 119:
case 108:
- case 136:
+ case 137:
case 127:
case 128:
case 123:
@@ -14552,7 +15379,7 @@ var ts;
case 116:
case 114:
case 130:
- case 139:
+ case 140:
if (isStartOfDeclaration()) {
return parseDeclaration();
}
@@ -14575,11 +15402,11 @@ var ts;
return parseClassDeclaration(fullStart, decorators, modifiers);
case 108:
return parseInterfaceDeclaration(fullStart, decorators, modifiers);
- case 136:
+ case 137:
return parseTypeAliasDeclaration(fullStart, decorators, modifiers);
case 82:
return parseEnumDeclaration(fullStart, decorators, modifiers);
- case 139:
+ case 140:
case 127:
case 128:
return parseModuleDeclaration(fullStart, decorators, modifiers);
@@ -14598,7 +15425,7 @@ var ts;
}
default:
if (decorators || modifiers) {
- var node = createMissingNode(244, true, ts.Diagnostics.Declaration_expected);
+ var node = createMissingNode(246, true, ts.Diagnostics.Declaration_expected);
node.pos = fullStart;
node.decorators = decorators;
node.modifiers = modifiers;
@@ -14619,16 +15446,16 @@ var ts;
}
function parseArrayBindingElement() {
if (token() === 25) {
- return createNode(198);
+ return createNode(199);
}
- var node = createNode(174);
+ var node = createNode(175);
node.dotDotDotToken = parseOptionalToken(23);
node.name = parseIdentifierOrPattern();
node.initializer = parseBindingElementInitializer(false);
return finishNode(node);
}
function parseObjectBindingElement() {
- var node = createNode(174);
+ var node = createNode(175);
node.dotDotDotToken = parseOptionalToken(23);
var tokenIsIdentifier = isIdentifier();
var propertyName = parsePropertyName();
@@ -14644,14 +15471,14 @@ var ts;
return finishNode(node);
}
function parseObjectBindingPattern() {
- var node = createNode(172);
+ var node = createNode(173);
parseExpected(16);
node.elements = parseDelimitedList(9, parseObjectBindingElement);
parseExpected(17);
return finishNode(node);
}
function parseArrayBindingPattern() {
- var node = createNode(173);
+ var node = createNode(174);
parseExpected(20);
node.elements = parseDelimitedList(10, parseArrayBindingElement);
parseExpected(21);
@@ -14670,7 +15497,7 @@ var ts;
return parseIdentifier();
}
function parseVariableDeclaration() {
- var node = createNode(223);
+ var node = createNode(225);
node.name = parseIdentifierOrPattern();
node.type = parseTypeAnnotation();
if (!isInOrOfKeyword(token())) {
@@ -14679,7 +15506,7 @@ var ts;
return finishNode(node);
}
function parseVariableDeclarationList(inForStatementInitializer) {
- var node = createNode(224);
+ var node = createNode(226);
switch (token()) {
case 103:
break;
@@ -14693,7 +15520,7 @@ var ts;
ts.Debug.fail();
}
nextToken();
- if (token() === 140 && lookAhead(canFollowContextualOfKeyword)) {
+ if (token() === 141 && lookAhead(canFollowContextualOfKeyword)) {
node.declarations = createMissingList();
}
else {
@@ -14708,7 +15535,7 @@ var ts;
return nextTokenIsIdentifier() && nextToken() === 19;
}
function parseVariableStatement(fullStart, decorators, modifiers) {
- var node = createNode(205, fullStart);
+ var node = createNode(207, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
node.declarationList = parseVariableDeclarationList(false);
@@ -14716,7 +15543,7 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseFunctionDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(225, fullStart);
+ var node = createNode(227, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
parseExpected(88);
@@ -14729,7 +15556,7 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseConstructorDeclaration(pos, decorators, modifiers) {
- var node = createNode(150, pos);
+ var node = createNode(151, pos);
node.decorators = decorators;
node.modifiers = modifiers;
parseExpected(122);
@@ -14738,7 +15565,7 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseMethodDeclaration(fullStart, decorators, modifiers, asteriskToken, name, questionToken, diagnosticMessage) {
- var method = createNode(149, fullStart);
+ var method = createNode(150, fullStart);
method.decorators = decorators;
method.modifiers = modifiers;
method.asteriskToken = asteriskToken;
@@ -14751,7 +15578,7 @@ var ts;
return addJSDocComment(finishNode(method));
}
function parsePropertyDeclaration(fullStart, decorators, modifiers, name, questionToken) {
- var property = createNode(147, fullStart);
+ var property = createNode(148, fullStart);
property.decorators = decorators;
property.modifiers = modifiers;
property.name = name;
@@ -14759,7 +15586,7 @@ var ts;
property.type = parseTypeAnnotation();
property.initializer = ts.hasModifier(property, 32)
? allowInAnd(parseNonParameterInitializer)
- : doOutsideOfContext(131072 | 65536, parseNonParameterInitializer);
+ : doOutsideOfContext(4096 | 2048, parseNonParameterInitializer);
parseSemicolon();
return addJSDocComment(finishNode(property));
}
@@ -14821,7 +15648,7 @@ var ts;
return true;
}
if (idToken !== undefined) {
- if (!ts.isKeyword(idToken) || idToken === 133 || idToken === 124) {
+ if (!ts.isKeyword(idToken) || idToken === 134 || idToken === 124) {
return true;
}
switch (token()) {
@@ -14844,7 +15671,7 @@ var ts;
if (!parseOptional(56)) {
break;
}
- var decorator = createNode(145, decoratorStart);
+ var decorator = createNode(146, decoratorStart);
decorator.expression = doInDecoratorContext(parseLeftHandSideExpressionOrHigher);
finishNode(decorator);
if (!decorators) {
@@ -14901,7 +15728,7 @@ var ts;
}
function parseClassElement() {
if (token() === 24) {
- var result = createNode(203);
+ var result = createNode(205);
nextToken();
return finishNode(result);
}
@@ -14926,16 +15753,16 @@ var ts;
return parsePropertyOrMethodDeclaration(fullStart, decorators, modifiers);
}
if (decorators || modifiers) {
- var name_13 = createMissingNode(70, true, ts.Diagnostics.Declaration_expected);
- return parsePropertyDeclaration(fullStart, decorators, modifiers, name_13, undefined);
+ var name = createMissingNode(70, true, ts.Diagnostics.Declaration_expected);
+ return parsePropertyDeclaration(fullStart, decorators, modifiers, name, undefined);
}
ts.Debug.fail("Should not have attempted to parse class member declaration.");
}
function parseClassExpression() {
- return parseClassDeclarationOrExpression(scanner.getStartPos(), undefined, undefined, 197);
+ return parseClassDeclarationOrExpression(scanner.getStartPos(), undefined, undefined, 198);
}
function parseClassDeclaration(fullStart, decorators, modifiers) {
- return parseClassDeclarationOrExpression(fullStart, decorators, modifiers, 226);
+ return parseClassDeclarationOrExpression(fullStart, decorators, modifiers, 228);
}
function parseClassDeclarationOrExpression(fullStart, decorators, modifiers, kind) {
var node = createNode(kind, fullStart);
@@ -14969,9 +15796,10 @@ var ts;
return undefined;
}
function parseHeritageClause() {
- if (token() === 84 || token() === 107) {
- var node = createNode(255);
- node.token = token();
+ var tok = token();
+ if (tok === 84 || tok === 107) {
+ var node = createNode(258);
+ node.token = tok;
nextToken();
node.types = parseDelimitedList(7, parseExpressionWithTypeArguments);
return finishNode(node);
@@ -14979,7 +15807,7 @@ var ts;
return undefined;
}
function parseExpressionWithTypeArguments() {
- var node = createNode(199);
+ var node = createNode(200);
node.expression = parseLeftHandSideExpressionOrHigher();
if (token() === 26) {
node.typeArguments = parseBracketedList(19, parseType, 26, 28);
@@ -14993,7 +15821,7 @@ var ts;
return parseList(5, parseClassElement);
}
function parseInterfaceDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(227, fullStart);
+ var node = createNode(229, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
parseExpected(108);
@@ -15004,10 +15832,10 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseTypeAliasDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(228, fullStart);
+ var node = createNode(230, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
- parseExpected(136);
+ parseExpected(137);
node.name = parseIdentifier();
node.typeParameters = parseTypeParameters();
parseExpected(57);
@@ -15016,13 +15844,13 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseEnumMember() {
- var node = createNode(260, scanner.getStartPos());
+ var node = createNode(263, scanner.getStartPos());
node.name = parsePropertyName();
node.initializer = allowInAnd(parseNonParameterInitializer);
return addJSDocComment(finishNode(node));
}
function parseEnumDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(229, fullStart);
+ var node = createNode(231, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
parseExpected(82);
@@ -15037,7 +15865,7 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseModuleBlock() {
- var node = createNode(231, scanner.getStartPos());
+ var node = createNode(233, scanner.getStartPos());
if (parseExpected(16)) {
node.statements = parseList(1, parseStatement);
parseExpected(17);
@@ -15048,7 +15876,7 @@ var ts;
return finishNode(node);
}
function parseModuleOrNamespaceDeclaration(fullStart, decorators, modifiers, flags) {
- var node = createNode(230, fullStart);
+ var node = createNode(232, fullStart);
var namespaceFlag = flags & 16;
node.decorators = decorators;
node.modifiers = modifiers;
@@ -15060,10 +15888,10 @@ var ts;
return addJSDocComment(finishNode(node));
}
function parseAmbientExternalModuleDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(230, fullStart);
+ var node = createNode(232, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
- if (token() === 139) {
+ if (token() === 140) {
node.name = parseIdentifier();
node.flags |= 512;
}
@@ -15080,7 +15908,7 @@ var ts;
}
function parseModuleDeclaration(fullStart, decorators, modifiers) {
var flags = 0;
- if (token() === 139) {
+ if (token() === 140) {
return parseAmbientExternalModuleDeclaration(fullStart, decorators, modifiers);
}
else if (parseOptional(128)) {
@@ -15105,7 +15933,7 @@ var ts;
return nextToken() === 40;
}
function parseNamespaceExportDeclaration(fullStart, decorators, modifiers) {
- var exportDeclaration = createNode(233, fullStart);
+ var exportDeclaration = createNode(235, fullStart);
exportDeclaration.decorators = decorators;
exportDeclaration.modifiers = modifiers;
parseExpected(117);
@@ -15120,38 +15948,41 @@ var ts;
var identifier;
if (isIdentifier()) {
identifier = parseIdentifier();
- if (token() !== 25 && token() !== 138) {
- var importEqualsDeclaration = createNode(234, fullStart);
- importEqualsDeclaration.decorators = decorators;
- importEqualsDeclaration.modifiers = modifiers;
- importEqualsDeclaration.name = identifier;
- parseExpected(57);
- importEqualsDeclaration.moduleReference = parseModuleReference();
- parseSemicolon();
- return addJSDocComment(finishNode(importEqualsDeclaration));
- }
- }
- var importDeclaration = createNode(235, fullStart);
+ if (token() !== 25 && token() !== 139) {
+ return parseImportEqualsDeclaration(fullStart, decorators, modifiers, identifier);
+ }
+ }
+ var importDeclaration = createNode(237, fullStart);
importDeclaration.decorators = decorators;
importDeclaration.modifiers = modifiers;
if (identifier ||
token() === 38 ||
token() === 16) {
importDeclaration.importClause = parseImportClause(identifier, afterImportPos);
- parseExpected(138);
+ parseExpected(139);
}
importDeclaration.moduleSpecifier = parseModuleSpecifier();
parseSemicolon();
return finishNode(importDeclaration);
}
+ function parseImportEqualsDeclaration(fullStart, decorators, modifiers, identifier) {
+ var importEqualsDeclaration = createNode(236, fullStart);
+ importEqualsDeclaration.decorators = decorators;
+ importEqualsDeclaration.modifiers = modifiers;
+ importEqualsDeclaration.name = identifier;
+ parseExpected(57);
+ importEqualsDeclaration.moduleReference = parseModuleReference();
+ parseSemicolon();
+ return addJSDocComment(finishNode(importEqualsDeclaration));
+ }
function parseImportClause(identifier, fullStart) {
- var importClause = createNode(236, fullStart);
+ var importClause = createNode(238, fullStart);
if (identifier) {
importClause.name = identifier;
}
if (!importClause.name ||
parseOptional(25)) {
- importClause.namedBindings = token() === 38 ? parseNamespaceImport() : parseNamedImportsOrExports(238);
+ importClause.namedBindings = token() === 38 ? parseNamespaceImport() : parseNamedImportsOrExports(240);
}
return finishNode(importClause);
}
@@ -15161,7 +15992,7 @@ var ts;
: parseEntityName(false);
}
function parseExternalModuleReference() {
- var node = createNode(245);
+ var node = createNode(247);
parseExpected(131);
parseExpected(18);
node.expression = parseModuleSpecifier();
@@ -15179,7 +16010,7 @@ var ts;
}
}
function parseNamespaceImport() {
- var namespaceImport = createNode(237);
+ var namespaceImport = createNode(239);
parseExpected(38);
parseExpected(117);
namespaceImport.name = parseIdentifier();
@@ -15187,14 +16018,14 @@ var ts;
}
function parseNamedImportsOrExports(kind) {
var node = createNode(kind);
- node.elements = parseBracketedList(22, kind === 238 ? parseImportSpecifier : parseExportSpecifier, 16, 17);
+ node.elements = parseBracketedList(22, kind === 240 ? parseImportSpecifier : parseExportSpecifier, 16, 17);
return finishNode(node);
}
function parseExportSpecifier() {
- return parseImportOrExportSpecifier(243);
+ return parseImportOrExportSpecifier(245);
}
function parseImportSpecifier() {
- return parseImportOrExportSpecifier(239);
+ return parseImportOrExportSpecifier(241);
}
function parseImportOrExportSpecifier(kind) {
var node = createNode(kind);
@@ -15213,23 +16044,23 @@ var ts;
else {
node.name = identifierName;
}
- if (kind === 239 && checkIdentifierIsKeyword) {
+ if (kind === 241 && checkIdentifierIsKeyword) {
parseErrorAtPosition(checkIdentifierStart, checkIdentifierEnd - checkIdentifierStart, ts.Diagnostics.Identifier_expected);
}
return finishNode(node);
}
function parseExportDeclaration(fullStart, decorators, modifiers) {
- var node = createNode(241, fullStart);
+ var node = createNode(243, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
if (parseOptional(38)) {
- parseExpected(138);
+ parseExpected(139);
node.moduleSpecifier = parseModuleSpecifier();
}
else {
- node.exportClause = parseNamedImportsOrExports(242);
- if (token() === 138 || (token() === 9 && !scanner.hasPrecedingLineBreak())) {
- parseExpected(138);
+ node.exportClause = parseNamedImportsOrExports(244);
+ if (token() === 139 || (token() === 9 && !scanner.hasPrecedingLineBreak())) {
+ parseExpected(139);
node.moduleSpecifier = parseModuleSpecifier();
}
}
@@ -15237,7 +16068,7 @@ var ts;
return finishNode(node);
}
function parseExportAssignment(fullStart, decorators, modifiers) {
- var node = createNode(240, fullStart);
+ var node = createNode(242, fullStart);
node.decorators = decorators;
node.modifiers = modifiers;
if (parseOptional(57)) {
@@ -15256,6 +16087,7 @@ var ts;
var typeReferenceDirectives = [];
var amdDependencies = [];
var amdModuleName;
+ var checkJsDirective = undefined;
while (true) {
var kind = triviaScanner.scan();
if (kind !== 2) {
@@ -15266,7 +16098,11 @@ var ts;
break;
}
}
- var range = { pos: triviaScanner.getTokenPos(), end: triviaScanner.getTextPos(), kind: triviaScanner.getToken() };
+ var range = {
+ kind: triviaScanner.getToken(),
+ pos: triviaScanner.getTokenPos(),
+ end: triviaScanner.getTextPos(),
+ };
var comment = sourceText.substring(range.pos, range.end);
var referencePathMatchResult = ts.getFileReferenceFromReferencePath(comment, range);
if (referencePathMatchResult) {
@@ -15306,20 +16142,30 @@ var ts;
amdDependencies.push(amdDependency);
}
}
+ var checkJsDirectiveRegEx = /^\/\/\/?\s*(@ts-check|@ts-nocheck)\s*$/gim;
+ var checkJsDirectiveMatchResult = checkJsDirectiveRegEx.exec(comment);
+ if (checkJsDirectiveMatchResult) {
+ checkJsDirective = {
+ enabled: ts.compareStrings(checkJsDirectiveMatchResult[1], "@ts-check", true) === 0,
+ end: range.end,
+ pos: range.pos
+ };
+ }
}
}
sourceFile.referencedFiles = referencedFiles;
sourceFile.typeReferenceDirectives = typeReferenceDirectives;
sourceFile.amdDependencies = amdDependencies;
sourceFile.moduleName = amdModuleName;
+ sourceFile.checkJsDirective = checkJsDirective;
}
function setExternalModuleIndicator(sourceFile) {
sourceFile.externalModuleIndicator = ts.forEach(sourceFile.statements, function (node) {
return ts.hasModifier(node, 1)
- || node.kind === 234 && node.moduleReference.kind === 245
- || node.kind === 235
- || node.kind === 240
- || node.kind === 241
+ || node.kind === 236 && node.moduleReference.kind === 247
+ || node.kind === 237
+ || node.kind === 242
+ || node.kind === 243
? node
: undefined;
});
@@ -15355,7 +16201,7 @@ var ts;
}
JSDocParser.parseJSDocTypeExpressionForTests = parseJSDocTypeExpressionForTests;
function parseJSDocTypeExpression() {
- var result = createNode(262, scanner.getTokenPos());
+ var result = createNode(266, scanner.getTokenPos());
parseExpected(16);
result.type = parseJSDocTopLevelType();
parseExpected(17);
@@ -15366,12 +16212,12 @@ var ts;
function parseJSDocTopLevelType() {
var type = parseJSDocType();
if (token() === 48) {
- var unionType = createNode(266, type.pos);
+ var unionType = createNode(270, type.pos);
unionType.types = parseJSDocTypeList(type);
type = finishNode(unionType);
}
if (token() === 57) {
- var optionalType = createNode(273, type.pos);
+ var optionalType = createNode(277, type.pos);
nextToken();
optionalType.type = type;
type = finishNode(optionalType);
@@ -15382,20 +16228,20 @@ var ts;
var type = parseBasicTypeExpression();
while (true) {
if (token() === 20) {
- var arrayType = createNode(265, type.pos);
+ var arrayType = createNode(269, type.pos);
arrayType.elementType = type;
nextToken();
parseExpected(21);
type = finishNode(arrayType);
}
else if (token() === 54) {
- var nullableType = createNode(268, type.pos);
+ var nullableType = createNode(272, type.pos);
nullableType.type = type;
nextToken();
type = finishNode(nullableType);
}
else if (token() === 50) {
- var nonNullableType = createNode(269, type.pos);
+ var nonNullableType = createNode(273, type.pos);
nonNullableType.type = type;
nextToken();
type = finishNode(nonNullableType);
@@ -15429,14 +16275,15 @@ var ts;
case 98:
return parseJSDocThisType();
case 118:
- case 134:
+ case 135:
case 132:
case 121:
- case 135:
+ case 136:
case 104:
case 94:
- case 137:
+ case 138:
case 129:
+ case 133:
return parseTokenNode();
case 9:
case 8:
@@ -15447,27 +16294,27 @@ var ts;
return parseJSDocTypeReference();
}
function parseJSDocThisType() {
- var result = createNode(277);
+ var result = createNode(281);
nextToken();
parseExpected(55);
result.type = parseJSDocType();
return finishNode(result);
}
function parseJSDocConstructorType() {
- var result = createNode(276);
+ var result = createNode(280);
nextToken();
parseExpected(55);
result.type = parseJSDocType();
return finishNode(result);
}
function parseJSDocVariadicType() {
- var result = createNode(275);
+ var result = createNode(279);
nextToken();
result.type = parseJSDocType();
return finishNode(result);
}
function parseJSDocFunctionType() {
- var result = createNode(274);
+ var result = createNode(278);
nextToken();
parseExpected(18);
result.parameters = parseDelimitedList(23, parseJSDocParameter);
@@ -15480,7 +16327,7 @@ var ts;
return finishNode(result);
}
function parseJSDocParameter() {
- var parameter = createNode(144);
+ var parameter = createNode(145);
parameter.type = parseJSDocType();
if (parseOptional(57)) {
parameter.questionToken = createNode(57);
@@ -15488,7 +16335,7 @@ var ts;
return finishNode(parameter);
}
function parseJSDocTypeReference() {
- var result = createNode(272);
+ var result = createNode(276);
result.name = parseSimplePropertyName();
if (token() === 26) {
result.typeArguments = parseTypeArguments();
@@ -15522,24 +16369,24 @@ var ts;
}
}
function parseQualifiedName(left) {
- var result = createNode(141, left.pos);
+ var result = createNode(142, left.pos);
result.left = left;
result.right = parseIdentifierName();
return finishNode(result);
}
function parseJSDocRecordType() {
- var result = createNode(270);
+ var result = createNode(274);
result.literal = parseTypeLiteral();
return finishNode(result);
}
function parseJSDocNonNullableType() {
- var result = createNode(269);
+ var result = createNode(273);
nextToken();
result.type = parseJSDocType();
return finishNode(result);
}
function parseJSDocTupleType() {
- var result = createNode(267);
+ var result = createNode(271);
nextToken();
result.types = parseDelimitedList(26, parseJSDocType);
checkForTrailingComma(result.types);
@@ -15553,7 +16400,7 @@ var ts;
}
}
function parseJSDocUnionType() {
- var result = createNode(266);
+ var result = createNode(270);
nextToken();
result.types = parseJSDocTypeList(parseJSDocType());
parseExpected(19);
@@ -15569,12 +16416,12 @@ var ts;
return types;
}
function parseJSDocAllType() {
- var result = createNode(263);
+ var result = createNode(267);
nextToken();
return finishNode(result);
}
function parseJSDocLiteralType() {
- var result = createNode(288);
+ var result = createNode(292);
result.literal = parseLiteralTypeNode();
return finishNode(result);
}
@@ -15587,11 +16434,11 @@ var ts;
token() === 28 ||
token() === 57 ||
token() === 48) {
- var result = createNode(264, pos);
+ var result = createNode(268, pos);
return finishNode(result);
}
else {
- var result = createNode(268, pos);
+ var result = createNode(272, pos);
result.type = parseJSDocType();
return finishNode(result);
}
@@ -15676,7 +16523,7 @@ var ts;
break;
case 38:
var asterisk = scanner.getTokenText();
- if (state === 1) {
+ if (state === 1 || state === 2) {
state = 2;
pushComment(asterisk);
}
@@ -15691,7 +16538,10 @@ var ts;
break;
case 5:
var whitespace = scanner.getTokenText();
- if (state === 2 || margin !== undefined && indent + whitespace.length > margin) {
+ if (state === 2) {
+ comments.push(whitespace);
+ }
+ else if (margin !== undefined && indent + whitespace.length > margin) {
comments.push(whitespace.slice(margin - indent - 1));
}
indent += whitespace.length;
@@ -15699,6 +16549,7 @@ var ts;
case 1:
break;
default:
+ state = 2;
pushComment(scanner.getTokenText());
break;
}
@@ -15731,7 +16582,7 @@ var ts;
content.charCodeAt(start + 3) !== 42;
}
function createJSDocComment() {
- var result = createNode(278, start);
+ var result = createNode(282, start);
result.tags = tags;
result.comment = comments.length ? comments.join("") : undefined;
return finishNode(result, end);
@@ -15788,7 +16639,7 @@ var ts;
}
function parseTagComments(indent) {
var comments = [];
- var state = 1;
+ var state = 0;
var margin;
function pushComment(text) {
if (!margin) {
@@ -15841,7 +16692,7 @@ var ts;
return comments;
}
function parseUnknownTag(atToken, tagName) {
- var result = createNode(279, atToken.pos);
+ var result = createNode(283, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
return finishNode(result);
@@ -15896,7 +16747,7 @@ var ts;
if (!typeExpression) {
typeExpression = tryParseTypeExpression();
}
- var result = createNode(281, atToken.pos);
+ var result = createNode(285, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.preParameterName = preName;
@@ -15907,20 +16758,20 @@ var ts;
return finishNode(result);
}
function parseReturnTag(atToken, tagName) {
- if (ts.forEach(tags, function (t) { return t.kind === 282; })) {
+ if (ts.forEach(tags, function (t) { return t.kind === 286; })) {
parseErrorAtPosition(tagName.pos, scanner.getTokenPos() - tagName.pos, ts.Diagnostics._0_tag_already_specified, tagName.text);
}
- var result = createNode(282, atToken.pos);
+ var result = createNode(286, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.typeExpression = tryParseTypeExpression();
return finishNode(result);
}
function parseTypeTag(atToken, tagName) {
- if (ts.forEach(tags, function (t) { return t.kind === 283; })) {
+ if (ts.forEach(tags, function (t) { return t.kind === 287; })) {
parseErrorAtPosition(tagName.pos, scanner.getTokenPos() - tagName.pos, ts.Diagnostics._0_tag_already_specified, tagName.text);
}
- var result = createNode(283, atToken.pos);
+ var result = createNode(287, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.typeExpression = tryParseTypeExpression();
@@ -15935,7 +16786,7 @@ var ts;
parseErrorAtPosition(scanner.getStartPos(), 0, ts.Diagnostics.Identifier_expected);
return undefined;
}
- var result = createNode(286, atToken.pos);
+ var result = createNode(290, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.name = name;
@@ -15944,7 +16795,7 @@ var ts;
}
function parseAugmentsTag(atToken, tagName) {
var typeExpression = tryParseTypeExpression();
- var result = createNode(280, atToken.pos);
+ var result = createNode(284, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.typeExpression = typeExpression;
@@ -15953,25 +16804,28 @@ var ts;
function parseTypedefTag(atToken, tagName) {
var typeExpression = tryParseTypeExpression();
skipWhitespace();
- var typedefTag = createNode(285, atToken.pos);
+ var typedefTag = createNode(289, atToken.pos);
typedefTag.atToken = atToken;
typedefTag.tagName = tagName;
typedefTag.fullName = parseJSDocTypeNameWithNamespace(0);
if (typedefTag.fullName) {
var rightNode = typedefTag.fullName;
- while (rightNode.kind !== 70) {
+ while (true) {
+ if (rightNode.kind === 70 || !rightNode.body) {
+ typedefTag.name = rightNode.kind === 70 ? rightNode : rightNode.name;
+ break;
+ }
rightNode = rightNode.body;
}
- typedefTag.name = rightNode;
}
typedefTag.typeExpression = typeExpression;
skipWhitespace();
if (typeExpression) {
- if (typeExpression.type.kind === 272) {
+ if (typeExpression.type.kind === 276) {
var jsDocTypeReference = typeExpression.type;
if (jsDocTypeReference.name.kind === 70) {
- var name_14 = jsDocTypeReference.name;
- if (name_14.text === "Object") {
+ var name = jsDocTypeReference.name;
+ if (name.text === "Object") {
typedefTag.jsDocTypeLiteral = scanChildTags();
}
}
@@ -15985,7 +16839,7 @@ var ts;
}
return finishNode(typedefTag);
function scanChildTags() {
- var jsDocTypeLiteral = createNode(287, scanner.getStartPos());
+ var jsDocTypeLiteral = createNode(291, scanner.getStartPos());
var resumePos = scanner.getStartPos();
var canParseTag = true;
var seenAsterisk = false;
@@ -16015,6 +16869,7 @@ var ts;
break;
case 70:
canParseTag = false;
+ break;
case 1:
break;
}
@@ -16026,7 +16881,7 @@ var ts;
var pos = scanner.getTokenPos();
var typeNameOrNamespaceName = parseJSDocIdentifierName();
if (typeNameOrNamespaceName && parseOptional(22)) {
- var jsDocNamespaceNode = createNode(230, pos);
+ var jsDocNamespaceNode = createNode(232, pos);
jsDocNamespaceNode.flags |= flags;
jsDocNamespaceNode.name = typeNameOrNamespaceName;
jsDocNamespaceNode.body = parseJSDocTypeNameWithNamespace(4);
@@ -16070,19 +16925,19 @@ var ts;
return false;
}
function parseTemplateTag(atToken, tagName) {
- if (ts.forEach(tags, function (t) { return t.kind === 284; })) {
+ if (ts.forEach(tags, function (t) { return t.kind === 288; })) {
parseErrorAtPosition(tagName.pos, scanner.getTokenPos() - tagName.pos, ts.Diagnostics._0_tag_already_specified, tagName.text);
}
var typeParameters = createNodeArray();
while (true) {
- var name_15 = parseJSDocIdentifierName();
+ var name = parseJSDocIdentifierName();
skipWhitespace();
- if (!name_15) {
+ if (!name) {
parseErrorAtPosition(scanner.getStartPos(), 0, ts.Diagnostics.Identifier_expected);
return undefined;
}
- var typeParameter = createNode(143, name_15.pos);
- typeParameter.name = name_15;
+ var typeParameter = createNode(144, name.pos);
+ typeParameter.name = name;
finishNode(typeParameter);
typeParameters.push(typeParameter);
if (token() === 25) {
@@ -16093,7 +16948,7 @@ var ts;
break;
}
}
- var result = createNode(284, atToken.pos);
+ var result = createNode(288, atToken.pos);
result.atToken = atToken;
result.tagName = tagName;
result.typeParameters = typeParameters;
@@ -16385,7 +17240,7 @@ var ts;
}
function visitArray(array) {
if (position >= array.pos && position < array.end) {
- for (var i = 0, n = array.length; i < n; i++) {
+ for (var i = 0; i < array.length; i++) {
var child = array[i];
if (child) {
if (child.pos === position) {
@@ -16412,16 +17267,16 @@ var ts;
var ts;
(function (ts) {
function getModuleInstanceState(node) {
- if (node.kind === 227 || node.kind === 228) {
+ if (node.kind === 229 || node.kind === 230) {
return 0;
}
else if (ts.isConstEnumDeclaration(node)) {
return 2;
}
- else if ((node.kind === 235 || node.kind === 234) && !(ts.hasModifier(node, 1))) {
+ else if ((node.kind === 237 || node.kind === 236) && !(ts.hasModifier(node, 1))) {
return 0;
}
- else if (node.kind === 231) {
+ else if (node.kind === 233) {
var state_1 = 0;
ts.forEachChild(node, function (n) {
switch (getModuleInstanceState(n)) {
@@ -16437,7 +17292,7 @@ var ts;
});
return state_1;
}
- else if (node.kind === 230) {
+ else if (node.kind === 232) {
var body = node.body;
return body ? getModuleInstanceState(body) : 1;
}
@@ -16519,7 +17374,7 @@ var ts;
}
return bindSourceFile;
function bindInStrictMode(file, opts) {
- if (opts.alwaysStrict && !ts.isDeclarationFile(file)) {
+ if ((opts.alwaysStrict === undefined ? opts.strict : opts.alwaysStrict) && !ts.isDeclarationFile(file)) {
return true;
}
else {
@@ -16546,7 +17401,7 @@ var ts;
if (symbolFlags & 107455) {
var valueDeclaration = symbol.valueDeclaration;
if (!valueDeclaration ||
- (valueDeclaration.kind !== node.kind && valueDeclaration.kind === 230)) {
+ (valueDeclaration.kind !== node.kind && valueDeclaration.kind === 232)) {
symbol.valueDeclaration = node;
}
}
@@ -16556,7 +17411,7 @@ var ts;
if (ts.isAmbientModule(node)) {
return ts.isGlobalScopeAugmentation(node) ? "__global" : "\"" + node.name.text + "\"";
}
- if (node.name.kind === 142) {
+ if (node.name.kind === 143) {
var nameExpression = node.name.expression;
if (ts.isStringOrNumericLiteral(nameExpression)) {
return nameExpression.text;
@@ -16567,46 +17422,47 @@ var ts;
return node.name.text;
}
switch (node.kind) {
- case 150:
+ case 151:
return "__constructor";
- case 158:
- case 153:
- return "__call";
case 159:
case 154:
- return "__new";
+ return "__call";
+ case 160:
case 155:
+ return "__new";
+ case 156:
return "__index";
- case 241:
+ case 243:
return "__export";
- case 240:
+ case 242:
return node.isExportEquals ? "export=" : "default";
- case 192:
+ case 193:
switch (ts.getSpecialPropertyAssignmentKind(node)) {
case 2:
return "export=";
case 1:
case 4:
+ case 5:
return node.left.name.text;
case 3:
return node.left.expression.name.text;
}
ts.Debug.fail("Unknown binary declaration kind");
break;
- case 225:
- case 226:
+ case 227:
+ case 228:
return ts.hasModifier(node, 512) ? "default" : undefined;
- case 274:
+ case 278:
return ts.isJSDocConstructSignature(node) ? "__new" : "__call";
- case 144:
- ts.Debug.assert(node.parent.kind === 274);
+ case 145:
+ ts.Debug.assert(node.parent.kind === 278);
var functionType = node.parent;
var index = ts.indexOf(functionType.parameters, node);
return "arg" + index;
- case 285:
+ case 289:
var parentNode = node.parent && node.parent.parent;
var nameFromParentNode = void 0;
- if (parentNode && parentNode.kind === 205) {
+ if (parentNode && parentNode.kind === 207) {
if (parentNode.declarationList.declarations.length > 0) {
var nameIdentifier = parentNode.declarationList.declarations[0].name;
if (nameIdentifier.kind === 70) {
@@ -16629,13 +17485,16 @@ var ts;
symbol = createSymbol(0, "__missing");
}
else {
- symbol = symbolTable[name] || (symbolTable[name] = createSymbol(0, name));
+ symbol = symbolTable.get(name);
+ if (!symbol) {
+ symbolTable.set(name, symbol = createSymbol(0, name));
+ }
if (name && (includes & 788448)) {
- classifiableNames[name] = name;
+ classifiableNames.set(name, name);
}
if (symbol.flags & excludes) {
if (symbol.isReplaceableByMethod) {
- symbol = symbolTable[name] = createSymbol(0, name);
+ symbolTable.set(name, symbol = createSymbol(0, name));
}
else {
if (node.name) {
@@ -16650,7 +17509,7 @@ var ts;
}
else {
if (symbol.declarations && symbol.declarations.length &&
- (isDefaultExport || (node.kind === 240 && !node.isExportEquals))) {
+ (isDefaultExport || (node.kind === 242 && !node.isExportEquals))) {
message_1 = ts.Diagnostics.A_module_cannot_have_multiple_default_exports;
}
}
@@ -16670,7 +17529,7 @@ var ts;
function declareModuleMember(node, symbolFlags, symbolExcludes) {
var hasExportModifier = ts.getCombinedModifierFlags(node) & 1;
if (symbolFlags & 8388608) {
- if (node.kind === 243 || (node.kind === 234 && hasExportModifier)) {
+ if (node.kind === 245 || (node.kind === 236 && hasExportModifier)) {
return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
}
else {
@@ -16678,7 +17537,7 @@ var ts;
}
}
else {
- var isJSDocTypedefInJSDocNamespace = node.kind === 285 &&
+ var isJSDocTypedefInJSDocNamespace = node.kind === 289 &&
node.name &&
node.name.kind === 70 &&
node.name.isInJSDocNamespace;
@@ -16733,13 +17592,13 @@ var ts;
activeLabels = undefined;
hasExplicitReturn = false;
bindChildren(node);
- node.flags &= ~64896;
+ node.flags &= ~1408;
if (!(currentFlow.flags & 1) && containerFlags & 8 && ts.nodeIsPresent(node.body)) {
node.flags |= 128;
if (hasExplicitReturn)
node.flags |= 256;
}
- if (node.kind === 261) {
+ if (node.kind === 264) {
node.flags |= emitFlags;
}
if (isIIFE) {
@@ -16815,66 +17674,72 @@ var ts;
return;
}
switch (node.kind) {
- case 210:
+ case 212:
bindWhileStatement(node);
break;
- case 209:
+ case 211:
bindDoStatement(node);
break;
- case 211:
+ case 213:
bindForStatement(node);
break;
- case 212:
- case 213:
+ case 214:
+ case 215:
bindForInOrForOfStatement(node);
break;
- case 208:
+ case 210:
bindIfStatement(node);
break;
- case 216:
- case 220:
+ case 218:
+ case 222:
bindReturnOrThrow(node);
break;
- case 215:
- case 214:
+ case 217:
+ case 216:
bindBreakOrContinueStatement(node);
break;
- case 221:
+ case 223:
bindTryStatement(node);
break;
- case 218:
+ case 220:
bindSwitchStatement(node);
break;
- case 232:
+ case 234:
bindCaseBlock(node);
break;
- case 253:
+ case 256:
bindCaseClause(node);
break;
- case 219:
+ case 221:
bindLabeledStatement(node);
break;
- case 190:
+ case 191:
bindPrefixUnaryExpressionFlow(node);
break;
- case 191:
+ case 192:
bindPostfixUnaryExpressionFlow(node);
break;
- case 192:
+ case 193:
bindBinaryExpressionFlow(node);
break;
- case 186:
+ case 187:
bindDeleteExpressionFlow(node);
break;
- case 193:
+ case 194:
bindConditionalExpressionFlow(node);
break;
- case 223:
+ case 225:
bindVariableDeclarationFlow(node);
break;
- case 179:
+ case 180:
bindCallExpressionFlow(node);
break;
+ case 282:
+ bindJSDocComment(node);
+ break;
+ case 289:
+ bindJSDocTypedefTag(node);
+ break;
default:
bindEachChild(node);
break;
@@ -16884,15 +17749,15 @@ var ts;
switch (expr.kind) {
case 70:
case 98:
- case 177:
+ case 178:
return isNarrowableReference(expr);
- case 179:
+ case 180:
return hasNarrowableArgument(expr);
- case 183:
+ case 184:
return isNarrowingExpression(expr.expression);
- case 192:
+ case 193:
return isNarrowingBinaryExpression(expr);
- case 190:
+ case 191:
return expr.operator === 50 && isNarrowingExpression(expr.operand);
}
return false;
@@ -16900,7 +17765,8 @@ var ts;
function isNarrowableReference(expr) {
return expr.kind === 70 ||
expr.kind === 98 ||
- expr.kind === 177 && isNarrowableReference(expr.expression);
+ expr.kind === 96 ||
+ expr.kind === 178 && isNarrowableReference(expr.expression);
}
function hasNarrowableArgument(expr) {
if (expr.arguments) {
@@ -16911,14 +17777,14 @@ var ts;
}
}
}
- if (expr.expression.kind === 177 &&
+ if (expr.expression.kind === 178 &&
isNarrowableReference(expr.expression.expression)) {
return true;
}
return false;
}
function isNarrowingTypeofOperands(expr1, expr2) {
- return expr1.kind === 187 && isNarrowableOperand(expr1.expression) && expr2.kind === 9;
+ return expr1.kind === 188 && isNarrowableOperand(expr1.expression) && expr2.kind === 9;
}
function isNarrowingBinaryExpression(expr) {
switch (expr.operatorToken.kind) {
@@ -16939,9 +17805,9 @@ var ts;
}
function isNarrowableOperand(expr) {
switch (expr.kind) {
- case 183:
+ case 184:
return isNarrowableOperand(expr.expression);
- case 192:
+ case 193:
switch (expr.operatorToken.kind) {
case 57:
return isNarrowableOperand(expr.left);
@@ -17035,33 +17901,33 @@ var ts;
function isStatementCondition(node) {
var parent = node.parent;
switch (parent.kind) {
- case 208:
case 210:
- case 209:
- return parent.expression === node;
+ case 212:
case 211:
- case 193:
+ return parent.expression === node;
+ case 213:
+ case 194:
return parent.condition === node;
}
return false;
}
function isLogicalExpression(node) {
while (true) {
- if (node.kind === 183) {
+ if (node.kind === 184) {
node = node.expression;
}
- else if (node.kind === 190 && node.operator === 50) {
+ else if (node.kind === 191 && node.operator === 50) {
node = node.operand;
}
else {
- return node.kind === 192 && (node.operatorToken.kind === 52 ||
+ return node.kind === 193 && (node.operatorToken.kind === 52 ||
node.operatorToken.kind === 53);
}
}
}
function isTopLevelLogicalExpression(node) {
- while (node.parent.kind === 183 ||
- node.parent.kind === 190 &&
+ while (node.parent.kind === 184 ||
+ node.parent.kind === 191 &&
node.parent.operator === 50) {
node = node.parent;
}
@@ -17103,7 +17969,7 @@ var ts;
}
function bindDoStatement(node) {
var preDoLabel = createLoopLabel();
- var enclosingLabeledStatement = node.parent.kind === 219
+ var enclosingLabeledStatement = node.parent.kind === 221
? ts.lastOrUndefined(activeLabels)
: undefined;
var preConditionLabel = enclosingLabeledStatement ? enclosingLabeledStatement.continueTarget : createBranchLabel();
@@ -17135,10 +18001,13 @@ var ts;
var postLoopLabel = createBranchLabel();
addAntecedent(preLoopLabel, currentFlow);
currentFlow = preLoopLabel;
+ if (node.kind === 215) {
+ bind(node.awaitModifier);
+ }
bind(node.expression);
addAntecedent(postLoopLabel, currentFlow);
bind(node.initializer);
- if (node.initializer.kind !== 224) {
+ if (node.initializer.kind !== 226) {
bindAssignmentTargetFlow(node.initializer);
}
bindIterativeStatement(node.statement, postLoopLabel, preLoopLabel);
@@ -17160,7 +18029,7 @@ var ts;
}
function bindReturnOrThrow(node) {
bind(node.expression);
- if (node.kind === 216) {
+ if (node.kind === 218) {
hasExplicitReturn = true;
if (currentReturnTarget) {
addAntecedent(currentReturnTarget, currentFlow);
@@ -17180,7 +18049,7 @@ var ts;
return undefined;
}
function bindBreakOrContinueFlow(node, breakTarget, continueTarget) {
- var flowLabel = node.kind === 215 ? breakTarget : continueTarget;
+ var flowLabel = node.kind === 217 ? breakTarget : continueTarget;
if (flowLabel) {
addAntecedent(flowLabel, currentFlow);
currentFlow = unreachableFlow;
@@ -17213,7 +18082,8 @@ var ts;
flowAfterCatch = currentFlow;
}
if (node.finallyBlock) {
- addAntecedent(preFinallyLabel, preTryFlow);
+ var preFinallyFlow = { flags: 2048, antecedent: preTryFlow, lock: {} };
+ addAntecedent(preFinallyLabel, preFinallyFlow);
currentFlow = finishFlowLabel(preFinallyLabel);
bind(node.finallyBlock);
if (!(currentFlow.flags & 1)) {
@@ -17223,6 +18093,11 @@ var ts;
: unreachableFlow;
}
}
+ if (!(currentFlow.flags & 1)) {
+ var afterFinallyFlow = { flags: 4096, antecedent: currentFlow };
+ preFinallyFlow.lock = afterFinallyFlow;
+ currentFlow = afterFinallyFlow;
+ }
}
else {
currentFlow = finishFlowLabel(preFinallyLabel);
@@ -17237,7 +18112,7 @@ var ts;
preSwitchCaseFlow = currentFlow;
bind(node.caseBlock);
addAntecedent(postSwitchLabel, currentFlow);
- var hasDefault = ts.forEach(node.caseBlock.clauses, function (c) { return c.kind === 254; });
+ var hasDefault = ts.forEach(node.caseBlock.clauses, function (c) { return c.kind === 257; });
node.possiblyExhaustive = !hasDefault && !postSwitchLabel.antecedents;
if (!hasDefault) {
addAntecedent(postSwitchLabel, createFlowSwitchClause(preSwitchCaseFlow, node, 0, 0));
@@ -17302,13 +18177,13 @@ var ts;
if (!activeLabel.referenced && !options.allowUnusedLabels) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node.label, ts.Diagnostics.Unused_label));
}
- if (!node.statement || node.statement.kind !== 209) {
+ if (!node.statement || node.statement.kind !== 211) {
addAntecedent(postStatementLabel, currentFlow);
currentFlow = finishFlowLabel(postStatementLabel);
}
}
function bindDestructuringTargetFlow(node) {
- if (node.kind === 192 && node.operatorToken.kind === 57) {
+ if (node.kind === 193 && node.operatorToken.kind === 57) {
bindAssignmentTargetFlow(node.left);
}
else {
@@ -17319,10 +18194,10 @@ var ts;
if (isNarrowableReference(node)) {
currentFlow = createFlowAssignment(currentFlow, node);
}
- else if (node.kind === 175) {
+ else if (node.kind === 176) {
for (var _i = 0, _a = node.elements; _i < _a.length; _i++) {
var e = _a[_i];
- if (e.kind === 196) {
+ if (e.kind === 197) {
bindAssignmentTargetFlow(e.expression);
}
else {
@@ -17330,16 +18205,16 @@ var ts;
}
}
}
- else if (node.kind === 176) {
+ else if (node.kind === 177) {
for (var _b = 0, _c = node.properties; _b < _c.length; _b++) {
var p = _c[_b];
- if (p.kind === 257) {
+ if (p.kind === 260) {
bindDestructuringTargetFlow(p.initializer);
}
- else if (p.kind === 258) {
+ else if (p.kind === 261) {
bindAssignmentTargetFlow(p.name);
}
- else if (p.kind === 259) {
+ else if (p.kind === 262) {
bindAssignmentTargetFlow(p.expression);
}
}
@@ -17395,7 +18270,7 @@ var ts;
bindEachChild(node);
if (ts.isAssignmentOperator(operator) && !ts.isAssignmentTarget(node)) {
bindAssignmentTargetFlow(node.left);
- if (operator === 57 && node.left.kind === 178) {
+ if (operator === 57 && node.left.kind === 179) {
var elementAccess = node.left;
if (isNarrowableOperand(elementAccess.expression)) {
currentFlow = createFlowArrayMutation(currentFlow, node);
@@ -17406,7 +18281,7 @@ var ts;
}
function bindDeleteExpressionFlow(node) {
bindEachChild(node);
- if (node.expression.kind === 177) {
+ if (node.expression.kind === 178) {
bindAssignmentTargetFlow(node.expression);
}
}
@@ -17439,16 +18314,31 @@ var ts;
}
function bindVariableDeclarationFlow(node) {
bindEachChild(node);
- if (node.initializer || node.parent.parent.kind === 212 || node.parent.parent.kind === 213) {
+ if (node.initializer || node.parent.parent.kind === 214 || node.parent.parent.kind === 215) {
bindInitializedVariableFlow(node);
}
}
+ function bindJSDocComment(node) {
+ ts.forEachChild(node, function (n) {
+ if (n.kind !== 289) {
+ bind(n);
+ }
+ });
+ }
+ function bindJSDocTypedefTag(node) {
+ ts.forEachChild(node, function (n) {
+ if (node.fullName && n === node.name && node.fullName.kind !== 70) {
+ return;
+ }
+ bind(n);
+ });
+ }
function bindCallExpressionFlow(node) {
var expr = node.expression;
- while (expr.kind === 183) {
+ while (expr.kind === 184) {
expr = expr.expression;
}
- if (expr.kind === 184 || expr.kind === 185) {
+ if (expr.kind === 185 || expr.kind === 186) {
bindEach(node.typeArguments);
bindEach(node.arguments);
bind(node.expression);
@@ -17456,7 +18346,7 @@ var ts;
else {
bindEachChild(node);
}
- if (node.expression.kind === 177) {
+ if (node.expression.kind === 178) {
var propertyAccess = node.expression;
if (isNarrowableOperand(propertyAccess.expression) && ts.isPushOrUnshiftIdentifier(propertyAccess.name)) {
currentFlow = createFlowArrayMutation(currentFlow, node);
@@ -17465,52 +18355,53 @@ var ts;
}
function getContainerFlags(node) {
switch (node.kind) {
- case 197:
- case 226:
- case 229:
- case 176:
- case 161:
- case 287:
- case 270:
+ case 198:
+ case 228:
+ case 231:
+ case 177:
+ case 162:
+ case 291:
+ case 274:
+ case 253:
return 1;
- case 227:
+ case 229:
return 1 | 64;
- case 274:
+ case 278:
+ case 232:
case 230:
- case 228:
- case 170:
+ case 171:
return 1 | 32;
- case 261:
+ case 264:
return 1 | 4 | 32;
- case 149:
+ case 150:
if (ts.isObjectLiteralOrClassExpressionMethod(node)) {
return 1 | 4 | 32 | 8 | 128;
}
- case 150:
- case 225:
- case 148:
case 151:
+ case 227:
+ case 149:
case 152:
case 153:
case 154:
case 155:
- case 158:
+ case 156:
case 159:
+ case 160:
return 1 | 4 | 32 | 8;
- case 184:
case 185:
+ case 186:
return 1 | 4 | 32 | 8 | 16;
- case 231:
+ case 233:
return 4;
- case 147:
+ case 148:
return node.initializer ? 4 : 0;
- case 256:
- case 211:
- case 212:
+ case 259:
case 213:
- case 232:
+ case 214:
+ case 215:
+ case 234:
return 2;
- case 204:
+ case 206:
return ts.isFunctionLike(node.parent) ? 0 : 2;
}
return 0;
@@ -17526,37 +18417,38 @@ var ts;
}
function declareSymbolAndAddToSymbolTableWorker(node, symbolFlags, symbolExcludes) {
switch (container.kind) {
- case 230:
+ case 232:
return declareModuleMember(node, symbolFlags, symbolExcludes);
- case 261:
+ case 264:
return declareSourceFileMember(node, symbolFlags, symbolExcludes);
- case 197:
- case 226:
+ case 198:
+ case 228:
return declareClassMember(node, symbolFlags, symbolExcludes);
- case 229:
+ case 231:
return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
- case 161:
- case 176:
- case 227:
- case 270:
- case 287:
+ case 162:
+ case 177:
+ case 229:
+ case 274:
+ case 291:
+ case 253:
return declareSymbol(container.symbol.members, container.symbol, node, symbolFlags, symbolExcludes);
- case 158:
case 159:
- case 153:
+ case 160:
case 154:
case 155:
- case 149:
- case 148:
+ case 156:
case 150:
+ case 149:
case 151:
case 152:
- case 225:
- case 184:
+ case 153:
+ case 227:
case 185:
- case 274:
- case 228:
- case 170:
+ case 186:
+ case 278:
+ case 230:
+ case 171:
return declareSymbol(container.locals, undefined, node, symbolFlags, symbolExcludes);
}
}
@@ -17571,11 +18463,11 @@ var ts;
: declareSymbol(file.locals, undefined, node, symbolFlags, symbolExcludes);
}
function hasExportDeclarations(node) {
- var body = node.kind === 261 ? node : node.body;
- if (body && (body.kind === 261 || body.kind === 231)) {
+ var body = node.kind === 264 ? node : node.body;
+ if (body && (body.kind === 264 || body.kind === 233)) {
for (var _i = 0, _a = body.statements; _i < _a.length; _i++) {
var stat = _a[_i];
- if (stat.kind === 241 || stat.kind === 240) {
+ if (stat.kind === 243 || stat.kind === 242) {
return true;
}
}
@@ -17597,7 +18489,7 @@ var ts;
errorOnFirstToken(node, ts.Diagnostics.export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always_visible);
}
if (ts.isExternalModuleAugmentation(node)) {
- declareSymbolAndAddToSymbolTable(node, 1024, 0);
+ declareModuleSymbol(node);
}
else {
var pattern = void 0;
@@ -17617,12 +18509,8 @@ var ts;
}
}
else {
- var state = getModuleInstanceState(node);
- if (state === 0) {
- declareSymbolAndAddToSymbolTable(node, 1024, 0);
- }
- else {
- declareSymbolAndAddToSymbolTable(node, 512, 106639);
+ var state = declareModuleSymbol(node);
+ if (state !== 0) {
if (node.symbol.flags & (16 | 32 | 256)) {
node.symbol.constEnumOnlyModule = false;
}
@@ -17638,29 +18526,35 @@ var ts;
}
}
}
+ function declareModuleSymbol(node) {
+ var state = getModuleInstanceState(node);
+ var instantiated = state !== 0;
+ declareSymbolAndAddToSymbolTable(node, instantiated ? 512 : 1024, instantiated ? 106639 : 0);
+ return state;
+ }
function bindFunctionOrConstructorType(node) {
var symbol = createSymbol(131072, getDeclarationName(node));
addDeclarationToSymbol(symbol, node, 131072);
var typeLiteralSymbol = createSymbol(2048, "__type");
addDeclarationToSymbol(typeLiteralSymbol, node, 2048);
typeLiteralSymbol.members = ts.createMap();
- typeLiteralSymbol.members[symbol.name] = symbol;
+ typeLiteralSymbol.members.set(symbol.name, symbol);
}
function bindObjectLiteralExpression(node) {
if (inStrictMode) {
var seen = ts.createMap();
for (var _i = 0, _a = node.properties; _i < _a.length; _i++) {
var prop = _a[_i];
- if (prop.kind === 259 || prop.name.kind !== 70) {
+ if (prop.kind === 262 || prop.name.kind !== 70) {
continue;
}
var identifier = prop.name;
- var currentKind = prop.kind === 257 || prop.kind === 258 || prop.kind === 149
+ var currentKind = prop.kind === 260 || prop.kind === 261 || prop.kind === 150
? 1
: 2;
- var existingKind = seen[identifier.text];
+ var existingKind = seen.get(identifier.text);
if (!existingKind) {
- seen[identifier.text] = currentKind;
+ seen.set(identifier.text, currentKind);
continue;
}
if (currentKind === 1 && existingKind === 1) {
@@ -17671,16 +18565,22 @@ var ts;
}
return bindAnonymousDeclaration(node, 4096, "__object");
}
+ function bindJsxAttributes(node) {
+ return bindAnonymousDeclaration(node, 4096, "__jsxAttributes");
+ }
+ function bindJsxAttribute(node, symbolFlags, symbolExcludes) {
+ return declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes);
+ }
function bindAnonymousDeclaration(node, symbolFlags, name) {
var symbol = createSymbol(symbolFlags, name);
addDeclarationToSymbol(symbol, node, symbolFlags);
}
function bindBlockScopedDeclaration(node, symbolFlags, symbolExcludes) {
switch (blockScopeContainer.kind) {
- case 230:
+ case 232:
declareModuleMember(node, symbolFlags, symbolExcludes);
break;
- case 261:
+ case 264:
if (ts.isExternalModule(container)) {
declareModuleMember(node, symbolFlags, symbolExcludes);
break;
@@ -17770,8 +18670,8 @@ var ts;
}
function checkStrictModeFunctionDeclaration(node) {
if (languageVersion < 2) {
- if (blockScopeContainer.kind !== 261 &&
- blockScopeContainer.kind !== 230 &&
+ if (blockScopeContainer.kind !== 264 &&
+ blockScopeContainer.kind !== 232 &&
!ts.isFunctionLike(blockScopeContainer)) {
var errorSpan = ts.getErrorSpanForNode(file, node);
file.bindDiagnostics.push(ts.createFileDiagnostic(file, errorSpan.start, errorSpan.length, getStrictModeBlockScopeFunctionDeclarationMessage(node)));
@@ -17779,7 +18679,7 @@ var ts;
}
}
function checkStrictModeNumericLiteral(node) {
- if (inStrictMode && node.isOctalLiteral) {
+ if (inStrictMode && node.numericLiteralFlags & 4) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node, ts.Diagnostics.Octal_literals_are_not_allowed_in_strict_mode));
}
}
@@ -17813,8 +18713,11 @@ var ts;
}
node.parent = parent;
var saveInStrictMode = inStrictMode;
+ if (ts.isInJavaScriptFile(node)) {
+ bindJSDocTypedefTagIfAny(node);
+ }
bindWorker(node);
- if (node.kind > 140) {
+ if (node.kind > 141) {
var saveParent = parent;
parent = node;
var containerFlags = getContainerFlags(node);
@@ -17831,6 +18734,26 @@ var ts;
}
inStrictMode = saveInStrictMode;
}
+ function bindJSDocTypedefTagIfAny(node) {
+ if (!node.jsDoc) {
+ return;
+ }
+ for (var _i = 0, _a = node.jsDoc; _i < _a.length; _i++) {
+ var jsDoc = _a[_i];
+ if (!jsDoc.tags) {
+ continue;
+ }
+ for (var _b = 0, _c = jsDoc.tags; _b < _c.length; _b++) {
+ var tag = _c[_b];
+ if (tag.kind === 289) {
+ var savedParent = parent;
+ parent = jsDoc;
+ bind(tag);
+ parent = savedParent;
+ }
+ }
+ }
+ }
function updateStrictModeStatementList(statements) {
if (!inStrictMode) {
for (var _i = 0, statements_2 = statements; _i < statements_2.length; _i++) {
@@ -17854,90 +18777,88 @@ var ts;
case 70:
if (node.isInJSDocNamespace) {
var parentNode = node.parent;
- while (parentNode && parentNode.kind !== 285) {
+ while (parentNode && parentNode.kind !== 289) {
parentNode = parentNode.parent;
}
bindBlockScopedDeclaration(parentNode, 524288, 793064);
break;
}
case 98:
- if (currentFlow && (ts.isExpression(node) || parent.kind === 258)) {
+ if (currentFlow && (ts.isExpression(node) || parent.kind === 261)) {
node.flowNode = currentFlow;
}
return checkStrictModeIdentifier(node);
- case 177:
+ case 178:
if (currentFlow && isNarrowableReference(node)) {
node.flowNode = currentFlow;
}
break;
- case 192:
- if (ts.isInJavaScriptFile(node)) {
- var specialKind = ts.getSpecialPropertyAssignmentKind(node);
- switch (specialKind) {
- case 1:
- bindExportsPropertyAssignment(node);
- break;
- case 2:
- bindModuleExportsAssignment(node);
- break;
- case 3:
- bindPrototypePropertyAssignment(node);
- break;
- case 4:
- bindThisPropertyAssignment(node);
- break;
- case 0:
- break;
- default:
- ts.Debug.fail("Unknown special property assignment kind");
- }
+ case 193:
+ var specialKind = ts.getSpecialPropertyAssignmentKind(node);
+ switch (specialKind) {
+ case 1:
+ bindExportsPropertyAssignment(node);
+ break;
+ case 2:
+ bindModuleExportsAssignment(node);
+ break;
+ case 3:
+ bindPrototypePropertyAssignment(node);
+ break;
+ case 4:
+ bindThisPropertyAssignment(node);
+ break;
+ case 5:
+ bindStaticPropertyAssignment(node);
+ break;
+ case 0:
+ break;
+ default:
+ ts.Debug.fail("Unknown special property assignment kind");
}
return checkStrictModeBinaryExpression(node);
- case 256:
+ case 259:
return checkStrictModeCatchClause(node);
- case 186:
+ case 187:
return checkStrictModeDeleteExpression(node);
case 8:
return checkStrictModeNumericLiteral(node);
- case 191:
+ case 192:
return checkStrictModePostfixUnaryExpression(node);
- case 190:
+ case 191:
return checkStrictModePrefixUnaryExpression(node);
- case 217:
+ case 219:
return checkStrictModeWithStatement(node);
- case 167:
+ case 168:
seenThisKeyword = true;
return;
- case 156:
+ case 157:
return checkTypePredicate(node);
- case 143:
- return declareSymbolAndAddToSymbolTable(node, 262144, 530920);
case 144:
+ return declareSymbolAndAddToSymbolTable(node, 262144, 530920);
+ case 145:
return bindParameter(node);
- case 223:
- case 174:
- if (node.dotDotDotToken && node.parent.kind === 172) {
- emitFlags |= 32768;
- }
+ case 225:
+ case 175:
return bindVariableDeclarationOrBindingElement(node);
+ case 148:
case 147:
- case 146:
- case 271:
- return bindPropertyOrMethodOrAccessor(node, 4 | (node.questionToken ? 536870912 : 0), 0);
- case 286:
+ case 275:
+ return bindPropertyOrMethodOrAccessor(node, 4 | (node.questionToken ? 67108864 : 0), 0);
+ case 290:
return bindJSDocProperty(node);
- case 257:
- case 258:
- return bindPropertyOrMethodOrAccessor(node, 4, 0);
case 260:
+ case 261:
+ return bindPropertyOrMethodOrAccessor(node, 4, 0);
+ case 263:
return bindPropertyOrMethodOrAccessor(node, 8, 900095);
- case 259:
- case 251:
+ case 262:
+ case 254:
var root = container;
var hasRest = false;
while (root.parent) {
- if (root.kind === 176 &&
- root.parent.kind === 192 &&
+ if (root.kind === 177 &&
+ root.parent.kind === 193 &&
root.parent.operatorToken.kind === 57 &&
root.parent.left === root) {
hasRest = true;
@@ -17945,80 +18866,83 @@ var ts;
}
root = root.parent;
}
- emitFlags |= hasRest ? 32768 : 16384;
return;
- case 153:
case 154:
case 155:
+ case 156:
return declareSymbolAndAddToSymbolTable(node, 131072, 0);
+ case 150:
case 149:
- case 148:
- return bindPropertyOrMethodOrAccessor(node, 8192 | (node.questionToken ? 536870912 : 0), ts.isObjectLiteralMethod(node) ? 0 : 99263);
- case 225:
+ return bindPropertyOrMethodOrAccessor(node, 8192 | (node.questionToken ? 67108864 : 0), ts.isObjectLiteralMethod(node) ? 0 : 99263);
+ case 227:
return bindFunctionDeclaration(node);
- case 150:
- return declareSymbolAndAddToSymbolTable(node, 16384, 0);
case 151:
- return bindPropertyOrMethodOrAccessor(node, 32768, 41919);
+ return declareSymbolAndAddToSymbolTable(node, 16384, 0);
case 152:
+ return bindPropertyOrMethodOrAccessor(node, 32768, 41919);
+ case 153:
return bindPropertyOrMethodOrAccessor(node, 65536, 74687);
- case 158:
case 159:
- case 274:
+ case 160:
+ case 278:
return bindFunctionOrConstructorType(node);
- case 161:
- case 170:
- case 287:
- case 270:
+ case 162:
+ case 171:
+ case 291:
+ case 274:
return bindAnonymousDeclaration(node, 2048, "__type");
- case 176:
+ case 177:
return bindObjectLiteralExpression(node);
- case 184:
case 185:
+ case 186:
return bindFunctionExpression(node);
- case 179:
+ case 180:
if (ts.isInJavaScriptFile(node)) {
bindCallExpression(node);
}
break;
- case 197:
- case 226:
+ case 198:
+ case 228:
inStrictMode = true;
return bindClassLikeDeclaration(node);
- case 227:
+ case 229:
return bindBlockScopedDeclaration(node, 64, 792968);
- case 285:
+ case 289:
if (!node.fullName || node.fullName.kind === 70) {
return bindBlockScopedDeclaration(node, 524288, 793064);
}
break;
- case 228:
+ case 230:
return bindBlockScopedDeclaration(node, 524288, 793064);
- case 229:
+ case 231:
return bindEnumDeclaration(node);
- case 230:
+ case 232:
return bindModuleDeclaration(node);
- case 234:
- case 237:
+ case 253:
+ return bindJsxAttributes(node);
+ case 252:
+ return bindJsxAttribute(node, 4, 0);
+ case 236:
case 239:
- case 243:
+ case 241:
+ case 245:
return declareSymbolAndAddToSymbolTable(node, 8388608, 8388608);
- case 233:
+ case 235:
return bindNamespaceExportDeclaration(node);
- case 236:
+ case 238:
return bindImportClause(node);
- case 241:
+ case 243:
return bindExportDeclaration(node);
- case 240:
+ case 242:
return bindExportAssignment(node);
- case 261:
+ case 264:
updateStrictModeStatementList(node.statements);
return bindSourceFileIfExternalModule();
- case 204:
+ case 206:
if (!ts.isFunctionLike(node.parent)) {
return;
}
- case 231:
+ case 233:
return updateStrictModeStatementList(node.statements);
}
}
@@ -18027,7 +18951,7 @@ var ts;
if (parameterName && parameterName.kind === 70) {
checkStrictModeIdentifier(parameterName);
}
- if (parameterName && parameterName.kind === 167) {
+ if (parameterName && parameterName.kind === 168) {
seenThisKeyword = true;
}
bind(type);
@@ -18046,7 +18970,7 @@ var ts;
bindAnonymousDeclaration(node, 8388608, getDeclarationName(node));
}
else {
- var flags = node.kind === 240 && ts.exportAssignmentIsAlias(node)
+ var flags = node.kind === 242 && ts.exportAssignmentIsAlias(node)
? 8388608
: 4;
declareSymbol(container.symbol.exports, container.symbol, node, flags, 4 | 8388608 | 32 | 16);
@@ -18056,17 +18980,17 @@ var ts;
if (node.modifiers && node.modifiers.length) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node, ts.Diagnostics.Modifiers_cannot_appear_here));
}
- if (node.parent.kind !== 261) {
+ if (node.parent.kind !== 264) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node, ts.Diagnostics.Global_module_exports_may_only_appear_at_top_level));
return;
}
else {
- var parent_4 = node.parent;
- if (!ts.isExternalModule(parent_4)) {
+ var parent_1 = node.parent;
+ if (!ts.isExternalModule(parent_1)) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node, ts.Diagnostics.Global_module_exports_may_only_appear_in_module_files));
return;
}
- if (!parent_4.isDeclarationFile) {
+ if (!parent_1.isDeclarationFile) {
file.bindDiagnostics.push(ts.createDiagnosticForNode(node, ts.Diagnostics.Global_module_exports_may_only_appear_in_declaration_files));
return;
}
@@ -18076,10 +19000,10 @@ var ts;
}
function bindExportDeclaration(node) {
if (!container.symbol || !container.symbol.exports) {
- bindAnonymousDeclaration(node, 1073741824, getDeclarationName(node));
+ bindAnonymousDeclaration(node, 33554432, getDeclarationName(node));
}
else if (!node.exportClause) {
- declareSymbol(container.symbol.exports, container.symbol, node, 1073741824, 0);
+ declareSymbol(container.symbol.exports, container.symbol, node, 33554432, 0);
}
}
function bindImportClause(node) {
@@ -18099,24 +19023,56 @@ var ts;
setCommonJsModuleIndicator(node);
declareSymbol(file.symbol.exports, file.symbol, node.left, 4 | 7340032, 0);
}
+ function isExportsOrModuleExportsOrAlias(node) {
+ return ts.isExportsIdentifier(node) ||
+ ts.isModuleExportsPropertyAccessExpression(node) ||
+ isNameOfExportsOrModuleExportsAliasDeclaration(node);
+ }
+ function isNameOfExportsOrModuleExportsAliasDeclaration(node) {
+ if (node.kind === 70) {
+ var symbol = lookupSymbolForName(node.text);
+ if (symbol && symbol.valueDeclaration && symbol.valueDeclaration.kind === 225) {
+ var declaration = symbol.valueDeclaration;
+ if (declaration.initializer) {
+ return isExportsOrModuleExportsOrAliasOrAssignemnt(declaration.initializer);
+ }
+ }
+ }
+ return false;
+ }
+ function isExportsOrModuleExportsOrAliasOrAssignemnt(node) {
+ return isExportsOrModuleExportsOrAlias(node) ||
+ (ts.isAssignmentExpression(node, true) && (isExportsOrModuleExportsOrAliasOrAssignemnt(node.left) || isExportsOrModuleExportsOrAliasOrAssignemnt(node.right)));
+ }
function bindModuleExportsAssignment(node) {
+ var assignedExpression = ts.getRightMostAssignedExpression(node.right);
+ if (ts.isEmptyObjectLiteral(assignedExpression) || isExportsOrModuleExportsOrAlias(assignedExpression)) {
+ setCommonJsModuleIndicator(node);
+ return;
+ }
setCommonJsModuleIndicator(node);
declareSymbol(file.symbol.exports, file.symbol, node, 4 | 7340032 | 512, 0);
}
function bindThisPropertyAssignment(node) {
ts.Debug.assert(ts.isInJavaScriptFile(node));
- if (container.kind === 225 || container.kind === 184) {
- container.symbol.members = container.symbol.members || ts.createMap();
- declareSymbol(container.symbol.members, container.symbol, node, 4, 0 & ~4);
- }
- else if (container.kind === 150) {
- var saveContainer = container;
- container = container.parent;
- var symbol = bindPropertyOrMethodOrAccessor(node, 4, 0);
- if (symbol) {
- symbol.isReplaceableByMethod = true;
- }
- container = saveContainer;
+ var container = ts.getThisContainer(node, false);
+ switch (container.kind) {
+ case 227:
+ case 185:
+ container.symbol.members = container.symbol.members || ts.createMap();
+ declareSymbol(container.symbol.members, container.symbol, node, 4, 0 & ~4);
+ break;
+ case 151:
+ case 148:
+ case 150:
+ case 152:
+ case 153:
+ var containingClass = container.parent;
+ var symbol = declareSymbol(ts.hasModifier(container, 32) ? containingClass.symbol.exports : containingClass.symbol.members, containingClass.symbol, node, 4, 0);
+ if (symbol) {
+ symbol.isReplaceableByMethod = true;
+ }
+ break;
}
}
function bindPrototypePropertyAssignment(node) {
@@ -18126,14 +19082,35 @@ var ts;
leftSideOfAssignment.parent = node;
constructorFunction.parent = classPrototype;
classPrototype.parent = leftSideOfAssignment;
- var funcSymbol = container.locals[constructorFunction.text];
- if (!funcSymbol || !(funcSymbol.flags & 16 || ts.isDeclarationOfFunctionExpression(funcSymbol))) {
- return;
+ bindPropertyAssignment(constructorFunction.text, leftSideOfAssignment, true);
+ }
+ function bindStaticPropertyAssignment(node) {
+ var leftSideOfAssignment = node.left;
+ var target = leftSideOfAssignment.expression;
+ leftSideOfAssignment.parent = node;
+ target.parent = leftSideOfAssignment;
+ if (isNameOfExportsOrModuleExportsAliasDeclaration(target)) {
+ bindExportsPropertyAssignment(node);
+ }
+ else {
+ bindPropertyAssignment(target.text, leftSideOfAssignment, false);
+ }
+ }
+ function lookupSymbolForName(name) {
+ return (container.symbol && container.symbol.exports && container.symbol.exports.get(name)) || (container.locals && container.locals.get(name));
+ }
+ function bindPropertyAssignment(functionName, propertyAccessExpression, isPrototypeProperty) {
+ var targetSymbol = lookupSymbolForName(functionName);
+ if (targetSymbol && ts.isDeclarationOfFunctionOrClassExpression(targetSymbol)) {
+ targetSymbol = targetSymbol.valueDeclaration.initializer.symbol;
}
- if (!funcSymbol.members) {
- funcSymbol.members = ts.createMap();
+ if (!targetSymbol || !(targetSymbol.flags & (16 | 32))) {
+ return;
}
- declareSymbol(funcSymbol.members, funcSymbol, leftSideOfAssignment, 4, 0);
+ var symbolTable = isPrototypeProperty ?
+ (targetSymbol.members || (targetSymbol.members = ts.createMap())) :
+ (targetSymbol.exports || (targetSymbol.exports = ts.createMap()));
+ declareSymbol(symbolTable, targetSymbol, propertyAccessExpression, 4, 0);
}
function bindCallExpression(node) {
if (!file.commonJsModuleIndicator && ts.isRequireCall(node, false)) {
@@ -18141,33 +19118,26 @@ var ts;
}
}
function bindClassLikeDeclaration(node) {
- if (!ts.isDeclarationFile(file) && !ts.isInAmbientContext(node)) {
- if (ts.getClassExtendsHeritageClauseElement(node) !== undefined) {
- emitFlags |= 1024;
- }
- if (ts.nodeIsDecorated(node)) {
- emitFlags |= 2048;
- }
- }
- if (node.kind === 226) {
+ if (node.kind === 228) {
bindBlockScopedDeclaration(node, 32, 899519);
}
else {
var bindingName = node.name ? node.name.text : "__class";
bindAnonymousDeclaration(node, 32, bindingName);
if (node.name) {
- classifiableNames[node.name.text] = node.name.text;
+ classifiableNames.set(node.name.text, node.name.text);
}
}
var symbol = node.symbol;
- var prototypeSymbol = createSymbol(4 | 134217728, "prototype");
- if (symbol.exports[prototypeSymbol.name]) {
+ var prototypeSymbol = createSymbol(4 | 16777216, "prototype");
+ var symbolExport = symbol.exports.get(prototypeSymbol.name);
+ if (symbolExport) {
if (node.name) {
node.name.parent = node;
}
- file.bindDiagnostics.push(ts.createDiagnosticForNode(symbol.exports[prototypeSymbol.name].declarations[0], ts.Diagnostics.Duplicate_identifier_0, prototypeSymbol.name));
+ file.bindDiagnostics.push(ts.createDiagnosticForNode(symbolExport.declarations[0], ts.Diagnostics.Duplicate_identifier_0, prototypeSymbol.name));
}
- symbol.exports[prototypeSymbol.name] = prototypeSymbol;
+ symbol.exports.set(prototypeSymbol.name, prototypeSymbol);
prototypeSymbol.parent = symbol;
}
function bindEnumDeclaration(node) {
@@ -18192,11 +19162,6 @@ var ts;
}
}
function bindParameter(node) {
- if (!ts.isDeclarationFile(file) &&
- !ts.isInAmbientContext(node) &&
- ts.nodeIsDecorated(node)) {
- emitFlags |= (2048 | 4096);
- }
if (inStrictMode) {
checkStrictModeEvalOrArguments(node, node.name);
}
@@ -18208,13 +19173,13 @@ var ts;
}
if (ts.isParameterPropertyDeclaration(node)) {
var classDeclaration = node.parent.parent;
- declareSymbol(classDeclaration.symbol.members, classDeclaration.symbol, node, 4 | (node.questionToken ? 536870912 : 0), 0);
+ declareSymbol(classDeclaration.symbol.members, classDeclaration.symbol, node, 4 | (node.questionToken ? 67108864 : 0), 0);
}
}
function bindFunctionDeclaration(node) {
if (!ts.isDeclarationFile(file) && !ts.isInAmbientContext(node)) {
- if (ts.isAsyncFunctionLike(node)) {
- emitFlags |= 8192;
+ if (ts.isAsyncFunction(node)) {
+ emitFlags |= 1024;
}
}
checkStrictModeFunctionName(node);
@@ -18228,8 +19193,8 @@ var ts;
}
function bindFunctionExpression(node) {
if (!ts.isDeclarationFile(file) && !ts.isInAmbientContext(node)) {
- if (ts.isAsyncFunctionLike(node)) {
- emitFlags |= 8192;
+ if (ts.isAsyncFunction(node)) {
+ emitFlags |= 1024;
}
}
if (currentFlow) {
@@ -18241,11 +19206,8 @@ var ts;
}
function bindPropertyOrMethodOrAccessor(node, symbolFlags, symbolExcludes) {
if (!ts.isDeclarationFile(file) && !ts.isInAmbientContext(node)) {
- if (ts.isAsyncFunctionLike(node)) {
- emitFlags |= 8192;
- }
- if (ts.nodeIsDecorated(node)) {
- emitFlags |= 2048;
+ if (ts.isAsyncFunction(node)) {
+ emitFlags |= 1024;
}
}
if (currentFlow && ts.isObjectLiteralOrClassExpressionMethod(node)) {
@@ -18267,15 +19229,15 @@ var ts;
return false;
}
if (currentFlow === unreachableFlow) {
- var reportError = (ts.isStatementButNotDeclaration(node) && node.kind !== 206) ||
- node.kind === 226 ||
- (node.kind === 230 && shouldReportErrorOnModuleDeclaration(node)) ||
- (node.kind === 229 && (!ts.isConstEnumDeclaration(node) || options.preserveConstEnums));
+ var reportError = (ts.isStatementButNotDeclaration(node) && node.kind !== 208) ||
+ node.kind === 228 ||
+ (node.kind === 232 && shouldReportErrorOnModuleDeclaration(node)) ||
+ (node.kind === 231 && (!ts.isConstEnumDeclaration(node) || options.preserveConstEnums));
if (reportError) {
currentFlow = reportedUnreachableFlow;
var reportUnreachableCode = !options.allowUnreachableCode &&
!ts.isInAmbientContext(node) &&
- (node.kind !== 205 ||
+ (node.kind !== 207 ||
ts.getCombinedNodeFlags(node.declarationList) & 3 ||
ts.forEach(node.declarationList.declarations, function (d) { return d.initializer; }));
if (reportUnreachableCode) {
@@ -18289,56 +19251,56 @@ var ts;
function computeTransformFlagsForNode(node, subtreeFlags) {
var kind = node.kind;
switch (kind) {
- case 179:
- return computeCallExpression(node, subtreeFlags);
case 180:
+ return computeCallExpression(node, subtreeFlags);
+ case 181:
return computeNewExpression(node, subtreeFlags);
- case 230:
+ case 232:
return computeModuleDeclaration(node, subtreeFlags);
- case 183:
+ case 184:
return computeParenthesizedExpression(node, subtreeFlags);
- case 192:
+ case 193:
return computeBinaryExpression(node, subtreeFlags);
- case 207:
+ case 209:
return computeExpressionStatement(node, subtreeFlags);
- case 144:
+ case 145:
return computeParameter(node, subtreeFlags);
- case 185:
+ case 186:
return computeArrowFunction(node, subtreeFlags);
- case 184:
+ case 185:
return computeFunctionExpression(node, subtreeFlags);
- case 225:
+ case 227:
return computeFunctionDeclaration(node, subtreeFlags);
- case 223:
+ case 225:
return computeVariableDeclaration(node, subtreeFlags);
- case 224:
+ case 226:
return computeVariableDeclarationList(node, subtreeFlags);
- case 205:
+ case 207:
return computeVariableStatement(node, subtreeFlags);
- case 219:
+ case 221:
return computeLabeledStatement(node, subtreeFlags);
- case 226:
+ case 228:
return computeClassDeclaration(node, subtreeFlags);
- case 197:
+ case 198:
return computeClassExpression(node, subtreeFlags);
- case 255:
+ case 258:
return computeHeritageClause(node, subtreeFlags);
- case 256:
+ case 259:
return computeCatchClause(node, subtreeFlags);
- case 199:
+ case 200:
return computeExpressionWithTypeArguments(node, subtreeFlags);
- case 150:
+ case 151:
return computeConstructor(node, subtreeFlags);
- case 147:
+ case 148:
return computePropertyDeclaration(node, subtreeFlags);
- case 149:
+ case 150:
return computeMethod(node, subtreeFlags);
- case 151:
case 152:
+ case 153:
return computeAccessor(node, subtreeFlags);
- case 234:
+ case 236:
return computeImportEquals(node, subtreeFlags);
- case 177:
+ case 178:
return computePropertyAccess(node, subtreeFlags);
default:
return computeOther(node, kind, subtreeFlags);
@@ -18363,8 +19325,8 @@ var ts;
switch (kind) {
case 96:
return true;
- case 177:
case 178:
+ case 179:
var expression = node.expression;
var expressionKind = expression.kind;
return expressionKind === 96;
@@ -18386,10 +19348,10 @@ var ts;
var transformFlags = subtreeFlags;
var operatorTokenKind = node.operatorToken.kind;
var leftKind = node.left.kind;
- if (operatorTokenKind === 57 && leftKind === 176) {
+ if (operatorTokenKind === 57 && leftKind === 177) {
transformFlags |= 8 | 192 | 3072;
}
- else if (operatorTokenKind === 57 && leftKind === 175) {
+ else if (operatorTokenKind === 57 && leftKind === 176) {
transformFlags |= 192 | 3072;
}
else if (operatorTokenKind === 39
@@ -18428,8 +19390,8 @@ var ts;
var expression = node.expression;
var expressionKind = expression.kind;
var expressionTransformFlags = expression.transformFlags;
- if (expressionKind === 200
- || expressionKind === 182) {
+ if (expressionKind === 201
+ || expressionKind === 183) {
transformFlags |= 3;
}
if (expressionTransformFlags & 1024) {
@@ -18526,9 +19488,9 @@ var ts;
transformFlags |= 8;
}
if (ts.hasModifier(node, 256)) {
- transformFlags |= 16;
+ transformFlags |= node.asteriskToken ? 8 : 16;
}
- if (node.asteriskToken && ts.getEmitFlags(node) & 131072) {
+ if (node.asteriskToken) {
transformFlags |= 768;
}
node.transformFlags = transformFlags | 536870912;
@@ -18571,7 +19533,7 @@ var ts;
transformFlags |= 3;
}
if (modifierFlags & 256) {
- transformFlags |= 16;
+ transformFlags |= node.asteriskToken ? 8 : 16;
}
if (subtreeFlags & 1048576) {
transformFlags |= 8;
@@ -18579,7 +19541,7 @@ var ts;
if (subtreeFlags & 163840) {
transformFlags |= 192;
}
- if (node.asteriskToken && ts.getEmitFlags(node) & 131072) {
+ if (node.asteriskToken) {
transformFlags |= 768;
}
}
@@ -18594,7 +19556,7 @@ var ts;
transformFlags |= 3;
}
if (ts.hasModifier(node, 256)) {
- transformFlags |= 16;
+ transformFlags |= node.asteriskToken ? 8 : 16;
}
if (subtreeFlags & 1048576) {
transformFlags |= 8;
@@ -18602,7 +19564,7 @@ var ts;
if (subtreeFlags & 163840) {
transformFlags |= 192;
}
- if (node.asteriskToken && ts.getEmitFlags(node) & 131072) {
+ if (node.asteriskToken) {
transformFlags |= 768;
}
node.transformFlags = transformFlags | 536870912;
@@ -18715,8 +19677,8 @@ var ts;
var excludeFlags = 536872257;
switch (kind) {
case 119:
- case 189:
- transformFlags |= 16;
+ case 190:
+ transformFlags |= 8 | 16;
break;
case 113:
case 111:
@@ -18724,50 +19686,66 @@ var ts;
case 116:
case 123:
case 75:
- case 229:
- case 260:
- case 182:
- case 200:
+ case 231:
+ case 263:
+ case 183:
case 201:
+ case 202:
case 130:
transformFlags |= 3;
break;
- case 246:
- case 247:
case 248:
- case 10:
case 249:
case 250:
+ case 10:
case 251:
case 252:
+ case 253:
+ case 254:
+ case 255:
transformFlags |= 4;
break;
- case 213:
- transformFlags |= 8;
case 12:
case 13:
case 14:
case 15:
- case 194:
- case 181:
- case 258:
+ case 195:
+ case 182:
+ case 261:
case 114:
+ case 203:
transformFlags |= 192;
break;
- case 195:
- transformFlags |= 192 | 16777216;
+ case 9:
+ if (node.hasExtendedUnicodeEscape) {
+ transformFlags |= 192;
+ }
+ break;
+ case 8:
+ if (node.numericLiteralFlags & 48) {
+ transformFlags |= 192;
+ }
+ break;
+ case 215:
+ if (node.awaitModifier) {
+ transformFlags |= 8;
+ }
+ transformFlags |= 192;
+ break;
+ case 196:
+ transformFlags |= 8 | 192 | 16777216;
break;
case 118:
case 132:
case 129:
- case 134:
- case 121:
+ case 133:
case 135:
+ case 121:
+ case 136:
case 104:
- case 143:
- case 146:
- case 148:
- case 153:
+ case 144:
+ case 147:
+ case 149:
case 154:
case 155:
case 156:
@@ -18781,26 +19759,27 @@ var ts;
case 164:
case 165:
case 166:
- case 227:
- case 228:
case 167:
+ case 229:
+ case 230:
case 168:
case 169:
case 170:
case 171:
+ case 172:
transformFlags = 3;
excludeFlags = -3;
break;
- case 142:
+ case 143:
transformFlags |= 2097152;
if (subtreeFlags & 16384) {
transformFlags |= 65536;
}
break;
- case 196:
+ case 197:
transformFlags |= 192 | 524288;
break;
- case 259:
+ case 262:
transformFlags |= 8 | 1048576;
break;
case 96:
@@ -18809,27 +19788,27 @@ var ts;
case 98:
transformFlags |= 16384;
break;
- case 172:
+ case 173:
transformFlags |= 192 | 8388608;
if (subtreeFlags & 524288) {
transformFlags |= 8 | 1048576;
}
excludeFlags = 537396545;
break;
- case 173:
+ case 174:
transformFlags |= 192 | 8388608;
excludeFlags = 537396545;
break;
- case 174:
+ case 175:
transformFlags |= 192;
if (node.dotDotDotToken) {
transformFlags |= 524288;
}
break;
- case 145:
+ case 146:
transformFlags |= 3 | 4096;
break;
- case 176:
+ case 177:
excludeFlags = 540087617;
if (subtreeFlags & 2097152) {
transformFlags |= 192;
@@ -18841,29 +19820,29 @@ var ts;
transformFlags |= 8;
}
break;
- case 175:
- case 180:
+ case 176:
+ case 181:
excludeFlags = 537396545;
if (subtreeFlags & 524288) {
transformFlags |= 192;
}
break;
- case 209:
- case 210:
case 211:
case 212:
+ case 213:
+ case 214:
if (subtreeFlags & 4194304) {
transformFlags |= 192;
}
break;
- case 261:
+ case 264:
if (subtreeFlags & 32768) {
transformFlags |= 192;
}
break;
+ case 218:
case 216:
- case 214:
- case 215:
+ case 217:
transformFlags |= 33554432;
break;
}
@@ -18871,56 +19850,57 @@ var ts;
return transformFlags & ~excludeFlags;
}
function getTransformFlagsSubtreeExclusions(kind) {
- if (kind >= 156 && kind <= 171) {
+ if (kind >= 157 && kind <= 172) {
return -3;
}
switch (kind) {
- case 179:
case 180:
- case 175:
+ case 181:
+ case 176:
return 537396545;
- case 230:
+ case 232:
return 574674241;
- case 144:
+ case 145:
return 536872257;
- case 185:
+ case 186:
return 601249089;
- case 184:
- case 225:
+ case 185:
+ case 227:
return 601281857;
- case 224:
- return 546309441;
case 226:
- case 197:
+ return 546309441;
+ case 228:
+ case 198:
return 539358529;
- case 150:
- return 601015617;
- case 149:
case 151:
+ return 601015617;
+ case 150:
case 152:
+ case 153:
return 601015617;
case 118:
case 132:
case 129:
- case 134:
- case 121:
case 135:
+ case 133:
+ case 121:
+ case 136:
case 104:
- case 143:
- case 146:
- case 148:
- case 153:
+ case 144:
+ case 147:
+ case 149:
case 154:
case 155:
- case 227:
- case 228:
+ case 156:
+ case 229:
+ case 230:
return -3;
- case 176:
+ case 177:
return 540087617;
- case 256:
+ case 259:
return 537920833;
- case 172:
case 173:
+ case 174:
return 537396545;
default:
return 536872257;
@@ -18938,6 +19918,12 @@ var ts;
return compilerOptions.traceResolution && host.trace !== undefined;
}
ts.isTraceEnabled = isTraceEnabled;
+ var Extensions;
+ (function (Extensions) {
+ Extensions[Extensions["TypeScript"] = 0] = "TypeScript";
+ Extensions[Extensions["JavaScript"] = 1] = "JavaScript";
+ Extensions[Extensions["DtsOnly"] = 2] = "DtsOnly";
+ })(Extensions || (Extensions = {}));
function resolvedTypeScriptOnly(resolved) {
if (!resolved) {
return undefined;
@@ -18945,9 +19931,6 @@ var ts;
ts.Debug.assert(ts.extensionIsTypeScript(resolved.extension));
return resolved.path;
}
- function resolvedFromAnyFile(path) {
- return { path: path, extension: ts.extensionFromPath(path) };
- }
function resolvedModuleFromResolved(_a, isExternalLibraryImport) {
var path = _a.path, extension = _a.extension;
return { resolvedFileName: path, extension: extension, isExternalLibraryImport: isExternalLibraryImport };
@@ -18959,37 +19942,28 @@ var ts;
return !(ts.isRootedDiskPath(moduleName) || ts.isExternalModuleNameRelative(moduleName));
}
ts.moduleHasNonRelativeName = moduleHasNonRelativeName;
- function tryReadTypesSection(extensions, packageJsonPath, baseDirectory, state) {
+ function tryReadPackageJsonFields(readTypes, packageJsonPath, baseDirectory, state) {
var jsonContent = readJson(packageJsonPath, state.host);
- switch (extensions) {
- case 2:
- case 0:
- return tryReadFromField("typings") || tryReadFromField("types");
- case 1:
- if (typeof jsonContent.main === "string") {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.No_types_specified_in_package_json_so_returning_main_value_of_0, jsonContent.main);
- }
- return ts.normalizePath(ts.combinePaths(baseDirectory, jsonContent.main));
- }
- return undefined;
- }
+ return readTypes ? tryReadFromField("typings") || tryReadFromField("types") : tryReadFromField("main");
function tryReadFromField(fieldName) {
- if (ts.hasProperty(jsonContent, fieldName)) {
- var typesFile = jsonContent[fieldName];
- if (typeof typesFile === "string") {
- var typesFilePath = ts.normalizePath(ts.combinePaths(baseDirectory, typesFile));
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.package_json_has_0_field_1_that_references_2, fieldName, typesFile, typesFilePath);
- }
- return typesFilePath;
+ if (!ts.hasProperty(jsonContent, fieldName)) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.package_json_does_not_have_a_0_field, fieldName);
}
- else {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.Expected_type_of_0_field_in_package_json_to_be_string_got_1, fieldName, typeof typesFile);
- }
+ return;
+ }
+ var fileName = jsonContent[fieldName];
+ if (typeof fileName !== "string") {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Expected_type_of_0_field_in_package_json_to_be_string_got_1, fieldName, typeof fileName);
}
+ return;
}
+ var path = ts.normalizePath(ts.combinePaths(baseDirectory, fileName));
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.package_json_has_0_field_1_that_references_2, fieldName, fileName, path);
+ }
+ return path;
}
}
function readJson(path, host) {
@@ -19022,11 +19996,12 @@ var ts;
return [ts.combinePaths(currentDirectory, nodeModulesAtTypes)];
}
var typeRoots;
- forEachAncestorDirectory(currentDirectory, function (directory) {
+ forEachAncestorDirectory(ts.normalizePath(currentDirectory), function (directory) {
var atTypes = ts.combinePaths(directory, nodeModulesAtTypes);
if (host.directoryExists(atTypes)) {
(typeRoots || (typeRoots = [])).push(atTypes);
}
+ return undefined;
});
return typeRoots;
}
@@ -19081,7 +20056,11 @@ var ts;
return ts.forEach(typeRoots, function (typeRoot) {
var candidate = ts.combinePaths(typeRoot, typeReferenceDirectiveName);
var candidateDirectory = ts.getDirectoryPath(candidate);
- return resolvedTypeScriptOnly(loadNodeModuleFromDirectory(2, candidate, failedLookupLocations, !directoryProbablyExists(candidateDirectory, host), moduleResolutionState));
+ var directoryExists = directoryProbablyExists(candidateDirectory, host);
+ if (!directoryExists && traceEnabled) {
+ trace(host, ts.Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, candidateDirectory);
+ }
+ return resolvedTypeScriptOnly(loadNodeModuleFromDirectory(Extensions.DtsOnly, candidate, failedLookupLocations, !directoryExists, moduleResolutionState));
});
}
else {
@@ -19097,7 +20076,8 @@ var ts;
if (traceEnabled) {
trace(host, ts.Diagnostics.Looking_up_in_node_modules_folder_initial_location_0, initialLocationForSecondaryLookup);
}
- resolvedFile = resolvedTypeScriptOnly(loadModuleFromNodeModules(2, typeReferenceDirectiveName, initialLocationForSecondaryLookup, failedLookupLocations, moduleResolutionState));
+ var result = loadModuleFromNodeModules(Extensions.DtsOnly, typeReferenceDirectiveName, initialLocationForSecondaryLookup, failedLookupLocations, moduleResolutionState, undefined);
+ resolvedFile = resolvedTypeScriptOnly(result && result.value);
if (!resolvedFile && traceEnabled) {
trace(host, ts.Diagnostics.Type_reference_directive_0_was_not_resolved, typeReferenceDirectiveName);
}
@@ -19138,31 +20118,116 @@ var ts;
return result;
}
ts.getAutomaticTypeDirectiveNames = getAutomaticTypeDirectiveNames;
- function resolveModuleName(moduleName, containingFile, compilerOptions, host) {
+ function createModuleResolutionCache(currentDirectory, getCanonicalFileName) {
+ var directoryToModuleNameMap = ts.createFileMap();
+ var moduleNameToDirectoryMap = ts.createMap();
+ return { getOrCreateCacheForDirectory: getOrCreateCacheForDirectory, getOrCreateCacheForModuleName: getOrCreateCacheForModuleName };
+ function getOrCreateCacheForDirectory(directoryName) {
+ var path = ts.toPath(directoryName, currentDirectory, getCanonicalFileName);
+ var perFolderCache = directoryToModuleNameMap.get(path);
+ if (!perFolderCache) {
+ perFolderCache = ts.createMap();
+ directoryToModuleNameMap.set(path, perFolderCache);
+ }
+ return perFolderCache;
+ }
+ function getOrCreateCacheForModuleName(nonRelativeModuleName) {
+ if (!moduleHasNonRelativeName(nonRelativeModuleName)) {
+ return undefined;
+ }
+ var perModuleNameCache = moduleNameToDirectoryMap.get(nonRelativeModuleName);
+ if (!perModuleNameCache) {
+ perModuleNameCache = createPerModuleNameCache();
+ moduleNameToDirectoryMap.set(nonRelativeModuleName, perModuleNameCache);
+ }
+ return perModuleNameCache;
+ }
+ function createPerModuleNameCache() {
+ var directoryPathMap = ts.createFileMap();
+ return { get: get, set: set };
+ function get(directory) {
+ return directoryPathMap.get(ts.toPath(directory, currentDirectory, getCanonicalFileName));
+ }
+ function set(directory, result) {
+ var path = ts.toPath(directory, currentDirectory, getCanonicalFileName);
+ if (directoryPathMap.contains(path)) {
+ return;
+ }
+ directoryPathMap.set(path, result);
+ var resolvedFileName = result.resolvedModule && result.resolvedModule.resolvedFileName;
+ var commonPrefix = getCommonPrefix(path, resolvedFileName);
+ var current = path;
+ while (true) {
+ var parent = ts.getDirectoryPath(current);
+ if (parent === current || directoryPathMap.contains(parent)) {
+ break;
+ }
+ directoryPathMap.set(parent, result);
+ current = parent;
+ if (current === commonPrefix) {
+ break;
+ }
+ }
+ }
+ function getCommonPrefix(directory, resolution) {
+ if (resolution === undefined) {
+ return undefined;
+ }
+ var resolutionDirectory = ts.toPath(ts.getDirectoryPath(resolution), currentDirectory, getCanonicalFileName);
+ var i = 0;
+ while (i < Math.min(directory.length, resolutionDirectory.length) && directory.charCodeAt(i) === resolutionDirectory.charCodeAt(i)) {
+ i++;
+ }
+ var sep = directory.lastIndexOf(ts.directorySeparator, i);
+ if (sep < 0) {
+ return undefined;
+ }
+ return directory.substr(0, sep);
+ }
+ }
+ }
+ ts.createModuleResolutionCache = createModuleResolutionCache;
+ function resolveModuleName(moduleName, containingFile, compilerOptions, host, cache) {
var traceEnabled = isTraceEnabled(compilerOptions, host);
if (traceEnabled) {
trace(host, ts.Diagnostics.Resolving_module_0_from_1, moduleName, containingFile);
}
- var moduleResolution = compilerOptions.moduleResolution;
- if (moduleResolution === undefined) {
- moduleResolution = ts.getEmitModuleKind(compilerOptions) === ts.ModuleKind.CommonJS ? ts.ModuleResolutionKind.NodeJs : ts.ModuleResolutionKind.Classic;
+ var containingDirectory = ts.getDirectoryPath(containingFile);
+ var perFolderCache = cache && cache.getOrCreateCacheForDirectory(containingDirectory);
+ var result = perFolderCache && perFolderCache.get(moduleName);
+ if (result) {
if (traceEnabled) {
- trace(host, ts.Diagnostics.Module_resolution_kind_is_not_specified_using_0, ts.ModuleResolutionKind[moduleResolution]);
+ trace(host, ts.Diagnostics.Resolution_for_module_0_was_found_in_cache, moduleName);
}
}
else {
- if (traceEnabled) {
- trace(host, ts.Diagnostics.Explicitly_specified_module_resolution_kind_Colon_0, ts.ModuleResolutionKind[moduleResolution]);
+ var moduleResolution = compilerOptions.moduleResolution;
+ if (moduleResolution === undefined) {
+ moduleResolution = ts.getEmitModuleKind(compilerOptions) === ts.ModuleKind.CommonJS ? ts.ModuleResolutionKind.NodeJs : ts.ModuleResolutionKind.Classic;
+ if (traceEnabled) {
+ trace(host, ts.Diagnostics.Module_resolution_kind_is_not_specified_using_0, ts.ModuleResolutionKind[moduleResolution]);
+ }
+ }
+ else {
+ if (traceEnabled) {
+ trace(host, ts.Diagnostics.Explicitly_specified_module_resolution_kind_Colon_0, ts.ModuleResolutionKind[moduleResolution]);
+ }
+ }
+ switch (moduleResolution) {
+ case ts.ModuleResolutionKind.NodeJs:
+ result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache);
+ break;
+ case ts.ModuleResolutionKind.Classic:
+ result = classicNameResolver(moduleName, containingFile, compilerOptions, host, cache);
+ break;
+ }
+ if (perFolderCache) {
+ perFolderCache.set(moduleName, result);
+ var perModuleNameCache = cache.getOrCreateCacheForModuleName(moduleName);
+ if (perModuleNameCache) {
+ perModuleNameCache.set(containingDirectory, result);
+ }
}
- }
- var result;
- switch (moduleResolution) {
- case ts.ModuleResolutionKind.NodeJs:
- result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host);
- break;
- case ts.ModuleResolutionKind.Classic:
- result = classicNameResolver(moduleName, containingFile, compilerOptions, host);
- break;
}
if (traceEnabled) {
if (result.resolvedModule) {
@@ -19287,37 +20352,43 @@ var ts;
return loader(extensions, candidate, failedLookupLocations, !directoryProbablyExists(ts.getDirectoryPath(candidate), state.host), state);
}
}
- function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host) {
+ function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache) {
+ return nodeModuleNameResolverWorker(moduleName, containingFile, compilerOptions, host, cache, false);
+ }
+ ts.nodeModuleNameResolver = nodeModuleNameResolver;
+ function nodeModuleNameResolverWorker(moduleName, containingFile, compilerOptions, host, cache, jsOnly) {
+ if (jsOnly === void 0) { jsOnly = false; }
var containingDirectory = ts.getDirectoryPath(containingFile);
var traceEnabled = isTraceEnabled(compilerOptions, host);
var failedLookupLocations = [];
var state = { compilerOptions: compilerOptions, host: host, traceEnabled: traceEnabled };
- var result = tryResolve(0) || tryResolve(1);
- if (result) {
- var resolved = result.resolved, isExternalLibraryImport = result.isExternalLibraryImport;
+ var result = jsOnly ? tryResolve(Extensions.JavaScript) : (tryResolve(Extensions.TypeScript) || tryResolve(Extensions.JavaScript));
+ if (result && result.value) {
+ var _a = result.value, resolved = _a.resolved, isExternalLibraryImport = _a.isExternalLibraryImport;
return createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations);
}
return { resolvedModule: undefined, failedLookupLocations: failedLookupLocations };
function tryResolve(extensions) {
- var resolved = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, nodeLoadModuleByRelativeName, failedLookupLocations, state);
+ var loader = function (extensions, candidate, failedLookupLocations, onlyRecordFailures, state) { return nodeLoadModuleByRelativeName(extensions, candidate, failedLookupLocations, onlyRecordFailures, state, true); };
+ var resolved = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loader, failedLookupLocations, state);
if (resolved) {
- return { resolved: resolved, isExternalLibraryImport: false };
+ return toSearchResult({ resolved: resolved, isExternalLibraryImport: false });
}
if (moduleHasNonRelativeName(moduleName)) {
if (traceEnabled) {
- trace(host, ts.Diagnostics.Loading_module_0_from_node_modules_folder, moduleName);
+ trace(host, ts.Diagnostics.Loading_module_0_from_node_modules_folder_target_file_type_1, moduleName, Extensions[extensions]);
}
- var resolved_1 = loadModuleFromNodeModules(extensions, moduleName, containingDirectory, failedLookupLocations, state);
- return resolved_1 && { resolved: { path: realpath(resolved_1.path, host, traceEnabled), extension: resolved_1.extension }, isExternalLibraryImport: true };
+ var resolved_1 = loadModuleFromNodeModules(extensions, moduleName, containingDirectory, failedLookupLocations, state, cache);
+ return resolved_1 && { value: resolved_1.value && { resolved: { path: realpath(resolved_1.value.path, host, traceEnabled), extension: resolved_1.value.extension }, isExternalLibraryImport: true } };
}
else {
var candidate = ts.normalizePath(ts.combinePaths(containingDirectory, moduleName));
- var resolved_2 = nodeLoadModuleByRelativeName(extensions, candidate, failedLookupLocations, false, state);
- return resolved_2 && { resolved: resolved_2, isExternalLibraryImport: false };
+ var resolved_2 = nodeLoadModuleByRelativeName(extensions, candidate, failedLookupLocations, false, state, true);
+ return resolved_2 && toSearchResult({ resolved: resolved_2, isExternalLibraryImport: false });
}
}
}
- ts.nodeModuleNameResolver = nodeModuleNameResolver;
+ ts.nodeModuleNameResolverWorker = nodeModuleNameResolverWorker;
function realpath(path, host, traceEnabled) {
if (!host.realpath) {
return path;
@@ -19328,12 +20399,35 @@ var ts;
}
return real;
}
- function nodeLoadModuleByRelativeName(extensions, candidate, failedLookupLocations, onlyRecordFailures, state) {
+ function nodeLoadModuleByRelativeName(extensions, candidate, failedLookupLocations, onlyRecordFailures, state, considerPackageJson) {
if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.Loading_module_as_file_Slash_folder_candidate_module_location_0, candidate);
+ trace(state.host, ts.Diagnostics.Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_type_1, candidate, Extensions[extensions]);
}
- var resolvedFromFile = !ts.pathEndsWithDirectorySeparator(candidate) && loadModuleFromFile(extensions, candidate, failedLookupLocations, onlyRecordFailures, state);
- return resolvedFromFile || loadNodeModuleFromDirectory(extensions, candidate, failedLookupLocations, onlyRecordFailures, state);
+ if (!ts.pathEndsWithDirectorySeparator(candidate)) {
+ if (!onlyRecordFailures) {
+ var parentOfCandidate = ts.getDirectoryPath(candidate);
+ if (!directoryProbablyExists(parentOfCandidate, state.host)) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, parentOfCandidate);
+ }
+ onlyRecordFailures = true;
+ }
+ }
+ var resolvedFromFile = loadModuleFromFile(extensions, candidate, failedLookupLocations, onlyRecordFailures, state);
+ if (resolvedFromFile) {
+ return resolvedFromFile;
+ }
+ }
+ if (!onlyRecordFailures) {
+ var candidateExists = directoryProbablyExists(candidate, state.host);
+ if (!candidateExists) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, candidate);
+ }
+ onlyRecordFailures = true;
+ }
+ }
+ return loadNodeModuleFromDirectory(extensions, candidate, failedLookupLocations, onlyRecordFailures, state, considerPackageJson);
}
function directoryProbablyExists(directoryName, host) {
return !host.directoryExists || host.directoryExists(directoryName);
@@ -19361,11 +20455,11 @@ var ts;
}
}
switch (extensions) {
- case 2:
+ case Extensions.DtsOnly:
return tryExtension(".d.ts", ts.Extension.Dts);
- case 0:
+ case Extensions.TypeScript:
return tryExtension(".ts", ts.Extension.Ts) || tryExtension(".tsx", ts.Extension.Tsx) || tryExtension(".d.ts", ts.Extension.Dts);
- case 1:
+ case Extensions.JavaScript:
return tryExtension(".js", ts.Extension.Js) || tryExtension(".jsx", ts.Extension.Jsx);
}
function tryExtension(ext, extension) {
@@ -19374,113 +20468,181 @@ var ts;
}
}
function tryFile(fileName, failedLookupLocations, onlyRecordFailures, state) {
- if (!onlyRecordFailures && state.host.fileExists(fileName)) {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.File_0_exist_use_it_as_a_name_resolution_result, fileName);
+ if (!onlyRecordFailures) {
+ if (state.host.fileExists(fileName)) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.File_0_exist_use_it_as_a_name_resolution_result, fileName);
+ }
+ return fileName;
}
- return fileName;
- }
- else {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.File_0_does_not_exist, fileName);
+ else {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.File_0_does_not_exist, fileName);
+ }
}
- failedLookupLocations.push(fileName);
- return undefined;
}
+ failedLookupLocations.push(fileName);
+ return undefined;
}
- function loadNodeModuleFromDirectory(extensions, candidate, failedLookupLocations, onlyRecordFailures, state) {
- var packageJsonPath = pathToPackageJson(candidate);
+ function loadNodeModuleFromDirectory(extensions, candidate, failedLookupLocations, onlyRecordFailures, state, considerPackageJson) {
+ if (considerPackageJson === void 0) { considerPackageJson = true; }
var directoryExists = !onlyRecordFailures && directoryProbablyExists(candidate, state.host);
- if (directoryExists && state.host.fileExists(packageJsonPath)) {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.Found_package_json_at_0, packageJsonPath);
- }
- var typesFile = tryReadTypesSection(extensions, packageJsonPath, candidate, state);
- if (typesFile) {
- var onlyRecordFailures_1 = !directoryProbablyExists(ts.getDirectoryPath(typesFile), state.host);
- var fromFile = tryFile(typesFile, failedLookupLocations, onlyRecordFailures_1, state);
- if (fromFile) {
- return resolvedFromAnyFile(fromFile);
- }
- var x = tryAddingExtensions(typesFile, 0, failedLookupLocations, onlyRecordFailures_1, state);
- if (x) {
- return x;
+ if (considerPackageJson) {
+ var packageJsonPath = pathToPackageJson(candidate);
+ if (directoryExists && state.host.fileExists(packageJsonPath)) {
+ var fromPackageJson = loadModuleFromPackageJson(packageJsonPath, extensions, candidate, failedLookupLocations, state);
+ if (fromPackageJson) {
+ return fromPackageJson;
}
}
else {
- if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.package_json_does_not_have_a_types_or_main_field);
+ if (directoryExists && state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.File_0_does_not_exist, packageJsonPath);
}
+ failedLookupLocations.push(packageJsonPath);
}
}
- else {
+ return loadModuleFromFile(extensions, ts.combinePaths(candidate, "index"), failedLookupLocations, !directoryExists, state);
+ }
+ function loadModuleFromPackageJson(packageJsonPath, extensions, candidate, failedLookupLocations, state) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Found_package_json_at_0, packageJsonPath);
+ }
+ var file = tryReadPackageJsonFields(extensions !== Extensions.JavaScript, packageJsonPath, candidate, state);
+ if (!file) {
+ return undefined;
+ }
+ var onlyRecordFailures = !directoryProbablyExists(ts.getDirectoryPath(file), state.host);
+ var fromFile = tryFile(file, failedLookupLocations, onlyRecordFailures, state);
+ if (fromFile) {
+ var resolved = fromFile && resolvedIfExtensionMatches(extensions, fromFile);
+ if (resolved) {
+ return resolved;
+ }
if (state.traceEnabled) {
- trace(state.host, ts.Diagnostics.File_0_does_not_exist, packageJsonPath);
+ trace(state.host, ts.Diagnostics.File_0_has_an_unsupported_extension_so_skipping_it, fromFile);
}
- failedLookupLocations.push(packageJsonPath);
}
- return loadModuleFromFile(extensions, ts.combinePaths(candidate, "index"), failedLookupLocations, !directoryExists, state);
+ var nextExtensions = extensions === Extensions.DtsOnly ? Extensions.TypeScript : extensions;
+ return nodeLoadModuleByRelativeName(nextExtensions, file, failedLookupLocations, onlyRecordFailures, state, false);
+ }
+ function resolvedIfExtensionMatches(extensions, path) {
+ var extension = ts.tryGetExtensionFromPath(path);
+ return extension !== undefined && extensionIsOk(extensions, extension) ? { path: path, extension: extension } : undefined;
+ }
+ function extensionIsOk(extensions, extension) {
+ switch (extensions) {
+ case Extensions.JavaScript:
+ return extension === ts.Extension.Js || extension === ts.Extension.Jsx;
+ case Extensions.TypeScript:
+ return extension === ts.Extension.Ts || extension === ts.Extension.Tsx || extension === ts.Extension.Dts;
+ case Extensions.DtsOnly:
+ return extension === ts.Extension.Dts;
+ }
}
function pathToPackageJson(directory) {
return ts.combinePaths(directory, "package.json");
}
- function loadModuleFromNodeModulesFolder(extensions, moduleName, directory, failedLookupLocations, state) {
- var nodeModulesFolder = ts.combinePaths(directory, "node_modules");
- var nodeModulesFolderExists = directoryProbablyExists(nodeModulesFolder, state.host);
+ function loadModuleFromNodeModulesFolder(extensions, moduleName, nodeModulesFolder, nodeModulesFolderExists, failedLookupLocations, state) {
var candidate = ts.normalizePath(ts.combinePaths(nodeModulesFolder, moduleName));
return loadModuleFromFile(extensions, candidate, failedLookupLocations, !nodeModulesFolderExists, state) ||
loadNodeModuleFromDirectory(extensions, candidate, failedLookupLocations, !nodeModulesFolderExists, state);
}
- function loadModuleFromNodeModules(extensions, moduleName, directory, failedLookupLocations, state) {
- return loadModuleFromNodeModulesWorker(extensions, moduleName, directory, failedLookupLocations, state, false);
+ function loadModuleFromNodeModules(extensions, moduleName, directory, failedLookupLocations, state, cache) {
+ return loadModuleFromNodeModulesWorker(extensions, moduleName, directory, failedLookupLocations, state, false, cache);
}
function loadModuleFromNodeModulesAtTypes(moduleName, directory, failedLookupLocations, state) {
- return loadModuleFromNodeModulesWorker(2, moduleName, directory, failedLookupLocations, state, true);
+ return loadModuleFromNodeModulesWorker(Extensions.DtsOnly, moduleName, directory, failedLookupLocations, state, true, undefined);
}
- function loadModuleFromNodeModulesWorker(extensions, moduleName, directory, failedLookupLocations, state, typesOnly) {
+ function loadModuleFromNodeModulesWorker(extensions, moduleName, directory, failedLookupLocations, state, typesOnly, cache) {
+ var perModuleNameCache = cache && cache.getOrCreateCacheForModuleName(moduleName);
return forEachAncestorDirectory(ts.normalizeSlashes(directory), function (ancestorDirectory) {
if (ts.getBaseFileName(ancestorDirectory) !== "node_modules") {
- return loadModuleFromNodeModulesOneLevel(extensions, moduleName, ancestorDirectory, failedLookupLocations, state, typesOnly);
+ var resolutionFromCache = tryFindNonRelativeModuleNameInCache(perModuleNameCache, moduleName, ancestorDirectory, state.traceEnabled, state.host);
+ if (resolutionFromCache) {
+ return resolutionFromCache;
+ }
+ return toSearchResult(loadModuleFromNodeModulesOneLevel(extensions, moduleName, ancestorDirectory, failedLookupLocations, state, typesOnly));
}
});
}
function loadModuleFromNodeModulesOneLevel(extensions, moduleName, directory, failedLookupLocations, state, typesOnly) {
if (typesOnly === void 0) { typesOnly = false; }
- var packageResult = typesOnly ? undefined : loadModuleFromNodeModulesFolder(extensions, moduleName, directory, failedLookupLocations, state);
+ var nodeModulesFolder = ts.combinePaths(directory, "node_modules");
+ var nodeModulesFolderExists = directoryProbablyExists(nodeModulesFolder, state.host);
+ if (!nodeModulesFolderExists && state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, nodeModulesFolder);
+ }
+ var packageResult = typesOnly ? undefined : loadModuleFromNodeModulesFolder(extensions, moduleName, nodeModulesFolder, nodeModulesFolderExists, failedLookupLocations, state);
if (packageResult) {
return packageResult;
}
- if (extensions !== 1) {
- return loadModuleFromNodeModulesFolder(2, ts.combinePaths("@types", moduleName), directory, failedLookupLocations, state);
+ if (extensions !== Extensions.JavaScript) {
+ var nodeModulesAtTypes_1 = ts.combinePaths(nodeModulesFolder, "@types");
+ var nodeModulesAtTypesExists = nodeModulesFolderExists;
+ if (nodeModulesFolderExists && !directoryProbablyExists(nodeModulesAtTypes_1, state.host)) {
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, nodeModulesAtTypes_1);
+ }
+ nodeModulesAtTypesExists = false;
+ }
+ return loadModuleFromNodeModulesFolder(Extensions.DtsOnly, mangleScopedPackage(moduleName, state), nodeModulesAtTypes_1, nodeModulesAtTypesExists, failedLookupLocations, state);
+ }
+ }
+ function mangleScopedPackage(moduleName, state) {
+ if (ts.startsWith(moduleName, "@")) {
+ var replaceSlash = moduleName.replace(ts.directorySeparator, "__");
+ if (replaceSlash !== moduleName) {
+ var mangled = replaceSlash.slice(1);
+ if (state.traceEnabled) {
+ trace(state.host, ts.Diagnostics.Scoped_package_detected_looking_in_0, mangled);
+ }
+ return mangled;
+ }
+ }
+ return moduleName;
+ }
+ function tryFindNonRelativeModuleNameInCache(cache, moduleName, containingDirectory, traceEnabled, host) {
+ var result = cache && cache.get(containingDirectory);
+ if (result) {
+ if (traceEnabled) {
+ trace(host, ts.Diagnostics.Resolution_for_module_0_was_found_in_cache, moduleName);
+ }
+ return { value: result.resolvedModule && { path: result.resolvedModule.resolvedFileName, extension: result.resolvedModule.extension } };
}
}
- function classicNameResolver(moduleName, containingFile, compilerOptions, host) {
+ function classicNameResolver(moduleName, containingFile, compilerOptions, host, cache) {
var traceEnabled = isTraceEnabled(compilerOptions, host);
var state = { compilerOptions: compilerOptions, host: host, traceEnabled: traceEnabled };
var failedLookupLocations = [];
var containingDirectory = ts.getDirectoryPath(containingFile);
- var resolved = tryResolve(0) || tryResolve(1);
- return createResolvedModuleWithFailedLookupLocations(resolved, false, failedLookupLocations);
+ var resolved = tryResolve(Extensions.TypeScript) || tryResolve(Extensions.JavaScript);
+ return createResolvedModuleWithFailedLookupLocations(resolved && resolved.value, false, failedLookupLocations);
function tryResolve(extensions) {
var resolvedUsingSettings = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loadModuleFromFile, failedLookupLocations, state);
if (resolvedUsingSettings) {
- return resolvedUsingSettings;
+ return { value: resolvedUsingSettings };
}
+ var perModuleNameCache = cache && cache.getOrCreateCacheForModuleName(moduleName);
if (moduleHasNonRelativeName(moduleName)) {
var resolved_3 = forEachAncestorDirectory(containingDirectory, function (directory) {
+ var resolutionFromCache = tryFindNonRelativeModuleNameInCache(perModuleNameCache, moduleName, directory, traceEnabled, host);
+ if (resolutionFromCache) {
+ return resolutionFromCache;
+ }
var searchName = ts.normalizePath(ts.combinePaths(directory, moduleName));
- return loadModuleFromFile(extensions, searchName, failedLookupLocations, false, state);
+ return toSearchResult(loadModuleFromFile(extensions, searchName, failedLookupLocations, false, state));
});
if (resolved_3) {
return resolved_3;
}
- if (extensions === 0) {
+ if (extensions === Extensions.TypeScript) {
return loadModuleFromNodeModulesAtTypes(moduleName, containingDirectory, failedLookupLocations, state);
}
}
else {
var candidate = ts.normalizePath(ts.combinePaths(containingDirectory, moduleName));
- return loadModuleFromFile(extensions, candidate, failedLookupLocations, false, state);
+ return toSearchResult(loadModuleFromFile(extensions, candidate, failedLookupLocations, false, state));
}
}
}
@@ -19492,10 +20654,13 @@ var ts;
}
var state = { compilerOptions: compilerOptions, host: host, traceEnabled: traceEnabled };
var failedLookupLocations = [];
- var resolved = loadModuleFromNodeModulesOneLevel(2, moduleName, globalCache, failedLookupLocations, state);
+ var resolved = loadModuleFromNodeModulesOneLevel(Extensions.DtsOnly, moduleName, globalCache, failedLookupLocations, state);
return createResolvedModuleWithFailedLookupLocations(resolved, true, failedLookupLocations);
}
ts.loadModuleFromGlobalCache = loadModuleFromGlobalCache;
+ function toSearchResult(value) {
+ return value !== undefined ? { value: value } : undefined;
+ }
function forEachAncestorDirectory(directory, callback) {
while (true) {
var result = callback(directory);
@@ -19535,23 +20700,29 @@ var ts;
ts.getSymbolId = getSymbolId;
function createTypeChecker(host, produceDiagnostics) {
var cancellationToken;
+ var requestedExternalEmitHelpers;
+ var externalHelpersModule;
var Symbol = ts.objectAllocator.getSymbolConstructor();
var Type = ts.objectAllocator.getTypeConstructor();
var Signature = ts.objectAllocator.getSignatureConstructor();
var typeCount = 0;
var symbolCount = 0;
+ var symbolInstantiationDepth = 0;
var emptyArray = [];
var emptySymbols = ts.createMap();
var compilerOptions = host.getCompilerOptions();
- var languageVersion = compilerOptions.target || 0;
+ var languageVersion = ts.getEmitScriptTarget(compilerOptions);
var modulekind = ts.getEmitModuleKind(compilerOptions);
var noUnusedIdentifiers = !!compilerOptions.noUnusedLocals || !!compilerOptions.noUnusedParameters;
var allowSyntheticDefaultImports = typeof compilerOptions.allowSyntheticDefaultImports !== "undefined" ? compilerOptions.allowSyntheticDefaultImports : modulekind === ts.ModuleKind.System;
- var strictNullChecks = compilerOptions.strictNullChecks;
+ var strictNullChecks = compilerOptions.strictNullChecks === undefined ? compilerOptions.strict : compilerOptions.strictNullChecks;
+ var noImplicitAny = compilerOptions.noImplicitAny === undefined ? compilerOptions.strict : compilerOptions.noImplicitAny;
+ var noImplicitThis = compilerOptions.noImplicitThis === undefined ? compilerOptions.strict : compilerOptions.noImplicitThis;
var emitResolver = createResolver();
- var undefinedSymbol = createSymbol(4 | 67108864, "undefined");
+ var nodeBuilder = createNodeBuilder();
+ var undefinedSymbol = createSymbol(4, "undefined");
undefinedSymbol.declarations = [];
- var argumentsSymbol = createSymbol(4 | 67108864, "arguments");
+ var argumentsSymbol = createSymbol(4, "arguments");
var checker = {
getNodeCount: function () { return ts.sum(host.getSourceFiles(), "nodeCount"); },
getIdentifierCount: function () { return ts.sum(host.getSourceFiles(), "identifierCount"); },
@@ -19560,47 +20731,127 @@ var ts;
isUndefinedSymbol: function (symbol) { return symbol === undefinedSymbol; },
isArgumentsSymbol: function (symbol) { return symbol === argumentsSymbol; },
isUnknownSymbol: function (symbol) { return symbol === unknownSymbol; },
+ getMergedSymbol: getMergedSymbol,
getDiagnostics: getDiagnostics,
getGlobalDiagnostics: getGlobalDiagnostics,
- getTypeOfSymbolAtLocation: getTypeOfSymbolAtLocation,
- getSymbolsOfParameterPropertyDeclaration: getSymbolsOfParameterPropertyDeclaration,
+ getTypeOfSymbolAtLocation: function (symbol, location) {
+ location = ts.getParseTreeNode(location);
+ return location ? getTypeOfSymbolAtLocation(symbol, location) : unknownType;
+ },
+ getSymbolsOfParameterPropertyDeclaration: function (parameter, parameterName) {
+ parameter = ts.getParseTreeNode(parameter, ts.isParameter);
+ ts.Debug.assert(parameter !== undefined, "Cannot get symbols of a synthetic parameter that cannot be resolved to a parse-tree node.");
+ return getSymbolsOfParameterPropertyDeclaration(parameter, parameterName);
+ },
getDeclaredTypeOfSymbol: getDeclaredTypeOfSymbol,
getPropertiesOfType: getPropertiesOfType,
getPropertyOfType: getPropertyOfType,
+ getIndexInfoOfType: getIndexInfoOfType,
getSignaturesOfType: getSignaturesOfType,
getIndexTypeOfType: getIndexTypeOfType,
getBaseTypes: getBaseTypes,
+ getBaseTypeOfLiteralType: getBaseTypeOfLiteralType,
+ getWidenedType: getWidenedType,
+ getTypeFromTypeNode: function (node) {
+ node = ts.getParseTreeNode(node, ts.isTypeNode);
+ return node ? getTypeFromTypeNode(node) : unknownType;
+ },
+ getParameterType: getTypeAtPosition,
getReturnTypeOfSignature: getReturnTypeOfSignature,
getNonNullableType: getNonNullableType,
- getSymbolsInScope: getSymbolsInScope,
- getSymbolAtLocation: getSymbolAtLocation,
- getShorthandAssignmentValueSymbol: getShorthandAssignmentValueSymbol,
- getExportSpecifierLocalTargetSymbol: getExportSpecifierLocalTargetSymbol,
- getTypeAtLocation: getTypeOfNode,
- getPropertySymbolOfDestructuringAssignment: getPropertySymbolOfDestructuringAssignment,
- typeToString: typeToString,
+ typeToTypeNode: nodeBuilder.typeToTypeNode,
+ indexInfoToIndexSignatureDeclaration: nodeBuilder.indexInfoToIndexSignatureDeclaration,
+ signatureToSignatureDeclaration: nodeBuilder.signatureToSignatureDeclaration,
+ getSymbolsInScope: function (location, meaning) {
+ location = ts.getParseTreeNode(location);
+ return location ? getSymbolsInScope(location, meaning) : [];
+ },
+ getSymbolAtLocation: function (node) {
+ node = ts.getParseTreeNode(node);
+ return node ? getSymbolAtLocation(node) : undefined;
+ },
+ getShorthandAssignmentValueSymbol: function (node) {
+ node = ts.getParseTreeNode(node);
+ return node ? getShorthandAssignmentValueSymbol(node) : undefined;
+ },
+ getExportSpecifierLocalTargetSymbol: function (node) {
+ node = ts.getParseTreeNode(node, ts.isExportSpecifier);
+ return node ? getExportSpecifierLocalTargetSymbol(node) : undefined;
+ },
+ getTypeAtLocation: function (node) {
+ node = ts.getParseTreeNode(node);
+ return node ? getTypeOfNode(node) : unknownType;
+ },
+ getPropertySymbolOfDestructuringAssignment: function (location) {
+ location = ts.getParseTreeNode(location, ts.isIdentifier);
+ return location ? getPropertySymbolOfDestructuringAssignment(location) : undefined;
+ },
+ signatureToString: function (signature, enclosingDeclaration, flags, kind) {
+ return signatureToString(signature, ts.getParseTreeNode(enclosingDeclaration), flags, kind);
+ },
+ typeToString: function (type, enclosingDeclaration, flags) {
+ return typeToString(type, ts.getParseTreeNode(enclosingDeclaration), flags);
+ },
getSymbolDisplayBuilder: getSymbolDisplayBuilder,
- symbolToString: symbolToString,
+ symbolToString: function (symbol, enclosingDeclaration, meaning) {
+ return symbolToString(symbol, ts.getParseTreeNode(enclosingDeclaration), meaning);
+ },
getAugmentedPropertiesOfType: getAugmentedPropertiesOfType,
getRootSymbols: getRootSymbols,
- getContextualType: getContextualType,
+ getContextualType: function (node) {
+ node = ts.getParseTreeNode(node, ts.isExpression);
+ return node ? getContextualType(node) : undefined;
+ },
getFullyQualifiedName: getFullyQualifiedName,
- getResolvedSignature: getResolvedSignature,
- getConstantValue: getConstantValue,
- isValidPropertyAccess: isValidPropertyAccess,
- getSignatureFromDeclaration: getSignatureFromDeclaration,
- isImplementationOfOverload: isImplementationOfOverload,
+ getResolvedSignature: function (node, candidatesOutArray) {
+ node = ts.getParseTreeNode(node, ts.isCallLikeExpression);
+ return node ? getResolvedSignature(node, candidatesOutArray) : undefined;
+ },
+ getConstantValue: function (node) {
+ node = ts.getParseTreeNode(node, canHaveConstantValue);
+ return node ? getConstantValue(node) : undefined;
+ },
+ isValidPropertyAccess: function (node, propertyName) {
+ node = ts.getParseTreeNode(node, ts.isPropertyAccessOrQualifiedName);
+ return node ? isValidPropertyAccess(node, propertyName) : false;
+ },
+ getSignatureFromDeclaration: function (declaration) {
+ declaration = ts.getParseTreeNode(declaration, ts.isFunctionLike);
+ return declaration ? getSignatureFromDeclaration(declaration) : undefined;
+ },
+ isImplementationOfOverload: function (node) {
+ node = ts.getParseTreeNode(node, ts.isFunctionLike);
+ return node ? isImplementationOfOverload(node) : undefined;
+ },
+ getImmediateAliasedSymbol: function (symbol) {
+ ts.Debug.assert((symbol.flags & 8388608) !== 0, "Should only get Alias here.");
+ var links = getSymbolLinks(symbol);
+ if (!links.immediateTarget) {
+ var node = getDeclarationOfAliasSymbol(symbol);
+ ts.Debug.assert(!!node);
+ links.immediateTarget = getTargetOfAliasDeclaration(node, true);
+ }
+ return links.immediateTarget;
+ },
getAliasedSymbol: resolveAlias,
getEmitResolver: getEmitResolver,
getExportsOfModule: getExportsOfModuleAsArray,
+ getExportsAndPropertiesOfModule: getExportsAndPropertiesOfModule,
getAmbientModules: getAmbientModules,
- getJsxElementAttributesType: getJsxElementAttributesType,
+ getAllAttributesTypeFromJsxOpeningLikeElement: function (node) {
+ node = ts.getParseTreeNode(node, ts.isJsxOpeningLikeElement);
+ return node ? getAllAttributesTypeFromJsxOpeningLikeElement(node) : undefined;
+ },
getJsxIntrinsicTagNames: getJsxIntrinsicTagNames,
- isOptionalParameter: isOptionalParameter,
+ isOptionalParameter: function (node) {
+ node = ts.getParseTreeNode(node, ts.isParameter);
+ return node ? isOptionalParameter(node) : false;
+ },
tryGetMemberInModuleExports: tryGetMemberInModuleExports,
tryFindAmbientModuleWithoutAugmentations: function (moduleName) {
return tryFindAmbientModule(moduleName, false);
- }
+ },
+ getApparentType: getApparentType
};
var tupleTypes = [];
var unionTypes = ts.createMap();
@@ -19609,8 +20860,8 @@ var ts;
var numericLiteralTypes = ts.createMap();
var indexedAccessTypes = ts.createMap();
var evolvingArrayTypes = [];
- var unknownSymbol = createSymbol(4 | 67108864, "unknown");
- var resolvingSymbol = createSymbol(67108864, "__resolving__");
+ var unknownSymbol = createSymbol(4, "unknown");
+ var resolvingSymbol = createSymbol(0, "__resolving__");
var anyType = createIntrinsicType(1, "any");
var autoType = createIntrinsicType(1, "any");
var unknownType = createIntrinsicType(1, "unknown");
@@ -19627,8 +20878,9 @@ var ts;
var voidType = createIntrinsicType(1024, "void");
var neverType = createIntrinsicType(8192, "never");
var silentNeverType = createIntrinsicType(8192, "never");
+ var nonPrimitiveType = createIntrinsicType(16777216, "object");
var emptyObjectType = createAnonymousType(undefined, emptySymbols, emptyArray, emptyArray, undefined, undefined);
- var emptyTypeLiteralSymbol = createSymbol(2048 | 67108864, "__type");
+ var emptyTypeLiteralSymbol = createSymbol(2048, "__type");
emptyTypeLiteralSymbol.members = ts.createMap();
var emptyTypeLiteralType = createAnonymousType(emptyTypeLiteralSymbol, emptySymbols, emptyArray, emptyArray, undefined, undefined);
var emptyGenericType = createAnonymousType(undefined, emptySymbols, emptyArray, emptyArray, undefined, undefined);
@@ -19636,16 +20888,15 @@ var ts;
var anyFunctionType = createAnonymousType(undefined, emptySymbols, emptyArray, emptyArray, undefined, undefined);
anyFunctionType.flags |= 8388608;
var noConstraintType = createAnonymousType(undefined, emptySymbols, emptyArray, emptyArray, undefined, undefined);
+ var circularConstraintType = createAnonymousType(undefined, emptySymbols, emptyArray, emptyArray, undefined, undefined);
var anySignature = createSignature(undefined, undefined, undefined, emptyArray, anyType, undefined, 0, false, false);
var unknownSignature = createSignature(undefined, undefined, undefined, emptyArray, unknownType, undefined, 0, false, false);
var resolvingSignature = createSignature(undefined, undefined, undefined, emptyArray, anyType, undefined, 0, false, false);
var silentNeverSignature = createSignature(undefined, undefined, undefined, emptyArray, silentNeverType, undefined, 0, false, false);
var enumNumberIndexInfo = createIndexInfo(stringType, true);
+ var jsObjectLiteralIndexInfo = createIndexInfo(anyType, false);
var globals = ts.createMap();
var patternAmbientModules;
- var getGlobalESSymbolConstructorSymbol;
- var getGlobalPromiseConstructorSymbol;
- var tryGetGlobalPromiseConstructorSymbol;
var globalObjectType;
var globalFunctionType;
var globalArrayType;
@@ -19654,26 +20905,26 @@ var ts;
var globalNumberType;
var globalBooleanType;
var globalRegExpType;
+ var globalThisType;
var anyArrayType;
var autoArrayType;
var anyReadonlyArrayType;
- var getGlobalTemplateStringsArrayType;
- var getGlobalESSymbolType;
- var getGlobalIterableType;
- var getGlobalIteratorType;
- var getGlobalIterableIteratorType;
- var getGlobalClassDecoratorType;
- var getGlobalParameterDecoratorType;
- var getGlobalPropertyDecoratorType;
- var getGlobalMethodDecoratorType;
- var getGlobalTypedPropertyDescriptorType;
- var getGlobalPromiseType;
- var tryGetGlobalPromiseType;
- var getGlobalPromiseLikeType;
- var getInstantiatedGlobalPromiseLikeType;
- var getGlobalPromiseConstructorLikeType;
- var getGlobalThenableType;
- var jsxElementClassType;
+ var deferredGlobalESSymbolConstructorSymbol;
+ var deferredGlobalESSymbolType;
+ var deferredGlobalTypedPropertyDescriptorType;
+ var deferredGlobalPromiseType;
+ var deferredGlobalPromiseConstructorSymbol;
+ var deferredGlobalPromiseConstructorLikeType;
+ var deferredGlobalIterableType;
+ var deferredGlobalIteratorType;
+ var deferredGlobalIterableIteratorType;
+ var deferredGlobalAsyncIterableType;
+ var deferredGlobalAsyncIteratorType;
+ var deferredGlobalAsyncIterableIteratorType;
+ var deferredGlobalTemplateStringsArrayType;
+ var deferredJsxElementClassType;
+ var deferredJsxElementType;
+ var deferredJsxStatelessElementType;
var deferredNodes;
var deferredUnusedIdentifierNodes;
var flowLoopStart = 0;
@@ -19694,9 +20945,10 @@ var ts;
var visitedFlowNodes = [];
var visitedFlowTypes = [];
var potentialThisCollisions = [];
+ var potentialNewTargetCollisions = [];
var awaitedTypeStack = [];
var diagnostics = ts.createDiagnosticCollection();
- var typeofEQFacts = ts.createMap({
+ var typeofEQFacts = ts.createMapFromTemplate({
"string": 1,
"number": 2,
"boolean": 4,
@@ -19705,7 +20957,7 @@ var ts;
"object": 16,
"function": 32
});
- var typeofNEFacts = ts.createMap({
+ var typeofNEFacts = ts.createMapFromTemplate({
"string": 128,
"number": 256,
"boolean": 512,
@@ -19714,14 +20966,14 @@ var ts;
"object": 2048,
"function": 4096
});
- var typeofTypesByName = ts.createMap({
+ var typeofTypesByName = ts.createMapFromTemplate({
"string": stringType,
"number": numberType,
"boolean": booleanType,
"symbol": esSymbolType,
"undefined": undefinedType
});
- var jsxElementType;
+ var typeofType = createTypeofType();
var _jsxNamespace;
var _jsxFactoryEntity;
var jsxTypes = ts.createMap();
@@ -19741,7 +20993,7 @@ var ts;
var enumRelation = ts.createMap();
var _displayBuilder;
var builtinGlobals = ts.createMap();
- builtinGlobals[undefinedSymbol.name] = undefinedSymbol;
+ builtinGlobals.set(undefinedSymbol.name, undefinedSymbol);
initializeTypeChecker();
return checker;
function getJsxNamespace() {
@@ -19771,7 +21023,12 @@ var ts;
}
function createSymbol(flags, name) {
symbolCount++;
- return new Symbol(flags, name);
+ var symbol = (new Symbol(flags | 134217728, name));
+ symbol.checkFlags = 0;
+ return symbol;
+ }
+ function isTransientSymbol(symbol) {
+ return (symbol.flags & 134217728) !== 0;
}
function getExcludedSymbolFlags(flags) {
var result = 0;
@@ -19817,7 +21074,7 @@ var ts;
mergedSymbols[source.mergeId] = target;
}
function cloneSymbol(symbol) {
- var result = createSymbol(symbol.flags | 33554432, symbol.name);
+ var result = createSymbol(symbol.flags, symbol.name);
result.declarations = symbol.declarations.slice(0);
result.parent = symbol.parent;
if (symbol.valueDeclaration)
@@ -19839,12 +21096,10 @@ var ts;
target.flags |= source.flags;
if (source.valueDeclaration &&
(!target.valueDeclaration ||
- (target.valueDeclaration.kind === 230 && source.valueDeclaration.kind !== 230))) {
+ (target.valueDeclaration.kind === 232 && source.valueDeclaration.kind !== 232))) {
target.valueDeclaration = source.valueDeclaration;
}
- ts.forEach(source.declarations, function (node) {
- target.declarations.push(node);
- });
+ ts.addRange(target.declarations, source.declarations);
if (source.members) {
if (!target.members)
target.members = ts.createMap();
@@ -19857,6 +21112,9 @@ var ts;
}
recordMergedSymbol(target, source);
}
+ else if (target.flags & 1024) {
+ error(source.valueDeclaration.name, ts.Diagnostics.Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity, symbolToString(target));
+ }
else {
var message_2 = target.flags & 2 || source.flags & 2
? ts.Diagnostics.Cannot_redeclare_block_scoped_variable_0 : ts.Diagnostics.Duplicate_identifier_0;
@@ -19869,18 +21127,19 @@ var ts;
}
}
function mergeSymbolTable(target, source) {
- for (var id in source) {
- var targetSymbol = target[id];
+ source.forEach(function (sourceSymbol, id) {
+ var targetSymbol = target.get(id);
if (!targetSymbol) {
- target[id] = source[id];
+ target.set(id, sourceSymbol);
}
else {
- if (!(targetSymbol.flags & 33554432)) {
- target[id] = targetSymbol = cloneSymbol(targetSymbol);
+ if (!(targetSymbol.flags & 134217728)) {
+ targetSymbol = cloneSymbol(targetSymbol);
+ target.set(id, targetSymbol);
}
- mergeSymbol(targetSymbol, source[id]);
+ mergeSymbol(targetSymbol, sourceSymbol);
}
- }
+ });
}
function mergeModuleAugmentation(moduleName) {
var moduleAugmentation = moduleName.parent;
@@ -19901,7 +21160,7 @@ var ts;
}
mainModule = resolveExternalModuleSymbol(mainModule);
if (mainModule.flags & 1920) {
- mainModule = mainModule.flags & 33554432 ? mainModule : cloneSymbol(mainModule);
+ mainModule = mainModule.flags & 134217728 ? mainModule : cloneSymbol(mainModule);
mergeSymbol(mainModule, moduleAugmentation.symbol);
}
else {
@@ -19910,20 +21169,21 @@ var ts;
}
}
function addToSymbolTable(target, source, message) {
- for (var id in source) {
- if (target[id]) {
- ts.forEach(target[id].declarations, addDeclarationDiagnostic(id, message));
+ source.forEach(function (sourceSymbol, id) {
+ var targetSymbol = target.get(id);
+ if (targetSymbol) {
+ ts.forEach(targetSymbol.declarations, addDeclarationDiagnostic(id, message));
}
else {
- target[id] = source[id];
+ target.set(id, sourceSymbol);
}
- }
+ });
function addDeclarationDiagnostic(id, message) {
return function (declaration) { return diagnostics.add(ts.createDiagnosticForNode(declaration, message, id)); };
}
}
function getSymbolLinks(symbol) {
- if (symbol.flags & 67108864)
+ if (symbol.flags & 134217728)
return symbol;
var id = getSymbolId(symbol);
return symbolLinks[id] || (symbolLinks[id] = {});
@@ -19935,14 +21195,17 @@ var ts;
function getObjectFlags(type) {
return type.flags & 32768 ? type.objectFlags : 0;
}
+ function getCheckFlags(symbol) {
+ return symbol.flags & 134217728 ? symbol.checkFlags : 0;
+ }
function isGlobalSourceFile(node) {
- return node.kind === 261 && !ts.isExternalOrCommonJsModule(node);
+ return node.kind === 264 && !ts.isExternalOrCommonJsModule(node);
}
function getSymbol(symbols, name, meaning) {
if (meaning) {
- var symbol = symbols[name];
+ var symbol = symbols.get(name);
if (symbol) {
- ts.Debug.assert((symbol.flags & 16777216) === 0, "Should never get an instantiated symbol here.");
+ ts.Debug.assert((getCheckFlags(symbol) & 1) === 0, "Should never get an instantiated symbol here.");
if (symbol.flags & meaning) {
return symbol;
}
@@ -19973,57 +21236,76 @@ var ts;
(!compilerOptions.outFile && !compilerOptions.out)) {
return true;
}
- if (isUsedInFunctionOrNonStaticProperty(usage)) {
+ if (isUsedInFunctionOrInstanceProperty(usage, declaration)) {
return true;
}
var sourceFiles = host.getSourceFiles();
return ts.indexOf(sourceFiles, declarationFile) <= ts.indexOf(sourceFiles, useFile);
}
if (declaration.pos <= usage.pos) {
- return declaration.kind !== 223 ||
- !isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage);
+ if (declaration.kind === 175) {
+ var errorBindingElement = ts.getAncestor(usage, 175);
+ if (errorBindingElement) {
+ return ts.findAncestor(errorBindingElement, ts.isBindingElement) !== ts.findAncestor(declaration, ts.isBindingElement) ||
+ declaration.pos < errorBindingElement.pos;
+ }
+ return isBlockScopedNameDeclaredBeforeUse(ts.getAncestor(declaration, 225), usage);
+ }
+ else if (declaration.kind === 225) {
+ return !isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage);
+ }
+ return true;
+ }
+ if (usage.parent.kind === 245) {
+ return true;
}
var container = ts.getEnclosingBlockScopeContainer(declaration);
- return isUsedInFunctionOrNonStaticProperty(usage, container);
+ return isInTypeQuery(usage) || isUsedInFunctionOrInstanceProperty(usage, declaration, container);
function isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage) {
var container = ts.getEnclosingBlockScopeContainer(declaration);
switch (declaration.parent.parent.kind) {
- case 205:
- case 211:
+ case 207:
case 213:
+ case 215:
if (isSameScopeDescendentOf(usage, declaration, container)) {
return true;
}
break;
}
switch (declaration.parent.parent.kind) {
- case 212:
- case 213:
+ case 214:
+ case 215:
if (isSameScopeDescendentOf(usage, declaration.parent.parent.expression, container)) {
return true;
}
}
return false;
}
- function isUsedInFunctionOrNonStaticProperty(usage, container) {
- var current = usage;
- while (current) {
+ function isUsedInFunctionOrInstanceProperty(usage, declaration, container) {
+ return !!ts.findAncestor(usage, function (current) {
if (current === container) {
- return false;
+ return "quit";
}
if (ts.isFunctionLike(current)) {
return true;
}
- var initializerOfNonStaticProperty = current.parent &&
- current.parent.kind === 147 &&
- (ts.getModifierFlags(current.parent) & 32) === 0 &&
+ var initializerOfProperty = current.parent &&
+ current.parent.kind === 148 &&
current.parent.initializer === current;
- if (initializerOfNonStaticProperty) {
- return true;
+ if (initializerOfProperty) {
+ if (ts.getModifierFlags(current.parent) & 32) {
+ if (declaration.kind === 150) {
+ return true;
+ }
+ }
+ else {
+ var isDeclarationInstanceProperty = declaration.kind === 148 && !(ts.getModifierFlags(declaration) & 32);
+ if (!isDeclarationInstanceProperty || ts.getContainingClass(usage) !== ts.getContainingClass(declaration)) {
+ return true;
+ }
+ }
}
- current = current.parent;
- }
- return false;
+ });
}
}
function resolveName(location, name, meaning, nameNotFoundMessage, nameArg) {
@@ -20038,18 +21320,18 @@ var ts;
if (result = getSymbol(location.locals, name, meaning)) {
var useResult = true;
if (ts.isFunctionLike(location) && lastLocation && lastLocation !== location.body) {
- if (meaning & result.flags & 793064 && lastLocation.kind !== 278) {
+ if (meaning & result.flags & 793064 && lastLocation.kind !== 282) {
useResult = result.flags & 262144
? lastLocation === location.type ||
- lastLocation.kind === 144 ||
- lastLocation.kind === 143
+ lastLocation.kind === 145 ||
+ lastLocation.kind === 144
: false;
}
if (meaning & 107455 && result.flags & 1) {
useResult =
- lastLocation.kind === 144 ||
+ lastLocation.kind === 145 ||
(lastLocation === location.type &&
- result.valueDeclaration.kind === 144);
+ result.valueDeclaration.kind === 145);
}
}
if (useResult) {
@@ -20061,23 +21343,24 @@ var ts;
}
}
switch (location.kind) {
- case 261:
+ case 264:
if (!ts.isExternalOrCommonJsModule(location))
break;
isInExternalModule = true;
- case 230:
+ case 232:
var moduleExports = getSymbolOfNode(location).exports;
- if (location.kind === 261 || ts.isAmbientModule(location)) {
- if (result = moduleExports["default"]) {
+ if (location.kind === 264 || ts.isAmbientModule(location)) {
+ if (result = moduleExports.get("default")) {
var localSymbol = ts.getLocalSymbolForExportDefault(result);
if (localSymbol && (result.flags & meaning) && localSymbol.name === name) {
break loop;
}
result = undefined;
}
- if (moduleExports[name] &&
- moduleExports[name].flags === 8388608 &&
- ts.getDeclarationOfKind(moduleExports[name], 243)) {
+ var moduleExport = moduleExports.get(name);
+ if (moduleExport &&
+ moduleExport.flags === 8388608 &&
+ ts.getDeclarationOfKind(moduleExport, 245)) {
break;
}
}
@@ -20085,13 +21368,13 @@ var ts;
break loop;
}
break;
- case 229:
+ case 231:
if (result = getSymbol(getSymbolOfNode(location).exports, name, meaning & 8)) {
break loop;
}
break;
+ case 148:
case 147:
- case 146:
if (ts.isClassLike(location.parent) && !(ts.getModifierFlags(location) & 32)) {
var ctor = findConstructorDeclaration(location.parent);
if (ctor && ctor.locals) {
@@ -20101,17 +21384,21 @@ var ts;
}
}
break;
- case 226:
- case 197:
- case 227:
+ case 228:
+ case 198:
+ case 229:
if (result = getSymbol(getSymbolOfNode(location).members, name, meaning & 793064)) {
+ if (!isTypeParameterSymbolDeclaredInContainer(result, location)) {
+ result = undefined;
+ break;
+ }
if (lastLocation && ts.getModifierFlags(lastLocation) & 32) {
error(errorLocation, ts.Diagnostics.Static_members_cannot_reference_class_type_parameters);
return undefined;
}
break loop;
}
- if (location.kind === 197 && meaning & 32) {
+ if (location.kind === 198 && meaning & 32) {
var className = location.name;
if (className && name === className.text) {
result = location.symbol;
@@ -20119,28 +21406,28 @@ var ts;
}
}
break;
- case 142:
+ case 143:
grandparent = location.parent.parent;
- if (ts.isClassLike(grandparent) || grandparent.kind === 227) {
+ if (ts.isClassLike(grandparent) || grandparent.kind === 229) {
if (result = getSymbol(getSymbolOfNode(grandparent).members, name, meaning & 793064)) {
error(errorLocation, ts.Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type);
return undefined;
}
}
break;
- case 149:
- case 148:
case 150:
+ case 149:
case 151:
case 152:
- case 225:
- case 185:
+ case 153:
+ case 227:
+ case 186:
if (meaning & 3 && name === "arguments") {
result = argumentsSymbol;
break loop;
}
break;
- case 184:
+ case 185:
if (meaning & 3 && name === "arguments") {
result = argumentsSymbol;
break loop;
@@ -20153,8 +21440,8 @@ var ts;
}
}
break;
- case 145:
- if (location.parent && location.parent.kind === 144) {
+ case 146:
+ if (location.parent && location.parent.kind === 145) {
location = location.parent;
}
if (location.parent && ts.isClassElement(location.parent)) {
@@ -20177,7 +21464,8 @@ var ts;
!checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) &&
!checkAndReportErrorForExtendingInterface(errorLocation) &&
!checkAndReportErrorForUsingTypeAsNamespace(errorLocation, name, meaning) &&
- !checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning)) {
+ !checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) &&
+ !checkAndReportErrorForUsingNamespaceModuleAsValue(errorLocation, name, meaning)) {
error(errorLocation, nameNotFoundMessage, typeof nameArg === "string" ? nameArg : ts.declarationNameToString(nameArg));
}
}
@@ -20189,21 +21477,31 @@ var ts;
error(errorLocation, ts.Diagnostics.Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor, ts.declarationNameToString(propertyName), typeof nameArg === "string" ? nameArg : ts.declarationNameToString(nameArg));
return undefined;
}
- if (meaning & 2) {
+ if (meaning & 2 ||
+ ((meaning & 32 || meaning & 384) && (meaning & 107455) === 107455)) {
var exportOrLocalSymbol = getExportSymbolOfValueSymbolIfExported(result);
- if (exportOrLocalSymbol.flags & 2) {
+ if (exportOrLocalSymbol.flags & 2 || exportOrLocalSymbol.flags & 32 || exportOrLocalSymbol.flags & 384) {
checkResolvedBlockScopedVariable(exportOrLocalSymbol, errorLocation);
}
}
if (result && isInExternalModule && (meaning & 107455) === 107455) {
var decls = result.declarations;
- if (decls && decls.length === 1 && decls[0].kind === 233) {
+ if (decls && decls.length === 1 && decls[0].kind === 235) {
error(errorLocation, ts.Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead, name);
}
}
}
return result;
}
+ function isTypeParameterSymbolDeclaredInContainer(symbol, container) {
+ for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
+ var decl = _a[_i];
+ if (decl.kind === 144 && decl.parent === container) {
+ return true;
+ }
+ }
+ return false;
+ }
function checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) {
if ((errorLocation.kind === 70 && (isTypeReferenceIdentifier(errorLocation)) || isInTypeQuery(errorLocation))) {
return false;
@@ -20244,9 +21542,9 @@ var ts;
function getEntityNameForExtendingInterface(node) {
switch (node.kind) {
case 70:
- case 177:
+ case 178:
return node.parent ? getEntityNameForExtendingInterface(node.parent) : undefined;
- case 199:
+ case 200:
ts.Debug.assert(ts.isEntityNameExpression(node.expression));
return node.expression;
default:
@@ -20273,65 +21571,84 @@ var ts;
}
return false;
}
- function checkResolvedBlockScopedVariable(result, errorLocation) {
- ts.Debug.assert((result.flags & 2) !== 0);
- var declaration = ts.forEach(result.declarations, function (d) { return ts.isBlockOrCatchScoped(d) ? d : undefined; });
- ts.Debug.assert(declaration !== undefined, "Block-scoped variable declaration is undefined");
- if (!ts.isInAmbientContext(declaration) && !isBlockScopedNameDeclaredBeforeUse(ts.getAncestor(declaration, 223), errorLocation)) {
- error(errorLocation, ts.Diagnostics.Block_scoped_variable_0_used_before_its_declaration, ts.declarationNameToString(declaration.name));
- }
- }
- function isSameScopeDescendentOf(initial, parent, stopAt) {
- if (!parent) {
- return false;
+ function checkAndReportErrorForUsingNamespaceModuleAsValue(errorLocation, name, meaning) {
+ if (meaning & (107455 & ~1024 & ~793064)) {
+ var symbol = resolveSymbol(resolveName(errorLocation, name, 1024 & ~107455, undefined, undefined));
+ if (symbol) {
+ error(errorLocation, ts.Diagnostics.Cannot_use_namespace_0_as_a_value, name);
+ return true;
+ }
}
- for (var current = initial; current && current !== stopAt && !ts.isFunctionLike(current); current = current.parent) {
- if (current === parent) {
+ else if (meaning & (793064 & ~1024 & ~107455)) {
+ var symbol = resolveSymbol(resolveName(errorLocation, name, 1024 & ~793064, undefined, undefined));
+ if (symbol) {
+ error(errorLocation, ts.Diagnostics.Cannot_use_namespace_0_as_a_type, name);
return true;
}
}
return false;
}
+ function checkResolvedBlockScopedVariable(result, errorLocation) {
+ ts.Debug.assert(!!(result.flags & 2 || result.flags & 32 || result.flags & 384));
+ var declaration = ts.forEach(result.declarations, function (d) { return ts.isBlockOrCatchScoped(d) || ts.isClassLike(d) || (d.kind === 231) ? d : undefined; });
+ ts.Debug.assert(declaration !== undefined, "Declaration to checkResolvedBlockScopedVariable is undefined");
+ if (!ts.isInAmbientContext(declaration) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) {
+ if (result.flags & 2) {
+ error(errorLocation, ts.Diagnostics.Block_scoped_variable_0_used_before_its_declaration, ts.declarationNameToString(declaration.name));
+ }
+ else if (result.flags & 32) {
+ error(errorLocation, ts.Diagnostics.Class_0_used_before_its_declaration, ts.declarationNameToString(declaration.name));
+ }
+ else if (result.flags & 384) {
+ error(errorLocation, ts.Diagnostics.Enum_0_used_before_its_declaration, ts.declarationNameToString(declaration.name));
+ }
+ }
+ }
+ function isSameScopeDescendentOf(initial, parent, stopAt) {
+ return parent && !!ts.findAncestor(initial, function (n) { return n === stopAt || ts.isFunctionLike(n) ? "quit" : n === parent; });
+ }
function getAnyImportSyntax(node) {
if (ts.isAliasSymbolDeclaration(node)) {
- if (node.kind === 234) {
+ if (node.kind === 236) {
return node;
}
- while (node && node.kind !== 235) {
- node = node.parent;
- }
- return node;
+ return ts.findAncestor(node, function (n) { return n.kind === 237; });
}
}
function getDeclarationOfAliasSymbol(symbol) {
- return ts.forEach(symbol.declarations, function (d) { return ts.isAliasSymbolDeclaration(d) ? d : undefined; });
+ return ts.find(symbol.declarations, ts.isAliasSymbolDeclaration);
}
- function getTargetOfImportEqualsDeclaration(node) {
- if (node.moduleReference.kind === 245) {
+ function getTargetOfImportEqualsDeclaration(node, dontResolveAlias) {
+ if (node.moduleReference.kind === 247) {
return resolveExternalModuleSymbol(resolveExternalModuleName(node, ts.getExternalModuleImportEqualsDeclarationExpression(node)));
}
- return getSymbolOfPartOfRightHandSideOfImportEquals(node.moduleReference);
+ return getSymbolOfPartOfRightHandSideOfImportEquals(node.moduleReference, dontResolveAlias);
}
- function getTargetOfImportClause(node) {
+ function getTargetOfImportClause(node, dontResolveAlias) {
var moduleSymbol = resolveExternalModuleName(node, node.parent.moduleSpecifier);
if (moduleSymbol) {
- var exportDefaultSymbol = ts.isShorthandAmbientModuleSymbol(moduleSymbol) ?
- moduleSymbol :
- moduleSymbol.exports["export="] ?
- getPropertyOfType(getTypeOfSymbol(moduleSymbol.exports["export="]), "default") :
- resolveSymbol(moduleSymbol.exports["default"]);
+ var exportDefaultSymbol = void 0;
+ if (ts.isShorthandAmbientModuleSymbol(moduleSymbol)) {
+ exportDefaultSymbol = moduleSymbol;
+ }
+ else {
+ var exportValue = moduleSymbol.exports.get("export=");
+ exportDefaultSymbol = exportValue
+ ? getPropertyOfType(getTypeOfSymbol(exportValue), "default")
+ : resolveSymbol(moduleSymbol.exports.get("default"), dontResolveAlias);
+ }
if (!exportDefaultSymbol && !allowSyntheticDefaultImports) {
error(node.name, ts.Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol));
}
else if (!exportDefaultSymbol && allowSyntheticDefaultImports) {
- return resolveExternalModuleSymbol(moduleSymbol) || resolveSymbol(moduleSymbol);
+ return resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) || resolveSymbol(moduleSymbol, dontResolveAlias);
}
return exportDefaultSymbol;
}
}
- function getTargetOfNamespaceImport(node) {
+ function getTargetOfNamespaceImport(node, dontResolveAlias) {
var moduleSpecifier = node.parent.parent.moduleSpecifier;
- return resolveESModuleSymbol(resolveExternalModuleName(node, moduleSpecifier), moduleSpecifier);
+ return resolveESModuleSymbol(resolveExternalModuleName(node, moduleSpecifier), moduleSpecifier, dontResolveAlias);
}
function combineValueAndTypeSymbols(valueSymbol, typeSymbol) {
if (valueSymbol.flags & (793064 | 1920)) {
@@ -20348,12 +21665,9 @@ var ts;
result.exports = valueSymbol.exports;
return result;
}
- function getExportOfModule(symbol, name) {
+ function getExportOfModule(symbol, name, dontResolveAlias) {
if (symbol.flags & 1536) {
- var exportedSymbol = getExportsOfSymbol(symbol)[name];
- if (exportedSymbol) {
- return resolveSymbol(exportedSymbol);
- }
+ return resolveSymbol(getExportsOfSymbol(symbol).get(name), dontResolveAlias);
}
}
function getPropertyOfVariable(symbol, name) {
@@ -20364,71 +21678,72 @@ var ts;
}
}
}
- function getExternalModuleMember(node, specifier) {
+ function getExternalModuleMember(node, specifier, dontResolveAlias) {
var moduleSymbol = resolveExternalModuleName(node, node.moduleSpecifier);
- var targetSymbol = resolveESModuleSymbol(moduleSymbol, node.moduleSpecifier);
+ var targetSymbol = resolveESModuleSymbol(moduleSymbol, node.moduleSpecifier, dontResolveAlias);
if (targetSymbol) {
- var name_16 = specifier.propertyName || specifier.name;
- if (name_16.text) {
+ var name = specifier.propertyName || specifier.name;
+ if (name.text) {
if (ts.isShorthandAmbientModuleSymbol(moduleSymbol)) {
return moduleSymbol;
}
var symbolFromVariable = void 0;
- if (moduleSymbol && moduleSymbol.exports && moduleSymbol.exports["export="]) {
- symbolFromVariable = getPropertyOfType(getTypeOfSymbol(targetSymbol), name_16.text);
+ if (moduleSymbol && moduleSymbol.exports && moduleSymbol.exports.get("export=")) {
+ symbolFromVariable = getPropertyOfType(getTypeOfSymbol(targetSymbol), name.text);
}
else {
- symbolFromVariable = getPropertyOfVariable(targetSymbol, name_16.text);
+ symbolFromVariable = getPropertyOfVariable(targetSymbol, name.text);
}
- symbolFromVariable = resolveSymbol(symbolFromVariable);
- var symbolFromModule = getExportOfModule(targetSymbol, name_16.text);
- if (!symbolFromModule && allowSyntheticDefaultImports && name_16.text === "default") {
- symbolFromModule = resolveExternalModuleSymbol(moduleSymbol) || resolveSymbol(moduleSymbol);
+ symbolFromVariable = resolveSymbol(symbolFromVariable, dontResolveAlias);
+ var symbolFromModule = getExportOfModule(targetSymbol, name.text, dontResolveAlias);
+ if (!symbolFromModule && allowSyntheticDefaultImports && name.text === "default") {
+ symbolFromModule = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) || resolveSymbol(moduleSymbol, dontResolveAlias);
}
var symbol = symbolFromModule && symbolFromVariable ?
combineValueAndTypeSymbols(symbolFromVariable, symbolFromModule) :
symbolFromModule || symbolFromVariable;
if (!symbol) {
- error(name_16, ts.Diagnostics.Module_0_has_no_exported_member_1, getFullyQualifiedName(moduleSymbol), ts.declarationNameToString(name_16));
+ error(name, ts.Diagnostics.Module_0_has_no_exported_member_1, getFullyQualifiedName(moduleSymbol), ts.declarationNameToString(name));
}
return symbol;
}
}
}
- function getTargetOfImportSpecifier(node) {
- return getExternalModuleMember(node.parent.parent.parent, node);
+ function getTargetOfImportSpecifier(node, dontResolveAlias) {
+ return getExternalModuleMember(node.parent.parent.parent, node, dontResolveAlias);
}
- function getTargetOfNamespaceExportDeclaration(node) {
- return resolveExternalModuleSymbol(node.parent.symbol);
+ function getTargetOfNamespaceExportDeclaration(node, dontResolveAlias) {
+ return resolveExternalModuleSymbol(node.parent.symbol, dontResolveAlias);
}
- function getTargetOfExportSpecifier(node) {
+ function getTargetOfExportSpecifier(node, dontResolveAlias) {
return node.parent.parent.moduleSpecifier ?
- getExternalModuleMember(node.parent.parent, node) :
- resolveEntityName(node.propertyName || node.name, 107455 | 793064 | 1920);
+ getExternalModuleMember(node.parent.parent, node, dontResolveAlias) :
+ resolveEntityName(node.propertyName || node.name, 107455 | 793064 | 1920, false, dontResolveAlias);
}
- function getTargetOfExportAssignment(node) {
- return resolveEntityName(node.expression, 107455 | 793064 | 1920);
+ function getTargetOfExportAssignment(node, dontResolveAlias) {
+ return resolveEntityName(node.expression, 107455 | 793064 | 1920, false, dontResolveAlias);
}
- function getTargetOfAliasDeclaration(node) {
+ function getTargetOfAliasDeclaration(node, dontRecursivelyResolve) {
switch (node.kind) {
- case 234:
- return getTargetOfImportEqualsDeclaration(node);
case 236:
- return getTargetOfImportClause(node);
- case 237:
- return getTargetOfNamespaceImport(node);
+ return getTargetOfImportEqualsDeclaration(node, dontRecursivelyResolve);
+ case 238:
+ return getTargetOfImportClause(node, dontRecursivelyResolve);
case 239:
- return getTargetOfImportSpecifier(node);
- case 243:
- return getTargetOfExportSpecifier(node);
- case 240:
- return getTargetOfExportAssignment(node);
- case 233:
- return getTargetOfNamespaceExportDeclaration(node);
+ return getTargetOfNamespaceImport(node, dontRecursivelyResolve);
+ case 241:
+ return getTargetOfImportSpecifier(node, dontRecursivelyResolve);
+ case 245:
+ return getTargetOfExportSpecifier(node, dontRecursivelyResolve);
+ case 242:
+ return getTargetOfExportAssignment(node, dontRecursivelyResolve);
+ case 235:
+ return getTargetOfNamespaceExportDeclaration(node, dontRecursivelyResolve);
}
}
- function resolveSymbol(symbol) {
- return symbol && symbol.flags & 8388608 && !(symbol.flags & (107455 | 793064 | 1920)) ? resolveAlias(symbol) : symbol;
+ function resolveSymbol(symbol, dontResolveAlias) {
+ var shouldResolve = !dontResolveAlias && symbol && symbol.flags & 8388608 && !(symbol.flags & (107455 | 793064 | 1920));
+ return shouldResolve ? resolveAlias(symbol) : symbol;
}
function resolveAlias(symbol) {
ts.Debug.assert((symbol.flags & 8388608) !== 0, "Should only get Alias here.");
@@ -20467,10 +21782,10 @@ var ts;
links.referenced = true;
var node = getDeclarationOfAliasSymbol(symbol);
ts.Debug.assert(!!node);
- if (node.kind === 240) {
+ if (node.kind === 242) {
checkExpressionCached(node.expression);
}
- else if (node.kind === 243) {
+ else if (node.kind === 245) {
checkExpressionCached(node.propertyName || node.name);
}
else if (ts.isInternalModuleImportEqualsDeclaration(node)) {
@@ -20482,11 +21797,11 @@ var ts;
if (entityName.kind === 70 && ts.isRightSideOfQualifiedNameOrPropertyAccess(entityName)) {
entityName = entityName.parent;
}
- if (entityName.kind === 70 || entityName.parent.kind === 141) {
+ if (entityName.kind === 70 || entityName.parent.kind === 142) {
return resolveEntityName(entityName, 1920, false, dontResolveAlias);
}
else {
- ts.Debug.assert(entityName.parent.kind === 234);
+ ts.Debug.assert(entityName.parent.kind === 236);
return resolveEntityName(entityName, 107455 | 793064 | 1920, false, dontResolveAlias);
}
}
@@ -20505,9 +21820,19 @@ var ts;
return undefined;
}
}
- else if (name.kind === 141 || name.kind === 177) {
- var left = name.kind === 141 ? name.left : name.expression;
- var right = name.kind === 141 ? name.right : name.name;
+ else if (name.kind === 142 || name.kind === 178) {
+ var left = void 0;
+ if (name.kind === 142) {
+ left = name.left;
+ }
+ else if (name.kind === 178 &&
+ (name.expression.kind === 184 || ts.isEntityNameExpression(name.expression))) {
+ left = name.expression;
+ }
+ else {
+ return undefined;
+ }
+ var right = name.kind === 142 ? name.right : name.name;
var namespace = resolveEntityName(left, 1920, ignoreErrors, false, location);
if (!namespace || ts.nodeIsMissing(right)) {
return undefined;
@@ -20523,10 +21848,15 @@ var ts;
return undefined;
}
}
+ else if (name.kind === 184) {
+ return ts.isEntityNameExpression(name.expression) ?
+ resolveEntityName(name.expression, meaning, ignoreErrors, dontResolveAlias, location) :
+ undefined;
+ }
else {
ts.Debug.fail("Unknown entity name kind.");
}
- ts.Debug.assert((symbol.flags & 16777216) === 0, "Should never get an instantiated symbol here.");
+ ts.Debug.assert((getCheckFlags(symbol) & 1) === 0, "Should never get an instantiated symbol here.");
return (symbol.flags & meaning) || dontResolveAlias ? symbol : resolveAlias(symbol);
}
function resolveExternalModuleName(location, moduleReferenceExpression) {
@@ -20534,7 +21864,7 @@ var ts;
}
function resolveExternalModuleNameWorker(location, moduleReferenceExpression, moduleNotFoundError, isForAugmentation) {
if (isForAugmentation === void 0) { isForAugmentation = false; }
- if (moduleReferenceExpression.kind !== 9) {
+ if (moduleReferenceExpression.kind !== 9 && moduleReferenceExpression.kind !== 12) {
return;
}
var moduleReferenceLiteral = moduleReferenceExpression;
@@ -20571,11 +21901,10 @@ var ts;
}
if (!isRelative && resolvedModule && !ts.extensionIsTypeScript(resolvedModule.extension)) {
if (isForAugmentation) {
- ts.Debug.assert(!!moduleNotFoundError);
var diag = ts.Diagnostics.Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augmented;
- error(errorNode, diag, moduleName, resolvedModule.resolvedFileName);
+ error(errorNode, diag, moduleReference, resolvedModule.resolvedFileName);
}
- else if (compilerOptions.noImplicitAny && moduleNotFoundError) {
+ else if (noImplicitAny && moduleNotFoundError) {
error(errorNode, ts.Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type, moduleReference, resolvedModule.resolvedFileName);
}
return undefined;
@@ -20597,27 +21926,35 @@ var ts;
}
return undefined;
}
- function resolveExternalModuleSymbol(moduleSymbol) {
- return moduleSymbol && getMergedSymbol(resolveSymbol(moduleSymbol.exports["export="])) || moduleSymbol;
+ function resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) {
+ return moduleSymbol && getMergedSymbol(resolveSymbol(moduleSymbol.exports.get("export="), dontResolveAlias)) || moduleSymbol;
}
- function resolveESModuleSymbol(moduleSymbol, moduleReferenceExpression) {
- var symbol = resolveExternalModuleSymbol(moduleSymbol);
- if (symbol && !(symbol.flags & (1536 | 3))) {
+ function resolveESModuleSymbol(moduleSymbol, moduleReferenceExpression, dontResolveAlias) {
+ var symbol = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias);
+ if (!dontResolveAlias && symbol && !(symbol.flags & (1536 | 3))) {
error(moduleReferenceExpression, ts.Diagnostics.Module_0_resolves_to_a_non_module_entity_and_cannot_be_imported_using_this_construct, symbolToString(moduleSymbol));
symbol = undefined;
}
return symbol;
}
function hasExportAssignmentSymbol(moduleSymbol) {
- return moduleSymbol.exports["export="] !== undefined;
+ return moduleSymbol.exports.get("export=") !== undefined;
}
function getExportsOfModuleAsArray(moduleSymbol) {
return symbolsToArray(getExportsOfModule(moduleSymbol));
}
+ function getExportsAndPropertiesOfModule(moduleSymbol) {
+ var exports = getExportsOfModuleAsArray(moduleSymbol);
+ var exportEquals = resolveExternalModuleSymbol(moduleSymbol);
+ if (exportEquals !== moduleSymbol) {
+ ts.addRange(exports, getPropertiesOfType(getTypeOfSymbol(exportEquals)));
+ }
+ return exports;
+ }
function tryGetMemberInModuleExports(memberName, moduleSymbol) {
var symbolTable = getExportsOfModule(moduleSymbol);
if (symbolTable) {
- return symbolTable[memberName];
+ return symbolTable.get(memberName);
}
}
function getExportsOfSymbol(symbol) {
@@ -20628,24 +21965,28 @@ var ts;
return links.resolvedExports || (links.resolvedExports = getExportsForModule(moduleSymbol));
}
function extendExportSymbols(target, source, lookupTable, exportNode) {
- for (var id in source) {
- if (id !== "default" && !target[id]) {
- target[id] = source[id];
+ source && source.forEach(function (sourceSymbol, id) {
+ if (id === "default")
+ return;
+ var targetSymbol = target.get(id);
+ if (!targetSymbol) {
+ target.set(id, sourceSymbol);
if (lookupTable && exportNode) {
- lookupTable[id] = {
+ lookupTable.set(id, {
specifierText: ts.getTextOfNode(exportNode.moduleSpecifier)
- };
+ });
}
}
- else if (lookupTable && exportNode && id !== "default" && target[id] && resolveSymbol(target[id]) !== resolveSymbol(source[id])) {
- if (!lookupTable[id].exportsWithDuplicate) {
- lookupTable[id].exportsWithDuplicate = [exportNode];
+ else if (lookupTable && exportNode && targetSymbol && resolveSymbol(targetSymbol) !== resolveSymbol(sourceSymbol)) {
+ var collisionTracker = lookupTable.get(id);
+ if (!collisionTracker.exportsWithDuplicate) {
+ collisionTracker.exportsWithDuplicate = [exportNode];
}
else {
- lookupTable[id].exportsWithDuplicate.push(exportNode);
+ collisionTracker.exportsWithDuplicate.push(exportNode);
}
}
- }
+ });
}
function getExportsForModule(moduleSymbol) {
var visitedSymbols = [];
@@ -20657,26 +21998,26 @@ var ts;
}
visitedSymbols.push(symbol);
var symbols = ts.cloneMap(symbol.exports);
- var exportStars = symbol.exports["__export"];
+ var exportStars = symbol.exports.get("__export");
if (exportStars) {
var nestedSymbols = ts.createMap();
- var lookupTable = ts.createMap();
+ var lookupTable_1 = ts.createMap();
for (var _i = 0, _a = exportStars.declarations; _i < _a.length; _i++) {
var node = _a[_i];
var resolvedModule = resolveExternalModuleName(node, node.moduleSpecifier);
var exportedSymbols = visit(resolvedModule);
- extendExportSymbols(nestedSymbols, exportedSymbols, lookupTable, node);
+ extendExportSymbols(nestedSymbols, exportedSymbols, lookupTable_1, node);
}
- for (var id in lookupTable) {
- var exportsWithDuplicate = lookupTable[id].exportsWithDuplicate;
- if (id === "export=" || !(exportsWithDuplicate && exportsWithDuplicate.length) || symbols[id]) {
- continue;
+ lookupTable_1.forEach(function (_a, id) {
+ var exportsWithDuplicate = _a.exportsWithDuplicate;
+ if (id === "export=" || !(exportsWithDuplicate && exportsWithDuplicate.length) || symbols.has(id)) {
+ return;
}
- for (var _b = 0, exportsWithDuplicate_1 = exportsWithDuplicate; _b < exportsWithDuplicate_1.length; _b++) {
- var node = exportsWithDuplicate_1[_b];
- diagnostics.add(ts.createDiagnosticForNode(node, ts.Diagnostics.Module_0_has_already_exported_a_member_named_1_Consider_explicitly_re_exporting_to_resolve_the_ambiguity, lookupTable[id].specifierText, id));
+ for (var _i = 0, exportsWithDuplicate_1 = exportsWithDuplicate; _i < exportsWithDuplicate_1.length; _i++) {
+ var node = exportsWithDuplicate_1[_i];
+ diagnostics.add(ts.createDiagnosticForNode(node, ts.Diagnostics.Module_0_has_already_exported_a_member_named_1_Consider_explicitly_re_exporting_to_resolve_the_ambiguity, lookupTable_1.get(id).specifierText, id));
}
- }
+ });
extendExportSymbols(symbols, nestedSymbols);
}
return symbols;
@@ -20698,22 +22039,13 @@ var ts;
: symbol;
}
function symbolIsValue(symbol) {
- if (symbol.flags & 16777216) {
- return symbolIsValue(getSymbolLinks(symbol).target);
- }
- if (symbol.flags & 107455) {
- return true;
- }
- if (symbol.flags & 8388608) {
- return (resolveAlias(symbol).flags & 107455) !== 0;
- }
- return false;
+ return !!(symbol.flags & 107455 || symbol.flags & 8388608 && resolveAlias(symbol).flags & 107455);
}
function findConstructorDeclaration(node) {
var members = node.members;
for (var _i = 0, members_1 = members; _i < members_1.length; _i++) {
var member = members_1[_i];
- if (member.kind === 150 && ts.nodeIsPresent(member.body)) {
+ if (member.kind === 151 && ts.nodeIsPresent(member.body)) {
return member;
}
}
@@ -20741,6 +22073,9 @@ var ts;
type.symbol = symbol;
return type;
}
+ function createTypeofType() {
+ return getUnionType(ts.convertToArray(typeofEQFacts.keys(), function (s) { return getLiteralTypeForText(32, s); }));
+ }
function isReservedMemberName(name) {
return name.charCodeAt(0) === 95 &&
name.charCodeAt(1) === 95 &&
@@ -20749,16 +22084,15 @@ var ts;
}
function getNamedMembers(members) {
var result;
- for (var id in members) {
+ members.forEach(function (symbol, id) {
if (!isReservedMemberName(id)) {
if (!result)
result = [];
- var symbol = members[id];
if (symbolIsValue(symbol)) {
result.push(symbol);
}
}
- }
+ });
return result || emptyArray;
}
function setStructuredTypeMembers(type, members, callSignatures, constructSignatures, stringIndexInfo, numberIndexInfo) {
@@ -20777,19 +22111,19 @@ var ts;
}
function forEachSymbolTableInScope(enclosingDeclaration, callback) {
var result;
- for (var location_1 = enclosingDeclaration; location_1; location_1 = location_1.parent) {
- if (location_1.locals && !isGlobalSourceFile(location_1)) {
- if (result = callback(location_1.locals)) {
+ for (var location = enclosingDeclaration; location; location = location.parent) {
+ if (location.locals && !isGlobalSourceFile(location)) {
+ if (result = callback(location.locals)) {
return result;
}
}
- switch (location_1.kind) {
- case 261:
- if (!ts.isExternalOrCommonJsModule(location_1)) {
+ switch (location.kind) {
+ case 264:
+ if (!ts.isExternalOrCommonJsModule(location)) {
break;
}
- case 230:
- if (result = callback(getSymbolOfNode(location_1).exports)) {
+ case 232:
+ if (result = callback(getSymbolOfNode(location).exports)) {
return result;
}
break;
@@ -20802,6 +22136,16 @@ var ts;
}
function getAccessibleSymbolChain(symbol, enclosingDeclaration, meaning, useOnlyExternalAliasing) {
function getAccessibleSymbolChainFromSymbolTable(symbols) {
+ return getAccessibleSymbolChainFromSymbolTableWorker(symbols, []);
+ }
+ function getAccessibleSymbolChainFromSymbolTableWorker(symbols, visitedSymbolTables) {
+ if (ts.contains(visitedSymbolTables, symbols)) {
+ return undefined;
+ }
+ visitedSymbolTables.push(symbols);
+ var result = trySymbolTable(symbols);
+ visitedSymbolTables.pop();
+ return result;
function canQualifySymbol(symbolFromSymbolTable, meaning) {
if (!needsQualification(symbolFromSymbolTable, enclosingDeclaration, meaning)) {
return true;
@@ -20815,26 +22159,28 @@ var ts;
canQualifySymbol(symbolFromSymbolTable, meaning);
}
}
- if (isAccessible(symbols[symbol.name])) {
- return [symbol];
- }
- return ts.forEachProperty(symbols, function (symbolFromSymbolTable) {
- if (symbolFromSymbolTable.flags & 8388608
- && symbolFromSymbolTable.name !== "export="
- && !ts.getDeclarationOfKind(symbolFromSymbolTable, 243)) {
- if (!useOnlyExternalAliasing ||
- ts.forEach(symbolFromSymbolTable.declarations, ts.isExternalModuleImportEqualsDeclaration)) {
- var resolvedImportedSymbol = resolveAlias(symbolFromSymbolTable);
- if (isAccessible(symbolFromSymbolTable, resolveAlias(symbolFromSymbolTable))) {
- return [symbolFromSymbolTable];
- }
- var accessibleSymbolsFromExports = resolvedImportedSymbol.exports ? getAccessibleSymbolChainFromSymbolTable(resolvedImportedSymbol.exports) : undefined;
- if (accessibleSymbolsFromExports && canQualifySymbol(symbolFromSymbolTable, getQualifiedLeftMeaning(meaning))) {
- return [symbolFromSymbolTable].concat(accessibleSymbolsFromExports);
+ function trySymbolTable(symbols) {
+ if (isAccessible(symbols.get(symbol.name))) {
+ return [symbol];
+ }
+ return ts.forEachEntry(symbols, function (symbolFromSymbolTable) {
+ if (symbolFromSymbolTable.flags & 8388608
+ && symbolFromSymbolTable.name !== "export="
+ && !ts.getDeclarationOfKind(symbolFromSymbolTable, 245)) {
+ if (!useOnlyExternalAliasing ||
+ ts.forEach(symbolFromSymbolTable.declarations, ts.isExternalModuleImportEqualsDeclaration)) {
+ var resolvedImportedSymbol = resolveAlias(symbolFromSymbolTable);
+ if (isAccessible(symbolFromSymbolTable, resolveAlias(symbolFromSymbolTable))) {
+ return [symbolFromSymbolTable];
+ }
+ var accessibleSymbolsFromExports = resolvedImportedSymbol.exports ? getAccessibleSymbolChainFromSymbolTableWorker(resolvedImportedSymbol.exports, visitedSymbolTables) : undefined;
+ if (accessibleSymbolsFromExports && canQualifySymbol(symbolFromSymbolTable, getQualifiedLeftMeaning(meaning))) {
+ return [symbolFromSymbolTable].concat(accessibleSymbolsFromExports);
+ }
}
}
- }
- });
+ });
+ }
}
if (symbol) {
if (!(isPropertyOrMethodDeclarationSymbol(symbol))) {
@@ -20845,14 +22191,14 @@ var ts;
function needsQualification(symbol, enclosingDeclaration, meaning) {
var qualify = false;
forEachSymbolTableInScope(enclosingDeclaration, function (symbolTable) {
- var symbolFromSymbolTable = symbolTable[symbol.name];
+ var symbolFromSymbolTable = symbolTable.get(symbol.name);
if (!symbolFromSymbolTable) {
return false;
}
if (symbolFromSymbolTable === symbol) {
return true;
}
- symbolFromSymbolTable = (symbolFromSymbolTable.flags & 8388608 && !ts.getDeclarationOfKind(symbolFromSymbolTable, 243)) ? resolveAlias(symbolFromSymbolTable) : symbolFromSymbolTable;
+ symbolFromSymbolTable = (symbolFromSymbolTable.flags & 8388608 && !ts.getDeclarationOfKind(symbolFromSymbolTable, 245)) ? resolveAlias(symbolFromSymbolTable) : symbolFromSymbolTable;
if (symbolFromSymbolTable.flags & meaning) {
qualify = true;
return true;
@@ -20866,10 +22212,10 @@ var ts;
for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
switch (declaration.kind) {
- case 147:
- case 149:
- case 151:
+ case 148:
+ case 150:
case 152:
+ case 153:
continue;
default:
return false;
@@ -20917,15 +22263,12 @@ var ts;
}
return { accessibility: 0 };
function getExternalModuleContainer(declaration) {
- for (; declaration; declaration = declaration.parent) {
- if (hasExternalModuleSymbol(declaration)) {
- return getSymbolOfNode(declaration);
- }
- }
+ var node = ts.findAncestor(declaration, hasExternalModuleSymbol);
+ return node && getSymbolOfNode(node);
}
}
function hasExternalModuleSymbol(declaration) {
- return ts.isAmbientModule(declaration) || (declaration.kind === 261 && ts.isExternalOrCommonJsModule(declaration));
+ return ts.isAmbientModule(declaration) || (declaration.kind === 264 && ts.isExternalOrCommonJsModule(declaration));
}
function hasVisibleDeclarations(symbol, shouldComputeAliasToMakeVisible) {
var aliasesToMakeVisible;
@@ -20959,11 +22302,11 @@ var ts;
}
function isEntityNameVisible(entityName, enclosingDeclaration) {
var meaning;
- if (entityName.parent.kind === 160 || ts.isExpressionWithTypeArgumentsInClassExtendsClause(entityName.parent)) {
+ if (entityName.parent.kind === 161 || ts.isExpressionWithTypeArgumentsInClassExtendsClause(entityName.parent)) {
meaning = 107455 | 1048576;
}
- else if (entityName.kind === 141 || entityName.kind === 177 ||
- entityName.parent.kind === 234) {
+ else if (entityName.kind === 142 || entityName.kind === 178 ||
+ entityName.parent.kind === 236) {
meaning = 1920;
}
else {
@@ -21011,6 +22354,483 @@ var ts;
}
return result;
}
+ function createNodeBuilder() {
+ var context;
+ return {
+ typeToTypeNode: function (type, enclosingDeclaration, flags) {
+ context = createNodeBuilderContext(enclosingDeclaration, flags);
+ var resultingNode = typeToTypeNodeHelper(type);
+ var result = context.encounteredError ? undefined : resultingNode;
+ return result;
+ },
+ indexInfoToIndexSignatureDeclaration: function (indexInfo, kind, enclosingDeclaration, flags) {
+ context = createNodeBuilderContext(enclosingDeclaration, flags);
+ var resultingNode = indexInfoToIndexSignatureDeclarationHelper(indexInfo, kind);
+ var result = context.encounteredError ? undefined : resultingNode;
+ return result;
+ },
+ signatureToSignatureDeclaration: function (signature, kind, enclosingDeclaration, flags) {
+ context = createNodeBuilderContext(enclosingDeclaration, flags);
+ var resultingNode = signatureToSignatureDeclarationHelper(signature, kind);
+ var result = context.encounteredError ? undefined : resultingNode;
+ return result;
+ }
+ };
+ function createNodeBuilderContext(enclosingDeclaration, flags) {
+ return {
+ enclosingDeclaration: enclosingDeclaration,
+ flags: flags,
+ encounteredError: false,
+ inObjectTypeLiteral: false,
+ checkAlias: true,
+ symbolStack: undefined
+ };
+ }
+ function typeToTypeNodeHelper(type) {
+ if (!type) {
+ context.encounteredError = true;
+ return undefined;
+ }
+ if (type.flags & 1) {
+ return ts.createKeywordTypeNode(118);
+ }
+ if (type.flags & 2) {
+ return ts.createKeywordTypeNode(135);
+ }
+ if (type.flags & 4) {
+ return ts.createKeywordTypeNode(132);
+ }
+ if (type.flags & 8) {
+ return ts.createKeywordTypeNode(121);
+ }
+ if (type.flags & 16) {
+ var name = symbolToName(type.symbol, false);
+ return ts.createTypeReferenceNode(name, undefined);
+ }
+ if (type.flags & (32)) {
+ return ts.createLiteralTypeNode((ts.createLiteral(type.text)));
+ }
+ if (type.flags & (64)) {
+ return ts.createLiteralTypeNode((ts.createNumericLiteral(type.text)));
+ }
+ if (type.flags & 128) {
+ return type.intrinsicName === "true" ? ts.createTrue() : ts.createFalse();
+ }
+ if (type.flags & 256) {
+ var name = symbolToName(type.symbol, false);
+ return ts.createTypeReferenceNode(name, undefined);
+ }
+ if (type.flags & 1024) {
+ return ts.createKeywordTypeNode(104);
+ }
+ if (type.flags & 2048) {
+ return ts.createKeywordTypeNode(138);
+ }
+ if (type.flags & 4096) {
+ return ts.createKeywordTypeNode(94);
+ }
+ if (type.flags & 8192) {
+ return ts.createKeywordTypeNode(129);
+ }
+ if (type.flags & 512) {
+ return ts.createKeywordTypeNode(136);
+ }
+ if (type.flags & 16777216) {
+ return ts.createKeywordTypeNode(133);
+ }
+ if (type.flags & 16384 && type.isThisType) {
+ if (context.inObjectTypeLiteral) {
+ if (!context.encounteredError && !(context.flags & ts.NodeBuilderFlags.allowThisInObjectLiteral)) {
+ context.encounteredError = true;
+ }
+ }
+ return ts.createThis();
+ }
+ var objectFlags = getObjectFlags(type);
+ if (objectFlags & 4) {
+ ts.Debug.assert(!!(type.flags & 32768));
+ return typeReferenceToTypeNode(type);
+ }
+ if (objectFlags & 3) {
+ ts.Debug.assert(!!(type.flags & 32768));
+ var name = symbolToName(type.symbol, false);
+ return ts.createTypeReferenceNode(name, undefined);
+ }
+ if (type.flags & 16384) {
+ var name = symbolToName(type.symbol, false);
+ return ts.createTypeReferenceNode(name, undefined);
+ }
+ if (context.checkAlias && type.aliasSymbol) {
+ var name = symbolToName(type.aliasSymbol, false);
+ var typeArgumentNodes = type.aliasTypeArguments && mapToTypeNodeArray(type.aliasTypeArguments);
+ return ts.createTypeReferenceNode(name, typeArgumentNodes);
+ }
+ context.checkAlias = false;
+ if (type.flags & 65536) {
+ var formattedUnionTypes = formatUnionTypes(type.types);
+ var unionTypeNodes = formattedUnionTypes && mapToTypeNodeArray(formattedUnionTypes);
+ if (unionTypeNodes && unionTypeNodes.length > 0) {
+ return ts.createUnionOrIntersectionTypeNode(165, unionTypeNodes);
+ }
+ else {
+ if (!context.encounteredError && !(context.flags & ts.NodeBuilderFlags.allowEmptyUnionOrIntersection)) {
+ context.encounteredError = true;
+ }
+ return undefined;
+ }
+ }
+ if (type.flags & 131072) {
+ return ts.createUnionOrIntersectionTypeNode(166, mapToTypeNodeArray(type.types));
+ }
+ if (objectFlags & (16 | 32)) {
+ ts.Debug.assert(!!(type.flags & 32768));
+ return createAnonymousTypeNode(type);
+ }
+ if (type.flags & 262144) {
+ var indexedType = type.type;
+ var indexTypeNode = typeToTypeNodeHelper(indexedType);
+ return ts.createTypeOperatorNode(indexTypeNode);
+ }
+ if (type.flags & 524288) {
+ var objectTypeNode = typeToTypeNodeHelper(type.objectType);
+ var indexTypeNode = typeToTypeNodeHelper(type.indexType);
+ return ts.createIndexedAccessTypeNode(objectTypeNode, indexTypeNode);
+ }
+ ts.Debug.fail("Should be unreachable.");
+ function mapToTypeNodeArray(types) {
+ var result = [];
+ for (var _i = 0, types_1 = types; _i < types_1.length; _i++) {
+ var type_1 = types_1[_i];
+ var typeNode = typeToTypeNodeHelper(type_1);
+ if (typeNode) {
+ result.push(typeNode);
+ }
+ }
+ return result;
+ }
+ function createMappedTypeNodeFromType(type) {
+ ts.Debug.assert(!!(type.flags & 32768));
+ var typeParameter = getTypeParameterFromMappedType(type);
+ var typeParameterNode = typeParameterToDeclaration(typeParameter);
+ var templateType = getTemplateTypeFromMappedType(type);
+ var templateTypeNode = typeToTypeNodeHelper(templateType);
+ var readonlyToken = type.declaration && type.declaration.readonlyToken ? ts.createToken(130) : undefined;
+ var questionToken = type.declaration && type.declaration.questionToken ? ts.createToken(54) : undefined;
+ return ts.createMappedTypeNode(readonlyToken, typeParameterNode, questionToken, templateTypeNode);
+ }
+ function createAnonymousTypeNode(type) {
+ var symbol = type.symbol;
+ if (symbol) {
+ if (symbol.flags & 32 && !getBaseTypeVariableOfClass(symbol) ||
+ symbol.flags & (384 | 512) ||
+ shouldWriteTypeOfFunctionSymbol()) {
+ return createTypeQueryNodeFromSymbol(symbol);
+ }
+ else if (ts.contains(context.symbolStack, symbol)) {
+ var typeAlias = getTypeAliasForTypeLiteral(type);
+ if (typeAlias) {
+ var entityName = symbolToName(typeAlias, false);
+ return ts.createTypeReferenceNode(entityName, undefined);
+ }
+ else {
+ return ts.createKeywordTypeNode(118);
+ }
+ }
+ else {
+ if (!context.symbolStack) {
+ context.symbolStack = [];
+ }
+ context.symbolStack.push(symbol);
+ var result = createTypeNodeFromObjectType(type);
+ context.symbolStack.pop();
+ return result;
+ }
+ }
+ else {
+ return createTypeNodeFromObjectType(type);
+ }
+ function shouldWriteTypeOfFunctionSymbol() {
+ var isStaticMethodSymbol = !!(symbol.flags & 8192 &&
+ ts.forEach(symbol.declarations, function (declaration) { return ts.getModifierFlags(declaration) & 32; }));
+ var isNonLocalFunctionSymbol = !!(symbol.flags & 16) &&
+ (symbol.parent ||
+ ts.forEach(symbol.declarations, function (declaration) {
+ return declaration.parent.kind === 264 || declaration.parent.kind === 233;
+ }));
+ if (isStaticMethodSymbol || isNonLocalFunctionSymbol) {
+ return ts.contains(context.symbolStack, symbol);
+ }
+ }
+ }
+ function createTypeNodeFromObjectType(type) {
+ if (type.objectFlags & 32) {
+ if (getConstraintTypeFromMappedType(type).flags & (16384 | 262144)) {
+ return createMappedTypeNodeFromType(type);
+ }
+ }
+ var resolved = resolveStructuredTypeMembers(type);
+ if (!resolved.properties.length && !resolved.stringIndexInfo && !resolved.numberIndexInfo) {
+ if (!resolved.callSignatures.length && !resolved.constructSignatures.length) {
+ return ts.createTypeLiteralNode(undefined);
+ }
+ if (resolved.callSignatures.length === 1 && !resolved.constructSignatures.length) {
+ var signature = resolved.callSignatures[0];
+ return signatureToSignatureDeclarationHelper(signature, 159);
+ }
+ if (resolved.constructSignatures.length === 1 && !resolved.callSignatures.length) {
+ var signature = resolved.constructSignatures[0];
+ return signatureToSignatureDeclarationHelper(signature, 160);
+ }
+ }
+ var saveInObjectTypeLiteral = context.inObjectTypeLiteral;
+ context.inObjectTypeLiteral = true;
+ var members = createTypeNodesFromResolvedType(resolved);
+ context.inObjectTypeLiteral = saveInObjectTypeLiteral;
+ return ts.createTypeLiteralNode(members);
+ }
+ function createTypeQueryNodeFromSymbol(symbol) {
+ var entityName = symbolToName(symbol, false);
+ return ts.createTypeQueryNode(entityName);
+ }
+ function typeReferenceToTypeNode(type) {
+ var typeArguments = type.typeArguments || emptyArray;
+ if (type.target === globalArrayType) {
+ var elementType = typeToTypeNodeHelper(typeArguments[0]);
+ return ts.createArrayTypeNode(elementType);
+ }
+ else if (type.target.objectFlags & 8) {
+ if (typeArguments.length > 0) {
+ var tupleConstituentNodes = mapToTypeNodeArray(typeArguments.slice(0, getTypeReferenceArity(type)));
+ if (tupleConstituentNodes && tupleConstituentNodes.length > 0) {
+ return ts.createTupleTypeNode(tupleConstituentNodes);
+ }
+ }
+ if (!context.encounteredError && !(context.flags & ts.NodeBuilderFlags.allowEmptyTuple)) {
+ context.encounteredError = true;
+ }
+ return undefined;
+ }
+ else {
+ var outerTypeParameters = type.target.outerTypeParameters;
+ var i = 0;
+ var qualifiedName = undefined;
+ if (outerTypeParameters) {
+ var length_1 = outerTypeParameters.length;
+ while (i < length_1) {
+ var start = i;
+ var parent = getParentSymbolOfTypeParameter(outerTypeParameters[i]);
+ do {
+ i++;
+ } while (i < length_1 && getParentSymbolOfTypeParameter(outerTypeParameters[i]) === parent);
+ if (!ts.rangeEquals(outerTypeParameters, typeArguments, start, i)) {
+ var qualifiedNamePart = symbolToName(parent, true);
+ if (!qualifiedName) {
+ qualifiedName = ts.createQualifiedName(qualifiedNamePart, undefined);
+ }
+ else {
+ ts.Debug.assert(!qualifiedName.right);
+ qualifiedName.right = qualifiedNamePart;
+ qualifiedName = ts.createQualifiedName(qualifiedName, undefined);
+ }
+ }
+ }
+ }
+ var entityName = undefined;
+ var nameIdentifier = symbolToName(type.symbol, true);
+ if (qualifiedName) {
+ ts.Debug.assert(!qualifiedName.right);
+ qualifiedName.right = nameIdentifier;
+ entityName = qualifiedName;
+ }
+ else {
+ entityName = nameIdentifier;
+ }
+ var typeParameterCount = (type.target.typeParameters || emptyArray).length;
+ var typeArgumentNodes = ts.some(typeArguments) ? mapToTypeNodeArray(typeArguments.slice(i, typeParameterCount - i)) : undefined;
+ return ts.createTypeReferenceNode(entityName, typeArgumentNodes);
+ }
+ }
+ function createTypeNodesFromResolvedType(resolvedType) {
+ var typeElements = [];
+ for (var _i = 0, _a = resolvedType.callSignatures; _i < _a.length; _i++) {
+ var signature = _a[_i];
+ typeElements.push(signatureToSignatureDeclarationHelper(signature, 154));
+ }
+ for (var _b = 0, _c = resolvedType.constructSignatures; _b < _c.length; _b++) {
+ var signature = _c[_b];
+ typeElements.push(signatureToSignatureDeclarationHelper(signature, 155));
+ }
+ if (resolvedType.stringIndexInfo) {
+ typeElements.push(indexInfoToIndexSignatureDeclarationHelper(resolvedType.stringIndexInfo, 0));
+ }
+ if (resolvedType.numberIndexInfo) {
+ typeElements.push(indexInfoToIndexSignatureDeclarationHelper(resolvedType.numberIndexInfo, 1));
+ }
+ var properties = resolvedType.properties;
+ if (!properties) {
+ return typeElements;
+ }
+ for (var _d = 0, properties_2 = properties; _d < properties_2.length; _d++) {
+ var propertySymbol = properties_2[_d];
+ var propertyType = getTypeOfSymbol(propertySymbol);
+ var oldDeclaration = propertySymbol.declarations && propertySymbol.declarations[0];
+ if (!oldDeclaration) {
+ return;
+ }
+ var propertyName = oldDeclaration.name;
+ var optionalToken = propertySymbol.flags & 67108864 ? ts.createToken(54) : undefined;
+ if (propertySymbol.flags & (16 | 8192) && !getPropertiesOfObjectType(propertyType).length) {
+ var signatures = getSignaturesOfType(propertyType, 0);
+ for (var _e = 0, signatures_1 = signatures; _e < signatures_1.length; _e++) {
+ var signature = signatures_1[_e];
+ var methodDeclaration = signatureToSignatureDeclarationHelper(signature, 149);
+ methodDeclaration.name = propertyName;
+ methodDeclaration.questionToken = optionalToken;
+ typeElements.push(methodDeclaration);
+ }
+ }
+ else {
+ var propertyTypeNode = propertyType ? typeToTypeNodeHelper(propertyType) : ts.createKeywordTypeNode(118);
+ typeElements.push(ts.createPropertySignature(propertyName, optionalToken, propertyTypeNode, undefined));
+ }
+ }
+ return typeElements.length ? typeElements : undefined;
+ }
+ }
+ function indexInfoToIndexSignatureDeclarationHelper(indexInfo, kind) {
+ var indexerTypeNode = ts.createKeywordTypeNode(kind === 0 ? 135 : 132);
+ var name = ts.getNameFromIndexInfo(indexInfo);
+ var indexingParameter = ts.createParameter(undefined, undefined, undefined, name, undefined, indexerTypeNode, undefined);
+ var typeNode = typeToTypeNodeHelper(indexInfo.type);
+ return ts.createIndexSignatureDeclaration(undefined, indexInfo.isReadonly ? [ts.createToken(130)] : undefined, [indexingParameter], typeNode);
+ }
+ function signatureToSignatureDeclarationHelper(signature, kind) {
+ var typeParameters = signature.typeParameters && signature.typeParameters.map(function (parameter) { return typeParameterToDeclaration(parameter); });
+ var parameters = signature.parameters.map(function (parameter) { return symbolToParameterDeclaration(parameter); });
+ var returnTypeNode;
+ if (signature.typePredicate) {
+ var typePredicate = signature.typePredicate;
+ var parameterName = typePredicate.kind === 1 ? ts.createIdentifier(typePredicate.parameterName) : ts.createThisTypeNode();
+ var typeNode = typeToTypeNodeHelper(typePredicate.type);
+ returnTypeNode = ts.createTypePredicateNode(parameterName, typeNode);
+ }
+ else {
+ var returnType = getReturnTypeOfSignature(signature);
+ returnTypeNode = returnType && typeToTypeNodeHelper(returnType);
+ }
+ var returnTypeNodeExceptAny = returnTypeNode && returnTypeNode.kind !== 118 ? returnTypeNode : undefined;
+ return ts.createSignatureDeclaration(kind, typeParameters, parameters, returnTypeNodeExceptAny);
+ }
+ function typeParameterToDeclaration(type) {
+ var constraint = getConstraintFromTypeParameter(type);
+ var constraintNode = constraint && typeToTypeNodeHelper(constraint);
+ var defaultParameter = getDefaultFromTypeParameter(type);
+ var defaultParameterNode = defaultParameter && typeToTypeNodeHelper(defaultParameter);
+ var name = symbolToName(type.symbol, true);
+ return ts.createTypeParameterDeclaration(name, constraintNode, defaultParameterNode);
+ }
+ function symbolToParameterDeclaration(parameterSymbol) {
+ var parameterDeclaration = ts.getDeclarationOfKind(parameterSymbol, 145);
+ var parameterType = getTypeOfSymbol(parameterSymbol);
+ var parameterTypeNode = typeToTypeNodeHelper(parameterType);
+ var parameterNode = ts.createParameter(parameterDeclaration.decorators, parameterDeclaration.modifiers, parameterDeclaration.dotDotDotToken && ts.createToken(23), ts.getSynthesizedClone(parameterDeclaration.name), parameterDeclaration.questionToken && ts.createToken(54), parameterTypeNode, parameterDeclaration.initializer);
+ return parameterNode;
+ }
+ function symbolToName(symbol, expectsIdentifier) {
+ var chain;
+ var isTypeParameter = symbol.flags & 262144;
+ if (!isTypeParameter && context.enclosingDeclaration) {
+ chain = getSymbolChain(symbol, 0, true);
+ ts.Debug.assert(chain && chain.length > 0);
+ }
+ else {
+ chain = [symbol];
+ }
+ if (expectsIdentifier && chain.length !== 1
+ && !context.encounteredError
+ && !(context.flags & ts.NodeBuilderFlags.allowQualifedNameInPlaceOfIdentifier)) {
+ context.encounteredError = true;
+ }
+ return createEntityNameFromSymbolChain(chain, chain.length - 1);
+ function createEntityNameFromSymbolChain(chain, index) {
+ ts.Debug.assert(chain && 0 <= index && index < chain.length);
+ var symbol = chain[index];
+ var typeParameterString = "";
+ if (index > 0) {
+ var parentSymbol = chain[index - 1];
+ var typeParameters = void 0;
+ if (getCheckFlags(symbol) & 1) {
+ typeParameters = getTypeParametersOfClassOrInterface(parentSymbol);
+ }
+ else {
+ var targetSymbol = getTargetSymbol(parentSymbol);
+ if (targetSymbol.flags & (32 | 64 | 524288)) {
+ typeParameters = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
+ }
+ }
+ if (typeParameters && typeParameters.length > 0) {
+ if (!context.encounteredError && !(context.flags & ts.NodeBuilderFlags.allowTypeParameterInQualifiedName)) {
+ context.encounteredError = true;
+ }
+ var writer = ts.getSingleLineStringWriter();
+ var displayBuilder = getSymbolDisplayBuilder();
+ displayBuilder.buildDisplayForTypeParametersAndDelimiters(typeParameters, writer, context.enclosingDeclaration, 0);
+ typeParameterString = writer.string();
+ ts.releaseStringWriter(writer);
+ }
+ }
+ var symbolName = getNameOfSymbol(symbol);
+ var symbolNameWithTypeParameters = typeParameterString.length > 0 ? symbolName + "<" + typeParameterString + ">" : symbolName;
+ var identifier = ts.createIdentifier(symbolNameWithTypeParameters);
+ return index > 0 ? ts.createQualifiedName(createEntityNameFromSymbolChain(chain, index - 1), identifier) : identifier;
+ }
+ function getSymbolChain(symbol, meaning, endOfChain) {
+ var accessibleSymbolChain = getAccessibleSymbolChain(symbol, context.enclosingDeclaration, meaning, false);
+ var parentSymbol;
+ if (!accessibleSymbolChain ||
+ needsQualification(accessibleSymbolChain[0], context.enclosingDeclaration, accessibleSymbolChain.length === 1 ? meaning : getQualifiedLeftMeaning(meaning))) {
+ var parent = getParentOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol);
+ if (parent) {
+ var parentChain = getSymbolChain(parent, getQualifiedLeftMeaning(meaning), false);
+ if (parentChain) {
+ parentSymbol = parent;
+ accessibleSymbolChain = parentChain.concat(accessibleSymbolChain || [symbol]);
+ }
+ }
+ }
+ if (accessibleSymbolChain) {
+ return accessibleSymbolChain;
+ }
+ if (endOfChain ||
+ !(!parentSymbol && ts.forEach(symbol.declarations, hasExternalModuleSymbol)) &&
+ !(symbol.flags & (2048 | 4096))) {
+ return [symbol];
+ }
+ }
+ function getNameOfSymbol(symbol) {
+ var declaration = ts.firstOrUndefined(symbol.declarations);
+ if (declaration) {
+ if (declaration.name) {
+ return ts.declarationNameToString(declaration.name);
+ }
+ if (declaration.parent && declaration.parent.kind === 225) {
+ return ts.declarationNameToString(declaration.parent.name);
+ }
+ if (!context.encounteredError && !(context.flags & ts.NodeBuilderFlags.allowAnonymousIdentifier)) {
+ context.encounteredError = true;
+ }
+ switch (declaration.kind) {
+ case 198:
+ return "(Anonymous class)";
+ case 185:
+ case 186:
+ return "(Anonymous function)";
+ }
+ }
+ return symbol.name;
+ }
+ }
+ }
function typePredicateToString(typePredicate, enclosingDeclaration, flags) {
var writer = ts.getSingleLineStringWriter();
getSymbolDisplayBuilder().buildTypePredicateDisplay(typePredicate, writer, enclosingDeclaration, flags);
@@ -21054,11 +22874,8 @@ var ts;
}
function getTypeAliasForTypeLiteral(type) {
if (type.symbol && type.symbol.flags & 2048) {
- var node = type.symbol.declarations[0].parent;
- while (node.kind === 166) {
- node = node.parent;
- }
- if (node.kind === 228) {
+ var node = ts.findAncestor(type.symbol.declarations[0].parent, function (n) { return n.kind !== 167; });
+ if (node.kind === 230) {
return getSymbolOfNode(node);
}
}
@@ -21066,29 +22883,32 @@ var ts;
}
function isTopLevelInExternalModuleAugmentation(node) {
return node && node.parent &&
- node.parent.kind === 231 &&
+ node.parent.kind === 233 &&
ts.isExternalModuleAugmentation(node.parent.parent);
}
function literalTypeToString(type) {
return type.flags & 32 ? "\"" + ts.escapeString(type.text) + "\"" : type.text;
}
- function getSymbolDisplayBuilder() {
- function getNameOfSymbol(symbol) {
- if (symbol.declarations && symbol.declarations.length) {
- var declaration = symbol.declarations[0];
- if (declaration.name) {
- return ts.declarationNameToString(declaration.name);
- }
- switch (declaration.kind) {
- case 197:
- return "(Anonymous class)";
- case 184:
- case 185:
- return "(Anonymous function)";
- }
+ function getNameOfSymbol(symbol) {
+ if (symbol.declarations && symbol.declarations.length) {
+ var declaration = symbol.declarations[0];
+ if (declaration.name) {
+ return ts.declarationNameToString(declaration.name);
+ }
+ if (declaration.parent && declaration.parent.kind === 225) {
+ return ts.declarationNameToString(declaration.parent.name);
+ }
+ switch (declaration.kind) {
+ case 198:
+ return "(Anonymous class)";
+ case 185:
+ case 186:
+ return "(Anonymous function)";
}
- return symbol.name;
}
+ return symbol.name;
+ }
+ function getSymbolDisplayBuilder() {
function appendSymbolNameOnly(symbol, writer) {
writer.writeSymbol(getNameOfSymbol(symbol), symbol);
}
@@ -21116,7 +22936,7 @@ var ts;
function appendParentTypeArgumentsAndSymbolName(symbol) {
if (parentSymbol) {
if (flags & 1) {
- if (symbol.flags & 16777216) {
+ if (getCheckFlags(symbol) & 1) {
buildDisplayForTypeArgumentsAndDelimiters(getTypeParametersOfClassOrInterface(parentSymbol), symbol.mapper, writer, enclosingDeclaration);
}
else {
@@ -21135,9 +22955,9 @@ var ts;
var accessibleSymbolChain = getAccessibleSymbolChain(symbol, enclosingDeclaration, meaning, !!(flags & 2));
if (!accessibleSymbolChain ||
needsQualification(accessibleSymbolChain[0], enclosingDeclaration, accessibleSymbolChain.length === 1 ? meaning : getQualifiedLeftMeaning(meaning))) {
- var parent_5 = getParentOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol);
- if (parent_5) {
- walkSymbol(parent_5, getQualifiedLeftMeaning(meaning), false);
+ var parent = getParentOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol);
+ if (parent) {
+ walkSymbol(parent, getQualifiedLeftMeaning(meaning), false);
}
}
if (accessibleSymbolChain) {
@@ -21167,7 +22987,7 @@ var ts;
return writeType(type, globalFlags);
function writeType(type, flags) {
var nextFlags = flags & ~512;
- if (type.flags & 16015) {
+ if (type.flags & 16793231) {
writer.writeKeyword(!(globalFlags & 16) && isTypeAny(type)
? "any"
: type.intrinsicName);
@@ -21192,7 +23012,7 @@ var ts;
else if (!(flags & 512) && type.aliasSymbol &&
isSymbolAccessible(type.aliasSymbol, enclosingDeclaration, 793064, false).accessibility === 0) {
var typeArguments = type.aliasTypeArguments;
- writeSymbolTypeReference(type.aliasSymbol, typeArguments, 0, typeArguments ? typeArguments.length : 0, nextFlags);
+ writeSymbolTypeReference(type.aliasSymbol, typeArguments, 0, ts.length(typeArguments), nextFlags);
}
else if (type.flags & 196608) {
writeUnionOrIntersectionType(type, nextFlags);
@@ -21267,15 +23087,15 @@ var ts;
var outerTypeParameters = type.target.outerTypeParameters;
var i = 0;
if (outerTypeParameters) {
- var length_1 = outerTypeParameters.length;
- while (i < length_1) {
+ var length_2 = outerTypeParameters.length;
+ while (i < length_2) {
var start = i;
- var parent_6 = getParentSymbolOfTypeParameter(outerTypeParameters[i]);
+ var parent = getParentSymbolOfTypeParameter(outerTypeParameters[i]);
do {
i++;
- } while (i < length_1 && getParentSymbolOfTypeParameter(outerTypeParameters[i]) === parent_6);
+ } while (i < length_2 && getParentSymbolOfTypeParameter(outerTypeParameters[i]) === parent);
if (!ts.rangeEquals(outerTypeParameters, typeArguments, start, i)) {
- writeSymbolTypeReference(parent_6, typeArguments, start, i, flags);
+ writeSymbolTypeReference(parent, typeArguments, start, i, flags);
writePunctuation(writer, 22);
}
}
@@ -21301,7 +23121,8 @@ var ts;
function writeAnonymousType(type, flags) {
var symbol = type.symbol;
if (symbol) {
- if (symbol.flags & (32 | 384 | 512)) {
+ if (symbol.flags & 32 && !getBaseTypeVariableOfClass(symbol) ||
+ symbol.flags & (384 | 512)) {
writeTypeOfSymbol(type, flags);
}
else if (shouldWriteTypeOfFunctionSymbol()) {
@@ -21334,7 +23155,7 @@ var ts;
var isNonLocalFunctionSymbol = !!(symbol.flags & 16) &&
(symbol.parent ||
ts.forEach(symbol.declarations, function (declaration) {
- return declaration.parent.kind === 261 || declaration.parent.kind === 231;
+ return declaration.parent.kind === 264 || declaration.parent.kind === 233;
}));
if (isStaticMethodSymbol || isNonLocalFunctionSymbol) {
return !!(flags & 2) ||
@@ -21347,32 +23168,13 @@ var ts;
writeSpace(writer);
buildSymbolDisplay(type.symbol, writer, enclosingDeclaration, 107455, 0, typeFormatFlags);
}
- function writeIndexSignature(info, keyword) {
- if (info) {
- if (info.isReadonly) {
- writeKeyword(writer, 130);
- writeSpace(writer);
- }
- writePunctuation(writer, 20);
- writer.writeParameter(info.declaration ? ts.declarationNameToString(info.declaration.parameters[0].name) : "x");
- writePunctuation(writer, 55);
- writeSpace(writer);
- writeKeyword(writer, keyword);
- writePunctuation(writer, 21);
- writePunctuation(writer, 55);
- writeSpace(writer);
- writeType(info.type, 0);
- writePunctuation(writer, 24);
- writer.writeLine();
- }
- }
function writePropertyWithModifiers(prop) {
if (isReadonlySymbol(prop)) {
writeKeyword(writer, 130);
writeSpace(writer);
}
buildSymbolDisplay(prop, writer);
- if (prop.flags & 536870912) {
+ if (prop.flags & 67108864) {
writePunctuation(writer, 54);
}
}
@@ -21448,15 +23250,15 @@ var ts;
writePunctuation(writer, 24);
writer.writeLine();
}
- writeIndexSignature(resolved.stringIndexInfo, 134);
- writeIndexSignature(resolved.numberIndexInfo, 132);
+ buildIndexSignatureDisplay(resolved.stringIndexInfo, writer, 0, enclosingDeclaration, globalFlags, symbolStack);
+ buildIndexSignatureDisplay(resolved.numberIndexInfo, writer, 1, enclosingDeclaration, globalFlags, symbolStack);
for (var _d = 0, _e = resolved.properties; _d < _e.length; _d++) {
var p = _e[_d];
var t = getTypeOfSymbol(p);
if (p.flags & (16 | 8192) && !getPropertiesOfObjectType(t).length) {
var signatures = getSignaturesOfType(t, 0);
- for (var _f = 0, signatures_1 = signatures; _f < signatures_1.length; _f++) {
- var signature = signatures_1[_f];
+ for (var _f = 0, signatures_2 = signatures; _f < signatures_2.length; _f++) {
+ var signature = signatures_2[_f];
writePropertyWithModifiers(p);
buildSignatureDisplay(signature, writer, enclosingDeclaration, globalFlagsToPass, undefined, symbolStack);
writePunctuation(writer, 24);
@@ -21515,32 +23317,43 @@ var ts;
writeSpace(writer);
buildTypeDisplay(constraint, writer, enclosingDeclaration, flags, symbolStack);
}
+ var defaultType = getDefaultFromTypeParameter(tp);
+ if (defaultType) {
+ writeSpace(writer);
+ writePunctuation(writer, 57);
+ writeSpace(writer);
+ buildTypeDisplay(defaultType, writer, enclosingDeclaration, flags, symbolStack);
+ }
}
function buildParameterDisplay(p, writer, enclosingDeclaration, flags, symbolStack) {
var parameterNode = p.valueDeclaration;
- if (ts.isRestParameter(parameterNode)) {
+ if (parameterNode ? ts.isRestParameter(parameterNode) : isTransientSymbol(p) && p.isRestParameter) {
writePunctuation(writer, 23);
}
- if (ts.isBindingPattern(parameterNode.name)) {
+ if (parameterNode && ts.isBindingPattern(parameterNode.name)) {
buildBindingPatternDisplay(parameterNode.name, writer, enclosingDeclaration, flags, symbolStack);
}
else {
appendSymbolNameOnly(p, writer);
}
- if (isOptionalParameter(parameterNode)) {
+ if (parameterNode && isOptionalParameter(parameterNode)) {
writePunctuation(writer, 54);
}
writePunctuation(writer, 55);
writeSpace(writer);
- buildTypeDisplay(getTypeOfSymbol(p), writer, enclosingDeclaration, flags, symbolStack);
+ var type = getTypeOfSymbol(p);
+ if (parameterNode && isRequiredInitializedParameter(parameterNode)) {
+ type = includeFalsyTypes(type, 2048);
+ }
+ buildTypeDisplay(type, writer, enclosingDeclaration, flags, symbolStack);
}
function buildBindingPatternDisplay(bindingPattern, writer, enclosingDeclaration, flags, symbolStack) {
- if (bindingPattern.kind === 172) {
+ if (bindingPattern.kind === 173) {
writePunctuation(writer, 16);
buildDisplayForCommaSeparatedList(bindingPattern.elements, writer, function (e) { return buildBindingElementDisplay(e, writer, enclosingDeclaration, flags, symbolStack); });
writePunctuation(writer, 17);
}
- else if (bindingPattern.kind === 173) {
+ else if (bindingPattern.kind === 174) {
writePunctuation(writer, 20);
var elements = bindingPattern.elements;
buildDisplayForCommaSeparatedList(elements, writer, function (e) { return buildBindingElementDisplay(e, writer, enclosingDeclaration, flags, symbolStack); });
@@ -21554,9 +23367,9 @@ var ts;
if (ts.isOmittedExpression(bindingElement)) {
return;
}
- ts.Debug.assert(bindingElement.kind === 174);
+ ts.Debug.assert(bindingElement.kind === 175);
if (bindingElement.propertyName) {
- writer.writeSymbol(ts.getTextOfNode(bindingElement.propertyName), bindingElement.symbol);
+ writer.writeProperty(ts.getTextOfNode(bindingElement.propertyName));
writePunctuation(writer, 55);
writeSpace(writer);
}
@@ -21628,6 +23441,10 @@ var ts;
buildTypeDisplay(predicate.type, writer, enclosingDeclaration, flags, symbolStack);
}
function buildReturnTypeDisplay(signature, writer, enclosingDeclaration, flags, symbolStack) {
+ var returnType = getReturnTypeOfSignature(signature);
+ if (flags & 2048 && isTypeAny(returnType)) {
+ return;
+ }
if (flags & 8) {
writeSpace(writer);
writePunctuation(writer, 35);
@@ -21640,7 +23457,6 @@ var ts;
buildTypePredicateDisplay(signature.typePredicate, writer, enclosingDeclaration, flags, symbolStack);
}
else {
- var returnType = getReturnTypeOfSignature(signature);
buildTypeDisplay(returnType, writer, enclosingDeclaration, flags, symbolStack);
}
}
@@ -21658,6 +23474,32 @@ var ts;
buildDisplayForParametersAndDelimiters(signature.thisParameter, signature.parameters, writer, enclosingDeclaration, flags, symbolStack);
buildReturnTypeDisplay(signature, writer, enclosingDeclaration, flags, symbolStack);
}
+ function buildIndexSignatureDisplay(info, writer, kind, enclosingDeclaration, globalFlags, symbolStack) {
+ if (info) {
+ if (info.isReadonly) {
+ writeKeyword(writer, 130);
+ writeSpace(writer);
+ }
+ writePunctuation(writer, 20);
+ writer.writeParameter(info.declaration ? ts.declarationNameToString(info.declaration.parameters[0].name) : "x");
+ writePunctuation(writer, 55);
+ writeSpace(writer);
+ switch (kind) {
+ case 1:
+ writeKeyword(writer, 132);
+ break;
+ case 0:
+ writeKeyword(writer, 135);
+ break;
+ }
+ writePunctuation(writer, 21);
+ writePunctuation(writer, 55);
+ writeSpace(writer);
+ buildTypeDisplay(info.type, writer, enclosingDeclaration, globalFlags, symbolStack);
+ writePunctuation(writer, 24);
+ writer.writeLine();
+ }
+ }
return _displayBuilder || (_displayBuilder = {
buildSymbolDisplay: buildSymbolDisplay,
buildTypeDisplay: buildTypeDisplay,
@@ -21668,6 +23510,7 @@ var ts;
buildDisplayForTypeParametersAndDelimiters: buildDisplayForTypeParametersAndDelimiters,
buildTypeParameterDisplayFromSymbol: buildTypeParameterDisplayFromSymbol,
buildSignatureDisplay: buildSignatureDisplay,
+ buildIndexSignatureDisplay: buildIndexSignatureDisplay,
buildReturnTypeDisplay: buildReturnTypeDisplay
});
}
@@ -21682,63 +23525,63 @@ var ts;
return false;
function determineIfDeclarationIsVisible() {
switch (node.kind) {
- case 174:
+ case 175:
return isDeclarationVisible(node.parent.parent);
- case 223:
+ case 225:
if (ts.isBindingPattern(node.name) &&
!node.name.elements.length) {
return false;
}
- case 230:
- case 226:
- case 227:
+ case 232:
case 228:
- case 225:
case 229:
- case 234:
+ case 230:
+ case 227:
+ case 231:
+ case 236:
if (ts.isExternalModuleAugmentation(node)) {
return true;
}
- var parent_7 = getDeclarationContainer(node);
+ var parent = getDeclarationContainer(node);
if (!(ts.getCombinedModifierFlags(node) & 1) &&
- !(node.kind !== 234 && parent_7.kind !== 261 && ts.isInAmbientContext(parent_7))) {
- return isGlobalSourceFile(parent_7);
+ !(node.kind !== 236 && parent.kind !== 264 && ts.isInAmbientContext(parent))) {
+ return isGlobalSourceFile(parent);
}
- return isDeclarationVisible(parent_7);
+ return isDeclarationVisible(parent);
+ case 148:
case 147:
- case 146:
- case 151:
case 152:
+ case 153:
+ case 150:
case 149:
- case 148:
if (ts.getModifierFlags(node) & (8 | 16)) {
return false;
}
- case 150:
- case 154:
- case 153:
+ case 151:
case 155:
- case 144:
- case 231:
- case 158:
+ case 154:
+ case 156:
+ case 145:
+ case 233:
case 159:
- case 161:
- case 157:
+ case 160:
case 162:
+ case 158:
case 163:
case 164:
case 165:
case 166:
+ case 167:
return isDeclarationVisible(node.parent);
- case 236:
- case 237:
+ case 238:
case 239:
+ case 241:
return false;
- case 143:
- case 261:
- case 233:
+ case 144:
+ case 264:
+ case 235:
return true;
- case 240:
+ case 242:
return false;
default:
return false;
@@ -21747,10 +23590,10 @@ var ts;
}
function collectLinkedAliases(node) {
var exportSymbol;
- if (node.parent && node.parent.kind === 240) {
+ if (node.parent && node.parent.kind === 242) {
exportSymbol = resolveName(node.parent, node.text, 107455 | 793064 | 1920 | 8388608, ts.Diagnostics.Cannot_find_name_0, node);
}
- else if (node.parent.kind === 243) {
+ else if (node.parent.kind === 245) {
var exportSpecifier = node.parent;
exportSymbol = exportSpecifier.parent.parent.moduleSpecifier ?
getExternalModuleMember(exportSpecifier.parent.parent, exportSpecifier) :
@@ -21782,8 +23625,8 @@ var ts;
function pushTypeResolution(target, propertyName) {
var resolutionCycleStartIndex = findResolutionCycleStartIndex(target, propertyName);
if (resolutionCycleStartIndex >= 0) {
- var length_2 = resolutionTargets.length;
- for (var i = resolutionCycleStartIndex; i < length_2; i++) {
+ var length_3 = resolutionTargets.length;
+ for (var i = resolutionCycleStartIndex; i < length_3; i++) {
resolutionResults[i] = false;
}
return false;
@@ -21825,21 +23668,20 @@ var ts;
return resolutionResults.pop();
}
function getDeclarationContainer(node) {
- node = ts.getRootDeclaration(node);
- while (node) {
+ node = ts.findAncestor(ts.getRootDeclaration(node), function (node) {
switch (node.kind) {
- case 223:
- case 224:
+ case 225:
+ case 226:
+ case 241:
+ case 240:
case 239:
case 238:
- case 237:
- case 236:
- node = node.parent;
- break;
+ return false;
default:
- return node.parent;
+ return true;
}
- }
+ });
+ return node && node.parent;
}
function getTypeOfPrototypeProperty(prototype) {
var classType = getDeclaredTypeOfSymbol(getParentOfSymbol(prototype));
@@ -21852,32 +23694,34 @@ var ts;
function isTypeAny(type) {
return type && (type.flags & 1) !== 0;
}
- function isTypeNever(type) {
- return type && (type.flags & 8192) !== 0;
- }
function getTypeForBindingElementParent(node) {
var symbol = getSymbolOfNode(node);
return symbol && getSymbolLinks(symbol).type || getTypeForVariableLikeDeclaration(node, false);
}
function isComputedNonLiteralName(name) {
- return name.kind === 142 && !ts.isStringOrNumericLiteral(name.expression);
+ return name.kind === 143 && !ts.isStringOrNumericLiteral(name.expression);
}
function getRestType(source, properties, symbol) {
- ts.Debug.assert(!!(source.flags & 32768), "Rest types only support object types right now.");
+ source = filterType(source, function (t) { return !(t.flags & 6144); });
+ if (source.flags & 8192) {
+ return emptyObjectType;
+ }
+ if (source.flags & 65536) {
+ return mapType(source, function (t) { return getRestType(t, properties, symbol); });
+ }
var members = ts.createMap();
var names = ts.createMap();
- for (var _i = 0, properties_2 = properties; _i < properties_2.length; _i++) {
- var name_17 = properties_2[_i];
- names[ts.getTextOfPropertyName(name_17)] = true;
+ for (var _i = 0, properties_3 = properties; _i < properties_3.length; _i++) {
+ var name = properties_3[_i];
+ names.set(ts.getTextOfPropertyName(name), true);
}
for (var _a = 0, _b = getPropertiesOfType(source); _a < _b.length; _a++) {
var prop = _b[_a];
- var inNamesToRemove = prop.name in names;
+ var inNamesToRemove = names.has(prop.name);
var isPrivate = getDeclarationModifierFlagsFromSymbol(prop) & (8 | 16);
- var isMethod = prop.flags & 8192;
var isSetOnlyAccessor = prop.flags & 65536 && !(prop.flags & 32768);
- if (!inNamesToRemove && !isPrivate && !isMethod && !isSetOnlyAccessor) {
- members[prop.name] = prop;
+ if (!inNamesToRemove && !isPrivate && !isClassMethod(prop) && !isSetOnlyAccessor) {
+ members.set(prop.name, prop);
}
}
var stringIndexInfo = getIndexInfoOfType(source, 0);
@@ -21897,9 +23741,9 @@ var ts;
return parentType;
}
var type;
- if (pattern.kind === 172) {
+ if (pattern.kind === 173) {
if (declaration.dotDotDotToken) {
- if (!(parentType.flags & 32768)) {
+ if (!isValidSpreadType(parentType)) {
error(declaration, ts.Diagnostics.Rest_types_may_only_be_created_from_object_types);
return unknownType;
}
@@ -21913,25 +23757,25 @@ var ts;
type = getRestType(parentType, literalMembers, declaration.symbol);
}
else {
- var name_18 = declaration.propertyName || declaration.name;
- if (isComputedNonLiteralName(name_18)) {
+ var name = declaration.propertyName || declaration.name;
+ if (isComputedNonLiteralName(name)) {
return anyType;
}
if (declaration.initializer) {
getContextualType(declaration.initializer);
}
- var text = ts.getTextOfPropertyName(name_18);
+ var text = ts.getTextOfPropertyName(name);
type = getTypeOfPropertyOfType(parentType, text) ||
isNumericLiteralName(text) && getIndexTypeOfType(parentType, 1) ||
getIndexTypeOfType(parentType, 0);
if (!type) {
- error(name_18, ts.Diagnostics.Type_0_has_no_property_1_and_no_string_index_signature, typeToString(parentType), ts.declarationNameToString(name_18));
+ error(name, ts.Diagnostics.Type_0_has_no_property_1_and_no_string_index_signature, typeToString(parentType), ts.declarationNameToString(name));
return unknownType;
}
}
}
else {
- var elementType = checkIteratedTypeOrElementType(parentType, pattern, false);
+ var elementType = checkIteratedTypeOrElementType(parentType, pattern, false, false);
if (declaration.dotDotDotToken) {
type = createArrayType(elementType);
}
@@ -21958,7 +23802,7 @@ var ts;
getUnionType([type, checkExpressionCached(declaration.initializer)], true) :
type;
}
- function getTypeForVariableLikeDeclarationFromJSDocComment(declaration) {
+ function getTypeForDeclarationFromJSDocComment(declaration) {
var jsdocType = ts.getJSDocType(declaration);
if (jsdocType) {
return getTypeFromTypeNode(jsdocType);
@@ -21971,33 +23815,35 @@ var ts;
}
function isEmptyArrayLiteral(node) {
var expr = ts.skipParentheses(node);
- return expr.kind === 175 && expr.elements.length === 0;
+ return expr.kind === 176 && expr.elements.length === 0;
}
function addOptionality(type, optional) {
return strictNullChecks && optional ? includeFalsyTypes(type, 2048) : type;
}
function getTypeForVariableLikeDeclaration(declaration, includeOptionality) {
- if (declaration.flags & 2097152) {
- var type = getTypeForVariableLikeDeclarationFromJSDocComment(declaration);
+ if (declaration.flags & 65536) {
+ var type = getTypeForDeclarationFromJSDocComment(declaration);
if (type && type !== unknownType) {
return type;
}
}
- if (declaration.parent.parent.kind === 212) {
+ if (declaration.parent.parent.kind === 214) {
var indexType = getIndexType(checkNonNullExpression(declaration.parent.parent.expression));
return indexType.flags & (16384 | 262144) ? indexType : stringType;
}
- if (declaration.parent.parent.kind === 213) {
- return checkRightHandSideOfForOf(declaration.parent.parent.expression) || anyType;
+ if (declaration.parent.parent.kind === 215) {
+ var forOfStatement = declaration.parent.parent;
+ return checkRightHandSideOfForOf(forOfStatement.expression, forOfStatement.awaitModifier) || anyType;
}
if (ts.isBindingPattern(declaration.parent)) {
return getTypeForBindingElement(declaration);
}
if (declaration.type) {
- return addOptionality(getTypeFromTypeNode(declaration.type), declaration.questionToken && includeOptionality);
+ var declaredType = getTypeFromTypeNode(declaration.type);
+ return addOptionality(declaredType, declaration.questionToken && includeOptionality);
}
- if ((compilerOptions.noImplicitAny || declaration.flags & 2097152) &&
- declaration.kind === 223 && !ts.isBindingPattern(declaration.name) &&
+ if ((noImplicitAny || declaration.flags & 65536) &&
+ declaration.kind === 225 && !ts.isBindingPattern(declaration.name) &&
!(ts.getCombinedModifierFlags(declaration) & 1) && !ts.isInAmbientContext(declaration)) {
if (!(ts.getCombinedNodeFlags(declaration) & 2) && (!declaration.initializer || isNullOrUndefined(declaration.initializer))) {
return autoType;
@@ -22006,10 +23852,10 @@ var ts;
return autoArrayType;
}
}
- if (declaration.kind === 144) {
+ if (declaration.kind === 145) {
var func = declaration.parent;
- if (func.kind === 152 && !ts.hasDynamicName(func)) {
- var getter = ts.getDeclarationOfKind(declaration.parent.symbol, 151);
+ if (func.kind === 153 && !ts.hasDynamicName(func)) {
+ var getter = ts.getDeclarationOfKind(declaration.parent.symbol, 152);
if (getter) {
var getterSignature = getSignatureFromDeclaration(getter);
var thisParameter = getAccessorThisParameter(func);
@@ -22035,7 +23881,10 @@ var ts;
var type = checkDeclarationInitializer(declaration);
return addOptionality(type, declaration.questionToken && includeOptionality);
}
- if (declaration.kind === 258) {
+ if (ts.isJsxAttribute(declaration)) {
+ return trueType;
+ }
+ if (declaration.kind === 261) {
return checkIdentifier(declaration.name);
}
if (ts.isBindingPattern(declaration.name)) {
@@ -22043,6 +23892,37 @@ var ts;
}
return undefined;
}
+ function getWidenedTypeFromJSSpecialPropertyDeclarations(symbol) {
+ var types = [];
+ var definedInConstructor = false;
+ var definedInMethod = false;
+ for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
+ var declaration = _a[_i];
+ var expression = declaration.kind === 193 ? declaration :
+ declaration.kind === 178 ? ts.getAncestor(declaration, 193) :
+ undefined;
+ if (!expression) {
+ return unknownType;
+ }
+ if (ts.isPropertyAccessExpression(expression.left) && expression.left.expression.kind === 98) {
+ if (ts.getThisContainer(expression, false).kind === 151) {
+ definedInConstructor = true;
+ }
+ else {
+ definedInMethod = true;
+ }
+ }
+ if (expression.flags & 65536) {
+ var type = getTypeForDeclarationFromJSDocComment(expression.parent);
+ if (type && type !== unknownType) {
+ types.push(getWidenedType(type));
+ continue;
+ }
+ }
+ types.push(getWidenedLiteralType(checkExpressionCached(expression.right)));
+ }
+ return getWidenedType(addOptionality(getUnionType(types, true), definedInMethod && !definedInConstructor));
+ }
function getTypeFromBindingElement(element, includePatternInType, reportErrors) {
if (element.initializer) {
return checkDeclarationInitializer(element);
@@ -22050,28 +23930,33 @@ var ts;
if (ts.isBindingPattern(element.name)) {
return getTypeFromBindingPattern(element.name, includePatternInType, reportErrors);
}
- if (reportErrors && compilerOptions.noImplicitAny && !declarationBelongsToPrivateAmbientMember(element)) {
+ if (reportErrors && noImplicitAny && !declarationBelongsToPrivateAmbientMember(element)) {
reportImplicitAnyError(element, anyType);
}
return anyType;
}
function getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors) {
var members = ts.createMap();
+ var stringIndexInfo;
var hasComputedProperties = false;
ts.forEach(pattern.elements, function (e) {
var name = e.propertyName || e.name;
- if (isComputedNonLiteralName(name) || e.dotDotDotToken) {
+ if (isComputedNonLiteralName(name)) {
hasComputedProperties = true;
return;
}
+ if (e.dotDotDotToken) {
+ stringIndexInfo = createIndexInfo(anyType, false);
+ return;
+ }
var text = ts.getTextOfPropertyName(name);
- var flags = 4 | 67108864 | (e.initializer ? 536870912 : 0);
+ var flags = 4 | (e.initializer ? 67108864 : 0);
var symbol = createSymbol(flags, text);
symbol.type = getTypeFromBindingElement(e, includePatternInType, reportErrors);
symbol.bindingElement = e;
- members[symbol.name] = symbol;
+ members.set(symbol.name, symbol);
});
- var result = createAnonymousType(undefined, members, emptyArray, emptyArray, undefined, undefined);
+ var result = createAnonymousType(undefined, members, emptyArray, emptyArray, stringIndexInfo, undefined);
if (includePatternInType) {
result.pattern = pattern;
}
@@ -22095,7 +23980,7 @@ var ts;
return result;
}
function getTypeFromBindingPattern(pattern, includePatternInType, reportErrors) {
- return pattern.kind === 172
+ return pattern.kind === 173
? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors)
: getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors);
}
@@ -22105,13 +23990,13 @@ var ts;
if (reportErrors) {
reportErrorsFromWidening(declaration, type);
}
- if (declaration.kind === 257) {
+ if (declaration.kind === 260) {
return type;
}
return getWidenedType(type);
}
type = declaration.dotDotDotToken ? anyArrayType : anyType;
- if (reportErrors && compilerOptions.noImplicitAny) {
+ if (reportErrors && noImplicitAny) {
if (!declarationBelongsToPrivateAmbientMember(declaration)) {
reportImplicitAnyError(declaration, type);
}
@@ -22120,56 +24005,38 @@ var ts;
}
function declarationBelongsToPrivateAmbientMember(declaration) {
var root = ts.getRootDeclaration(declaration);
- var memberDeclaration = root.kind === 144 ? root.parent : root;
+ var memberDeclaration = root.kind === 145 ? root.parent : root;
return isPrivateWithinAmbient(memberDeclaration);
}
function getTypeOfVariableOrParameterOrProperty(symbol) {
var links = getSymbolLinks(symbol);
if (!links.type) {
- if (symbol.flags & 134217728) {
+ if (symbol.flags & 16777216) {
return links.type = getTypeOfPrototypeProperty(symbol);
}
var declaration = symbol.valueDeclaration;
if (ts.isCatchClauseVariableDeclarationOrBindingElement(declaration)) {
return links.type = anyType;
}
- if (declaration.kind === 240) {
+ if (declaration.kind === 242) {
return links.type = checkExpression(declaration.expression);
}
- if (declaration.flags & 2097152 && declaration.kind === 286 && declaration.typeExpression) {
+ if (declaration.flags & 65536 && declaration.kind === 290 && declaration.typeExpression) {
return links.type = getTypeFromTypeNode(declaration.typeExpression.type);
}
if (!pushTypeResolution(symbol, 0)) {
return unknownType;
}
var type = void 0;
- if (declaration.kind === 192 ||
- declaration.kind === 177 && declaration.parent.kind === 192) {
- if (declaration.flags & 2097152) {
- var jsdocType = ts.getJSDocType(declaration.parent);
- if (jsdocType) {
- return links.type = getTypeFromTypeNode(jsdocType);
- }
- }
- var declaredTypes = ts.map(symbol.declarations, function (decl) { return decl.kind === 192 ?
- checkExpressionCached(decl.right) :
- checkExpressionCached(decl.parent.right); });
- type = getUnionType(declaredTypes, true);
+ if (declaration.kind === 193 ||
+ declaration.kind === 178 && declaration.parent.kind === 193) {
+ type = getWidenedTypeFromJSSpecialPropertyDeclarations(symbol);
}
else {
type = getWidenedTypeForVariableLikeDeclaration(declaration, true);
}
if (!popTypeResolution()) {
- if (symbol.valueDeclaration.type) {
- type = unknownType;
- error(symbol.valueDeclaration, ts.Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
- }
- else {
- type = anyType;
- if (compilerOptions.noImplicitAny) {
- error(symbol.valueDeclaration, ts.Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer, symbolToString(symbol));
- }
- }
+ type = reportCircularityError(symbol);
}
links.type = type;
}
@@ -22177,7 +24044,7 @@ var ts;
}
function getAnnotatedAccessorType(accessor) {
if (accessor) {
- if (accessor.kind === 151) {
+ if (accessor.kind === 152) {
return accessor.type && getTypeFromTypeNode(accessor.type);
}
else {
@@ -22197,10 +24064,10 @@ var ts;
function getTypeOfAccessors(symbol) {
var links = getSymbolLinks(symbol);
if (!links.type) {
- var getter = ts.getDeclarationOfKind(symbol, 151);
- var setter = ts.getDeclarationOfKind(symbol, 152);
- if (getter && getter.flags & 2097152) {
- var jsDocType = getTypeForVariableLikeDeclarationFromJSDocComment(getter);
+ var getter = ts.getDeclarationOfKind(symbol, 152);
+ var setter = ts.getDeclarationOfKind(symbol, 153);
+ if (getter && getter.flags & 65536) {
+ var jsDocType = getTypeForDeclarationFromJSDocComment(getter);
if (jsDocType) {
return links.type = jsDocType;
}
@@ -22223,7 +24090,7 @@ var ts;
type = getReturnTypeFromBody(getter);
}
else {
- if (compilerOptions.noImplicitAny) {
+ if (noImplicitAny) {
if (setter) {
error(setter, ts.Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation, symbolToString(symbol));
}
@@ -22238,8 +24105,8 @@ var ts;
}
if (!popTypeResolution()) {
type = anyType;
- if (compilerOptions.noImplicitAny) {
- var getter_1 = ts.getDeclarationOfKind(symbol, 151);
+ if (noImplicitAny) {
+ var getter_1 = ts.getDeclarationOfKind(symbol, 152);
error(getter_1, ts.Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol));
}
}
@@ -22247,6 +24114,10 @@ var ts;
}
return links.type;
}
+ function getBaseTypeVariableOfClass(symbol) {
+ var baseConstructorType = getBaseConstructorTypeOfClass(getDeclaredTypeOfClassOrInterface(symbol));
+ return baseConstructorType.flags & 540672 ? baseConstructorType : undefined;
+ }
function getTypeOfFuncClassEnumModule(symbol) {
var links = getSymbolLinks(symbol);
if (!links.type) {
@@ -22255,8 +24126,13 @@ var ts;
}
else {
var type = createObjectType(16, symbol);
- links.type = strictNullChecks && symbol.flags & 536870912 ?
- includeFalsyTypes(type, 2048) : type;
+ if (symbol.flags & 32) {
+ var baseTypeVariable = getBaseTypeVariableOfClass(symbol);
+ links.type = baseTypeVariable ? getIntersectionType([type, baseTypeVariable]) : type;
+ }
+ else {
+ links.type = strictNullChecks && symbol.flags & 67108864 ? includeFalsyTypes(type, 2048) : type;
+ }
}
}
return links.type;
@@ -22281,12 +24157,37 @@ var ts;
function getTypeOfInstantiatedSymbol(symbol) {
var links = getSymbolLinks(symbol);
if (!links.type) {
- links.type = instantiateType(getTypeOfSymbol(links.target), links.mapper);
+ if (symbolInstantiationDepth === 100) {
+ error(symbol.valueDeclaration, ts.Diagnostics.Generic_type_instantiation_is_excessively_deep_and_possibly_infinite);
+ links.type = unknownType;
+ }
+ else {
+ if (!pushTypeResolution(symbol, 0)) {
+ return unknownType;
+ }
+ symbolInstantiationDepth++;
+ var type = instantiateType(getTypeOfSymbol(links.target), links.mapper);
+ symbolInstantiationDepth--;
+ if (!popTypeResolution()) {
+ type = reportCircularityError(symbol);
+ }
+ links.type = type;
+ }
}
return links.type;
}
+ function reportCircularityError(symbol) {
+ if (symbol.valueDeclaration.type) {
+ error(symbol.valueDeclaration, ts.Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+ return unknownType;
+ }
+ if (noImplicitAny) {
+ error(symbol.valueDeclaration, ts.Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer, symbolToString(symbol));
+ }
+ return anyType;
+ }
function getTypeOfSymbol(symbol) {
- if (symbol.flags & 16777216) {
+ if (getCheckFlags(symbol) & 1) {
return getTypeOfInstantiatedSymbol(symbol);
}
if (symbol.flags & (3 | 4)) {
@@ -22306,19 +24207,30 @@ var ts;
}
return unknownType;
}
+ function isReferenceToType(type, target) {
+ return type !== undefined
+ && target !== undefined
+ && (getObjectFlags(type) & 4) !== 0
+ && type.target === target;
+ }
function getTargetType(type) {
return getObjectFlags(type) & 4 ? type.target : type;
}
function hasBaseType(type, checkBase) {
return check(type);
function check(type) {
- var target = getTargetType(type);
- return target === checkBase || ts.forEach(getBaseTypes(target), check);
+ if (getObjectFlags(type) & (3 | 4)) {
+ var target = getTargetType(type);
+ return target === checkBase || ts.forEach(getBaseTypes(target), check);
+ }
+ else if (type.flags & 131072) {
+ return ts.forEach(type.types, check);
+ }
}
}
function appendTypeParameters(typeParameters, declarations) {
- for (var _i = 0, declarations_2 = declarations; _i < declarations_2.length; _i++) {
- var declaration = declarations_2[_i];
+ for (var _i = 0, declarations_3 = declarations; _i < declarations_3.length; _i++) {
+ var declaration = declarations_3[_i];
var tp = getDeclaredTypeOfTypeParameter(getSymbolOfNode(declaration));
if (!typeParameters) {
typeParameters = [tp];
@@ -22335,9 +24247,9 @@ var ts;
if (!node) {
return typeParameters;
}
- if (node.kind === 226 || node.kind === 197 ||
- node.kind === 225 || node.kind === 184 ||
- node.kind === 149 || node.kind === 185) {
+ if (node.kind === 228 || node.kind === 198 ||
+ node.kind === 227 || node.kind === 185 ||
+ node.kind === 150 || node.kind === 186) {
var declarations = node.typeParameters;
if (declarations) {
return appendTypeParameters(appendOuterTypeParameters(typeParameters, node), declarations);
@@ -22346,15 +24258,15 @@ var ts;
}
}
function getOuterTypeParametersOfClassOrInterface(symbol) {
- var declaration = symbol.flags & 32 ? symbol.valueDeclaration : ts.getDeclarationOfKind(symbol, 227);
+ var declaration = symbol.flags & 32 ? symbol.valueDeclaration : ts.getDeclarationOfKind(symbol, 229);
return appendOuterTypeParameters(undefined, declaration);
}
function getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol) {
var result;
for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
var node = _a[_i];
- if (node.kind === 227 || node.kind === 226 ||
- node.kind === 197 || node.kind === 228) {
+ if (node.kind === 229 || node.kind === 228 ||
+ node.kind === 198 || node.kind === 230) {
var declaration = node;
if (declaration.typeParameters) {
result = appendTypeParameters(result, declaration.typeParameters);
@@ -22366,18 +24278,34 @@ var ts;
function getTypeParametersOfClassOrInterface(symbol) {
return ts.concatenate(getOuterTypeParametersOfClassOrInterface(symbol), getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol));
}
+ function isMixinConstructorType(type) {
+ var signatures = getSignaturesOfType(type, 1);
+ if (signatures.length === 1) {
+ var s = signatures[0];
+ return !s.typeParameters && s.parameters.length === 1 && s.hasRestParameter && getTypeOfParameter(s.parameters[0]) === anyArrayType;
+ }
+ return false;
+ }
function isConstructorType(type) {
- return type.flags & 32768 && getSignaturesOfType(type, 1).length > 0;
+ if (isValidBaseType(type) && getSignaturesOfType(type, 1).length > 0) {
+ return true;
+ }
+ if (type.flags & 540672) {
+ var constraint = getBaseConstraintOfType(type);
+ return constraint && isValidBaseType(constraint) && isMixinConstructorType(constraint);
+ }
+ return false;
}
function getBaseTypeNodeOfClass(type) {
return ts.getClassExtendsHeritageClauseElement(type.symbol.valueDeclaration);
}
- function getConstructorsForTypeArguments(type, typeArgumentNodes) {
- var typeArgCount = typeArgumentNodes ? typeArgumentNodes.length : 0;
- return ts.filter(getSignaturesOfType(type, 1), function (sig) { return (sig.typeParameters ? sig.typeParameters.length : 0) === typeArgCount; });
+ function getConstructorsForTypeArguments(type, typeArgumentNodes, location) {
+ var typeArgCount = ts.length(typeArgumentNodes);
+ var isJavaScript = ts.isInJavaScriptFile(location);
+ return ts.filter(getSignaturesOfType(type, 1), function (sig) { return (isJavaScript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= ts.length(sig.typeParameters); });
}
- function getInstantiatedConstructorsForTypeArguments(type, typeArgumentNodes) {
- var signatures = getConstructorsForTypeArguments(type, typeArgumentNodes);
+ function getInstantiatedConstructorsForTypeArguments(type, typeArgumentNodes, location) {
+ var signatures = getConstructorsForTypeArguments(type, typeArgumentNodes, location);
if (typeArgumentNodes) {
var typeArguments_1 = ts.map(typeArgumentNodes, getTypeFromTypeNode);
signatures = ts.map(signatures, function (sig) { return getSignatureInstantiation(sig, typeArguments_1); });
@@ -22394,14 +24322,14 @@ var ts;
return unknownType;
}
var baseConstructorType = checkExpression(baseTypeNode.expression);
- if (baseConstructorType.flags & 32768) {
+ if (baseConstructorType.flags & (32768 | 131072)) {
resolveStructuredTypeMembers(baseConstructorType);
}
if (!popTypeResolution()) {
error(type.symbol.valueDeclaration, ts.Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol));
return type.resolvedBaseConstructorType = unknownType;
}
- if (baseConstructorType !== unknownType && baseConstructorType !== nullWideningType && !isConstructorType(baseConstructorType)) {
+ if (!(baseConstructorType.flags & 1) && baseConstructorType !== nullWideningType && !isConstructorType(baseConstructorType)) {
error(baseTypeNode.expression, ts.Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType));
return type.resolvedBaseConstructorType = unknownType;
}
@@ -22430,8 +24358,8 @@ var ts;
}
function resolveBaseTypesOfClass(type) {
type.resolvedBaseTypes = type.resolvedBaseTypes || emptyArray;
- var baseConstructorType = getBaseConstructorTypeOfClass(type);
- if (!(baseConstructorType.flags & 32768)) {
+ var baseConstructorType = getApparentType(getBaseConstructorTypeOfClass(type));
+ if (!(baseConstructorType.flags & (32768 | 131072 | 1))) {
return;
}
var baseTypeNode = getBaseTypeNodeOfClass(type);
@@ -22441,8 +24369,11 @@ var ts;
areAllOuterTypeParametersApplied(originalBaseType)) {
baseType = getTypeFromClassOrInterfaceReference(baseTypeNode, baseConstructorType.symbol);
}
+ else if (baseConstructorType.flags & 1) {
+ baseType = baseConstructorType;
+ }
else {
- var constructors = getInstantiatedConstructorsForTypeArguments(baseConstructorType, baseTypeNode.typeArguments);
+ var constructors = getInstantiatedConstructorsForTypeArguments(baseConstructorType, baseTypeNode.typeArguments, baseTypeNode);
if (!constructors.length) {
error(baseTypeNode.expression, ts.Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments);
return;
@@ -22459,7 +24390,7 @@ var ts;
if (baseType === unknownType) {
return;
}
- if (!(getObjectFlags(getTargetType(baseType)) & 3)) {
+ if (!isValidBaseType(baseType)) {
error(baseTypeNode.expression, ts.Diagnostics.Base_constructor_return_type_0_is_not_a_class_or_interface_type, typeToString(baseType));
return;
}
@@ -22483,16 +24414,20 @@ var ts;
}
return true;
}
+ function isValidBaseType(type) {
+ return type.flags & (32768 | 16777216 | 1) && !isGenericMappedType(type) ||
+ type.flags & 131072 && !ts.forEach(type.types, function (t) { return !isValidBaseType(t); });
+ }
function resolveBaseTypesOfInterface(type) {
type.resolvedBaseTypes = type.resolvedBaseTypes || emptyArray;
for (var _i = 0, _a = type.symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
- if (declaration.kind === 227 && ts.getInterfaceBaseTypeNodes(declaration)) {
+ if (declaration.kind === 229 && ts.getInterfaceBaseTypeNodes(declaration)) {
for (var _b = 0, _c = ts.getInterfaceBaseTypeNodes(declaration); _b < _c.length; _b++) {
var node = _c[_b];
var baseType = getTypeFromTypeNode(node);
if (baseType !== unknownType) {
- if (getObjectFlags(getTargetType(baseType)) & 3) {
+ if (isValidBaseType(baseType)) {
if (type !== baseType && !hasBaseType(baseType, type)) {
if (type.resolvedBaseTypes === emptyArray) {
type.resolvedBaseTypes = [baseType];
@@ -22516,7 +24451,7 @@ var ts;
function isIndependentInterface(symbol) {
for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
- if (declaration.kind === 227) {
+ if (declaration.kind === 229) {
if (declaration.flags & 64) {
return false;
}
@@ -22549,7 +24484,7 @@ var ts;
type.outerTypeParameters = outerTypeParameters;
type.localTypeParameters = localTypeParameters;
type.instantiations = ts.createMap();
- type.instantiations[getTypeListId(type.typeParameters)] = type;
+ type.instantiations.set(getTypeListId(type.typeParameters), type);
type.target = type;
type.typeArguments = type.typeParameters;
type.thisType = createType(16384);
@@ -22566,7 +24501,7 @@ var ts;
if (!pushTypeResolution(symbol, 2)) {
return unknownType;
}
- var declaration = ts.getDeclarationOfKind(symbol, 285);
+ var declaration = ts.getDeclarationOfKind(symbol, 289);
var type = void 0;
if (declaration) {
if (declaration.jsDocTypeLiteral) {
@@ -22577,7 +24512,7 @@ var ts;
}
}
else {
- declaration = ts.getDeclarationOfKind(symbol, 228);
+ declaration = ts.getDeclarationOfKind(symbol, 230);
type = getTypeFromTypeNode(declaration.type);
}
if (popTypeResolution()) {
@@ -22585,7 +24520,7 @@ var ts;
if (typeParameters) {
links.typeParameters = typeParameters;
links.instantiations = ts.createMap();
- links.instantiations[getTypeListId(typeParameters)] = type;
+ links.instantiations.set(getTypeListId(typeParameters), type);
}
}
else {
@@ -22602,14 +24537,14 @@ var ts;
return !ts.isInAmbientContext(member);
}
return expr.kind === 8 ||
- expr.kind === 190 && expr.operator === 37 &&
+ expr.kind === 191 && expr.operator === 37 &&
expr.operand.kind === 8 ||
- expr.kind === 70 && !!symbol.exports[expr.text];
+ expr.kind === 70 && !!symbol.exports.get(expr.text);
}
function enumHasLiteralMembers(symbol) {
for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
- if (declaration.kind === 229) {
+ if (declaration.kind === 231) {
for (var _b = 0, _c = declaration.members; _b < _c.length; _b++) {
var member = _c[_b];
if (!isLiteralEnumMember(symbol, member)) {
@@ -22634,10 +24569,10 @@ var ts;
enumType.symbol = symbol;
if (enumHasLiteralMembers(symbol)) {
var memberTypeList = [];
- var memberTypes = ts.createMap();
+ var memberTypes = [];
for (var _i = 0, _a = enumType.symbol.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
- if (declaration.kind === 229) {
+ if (declaration.kind === 231) {
computeEnumMemberValues(declaration);
for (var _b = 0, _c = declaration.members; _b < _c.length; _b++) {
var member = _c[_b];
@@ -22654,7 +24589,7 @@ var ts;
if (memberTypeList.length > 1) {
enumType.flags |= 65536;
enumType.types = memberTypeList;
- unionTypes[getTypeListId(memberTypeList)] = enumType;
+ unionTypes.set(getTypeListId(memberTypeList), enumType);
}
}
}
@@ -22675,9 +24610,6 @@ var ts;
if (!links.declaredType) {
var type = createType(16384);
type.symbol = symbol;
- if (!ts.getDeclarationOfKind(symbol, 143).constraint) {
- type.constraint = noConstraintType;
- }
links.declaredType = type;
}
return links.declaredType;
@@ -22690,7 +24622,6 @@ var ts;
return links.declaredType;
}
function getDeclaredTypeOfSymbol(symbol) {
- ts.Debug.assert((symbol.flags & 16777216) === 0);
if (symbol.flags & (32 | 64)) {
return getDeclaredTypeOfClassOrInterface(symbol);
}
@@ -22725,19 +24656,20 @@ var ts;
function isIndependentType(node) {
switch (node.kind) {
case 118:
- case 134:
+ case 135:
case 132:
case 121:
- case 135:
+ case 136:
+ case 133:
case 104:
- case 137:
+ case 138:
case 94:
case 129:
- case 171:
+ case 172:
return true;
- case 162:
+ case 163:
return isIndependentType(node.elementType);
- case 157:
+ case 158:
return isIndependentTypeReference(node);
}
return false;
@@ -22746,7 +24678,7 @@ var ts;
return node.type && isIndependentType(node.type) || !node.type && !node.initializer;
}
function isIndependentFunctionLikeDeclaration(node) {
- if (node.kind !== 150 && (!node.type || !isIndependentType(node.type))) {
+ if (node.kind !== 151 && (!node.type || !isIndependentType(node.type))) {
return false;
}
for (var _i = 0, _a = node.parameters; _i < _a.length; _i++) {
@@ -22762,12 +24694,12 @@ var ts;
var declaration = symbol.declarations[0];
if (declaration) {
switch (declaration.kind) {
+ case 148:
case 147:
- case 146:
return isIndependentVariableLikeDeclaration(declaration);
- case 149:
- case 148:
case 150:
+ case 149:
+ case 151:
return isIndependentFunctionLikeDeclaration(declaration);
}
}
@@ -22778,7 +24710,7 @@ var ts;
var result = ts.createMap();
for (var _i = 0, symbols_1 = symbols; _i < symbols_1.length; _i++) {
var symbol = symbols_1[_i];
- result[symbol.name] = symbol;
+ result.set(symbol.name, symbol);
}
return result;
}
@@ -22786,15 +24718,15 @@ var ts;
var result = ts.createMap();
for (var _i = 0, symbols_2 = symbols; _i < symbols_2.length; _i++) {
var symbol = symbols_2[_i];
- result[symbol.name] = mappingThisOnly && isIndependentMember(symbol) ? symbol : instantiateSymbol(symbol, mapper);
+ result.set(symbol.name, mappingThisOnly && isIndependentMember(symbol) ? symbol : instantiateSymbol(symbol, mapper));
}
return result;
}
function addInheritedMembers(symbols, baseSymbols) {
for (var _i = 0, baseSymbols_1 = baseSymbols; _i < baseSymbols_1.length; _i++) {
var s = baseSymbols_1[_i];
- if (!symbols[s.name]) {
- symbols[s.name] = s;
+ if (!symbols.has(s.name)) {
+ symbols.set(s.name, s);
}
}
}
@@ -22802,8 +24734,8 @@ var ts;
if (!type.declaredProperties) {
var symbol = type.symbol;
type.declaredProperties = getNamedMembers(symbol.members);
- type.declaredCallSignatures = getSignaturesOfSymbol(symbol.members["__call"]);
- type.declaredConstructSignatures = getSignaturesOfSymbol(symbol.members["__new"]);
+ type.declaredCallSignatures = getSignaturesOfSymbol(symbol.members.get("__call"));
+ type.declaredConstructSignatures = getSignaturesOfSymbol(symbol.members.get("__new"));
type.declaredStringIndexInfo = getIndexInfoOfSymbol(symbol, 0);
type.declaredNumberIndexInfo = getIndexInfoOfSymbol(symbol, 1);
}
@@ -22811,7 +24743,14 @@ var ts;
}
function getTypeWithThisArgument(type, thisArgument) {
if (getObjectFlags(type) & 4) {
- return createTypeReference(type.target, ts.concatenate(type.typeArguments, [thisArgument || type.target.thisType]));
+ var target = type.target;
+ var typeArguments = type.typeArguments;
+ if (ts.length(target.typeParameters) === ts.length(typeArguments)) {
+ return createTypeReference(target, ts.concatenate(typeArguments, [thisArgument || target.thisType]));
+ }
+ }
+ else if (type.flags & 131072) {
+ return getIntersectionType(ts.map(type.types, function (t) { return getTypeWithThisArgument(t, thisArgument); }));
}
return type;
}
@@ -22847,10 +24786,14 @@ var ts;
for (var _i = 0, baseTypes_1 = baseTypes; _i < baseTypes_1.length; _i++) {
var baseType = baseTypes_1[_i];
var instantiatedBaseType = thisArgument ? getTypeWithThisArgument(instantiateType(baseType, mapper), thisArgument) : baseType;
- addInheritedMembers(members, getPropertiesOfObjectType(instantiatedBaseType));
+ addInheritedMembers(members, getPropertiesOfType(instantiatedBaseType));
callSignatures = ts.concatenate(callSignatures, getSignaturesOfType(instantiatedBaseType, 0));
constructSignatures = ts.concatenate(constructSignatures, getSignaturesOfType(instantiatedBaseType, 1));
- stringIndexInfo = stringIndexInfo || getIndexInfoOfType(instantiatedBaseType, 0);
+ if (!stringIndexInfo) {
+ stringIndexInfo = instantiatedBaseType === anyType ?
+ createIndexInfo(anyType, false) :
+ getIndexInfoOfType(instantiatedBaseType, 0);
+ }
numberIndexInfo = numberIndexInfo || getIndexInfoOfType(instantiatedBaseType, 1);
}
}
@@ -22889,14 +24832,16 @@ var ts;
return [createSignature(undefined, classType.localTypeParameters, undefined, emptyArray, classType, undefined, 0, false, false)];
}
var baseTypeNode = getBaseTypeNodeOfClass(classType);
+ var isJavaScript = ts.isInJavaScriptFile(baseTypeNode);
var typeArguments = ts.map(baseTypeNode.typeArguments, getTypeFromTypeNode);
- var typeArgCount = typeArguments ? typeArguments.length : 0;
+ var typeArgCount = ts.length(typeArguments);
var result = [];
for (var _i = 0, baseSignatures_1 = baseSignatures; _i < baseSignatures_1.length; _i++) {
var baseSig = baseSignatures_1[_i];
- var typeParamCount = baseSig.typeParameters ? baseSig.typeParameters.length : 0;
- if (typeParamCount === typeArgCount) {
- var sig = typeParamCount ? createSignatureInstantiation(baseSig, typeArguments) : cloneSignature(baseSig);
+ var minTypeArgumentCount = getMinTypeArgumentCount(baseSig.typeParameters);
+ var typeParamCount = ts.length(baseSig.typeParameters);
+ if ((isJavaScript || typeArgCount >= minTypeArgumentCount) && typeArgCount <= typeParamCount) {
+ var sig = typeParamCount ? createSignatureInstantiation(baseSig, fillMissingTypeArguments(typeArguments, baseSig.typeParameters, minTypeArgumentCount, baseTypeNode)) : cloneSignature(baseSig);
sig.typeParameters = classType.localTypeParameters;
sig.resolvedReturnType = classType;
result.push(sig);
@@ -22950,7 +24895,7 @@ var ts;
s = cloneSignature(signature);
if (ts.forEach(unionSignatures, function (sig) { return sig.thisParameter; })) {
var thisType = getUnionType(ts.map(unionSignatures, function (sig) { return getTypeOfSymbol(sig.thisParameter) || anyType; }), true);
- s.thisParameter = createTransientSymbol(signature.thisParameter, thisType);
+ s.thisParameter = createSymbolWithType(signature.thisParameter, thisType);
}
s.resolvedReturnType = undefined;
s.unionSignatures = unionSignatures;
@@ -22965,8 +24910,8 @@ var ts;
function getUnionIndexInfo(types, kind) {
var indexTypes = [];
var isAnyReadonly = false;
- for (var _i = 0, types_1 = types; _i < types_1.length; _i++) {
- var type = types_1[_i];
+ for (var _i = 0, types_2 = types; _i < types_2.length; _i++) {
+ var type = types_2[_i];
var indexInfo = getIndexInfoOfType(type, kind);
if (!indexInfo) {
return undefined;
@@ -22992,17 +24937,44 @@ var ts;
function unionSpreadIndexInfos(info1, info2) {
return info1 && info2 && createIndexInfo(getUnionType([info1.type, info2.type]), info1.isReadonly || info2.isReadonly);
}
+ function includeMixinType(type, types, index) {
+ var mixedTypes = [];
+ for (var i = 0; i < types.length; i++) {
+ if (i === index) {
+ mixedTypes.push(type);
+ }
+ else if (isMixinConstructorType(types[i])) {
+ mixedTypes.push(getReturnTypeOfSignature(getSignaturesOfType(types[i], 1)[0]));
+ }
+ }
+ return getIntersectionType(mixedTypes);
+ }
function resolveIntersectionTypeMembers(type) {
var callSignatures = emptyArray;
var constructSignatures = emptyArray;
- var stringIndexInfo = undefined;
- var numberIndexInfo = undefined;
- for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
- var t = _a[_i];
+ var stringIndexInfo;
+ var numberIndexInfo;
+ var types = type.types;
+ var mixinCount = ts.countWhere(types, isMixinConstructorType);
+ var _loop_3 = function (i) {
+ var t = type.types[i];
+ if (mixinCount === 0 || mixinCount === types.length && i === 0 || !isMixinConstructorType(t)) {
+ var signatures = getSignaturesOfType(t, 1);
+ if (signatures.length && mixinCount > 0) {
+ signatures = ts.map(signatures, function (s) {
+ var clone = cloneSignature(s);
+ clone.resolvedReturnType = includeMixinType(getReturnTypeOfSignature(s), types, i);
+ return clone;
+ });
+ }
+ constructSignatures = ts.concatenate(constructSignatures, signatures);
+ }
callSignatures = ts.concatenate(callSignatures, getSignaturesOfType(t, 0));
- constructSignatures = ts.concatenate(constructSignatures, getSignaturesOfType(t, 1));
stringIndexInfo = intersectIndexInfos(stringIndexInfo, getIndexInfoOfType(t, 0));
numberIndexInfo = intersectIndexInfos(numberIndexInfo, getIndexInfoOfType(t, 1));
+ };
+ for (var i = 0; i < types.length; i++) {
+ _loop_3(i);
}
setStructuredTypeMembers(type, emptySymbols, callSignatures, constructSignatures, stringIndexInfo, numberIndexInfo);
}
@@ -23018,8 +24990,8 @@ var ts;
}
else if (symbol.flags & 2048) {
var members = symbol.members;
- var callSignatures = getSignaturesOfSymbol(members["__call"]);
- var constructSignatures = getSignaturesOfSymbol(members["__new"]);
+ var callSignatures = getSignaturesOfSymbol(members.get("__call"));
+ var constructSignatures = getSignaturesOfSymbol(members.get("__new"));
var stringIndexInfo = getIndexInfoOfSymbol(symbol, 0);
var numberIndexInfo = getIndexInfoOfSymbol(symbol, 1);
setStructuredTypeMembers(type, members, callSignatures, constructSignatures, stringIndexInfo, numberIndexInfo);
@@ -23027,23 +24999,27 @@ var ts;
else {
var members = emptySymbols;
var constructSignatures = emptyArray;
- if (symbol.flags & 1952) {
+ var stringIndexInfo = undefined;
+ if (symbol.exports) {
members = getExportsOfSymbol(symbol);
}
if (symbol.flags & 32) {
var classType = getDeclaredTypeOfClassOrInterface(symbol);
- constructSignatures = getSignaturesOfSymbol(symbol.members["__constructor"]);
+ constructSignatures = getSignaturesOfSymbol(symbol.members.get("__constructor"));
if (!constructSignatures.length) {
constructSignatures = getDefaultConstructSignatures(classType);
}
var baseConstructorType = getBaseConstructorTypeOfClass(classType);
- if (baseConstructorType.flags & 32768) {
+ if (baseConstructorType.flags & (32768 | 131072 | 540672)) {
members = createSymbolTable(getNamedMembers(members));
- addInheritedMembers(members, getPropertiesOfObjectType(baseConstructorType));
+ addInheritedMembers(members, getPropertiesOfType(baseConstructorType));
+ }
+ else if (baseConstructorType === anyType) {
+ stringIndexInfo = createIndexInfo(anyType, false);
}
}
var numberIndexInfo = symbol.flags & 384 ? enumNumberIndexInfo : undefined;
- setStructuredTypeMembers(type, members, emptyArray, constructSignatures, undefined, numberIndexInfo);
+ setStructuredTypeMembers(type, members, emptyArray, constructSignatures, stringIndexInfo, numberIndexInfo);
if (symbol.flags & (16 | 8192)) {
type.callSignatures = getSignaturesOfSymbol(symbol);
}
@@ -23052,37 +25028,48 @@ var ts;
function resolveMappedTypeMembers(type) {
var members = ts.createMap();
var stringIndexInfo;
- var numberIndexInfo;
setStructuredTypeMembers(type, emptySymbols, emptyArray, emptyArray, undefined, undefined);
var typeParameter = getTypeParameterFromMappedType(type);
var constraintType = getConstraintTypeFromMappedType(type);
var templateType = getTemplateTypeFromMappedType(type);
- var isReadonly = !!type.declaration.readonlyToken;
- var isOptional = !!type.declaration.questionToken;
- var keyType = constraintType.flags & 16384 ? getApparentType(constraintType) : constraintType;
- var iterationType = keyType.flags & 262144 ? getIndexType(getApparentType(keyType.type)) : keyType;
- forEachType(iterationType, function (t) {
- var iterationMapper = createUnaryTypeMapper(typeParameter, t);
+ var modifiersType = getApparentType(getModifiersTypeFromMappedType(type));
+ var templateReadonly = !!type.declaration.readonlyToken;
+ var templateOptional = !!type.declaration.questionToken;
+ if (type.declaration.typeParameter.constraint.kind === 169) {
+ for (var _i = 0, _a = getPropertiesOfType(modifiersType); _i < _a.length; _i++) {
+ var propertySymbol = _a[_i];
+ addMemberForKeyType(getLiteralTypeFromPropertyName(propertySymbol), propertySymbol);
+ }
+ if (getIndexInfoOfType(modifiersType, 0)) {
+ addMemberForKeyType(stringType);
+ }
+ }
+ else {
+ var keyType = constraintType.flags & 540672 ? getApparentType(constraintType) : constraintType;
+ var iterationType = keyType.flags & 262144 ? getIndexType(getApparentType(keyType.type)) : keyType;
+ forEachType(iterationType, addMemberForKeyType);
+ }
+ setStructuredTypeMembers(type, members, emptyArray, emptyArray, stringIndexInfo, undefined);
+ function addMemberForKeyType(t, propertySymbol) {
+ var iterationMapper = createTypeMapper([typeParameter], [t]);
var templateMapper = type.mapper ? combineTypeMappers(type.mapper, iterationMapper) : iterationMapper;
var propType = instantiateType(templateType, templateMapper);
- if (t.flags & (32 | 64 | 256)) {
+ if (t.flags & 32) {
var propName = t.text;
- var prop = createSymbol(4 | 67108864 | (isOptional ? 536870912 : 0), propName);
- prop.type = addOptionality(propType, isOptional);
- prop.isReadonly = isReadonly;
- members[propName] = prop;
+ var modifiersProp = getPropertyOfType(modifiersType, propName);
+ var isOptional = templateOptional || !!(modifiersProp && modifiersProp.flags & 67108864);
+ var prop = createSymbol(4 | (isOptional ? 67108864 : 0), propName);
+ prop.checkFlags = templateReadonly || modifiersProp && isReadonlySymbol(modifiersProp) ? 8 : 0;
+ prop.type = propType;
+ if (propertySymbol) {
+ prop.syntheticOrigin = propertySymbol;
+ }
+ members.set(propName, prop);
}
else if (t.flags & 2) {
- stringIndexInfo = createIndexInfo(propType, isReadonly);
+ stringIndexInfo = createIndexInfo(propType, templateReadonly);
}
- else if (t.flags & 4) {
- numberIndexInfo = createIndexInfo(propType, isReadonly);
- }
- });
- if (stringIndexInfo && numberIndexInfo && isTypeIdenticalTo(stringIndexInfo.type, numberIndexInfo.type)) {
- numberIndexInfo = undefined;
}
- setStructuredTypeMembers(type, members, emptyArray, emptyArray, stringIndexInfo, numberIndexInfo);
}
function getTypeParameterFromMappedType(type) {
return type.typeParameter ||
@@ -23095,16 +25082,28 @@ var ts;
function getTemplateTypeFromMappedType(type) {
return type.templateType ||
(type.templateType = type.declaration.type ?
- instantiateType(getTypeFromTypeNode(type.declaration.type), type.mapper || identityMapper) :
+ instantiateType(addOptionality(getTypeFromTypeNode(type.declaration.type), !!type.declaration.questionToken), type.mapper || identityMapper) :
unknownType);
}
- function getErasedTemplateTypeFromMappedType(type) {
- return instantiateType(getTemplateTypeFromMappedType(type), createUnaryTypeMapper(getTypeParameterFromMappedType(type), anyType));
+ function getModifiersTypeFromMappedType(type) {
+ if (!type.modifiersType) {
+ var constraintDeclaration = type.declaration.typeParameter.constraint;
+ if (constraintDeclaration.kind === 169) {
+ type.modifiersType = instantiateType(getTypeFromTypeNode(constraintDeclaration.type), type.mapper || identityMapper);
+ }
+ else {
+ var declaredType = getTypeFromMappedTypeNode(type.declaration);
+ var constraint = getConstraintTypeFromMappedType(declaredType);
+ var extendedConstraint = constraint && constraint.flags & 16384 ? getConstraintOfTypeParameter(constraint) : constraint;
+ type.modifiersType = extendedConstraint && extendedConstraint.flags & 262144 ? instantiateType(extendedConstraint.type, type.mapper || identityMapper) : emptyObjectType;
+ }
+ }
+ return type.modifiersType;
}
function isGenericMappedType(type) {
if (getObjectFlags(type) & 32) {
var constraintType = getConstraintTypeFromMappedType(type);
- return !!(constraintType.flags & (16384 | 262144));
+ return maybeTypeOfKind(constraintType, 540672 | 262144);
}
return false;
}
@@ -23142,35 +25141,33 @@ var ts;
function getPropertyOfObjectType(type, name) {
if (type.flags & 32768) {
var resolved = resolveStructuredTypeMembers(type);
- var symbol = resolved.members[name];
+ var symbol = resolved.members.get(name);
if (symbol && symbolIsValue(symbol)) {
return symbol;
}
}
}
function getPropertiesOfUnionOrIntersectionType(type) {
- for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
- var current = _a[_i];
- for (var _b = 0, _c = getPropertiesOfType(current); _b < _c.length; _b++) {
- var prop = _c[_b];
- getUnionOrIntersectionProperty(type, prop.name);
- }
- if (type.flags & 65536) {
- break;
- }
- }
- var props = type.resolvedProperties;
- if (props) {
- var result = [];
- for (var key in props) {
- var prop = props[key];
- if (!(prop.flags & 268435456 && prop.isPartial)) {
- result.push(prop);
+ if (!type.resolvedProperties) {
+ var members = ts.createMap();
+ for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
+ var current = _a[_i];
+ for (var _b = 0, _c = getPropertiesOfType(current); _b < _c.length; _b++) {
+ var prop = _c[_b];
+ if (!members.has(prop.name)) {
+ var combinedProp = getPropertyOfUnionOrIntersectionType(type, prop.name);
+ if (combinedProp) {
+ members.set(prop.name, combinedProp);
+ }
+ }
+ }
+ if (type.flags & 65536) {
+ break;
}
}
- return result;
+ type.resolvedProperties = getNamedMembers(members);
}
- return emptyArray;
+ return type.resolvedProperties;
}
function getPropertiesOfType(type) {
type = getApparentType(type);
@@ -23178,41 +25175,126 @@ var ts;
getPropertiesOfUnionOrIntersectionType(type) :
getPropertiesOfObjectType(type);
}
- function getApparentTypeOfTypeParameter(type) {
- if (!type.resolvedApparentType) {
- var constraintType = getConstraintOfTypeParameter(type);
- while (constraintType && constraintType.flags & 16384) {
- constraintType = getConstraintOfTypeParameter(constraintType);
+ function getConstraintOfType(type) {
+ return type.flags & 16384 ? getConstraintOfTypeParameter(type) :
+ type.flags & 524288 ? getConstraintOfIndexedAccess(type) :
+ getBaseConstraintOfType(type);
+ }
+ function getConstraintOfTypeParameter(typeParameter) {
+ return hasNonCircularBaseConstraint(typeParameter) ? getConstraintFromTypeParameter(typeParameter) : undefined;
+ }
+ function getConstraintOfIndexedAccess(type) {
+ var baseObjectType = getBaseConstraintOfType(type.objectType);
+ var baseIndexType = getBaseConstraintOfType(type.indexType);
+ return baseObjectType || baseIndexType ? getIndexedAccessType(baseObjectType || type.objectType, baseIndexType || type.indexType) : undefined;
+ }
+ function getBaseConstraintOfType(type) {
+ if (type.flags & (540672 | 196608)) {
+ var constraint = getResolvedBaseConstraint(type);
+ if (constraint !== noConstraintType && constraint !== circularConstraintType) {
+ return constraint;
}
- type.resolvedApparentType = getTypeWithThisArgument(constraintType || emptyObjectType, type);
}
- return type.resolvedApparentType;
+ else if (type.flags & 262144) {
+ return stringType;
+ }
+ return undefined;
}
- function getApparentTypeOfIndexedAccess(type) {
- return getIndexTypeOfType(getApparentType(type.objectType), 0) || type;
+ function hasNonCircularBaseConstraint(type) {
+ return getResolvedBaseConstraint(type) !== circularConstraintType;
+ }
+ function getResolvedBaseConstraint(type) {
+ var typeStack;
+ var circular;
+ if (!type.resolvedBaseConstraint) {
+ typeStack = [];
+ var constraint = getBaseConstraint(type);
+ type.resolvedBaseConstraint = circular ? circularConstraintType : getTypeWithThisArgument(constraint || noConstraintType, type);
+ }
+ return type.resolvedBaseConstraint;
+ function getBaseConstraint(t) {
+ if (ts.contains(typeStack, t)) {
+ circular = true;
+ return undefined;
+ }
+ typeStack.push(t);
+ var result = computeBaseConstraint(t);
+ typeStack.pop();
+ return result;
+ }
+ function computeBaseConstraint(t) {
+ if (t.flags & 16384) {
+ var constraint = getConstraintFromTypeParameter(t);
+ return t.isThisType ? constraint :
+ constraint ? getBaseConstraint(constraint) : undefined;
+ }
+ if (t.flags & 196608) {
+ var types = t.types;
+ var baseTypes = [];
+ for (var _i = 0, types_3 = types; _i < types_3.length; _i++) {
+ var type_2 = types_3[_i];
+ var baseType = getBaseConstraint(type_2);
+ if (baseType) {
+ baseTypes.push(baseType);
+ }
+ }
+ return t.flags & 65536 && baseTypes.length === types.length ? getUnionType(baseTypes) :
+ t.flags & 131072 && baseTypes.length ? getIntersectionType(baseTypes) :
+ undefined;
+ }
+ if (t.flags & 262144) {
+ return stringType;
+ }
+ if (t.flags & 524288) {
+ var baseObjectType = getBaseConstraint(t.objectType);
+ var baseIndexType = getBaseConstraint(t.indexType);
+ var baseIndexedAccess = baseObjectType && baseIndexType ? getIndexedAccessType(baseObjectType, baseIndexType) : undefined;
+ return baseIndexedAccess && baseIndexedAccess !== unknownType ? getBaseConstraint(baseIndexedAccess) : undefined;
+ }
+ return t;
+ }
+ }
+ function getApparentTypeOfIntersectionType(type) {
+ return type.resolvedApparentType || (type.resolvedApparentType = getTypeWithThisArgument(type, type));
+ }
+ function getDefaultFromTypeParameter(typeParameter) {
+ if (!typeParameter.default) {
+ if (typeParameter.target) {
+ var targetDefault = getDefaultFromTypeParameter(typeParameter.target);
+ typeParameter.default = targetDefault ? instantiateType(targetDefault, typeParameter.mapper) : noConstraintType;
+ }
+ else {
+ var defaultDeclaration = typeParameter.symbol && ts.forEach(typeParameter.symbol.declarations, function (decl) { return ts.isTypeParameter(decl) && decl.default; });
+ typeParameter.default = defaultDeclaration ? getTypeFromTypeNode(defaultDeclaration) : noConstraintType;
+ }
+ }
+ return typeParameter.default === noConstraintType ? undefined : typeParameter.default;
}
function getApparentType(type) {
- var t = type.flags & 16384 ? getApparentTypeOfTypeParameter(type) :
- type.flags & 524288 ? getApparentTypeOfIndexedAccess(type) :
- type;
- return t.flags & 262178 ? globalStringType :
- t.flags & 340 ? globalNumberType :
- t.flags & 136 ? globalBooleanType :
- t.flags & 512 ? getGlobalESSymbolType() :
- t;
+ var t = type.flags & 540672 ? getBaseConstraintOfType(type) || emptyObjectType : type;
+ return t.flags & 131072 ? getApparentTypeOfIntersectionType(t) :
+ t.flags & 262178 ? globalStringType :
+ t.flags & 340 ? globalNumberType :
+ t.flags & 136 ? globalBooleanType :
+ t.flags & 512 ? getGlobalESSymbolType(languageVersion >= 2) :
+ t.flags & 16777216 ? emptyObjectType :
+ t;
}
function createUnionOrIntersectionProperty(containingType, name) {
- var types = containingType.types;
var props;
- var commonFlags = (containingType.flags & 131072) ? 536870912 : 0;
- var isReadonly = false;
- var isPartial = false;
- for (var _i = 0, types_2 = types; _i < types_2.length; _i++) {
- var current = types_2[_i];
+ var types = containingType.types;
+ var isUnion = containingType.flags & 65536;
+ var excludeModifiers = isUnion ? 24 : 0;
+ var commonFlags = isUnion ? 0 : 67108864;
+ var syntheticFlag = 4;
+ var checkFlags = 0;
+ for (var _i = 0, types_4 = types; _i < types_4.length; _i++) {
+ var current = types_4[_i];
var type = getApparentType(current);
if (type !== unknownType) {
var prop = getPropertyOfType(type, name);
- if (prop && !(getDeclarationModifierFlagsFromSymbol(prop) & (8 | 16))) {
+ var modifiers = prop ? getDeclarationModifierFlagsFromSymbol(prop) : 0;
+ if (prop && !(modifiers & excludeModifiers)) {
commonFlags &= prop.flags;
if (!props) {
props = [prop];
@@ -23220,25 +25302,29 @@ var ts;
else if (!ts.contains(props, prop)) {
props.push(prop);
}
- if (isReadonlySymbol(prop)) {
- isReadonly = true;
+ checkFlags |= (isReadonlySymbol(prop) ? 8 : 0) |
+ (!(modifiers & 24) ? 64 : 0) |
+ (modifiers & 16 ? 128 : 0) |
+ (modifiers & 8 ? 256 : 0) |
+ (modifiers & 32 ? 512 : 0);
+ if (!isMethodLike(prop)) {
+ syntheticFlag = 2;
}
}
- else if (containingType.flags & 65536) {
- isPartial = true;
+ else if (isUnion) {
+ checkFlags |= 16;
}
}
}
if (!props) {
return undefined;
}
- if (props.length === 1 && !isPartial) {
+ if (props.length === 1 && !(checkFlags & 16)) {
return props[0];
}
var propTypes = [];
var declarations = [];
var commonType = undefined;
- var hasNonUniformType = false;
for (var _a = 0, props_1 = props; _a < props_1.length; _a++) {
var prop = props_1[_a];
if (prop.declarations) {
@@ -23249,39 +25335,37 @@ var ts;
commonType = type;
}
else if (type !== commonType) {
- hasNonUniformType = true;
+ checkFlags |= 32;
}
propTypes.push(type);
}
- var result = createSymbol(4 | 67108864 | 268435456 | commonFlags, name);
+ var result = createSymbol(4 | commonFlags, name);
+ result.checkFlags = syntheticFlag | checkFlags;
result.containingType = containingType;
- result.hasNonUniformType = hasNonUniformType;
- result.isPartial = isPartial;
result.declarations = declarations;
- result.isReadonly = isReadonly;
- result.type = containingType.flags & 65536 ? getUnionType(propTypes) : getIntersectionType(propTypes);
+ result.type = isUnion ? getUnionType(propTypes) : getIntersectionType(propTypes);
return result;
}
function getUnionOrIntersectionProperty(type, name) {
- var properties = type.resolvedProperties || (type.resolvedProperties = ts.createMap());
- var property = properties[name];
+ var properties = type.propertyCache || (type.propertyCache = ts.createMap());
+ var property = properties.get(name);
if (!property) {
property = createUnionOrIntersectionProperty(type, name);
if (property) {
- properties[name] = property;
+ properties.set(name, property);
}
}
return property;
}
function getPropertyOfUnionOrIntersectionType(type, name) {
var property = getUnionOrIntersectionProperty(type, name);
- return property && !(property.flags & 268435456 && property.isPartial) ? property : undefined;
+ return property && !(getCheckFlags(property) & 16) ? property : undefined;
}
function getPropertyOfType(type, name) {
type = getApparentType(type);
if (type.flags & 32768) {
var resolved = resolveStructuredTypeMembers(type);
- var symbol = resolved.members[name];
+ var symbol = resolved.members.get(name);
if (symbol && symbolIsValue(symbol)) {
return symbol;
}
@@ -23340,7 +25424,7 @@ var ts;
return undefined;
}
function getTypeParametersFromJSDocTemplate(declaration) {
- if (declaration.flags & 2097152) {
+ if (declaration.flags & 65536) {
var templateTag = ts.getJSDocTemplateTag(declaration);
if (templateTag) {
return getTypeParametersFromDeclaration(templateTag.typeParameters);
@@ -23360,16 +25444,16 @@ var ts;
}
function symbolsToArray(symbols) {
var result = [];
- for (var id in symbols) {
+ symbols.forEach(function (symbol, id) {
if (!isReservedMemberName(id)) {
- result.push(symbols[id]);
+ result.push(symbol);
}
- }
+ });
return result;
}
function isJSDocOptionalParameter(node) {
- if (node.flags & 2097152) {
- if (node.type && node.type.kind === 273) {
+ if (node.flags & 65536) {
+ if (node.type && node.type.kind === 277) {
return true;
}
var paramTags = ts.getJSDocParameterTags(node);
@@ -23380,7 +25464,7 @@ var ts;
return true;
}
if (paramTag.typeExpression) {
- return paramTag.typeExpression.type.kind === 273;
+ return paramTag.typeExpression.type.kind === 277;
}
}
}
@@ -23404,6 +25488,12 @@ var ts;
ts.Debug.assert(parameterIndex >= 0);
return parameterIndex >= signature.minArgumentCount;
}
+ var iife = ts.getImmediatelyInvokedFunctionExpression(node.parent);
+ if (iife) {
+ return !node.type &&
+ !node.dotDotDotToken &&
+ ts.indexOf(node.parent.parameters, node) >= iife.arguments.length;
+ }
return false;
}
function createTypePredicateFromTypePredicateNode(node) {
@@ -23423,16 +25513,50 @@ var ts;
};
}
}
+ function getMinTypeArgumentCount(typeParameters) {
+ var minTypeArgumentCount = 0;
+ if (typeParameters) {
+ for (var i = 0; i < typeParameters.length; i++) {
+ if (!getDefaultFromTypeParameter(typeParameters[i])) {
+ minTypeArgumentCount = i + 1;
+ }
+ }
+ }
+ return minTypeArgumentCount;
+ }
+ function fillMissingTypeArguments(typeArguments, typeParameters, minTypeArgumentCount, location) {
+ var numTypeParameters = ts.length(typeParameters);
+ if (numTypeParameters) {
+ var numTypeArguments = ts.length(typeArguments);
+ var isJavaScript = ts.isInJavaScriptFile(location);
+ if ((isJavaScript || numTypeArguments >= minTypeArgumentCount) && numTypeArguments <= numTypeParameters) {
+ if (!typeArguments) {
+ typeArguments = [];
+ }
+ for (var i = numTypeArguments; i < numTypeParameters; i++) {
+ typeArguments[i] = isJavaScript ? anyType : emptyObjectType;
+ }
+ for (var i = numTypeArguments; i < numTypeParameters; i++) {
+ var mapper = createTypeMapper(typeParameters, typeArguments);
+ var defaultType = getDefaultFromTypeParameter(typeParameters[i]);
+ typeArguments[i] = defaultType ? instantiateType(defaultType, mapper) : isJavaScript ? anyType : emptyObjectType;
+ }
+ }
+ }
+ return typeArguments;
+ }
function getSignatureFromDeclaration(declaration) {
var links = getNodeLinks(declaration);
if (!links.resolvedSignature) {
var parameters = [];
var hasLiteralTypes = false;
- var minArgumentCount = -1;
+ var minArgumentCount = 0;
var thisParameter = undefined;
var hasThisParameter = void 0;
+ var iife = ts.getImmediatelyInvokedFunctionExpression(declaration);
var isJSConstructSignature = ts.isJSDocConstructSignature(declaration);
- for (var i = isJSConstructSignature ? 1 : 0, n = declaration.parameters.length; i < n; i++) {
+ var isUntypedSignatureInJSFile = !iife && !isJSConstructSignature && ts.isInJavaScriptFile(declaration) && !ts.hasJSDocParameterTags(declaration);
+ for (var i = isJSConstructSignature ? 1 : 0; i < declaration.parameters.length; i++) {
var param = declaration.parameters[i];
var paramSymbol = param.symbol;
if (paramSymbol && !!(paramSymbol.flags & 4) && !ts.isBindingPattern(param.name)) {
@@ -23446,41 +25570,34 @@ var ts;
else {
parameters.push(paramSymbol);
}
- if (param.type && param.type.kind === 171) {
+ if (param.type && param.type.kind === 172) {
hasLiteralTypes = true;
}
- if (param.initializer || param.questionToken || param.dotDotDotToken || isJSDocOptionalParameter(param)) {
- if (minArgumentCount < 0) {
- minArgumentCount = i - (hasThisParameter ? 1 : 0);
- }
- }
- else {
- minArgumentCount = -1;
+ var isOptionalParameter_1 = param.initializer || param.questionToken || param.dotDotDotToken ||
+ iife && parameters.length > iife.arguments.length && !param.type ||
+ isJSDocOptionalParameter(param) ||
+ isUntypedSignatureInJSFile;
+ if (!isOptionalParameter_1) {
+ minArgumentCount = parameters.length;
}
}
- if ((declaration.kind === 151 || declaration.kind === 152) &&
+ if ((declaration.kind === 152 || declaration.kind === 153) &&
!ts.hasDynamicName(declaration) &&
(!hasThisParameter || !thisParameter)) {
- var otherKind = declaration.kind === 151 ? 152 : 151;
+ var otherKind = declaration.kind === 152 ? 153 : 152;
var other = ts.getDeclarationOfKind(declaration.symbol, otherKind);
if (other) {
thisParameter = getAnnotatedAccessorThisParameter(other);
}
}
- if (minArgumentCount < 0) {
- minArgumentCount = declaration.parameters.length - (hasThisParameter ? 1 : 0);
- }
- if (isJSConstructSignature) {
- minArgumentCount--;
- }
- var classType = declaration.kind === 150 ?
+ var classType = declaration.kind === 151 ?
getDeclaredTypeOfClassOrInterface(getMergedSymbol(declaration.parent.symbol))
: undefined;
var typeParameters = classType ? classType.localTypeParameters :
declaration.typeParameters ? getTypeParametersFromDeclaration(declaration.typeParameters) :
getTypeParametersFromJSDocTemplate(declaration);
var returnType = getSignatureReturnTypeFromDeclaration(declaration, isJSConstructSignature, classType);
- var typePredicate = declaration.type && declaration.type.kind === 156 ?
+ var typePredicate = declaration.type && declaration.type.kind === 157 ?
createTypePredicateFromTypePredicateNode(declaration.type) :
undefined;
links.resolvedSignature = createSignature(declaration, typeParameters, thisParameter, parameters, returnType, typePredicate, minArgumentCount, ts.hasRestParameter(declaration), hasLiteralTypes);
@@ -23497,41 +25614,69 @@ var ts;
else if (declaration.type) {
return getTypeFromTypeNode(declaration.type);
}
- if (declaration.flags & 2097152) {
+ if (declaration.flags & 65536) {
var type = getReturnTypeFromJSDocComment(declaration);
if (type && type !== unknownType) {
return type;
}
}
- if (declaration.kind === 151 && !ts.hasDynamicName(declaration)) {
- var setter = ts.getDeclarationOfKind(declaration.symbol, 152);
+ if (declaration.kind === 152 && !ts.hasDynamicName(declaration)) {
+ var setter = ts.getDeclarationOfKind(declaration.symbol, 153);
return getAnnotatedAccessorType(setter);
}
if (ts.nodeIsMissing(declaration.body)) {
return anyType;
}
}
+ function containsArgumentsReference(declaration) {
+ var links = getNodeLinks(declaration);
+ if (links.containsArgumentsReference === undefined) {
+ if (links.flags & 8192) {
+ links.containsArgumentsReference = true;
+ }
+ else {
+ links.containsArgumentsReference = traverse(declaration.body);
+ }
+ }
+ return links.containsArgumentsReference;
+ function traverse(node) {
+ if (!node)
+ return false;
+ switch (node.kind) {
+ case 70:
+ return node.text === "arguments" && ts.isPartOfExpression(node);
+ case 148:
+ case 150:
+ case 152:
+ case 153:
+ return node.name.kind === 143
+ && traverse(node.name);
+ default:
+ return !ts.nodeStartsNewLexicalEnvironment(node) && !ts.isPartOfTypeNode(node) && ts.forEachChild(node, traverse);
+ }
+ }
+ }
function getSignaturesOfSymbol(symbol) {
if (!symbol)
return emptyArray;
var result = [];
- for (var i = 0, len = symbol.declarations.length; i < len; i++) {
+ for (var i = 0; i < symbol.declarations.length; i++) {
var node = symbol.declarations[i];
switch (node.kind) {
- case 158:
case 159:
- case 225:
- case 149:
- case 148:
+ case 160:
+ case 227:
case 150:
- case 153:
+ case 149:
+ case 151:
case 154:
case 155:
- case 151:
+ case 156:
case 152:
- case 184:
+ case 153:
case 185:
- case 274:
+ case 186:
+ case 278:
if (i > 0 && node.body) {
var previous = symbol.declarations[i - 1];
if (node.parent === previous.parent && node.kind === previous.kind && node.pos === previous.end) {
@@ -23575,7 +25720,7 @@ var ts;
}
if (!popTypeResolution()) {
type = anyType;
- if (compilerOptions.noImplicitAny) {
+ if (noImplicitAny) {
var declaration = signature.declaration;
if (declaration.name) {
error(declaration.name, ts.Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, ts.declarationNameToString(declaration.name));
@@ -23599,9 +25744,14 @@ var ts;
return anyType;
}
function getSignatureInstantiation(signature, typeArguments) {
+ typeArguments = fillMissingTypeArguments(typeArguments, signature.typeParameters, getMinTypeArgumentCount(signature.typeParameters));
var instantiations = signature.instantiations || (signature.instantiations = ts.createMap());
var id = getTypeListId(typeArguments);
- return instantiations[id] || (instantiations[id] = createSignatureInstantiation(signature, typeArguments));
+ var instantiation = instantiations.get(id);
+ if (!instantiation) {
+ instantiations.set(id, instantiation = createSignatureInstantiation(signature, typeArguments));
+ }
+ return instantiation;
}
function createSignatureInstantiation(signature, typeArguments) {
return instantiateSignature(signature, createTypeMapper(signature.typeParameters, typeArguments), true);
@@ -23616,7 +25766,7 @@ var ts;
}
function getOrCreateTypeFromSignature(signature) {
if (!signature.isolatedSignatureType) {
- var isConstructor = signature.declaration.kind === 150 || signature.declaration.kind === 154;
+ var isConstructor = signature.declaration.kind === 151 || signature.declaration.kind === 155;
var type = createObjectType(16);
type.members = emptySymbols;
type.properties = emptyArray;
@@ -23627,10 +25777,10 @@ var ts;
return signature.isolatedSignatureType;
}
function getIndexSymbol(symbol) {
- return symbol.members["__index"];
+ return symbol.members.get("__index");
}
function getIndexDeclarationOfSymbol(symbol, kind) {
- var syntaxKind = kind === 1 ? 132 : 134;
+ var syntaxKind = kind === 1 ? 132 : 135;
var indexSymbol = getIndexSymbol(symbol);
if (indexSymbol) {
for (var _i = 0, _a = indexSymbol.declarations; _i < _a.length; _i++) {
@@ -23657,21 +25807,9 @@ var ts;
return undefined;
}
function getConstraintDeclaration(type) {
- return ts.getDeclarationOfKind(type.symbol, 143).constraint;
- }
- function hasConstraintReferenceTo(type, target) {
- var checked;
- while (type && type.flags & 16384 && !(type.isThisType) && !ts.contains(checked, type)) {
- if (type === target) {
- return true;
- }
- (checked || (checked = [])).push(type);
- var constraintDeclaration = getConstraintDeclaration(type);
- type = constraintDeclaration && getTypeFromTypeNode(constraintDeclaration);
- }
- return false;
+ return ts.getDeclarationOfKind(type.symbol, 144).constraint;
}
- function getConstraintOfTypeParameter(typeParameter) {
+ function getConstraintFromTypeParameter(typeParameter) {
if (!typeParameter.constraint) {
if (typeParameter.target) {
var targetConstraint = getConstraintOfTypeParameter(typeParameter.target);
@@ -23679,28 +25817,23 @@ var ts;
}
else {
var constraintDeclaration = getConstraintDeclaration(typeParameter);
- var constraint = getTypeFromTypeNode(constraintDeclaration);
- if (hasConstraintReferenceTo(constraint, typeParameter)) {
- error(constraintDeclaration, ts.Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(typeParameter));
- constraint = unknownType;
- }
- typeParameter.constraint = constraint;
+ typeParameter.constraint = constraintDeclaration ? getTypeFromTypeNode(constraintDeclaration) : noConstraintType;
}
}
return typeParameter.constraint === noConstraintType ? undefined : typeParameter.constraint;
}
function getParentSymbolOfTypeParameter(typeParameter) {
- return getSymbolOfNode(ts.getDeclarationOfKind(typeParameter.symbol, 143).parent);
+ return getSymbolOfNode(ts.getDeclarationOfKind(typeParameter.symbol, 144).parent);
}
function getTypeListId(types) {
var result = "";
if (types) {
- var length_3 = types.length;
+ var length_4 = types.length;
var i = 0;
- while (i < length_3) {
+ while (i < length_4) {
var startId = types[i].id;
var count = 1;
- while (i + count < length_3 && types[i + count].id === startId + count) {
+ while (i + count < length_4 && types[i + count].id === startId + count) {
count++;
}
if (result.length) {
@@ -23717,8 +25850,8 @@ var ts;
}
function getPropagatingFlagsOfTypes(types, excludeKinds) {
var result = 0;
- for (var _i = 0, types_3 = types; _i < types_3.length; _i++) {
- var type = types_3[_i];
+ for (var _i = 0, types_5 = types; _i < types_5.length; _i++) {
+ var type = types_5[_i];
if (!(type.flags & excludeKinds)) {
result |= type.flags;
}
@@ -23727,9 +25860,10 @@ var ts;
}
function createTypeReference(target, typeArguments) {
var id = getTypeListId(typeArguments);
- var type = target.instantiations[id];
+ var type = target.instantiations.get(id);
if (!type) {
- type = target.instantiations[id] = createObjectType(4, target.symbol);
+ type = createObjectType(4, target.symbol);
+ target.instantiations.set(id, type);
type.flags |= typeArguments ? getPropagatingFlagsOfTypes(typeArguments, 0) : 0;
type.target = target;
type.typeArguments = typeArguments;
@@ -23745,17 +25879,22 @@ var ts;
return type;
}
function getTypeReferenceArity(type) {
- return type.target.typeParameters ? type.target.typeParameters.length : 0;
+ return ts.length(type.target.typeParameters);
}
function getTypeFromClassOrInterfaceReference(node, symbol) {
var type = getDeclaredTypeOfSymbol(getMergedSymbol(symbol));
var typeParameters = type.localTypeParameters;
if (typeParameters) {
- if (!node.typeArguments || node.typeArguments.length !== typeParameters.length) {
- error(node, ts.Diagnostics.Generic_type_0_requires_1_type_argument_s, typeToString(type, undefined, 1), typeParameters.length);
+ var numTypeArguments = ts.length(node.typeArguments);
+ var minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
+ if (!ts.isInJavaScriptFile(node) && (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length)) {
+ error(node, minTypeArgumentCount === typeParameters.length
+ ? ts.Diagnostics.Generic_type_0_requires_1_type_argument_s
+ : ts.Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments, typeToString(type, undefined, 1), minTypeArgumentCount, typeParameters.length);
return unknownType;
}
- return createTypeReference(type, ts.concatenate(type.outerTypeParameters, ts.map(node.typeArguments, getTypeFromTypeNode)));
+ var typeArguments = ts.concatenate(type.outerTypeParameters, fillMissingTypeArguments(ts.map(node.typeArguments, getTypeFromTypeNode), typeParameters, minTypeArgumentCount, node));
+ return createTypeReference(type, typeArguments);
}
if (node.typeArguments) {
error(node, ts.Diagnostics.Type_0_is_not_generic, typeToString(type));
@@ -23768,14 +25907,22 @@ var ts;
var links = getSymbolLinks(symbol);
var typeParameters = links.typeParameters;
var id = getTypeListId(typeArguments);
- return links.instantiations[id] || (links.instantiations[id] = instantiateTypeNoAlias(type, createTypeMapper(typeParameters, typeArguments)));
+ var instantiation = links.instantiations.get(id);
+ if (!instantiation) {
+ links.instantiations.set(id, instantiation = instantiateTypeNoAlias(type, createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters)))));
+ }
+ return instantiation;
}
function getTypeFromTypeAliasReference(node, symbol) {
var type = getDeclaredTypeOfSymbol(symbol);
var typeParameters = getSymbolLinks(symbol).typeParameters;
if (typeParameters) {
- if (!node.typeArguments || node.typeArguments.length !== typeParameters.length) {
- error(node, ts.Diagnostics.Generic_type_0_requires_1_type_argument_s, symbolToString(symbol), typeParameters.length);
+ var numTypeArguments = ts.length(node.typeArguments);
+ var minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
+ if (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length) {
+ error(node, minTypeArgumentCount === typeParameters.length
+ ? ts.Diagnostics.Generic_type_0_requires_1_type_argument_s
+ : ts.Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments, symbolToString(symbol), minTypeArgumentCount, typeParameters.length);
return unknownType;
}
var typeArguments = ts.map(node.typeArguments, getTypeFromTypeNode);
@@ -23796,11 +25943,11 @@ var ts;
}
function getTypeReferenceName(node) {
switch (node.kind) {
- case 157:
+ case 158:
return node.typeName;
- case 272:
+ case 276:
return node.name;
- case 199:
+ case 200:
var expr = node.expression;
if (ts.isEntityNameExpression(expr)) {
return expr;
@@ -23824,23 +25971,58 @@ var ts;
if (symbol.flags & 524288) {
return getTypeFromTypeAliasReference(node, symbol);
}
- if (symbol.flags & 107455 && node.kind === 272) {
+ if (symbol.flags & 107455 && node.kind === 276) {
return getTypeOfSymbol(symbol);
}
return getTypeFromNonGenericTypeReference(node, symbol);
}
+ function getPrimitiveTypeFromJSDocTypeReference(node) {
+ if (ts.isIdentifier(node.name)) {
+ switch (node.name.text) {
+ case "String":
+ return stringType;
+ case "Number":
+ return numberType;
+ case "Boolean":
+ return booleanType;
+ case "Void":
+ return voidType;
+ case "Undefined":
+ return undefinedType;
+ case "Null":
+ return nullType;
+ case "Object":
+ return anyType;
+ case "Function":
+ return anyFunctionType;
+ case "Array":
+ case "array":
+ return !node.typeArguments || !node.typeArguments.length ? createArrayType(anyType) : undefined;
+ case "Promise":
+ case "promise":
+ return !node.typeArguments || !node.typeArguments.length ? createPromiseType(anyType) : undefined;
+ }
+ }
+ }
+ function getTypeFromJSDocNullableTypeNode(node) {
+ var type = getTypeFromTypeNode(node.type);
+ return strictNullChecks ? getUnionType([type, nullType]) : type;
+ }
function getTypeFromTypeReference(node) {
var links = getNodeLinks(node);
if (!links.resolvedType) {
var symbol = void 0;
var type = void 0;
- if (node.kind === 272) {
- var typeReferenceName = getTypeReferenceName(node);
- symbol = resolveTypeReferenceName(typeReferenceName);
- type = getTypeReferenceType(node, symbol);
+ if (node.kind === 276) {
+ type = getPrimitiveTypeFromJSDocTypeReference(node);
+ if (!type) {
+ var typeReferenceName = getTypeReferenceName(node);
+ symbol = resolveTypeReferenceName(typeReferenceName);
+ type = getTypeReferenceType(node, symbol);
+ }
}
else {
- var typeNameOrExpression = node.kind === 157
+ var typeNameOrExpression = node.kind === 158
? node.typeName
: ts.isEntityNameExpression(node.expression)
? node.expression
@@ -23866,12 +26048,12 @@ var ts;
function getTypeOfGlobalSymbol(symbol, arity) {
function getTypeDeclaration(symbol) {
var declarations = symbol.declarations;
- for (var _i = 0, declarations_3 = declarations; _i < declarations_3.length; _i++) {
- var declaration = declarations_3[_i];
+ for (var _i = 0, declarations_4 = declarations; _i < declarations_4.length; _i++) {
+ var declaration = declarations_4[_i];
switch (declaration.kind) {
- case 226:
- case 227:
+ case 228:
case 229:
+ case 231:
return declaration;
}
}
@@ -23884,44 +26066,91 @@ var ts;
error(getTypeDeclaration(symbol), ts.Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbol.name);
return arity ? emptyGenericType : emptyObjectType;
}
- if ((type.typeParameters ? type.typeParameters.length : 0) !== arity) {
+ if (ts.length(type.typeParameters) !== arity) {
error(getTypeDeclaration(symbol), ts.Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbol.name, arity);
return arity ? emptyGenericType : emptyObjectType;
}
return type;
}
- function getGlobalValueSymbol(name) {
- return getGlobalSymbol(name, 107455, ts.Diagnostics.Cannot_find_global_value_0);
+ function getGlobalValueSymbol(name, reportErrors) {
+ return getGlobalSymbol(name, 107455, reportErrors ? ts.Diagnostics.Cannot_find_global_value_0 : undefined);
}
- function getGlobalTypeSymbol(name) {
- return getGlobalSymbol(name, 793064, ts.Diagnostics.Cannot_find_global_type_0);
+ function getGlobalTypeSymbol(name, reportErrors) {
+ return getGlobalSymbol(name, 793064, reportErrors ? ts.Diagnostics.Cannot_find_global_type_0 : undefined);
}
function getGlobalSymbol(name, meaning, diagnostic) {
return resolveName(undefined, name, meaning, diagnostic, name);
}
- function getGlobalType(name, arity) {
+ function getGlobalType(name, arity, reportErrors) {
+ var symbol = getGlobalTypeSymbol(name, reportErrors);
+ return symbol || reportErrors ? getTypeOfGlobalSymbol(symbol, arity) : undefined;
+ }
+ function getGlobalTypedPropertyDescriptorType() {
+ return deferredGlobalTypedPropertyDescriptorType || (deferredGlobalTypedPropertyDescriptorType = getGlobalType("TypedPropertyDescriptor", 1, true)) || emptyGenericType;
+ }
+ function getGlobalTemplateStringsArrayType() {
+ return deferredGlobalTemplateStringsArrayType || (deferredGlobalTemplateStringsArrayType = getGlobalType("TemplateStringsArray", 0, true)) || emptyObjectType;
+ }
+ function getGlobalESSymbolConstructorSymbol(reportErrors) {
+ return deferredGlobalESSymbolConstructorSymbol || (deferredGlobalESSymbolConstructorSymbol = getGlobalValueSymbol("Symbol", reportErrors));
+ }
+ function getGlobalESSymbolType(reportErrors) {
+ return deferredGlobalESSymbolType || (deferredGlobalESSymbolType = getGlobalType("Symbol", 0, reportErrors)) || emptyObjectType;
+ }
+ function getGlobalPromiseType(reportErrors) {
+ return deferredGlobalPromiseType || (deferredGlobalPromiseType = getGlobalType("Promise", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalPromiseConstructorSymbol(reportErrors) {
+ return deferredGlobalPromiseConstructorSymbol || (deferredGlobalPromiseConstructorSymbol = getGlobalValueSymbol("Promise", reportErrors));
+ }
+ function getGlobalPromiseConstructorLikeType(reportErrors) {
+ return deferredGlobalPromiseConstructorLikeType || (deferredGlobalPromiseConstructorLikeType = getGlobalType("PromiseConstructorLike", 0, reportErrors)) || emptyObjectType;
+ }
+ function getGlobalAsyncIterableType(reportErrors) {
+ return deferredGlobalAsyncIterableType || (deferredGlobalAsyncIterableType = getGlobalType("AsyncIterable", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalAsyncIteratorType(reportErrors) {
+ return deferredGlobalAsyncIteratorType || (deferredGlobalAsyncIteratorType = getGlobalType("AsyncIterator", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalAsyncIterableIteratorType(reportErrors) {
+ return deferredGlobalAsyncIterableIteratorType || (deferredGlobalAsyncIterableIteratorType = getGlobalType("AsyncIterableIterator", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalIterableType(reportErrors) {
+ return deferredGlobalIterableType || (deferredGlobalIterableType = getGlobalType("Iterable", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalIteratorType(reportErrors) {
+ return deferredGlobalIteratorType || (deferredGlobalIteratorType = getGlobalType("Iterator", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalIterableIteratorType(reportErrors) {
+ return deferredGlobalIterableIteratorType || (deferredGlobalIterableIteratorType = getGlobalType("IterableIterator", 1, reportErrors)) || emptyGenericType;
+ }
+ function getGlobalTypeOrUndefined(name, arity) {
if (arity === void 0) { arity = 0; }
- return getTypeOfGlobalSymbol(getGlobalTypeSymbol(name), arity);
+ var symbol = getGlobalSymbol(name, 793064, undefined);
+ return symbol && getTypeOfGlobalSymbol(symbol, arity);
}
function getExportedTypeFromNamespace(namespace, name) {
var namespaceSymbol = getGlobalSymbol(namespace, 1920, undefined);
var typeSymbol = namespaceSymbol && getSymbol(namespaceSymbol.exports, name, 793064);
return typeSymbol && getDeclaredTypeOfSymbol(typeSymbol);
}
- function createTypedPropertyDescriptorType(propertyType) {
- var globalTypedPropertyDescriptorType = getGlobalTypedPropertyDescriptorType();
- return globalTypedPropertyDescriptorType !== emptyGenericType
- ? createTypeReference(globalTypedPropertyDescriptorType, [propertyType])
- : emptyObjectType;
- }
function createTypeFromGenericGlobalType(genericGlobalType, typeArguments) {
return genericGlobalType !== emptyGenericType ? createTypeReference(genericGlobalType, typeArguments) : emptyObjectType;
}
- function createIterableType(elementType) {
- return createTypeFromGenericGlobalType(getGlobalIterableType(), [elementType]);
+ function createTypedPropertyDescriptorType(propertyType) {
+ return createTypeFromGenericGlobalType(getGlobalTypedPropertyDescriptorType(), [propertyType]);
}
- function createIterableIteratorType(elementType) {
- return createTypeFromGenericGlobalType(getGlobalIterableIteratorType(), [elementType]);
+ function createAsyncIterableType(iteratedType) {
+ return createTypeFromGenericGlobalType(getGlobalAsyncIterableType(true), [iteratedType]);
+ }
+ function createAsyncIterableIteratorType(iteratedType) {
+ return createTypeFromGenericGlobalType(getGlobalAsyncIterableIteratorType(true), [iteratedType]);
+ }
+ function createIterableType(iteratedType) {
+ return createTypeFromGenericGlobalType(getGlobalIterableType(true), [iteratedType]);
+ }
+ function createIterableIteratorType(iteratedType) {
+ return createTypeFromGenericGlobalType(getGlobalIterableIteratorType(true), [iteratedType]);
}
function createArrayType(elementType) {
return createTypeFromGenericGlobalType(globalArrayType, [elementType]);
@@ -23939,7 +26168,7 @@ var ts;
for (var i = 0; i < arity; i++) {
var typeParameter = createType(16384);
typeParameters.push(typeParameter);
- var property = createSymbol(4 | 67108864, "" + i);
+ var property = createSymbol(4, "" + i);
property.type = typeParameter;
properties.push(property);
}
@@ -23948,7 +26177,7 @@ var ts;
type.outerTypeParameters = undefined;
type.localTypeParameters = typeParameters;
type.instantiations = ts.createMap();
- type.instantiations[getTypeListId(type.typeParameters)] = type;
+ type.instantiations.set(getTypeListId(type.typeParameters), type);
type.target = type;
type.typeArguments = type.typeParameters;
type.thisType = createType(16384);
@@ -24030,14 +26259,14 @@ var ts;
}
}
function addTypesToUnion(typeSet, types) {
- for (var _i = 0, types_4 = types; _i < types_4.length; _i++) {
- var type = types_4[_i];
+ for (var _i = 0, types_6 = types; _i < types_6.length; _i++) {
+ var type = types_6[_i];
addTypeToUnion(typeSet, type);
}
}
function containsIdenticalType(types, type) {
- for (var _i = 0, types_5 = types; _i < types_5.length; _i++) {
- var t = types_5[_i];
+ for (var _i = 0, types_7 = types; _i < types_7.length; _i++) {
+ var t = types_7[_i];
if (isTypeIdenticalTo(t, type)) {
return true;
}
@@ -24045,8 +26274,9 @@ var ts;
return false;
}
function isSubtypeOfAny(candidate, types) {
- for (var i = 0, len = types.length; i < len; i++) {
- if (candidate !== types[i] && isTypeSubtypeOf(candidate, types[i])) {
+ for (var _i = 0, types_8 = types; _i < types_8.length; _i++) {
+ var type = types_8[_i];
+ if (candidate !== type && isTypeSubtypeOf(candidate, type)) {
return true;
}
}
@@ -24124,10 +26354,11 @@ var ts;
return types[0];
}
var id = getTypeListId(types);
- var type = unionTypes[id];
+ var type = unionTypes.get(id);
if (!type) {
var propagatedFlags = getPropagatingFlagsOfTypes(types, 6144);
- type = unionTypes[id] = createType(65536 | propagatedFlags);
+ type = createType(65536 | propagatedFlags);
+ unionTypes.set(id, type);
type.types = types;
type.aliasSymbol = aliasSymbol;
type.aliasTypeArguments = aliasTypeArguments;
@@ -24148,13 +26379,25 @@ var ts;
else if (type.flags & 1) {
typeSet.containsAny = true;
}
+ else if (getObjectFlags(type) & 16 && isEmptyObjectType(type)) {
+ typeSet.containsEmptyObject = true;
+ }
else if (!(type.flags & 8192) && (strictNullChecks || !(type.flags & 6144)) && !ts.contains(typeSet, type)) {
- typeSet.push(type);
+ if (type.flags & 32768) {
+ typeSet.containsObjectType = true;
+ }
+ if (type.flags & 65536 && typeSet.unionIndex === undefined) {
+ typeSet.unionIndex = typeSet.length;
+ }
+ if (!(type.flags & 32768 && type.objectFlags & 16 &&
+ type.symbol && type.symbol.flags & (16 | 8192) && containsIdenticalType(typeSet, type))) {
+ typeSet.push(type);
+ }
}
}
function addTypesToIntersection(typeSet, types) {
- for (var _i = 0, types_6 = types; _i < types_6.length; _i++) {
- var type = types_6[_i];
+ for (var _i = 0, types_9 = types; _i < types_9.length; _i++) {
+ var type = types_9[_i];
addTypeToIntersection(typeSet, type);
}
}
@@ -24162,30 +26405,28 @@ var ts;
if (types.length === 0) {
return emptyObjectType;
}
- var _loop_2 = function (i) {
- var type_1 = types[i];
- if (type_1.flags & 65536) {
- return { value: getUnionType(ts.map(type_1.types, function (t) { return getIntersectionType(ts.replaceElement(types, i, t)); }), false, aliasSymbol, aliasTypeArguments) };
- }
- };
- for (var i = 0; i < types.length; i++) {
- var state_2 = _loop_2(i);
- if (typeof state_2 === "object")
- return state_2.value;
- }
var typeSet = [];
addTypesToIntersection(typeSet, types);
if (typeSet.containsAny) {
return anyType;
}
+ if (typeSet.containsEmptyObject && !typeSet.containsObjectType) {
+ typeSet.push(emptyObjectType);
+ }
if (typeSet.length === 1) {
return typeSet[0];
}
+ var unionIndex = typeSet.unionIndex;
+ if (unionIndex !== undefined) {
+ var unionType = typeSet[unionIndex];
+ return getUnionType(ts.map(unionType.types, function (t) { return getIntersectionType(ts.replaceElement(typeSet, unionIndex, t)); }), false, aliasSymbol, aliasTypeArguments);
+ }
var id = getTypeListId(typeSet);
- var type = intersectionTypes[id];
+ var type = intersectionTypes.get(id);
if (!type) {
var propagatedFlags = getPropagatingFlagsOfTypes(typeSet, 6144);
- type = intersectionTypes[id] = createType(131072 | propagatedFlags);
+ type = createType(131072 | propagatedFlags);
+ intersectionTypes.set(id, type);
type.types = typeSet;
type.aliasSymbol = aliasSymbol;
type.aliasTypeArguments = aliasTypeArguments;
@@ -24199,7 +26440,7 @@ var ts;
}
return links.resolvedType;
}
- function getIndexTypeForTypeParameter(type) {
+ function getIndexTypeForGenericType(type) {
if (!type.resolvedIndexType) {
type.resolvedIndexType = createType(262144);
type.resolvedIndexType.type = type;
@@ -24215,7 +26456,7 @@ var ts;
return getUnionType(ts.map(getPropertiesOfType(type), getLiteralTypeFromPropertyName));
}
function getIndexType(type) {
- return type.flags & 16384 ? getIndexTypeForTypeParameter(type) :
+ return maybeTypeOfKind(type, 540672) ? getIndexTypeForGenericType(type) :
getObjectFlags(type) & 32 ? getConstraintTypeFromMappedType(type) :
type.flags & 1 || getIndexInfoOfType(type, 0) ? stringType :
getLiteralTypeFromPropertyNames(type);
@@ -24238,7 +26479,7 @@ var ts;
return type;
}
function getPropertyTypeForIndexType(objectType, indexType, accessNode, cacheSymbol) {
- var accessExpression = accessNode && accessNode.kind === 178 ? accessNode : undefined;
+ var accessExpression = accessNode && accessNode.kind === 179 ? accessNode : undefined;
var propName = indexType.flags & (32 | 64 | 256) ?
indexType.text :
accessExpression && checkThatExpressionIsProperSymbolReference(accessExpression.argumentExpression, indexType, false) ?
@@ -24267,14 +26508,14 @@ var ts;
getIndexInfoOfType(objectType, 0) ||
undefined;
if (indexInfo) {
- if (accessExpression && ts.isAssignmentTarget(accessExpression) && indexInfo.isReadonly) {
+ if (accessExpression && indexInfo.isReadonly && (ts.isAssignmentTarget(accessExpression) || ts.isDeleteTarget(accessExpression))) {
error(accessExpression, ts.Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
return unknownType;
}
return indexInfo.type;
}
if (accessExpression && !isConstEnumObjectType(objectType)) {
- if (compilerOptions.noImplicitAny && !compilerOptions.suppressImplicitAnyIndexErrors) {
+ if (noImplicitAny && !compilerOptions.suppressImplicitAnyIndexErrors) {
if (getIndexTypeOfType(objectType, 1)) {
error(accessExpression.argumentExpression, ts.Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number);
}
@@ -24286,7 +26527,7 @@ var ts;
}
}
if (accessNode) {
- var indexNode = accessNode.kind === 178 ? accessNode.argumentExpression : accessNode.indexType;
+ var indexNode = accessNode.kind === 179 ? accessNode.argumentExpression : accessNode.indexType;
if (indexType.flags & (32 | 64)) {
error(indexNode, ts.Diagnostics.Property_0_does_not_exist_on_type_1, indexType.text, typeToString(objectType));
}
@@ -24296,34 +26537,36 @@ var ts;
else {
error(indexNode, ts.Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
}
+ return unknownType;
}
- return unknownType;
+ return anyType;
}
function getIndexedAccessForMappedType(type, indexType, accessNode) {
- var accessExpression = accessNode && accessNode.kind === 178 ? accessNode : undefined;
+ var accessExpression = accessNode && accessNode.kind === 179 ? accessNode : undefined;
if (accessExpression && ts.isAssignmentTarget(accessExpression) && type.declaration.readonlyToken) {
error(accessExpression, ts.Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(type));
return unknownType;
}
- var mapper = createUnaryTypeMapper(getTypeParameterFromMappedType(type), indexType);
+ var mapper = createTypeMapper([getTypeParameterFromMappedType(type)], [indexType]);
var templateMapper = type.mapper ? combineTypeMappers(type.mapper, mapper) : mapper;
- return addOptionality(instantiateType(getTemplateTypeFromMappedType(type), templateMapper), !!type.declaration.questionToken);
+ return instantiateType(getTemplateTypeFromMappedType(type), templateMapper);
}
function getIndexedAccessType(objectType, indexType, accessNode) {
- if (indexType.flags & 16384 ||
- objectType.flags & 16384 && indexType.flags & 262144 ||
+ if (maybeTypeOfKind(indexType, 540672 | 262144) ||
+ maybeTypeOfKind(objectType, 540672) && !(accessNode && accessNode.kind === 179) ||
isGenericMappedType(objectType)) {
- if (accessNode) {
- if (!isTypeAssignableTo(indexType, getIndexType(objectType))) {
- error(accessNode, ts.Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
- return unknownType;
- }
+ if (objectType.flags & 1) {
+ return objectType;
}
if (isGenericMappedType(objectType)) {
return getIndexedAccessForMappedType(objectType, indexType, accessNode);
}
var id = objectType.id + "," + indexType.id;
- return indexedAccessTypes[id] || (indexedAccessTypes[id] = createIndexedAccessType(objectType, indexType));
+ var type = indexedAccessTypes.get(id);
+ if (!type) {
+ indexedAccessTypes.set(id, type = createIndexedAccessType(objectType, indexType));
+ }
+ return type;
}
var apparentObjectType = getApparentType(objectType);
if (indexType.flags & 65536 && !(indexType.flags & 8190)) {
@@ -24363,7 +26606,7 @@ var ts;
var links = getNodeLinks(node);
if (!links.resolvedType) {
var aliasSymbol = getAliasSymbolForTypeNode(node);
- if (ts.isEmpty(node.symbol.members) && !aliasSymbol) {
+ if (node.symbol.members.size === 0 && !aliasSymbol) {
links.resolvedType = emptyTypeLiteralType;
}
else {
@@ -24376,17 +26619,33 @@ var ts;
return links.resolvedType;
}
function getAliasSymbolForTypeNode(node) {
- return node.parent.kind === 228 ? getSymbolOfNode(node.parent) : undefined;
+ return node.parent.kind === 230 ? getSymbolOfNode(node.parent) : undefined;
}
function getAliasTypeArgumentsForTypeNode(node) {
var symbol = getAliasSymbolForTypeNode(node);
return symbol ? getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol) : undefined;
}
- function getSpreadType(left, right, isFromObjectLiteral) {
- ts.Debug.assert(!!(left.flags & (32768 | 1)) && !!(right.flags & (32768 | 1)), "Only object types may be spread.");
+ function getSpreadType(left, right) {
if (left.flags & 1 || right.flags & 1) {
return anyType;
}
+ left = filterType(left, function (t) { return !(t.flags & 6144); });
+ if (left.flags & 8192) {
+ return right;
+ }
+ right = filterType(right, function (t) { return !(t.flags & 6144); });
+ if (right.flags & 8192) {
+ return left;
+ }
+ if (left.flags & 65536) {
+ return mapType(left, function (t) { return getSpreadType(t, right); });
+ }
+ if (right.flags & 65536) {
+ return mapType(right, function (t) { return getSpreadType(left, t); });
+ }
+ if (right.flags & 16777216) {
+ return emptyObjectType;
+ }
var members = ts.createMap();
var skippedPrivateMembers = ts.createMap();
var stringIndexInfo;
@@ -24401,42 +26660,55 @@ var ts;
}
for (var _i = 0, _a = getPropertiesOfType(right); _i < _a.length; _i++) {
var rightProp = _a[_i];
- var isOwnProperty = !(rightProp.flags & 8192) || isFromObjectLiteral;
var isSetterWithoutGetter = rightProp.flags & 65536 && !(rightProp.flags & 32768);
if (getDeclarationModifierFlagsFromSymbol(rightProp) & (8 | 16)) {
- skippedPrivateMembers[rightProp.name] = true;
+ skippedPrivateMembers.set(rightProp.name, true);
}
- else if (isOwnProperty && !isSetterWithoutGetter) {
- members[rightProp.name] = rightProp;
+ else if (!isClassMethod(rightProp) && !isSetterWithoutGetter) {
+ members.set(rightProp.name, getNonReadonlySymbol(rightProp));
}
}
for (var _b = 0, _c = getPropertiesOfType(left); _b < _c.length; _b++) {
var leftProp = _c[_b];
if (leftProp.flags & 65536 && !(leftProp.flags & 32768)
- || leftProp.name in skippedPrivateMembers) {
+ || skippedPrivateMembers.has(leftProp.name)
+ || isClassMethod(leftProp)) {
continue;
}
- if (leftProp.name in members) {
- var rightProp = members[leftProp.name];
+ if (members.has(leftProp.name)) {
+ var rightProp = members.get(leftProp.name);
var rightType = getTypeOfSymbol(rightProp);
- if (maybeTypeOfKind(rightType, 2048) || rightProp.flags & 536870912) {
+ if (maybeTypeOfKind(rightType, 2048) || rightProp.flags & 67108864) {
var declarations = ts.concatenate(leftProp.declarations, rightProp.declarations);
- var flags = 4 | 67108864 | (leftProp.flags & 536870912);
+ var flags = 4 | (leftProp.flags & 67108864);
var result = createSymbol(flags, leftProp.name);
result.type = getUnionType([getTypeOfSymbol(leftProp), getTypeWithFacts(rightType, 131072)]);
result.leftSpread = leftProp;
result.rightSpread = rightProp;
result.declarations = declarations;
- result.isReadonly = isReadonlySymbol(leftProp) || isReadonlySymbol(rightProp);
- members[leftProp.name] = result;
+ members.set(leftProp.name, result);
}
}
else {
- members[leftProp.name] = leftProp;
+ members.set(leftProp.name, getNonReadonlySymbol(leftProp));
}
}
return createAnonymousType(undefined, members, emptyArray, emptyArray, stringIndexInfo, numberIndexInfo);
}
+ function getNonReadonlySymbol(prop) {
+ if (!isReadonlySymbol(prop)) {
+ return prop;
+ }
+ var flags = 4 | (prop.flags & 67108864);
+ var result = createSymbol(flags, prop.name);
+ result.type = getTypeOfSymbol(prop);
+ result.declarations = prop.declarations;
+ result.syntheticOrigin = prop;
+ return result;
+ }
+ function isClassMethod(prop) {
+ return prop.flags & 8192 && ts.find(prop.declarations, function (decl) { return ts.isClassLike(decl.parent); });
+ }
function createLiteralType(flags, text) {
var type = createType(flags);
type.text = text;
@@ -24458,7 +26730,11 @@ var ts;
}
function getLiteralTypeForText(flags, text) {
var map = flags & 32 ? stringLiteralTypes : numericLiteralTypes;
- return map[text] || (map[text] = createLiteralType(flags, text));
+ var type = map.get(text);
+ if (!type) {
+ map.set(text, type = createLiteralType(flags, text));
+ }
+ return type;
}
function getTypeFromLiteralTypeNode(node) {
var links = getNodeLinks(node);
@@ -24486,9 +26762,9 @@ var ts;
function getThisType(node) {
var container = ts.getThisContainer(node, false);
var parent = container && container.parent;
- if (parent && (ts.isClassLike(parent) || parent.kind === 227)) {
+ if (parent && (ts.isClassLike(parent) || parent.kind === 229)) {
if (!(ts.getModifierFlags(container) & 32) &&
- (container.kind !== 150 || ts.isNodeDescendantOf(node, container.body))) {
+ (container.kind !== 151 || ts.isNodeDescendantOf(node, container.body))) {
return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(parent)).thisType;
}
}
@@ -24505,85 +26781,82 @@ var ts;
function getTypeFromTypeNode(node) {
switch (node.kind) {
case 118:
- case 263:
- case 264:
+ case 267:
+ case 268:
return anyType;
- case 134:
+ case 135:
return stringType;
case 132:
return numberType;
case 121:
return booleanType;
- case 135:
+ case 136:
return esSymbolType;
case 104:
return voidType;
- case 137:
+ case 138:
return undefinedType;
case 94:
return nullType;
case 129:
return neverType;
- case 289:
- return nullType;
- case 290:
- return undefinedType;
- case 291:
- return neverType;
- case 167:
+ case 133:
+ return nonPrimitiveType;
+ case 168:
case 98:
return getTypeFromThisTypeNode(node);
- case 171:
+ case 172:
return getTypeFromLiteralTypeNode(node);
- case 288:
+ case 292:
return getTypeFromLiteralTypeNode(node.literal);
- case 157:
- case 272:
+ case 158:
+ case 276:
return getTypeFromTypeReference(node);
- case 156:
+ case 157:
return booleanType;
- case 199:
+ case 200:
return getTypeFromTypeReference(node);
- case 160:
+ case 161:
return getTypeFromTypeQueryNode(node);
- case 162:
- case 265:
- return getTypeFromArrayTypeNode(node);
case 163:
- return getTypeFromTupleTypeNode(node);
+ case 269:
+ return getTypeFromArrayTypeNode(node);
case 164:
- case 266:
- return getTypeFromUnionTypeNode(node);
+ return getTypeFromTupleTypeNode(node);
case 165:
- return getTypeFromIntersectionTypeNode(node);
+ case 270:
+ return getTypeFromUnionTypeNode(node);
case 166:
- case 268:
- case 269:
- case 276:
- case 277:
+ return getTypeFromIntersectionTypeNode(node);
+ case 272:
+ return getTypeFromJSDocNullableTypeNode(node);
+ case 167:
case 273:
+ case 280:
+ case 281:
+ case 277:
return getTypeFromTypeNode(node.type);
- case 270:
+ case 274:
return getTypeFromTypeNode(node.literal);
- case 158:
case 159:
- case 161:
- case 287:
- case 274:
+ case 160:
+ case 162:
+ case 291:
+ case 278:
return getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node);
- case 168:
- return getTypeFromTypeOperatorNode(node);
case 169:
- return getTypeFromIndexedAccessTypeNode(node);
+ return getTypeFromTypeOperatorNode(node);
case 170:
+ return getTypeFromIndexedAccessTypeNode(node);
+ case 171:
return getTypeFromMappedTypeNode(node);
case 70:
- case 141:
+ case 142:
var symbol = getSymbolAtLocation(node);
return symbol && getDeclaredTypeOfSymbol(symbol);
- case 267:
+ case 271:
return getTypeFromJSDocTupleType(node);
- case 275:
+ case 279:
return getTypeFromJSDocVariadicType(node);
default:
return unknownType;
@@ -24610,13 +26883,13 @@ var ts;
var instantiations = mapper.instantiations || (mapper.instantiations = []);
return instantiations[type.id] || (instantiations[type.id] = instantiator(type, mapper));
}
- function createUnaryTypeMapper(source, target) {
+ function makeUnaryTypeMapper(source, target) {
return function (t) { return t === source ? target : t; };
}
- function createBinaryTypeMapper(source1, target1, source2, target2) {
+ function makeBinaryTypeMapper(source1, target1, source2, target2) {
return function (t) { return t === source1 ? target1 : t === source2 ? target2 : t; };
}
- function createArrayTypeMapper(sources, targets) {
+ function makeArrayTypeMapper(sources, targets) {
return function (t) {
for (var i = 0; i < sources.length; i++) {
if (t === sources[i]) {
@@ -24627,16 +26900,20 @@ var ts;
};
}
function createTypeMapper(sources, targets) {
- var count = sources.length;
- var mapper = count == 1 ? createUnaryTypeMapper(sources[0], targets ? targets[0] : anyType) :
- count == 2 ? createBinaryTypeMapper(sources[0], targets ? targets[0] : anyType, sources[1], targets ? targets[1] : anyType) :
- createArrayTypeMapper(sources, targets);
+ var mapper = sources.length === 1 ? makeUnaryTypeMapper(sources[0], targets ? targets[0] : anyType) :
+ sources.length === 2 ? makeBinaryTypeMapper(sources[0], targets ? targets[0] : anyType, sources[1], targets ? targets[1] : anyType) :
+ makeArrayTypeMapper(sources, targets);
mapper.mappedTypes = sources;
return mapper;
}
function createTypeEraser(sources) {
return createTypeMapper(sources, undefined);
}
+ function createBackreferenceMapper(typeParameters, index) {
+ var mapper = function (t) { return ts.indexOf(typeParameters, t) >= index ? emptyObjectType : t; };
+ mapper.mappedTypes = typeParameters;
+ return mapper;
+ }
function getInferenceMapper(context) {
if (!context.mapper) {
var mapper = function (t) {
@@ -24660,7 +26937,12 @@ var ts;
}
function combineTypeMappers(mapper1, mapper2) {
var mapper = function (t) { return instantiateType(mapper1(t), mapper2); };
- mapper.mappedTypes = mapper1.mappedTypes;
+ mapper.mappedTypes = ts.concatenate(mapper1.mappedTypes, mapper2.mappedTypes);
+ return mapper;
+ }
+ function createReplacementMapper(source, target, baseMapper) {
+ var mapper = function (t) { return t === source ? target : baseMapper(t); };
+ mapper.mappedTypes = baseMapper.mappedTypes;
return mapper;
}
function cloneTypeParameter(typeParameter) {
@@ -24705,12 +26987,13 @@ var ts;
return result;
}
function instantiateSymbol(symbol, mapper) {
- if (symbol.flags & 16777216) {
+ if (getCheckFlags(symbol) & 1) {
var links = getSymbolLinks(symbol);
symbol = links.target;
mapper = combineTypeMappers(links.mapper, mapper);
}
- var result = createSymbol(16777216 | 67108864 | symbol.flags, symbol.name);
+ var result = createSymbol(symbol.flags, symbol.name);
+ result.checkFlags = 1;
result.declarations = symbol.declarations;
result.parent = symbol.parent;
result.target = symbol;
@@ -24731,18 +27014,17 @@ var ts;
function instantiateMappedType(type, mapper) {
var constraintType = getConstraintTypeFromMappedType(type);
if (constraintType.flags & 262144) {
- var typeParameter_1 = constraintType.type;
- var mappedTypeParameter = mapper(typeParameter_1);
- if (typeParameter_1 !== mappedTypeParameter) {
- return mapType(mappedTypeParameter, function (t) {
- if (isMappableType(t)) {
- var replacementMapper = createUnaryTypeMapper(typeParameter_1, t);
- var combinedMapper = mapper.mappedTypes && mapper.mappedTypes.length === 1 ? replacementMapper : combineTypeMappers(replacementMapper, mapper);
- combinedMapper.mappedTypes = mapper.mappedTypes;
- return instantiateMappedObjectType(type, combinedMapper);
- }
- return t;
- });
+ var typeVariable_1 = constraintType.type;
+ if (typeVariable_1.flags & 16384) {
+ var mappedTypeVariable = instantiateType(typeVariable_1, mapper);
+ if (typeVariable_1 !== mappedTypeVariable) {
+ return mapType(mappedTypeVariable, function (t) {
+ if (isMappableType(t)) {
+ return instantiateMappedObjectType(type, createReplacementMapper(typeVariable_1, t, mapper));
+ }
+ return t;
+ });
+ }
}
}
return instantiateMappedObjectType(type, mapper);
@@ -24763,26 +27045,28 @@ var ts;
return false;
}
var mappedTypes = mapper.mappedTypes;
- var node = symbol.declarations[0].parent;
- while (node) {
+ return !!ts.findAncestor(symbol.declarations[0], function (node) {
+ if (node.kind === 232 || node.kind === 264) {
+ return "quit";
+ }
switch (node.kind) {
- case 158:
case 159:
- case 225:
- case 149:
- case 148:
+ case 160:
+ case 227:
case 150:
- case 153:
+ case 149:
+ case 151:
case 154:
case 155:
- case 151:
+ case 156:
case 152:
- case 184:
+ case 153:
case 185:
- case 226:
- case 197:
- case 227:
+ case 186:
case 228:
+ case 198:
+ case 229:
+ case 230:
var declaration = node;
if (declaration.typeParameters) {
for (var _i = 0, _a = declaration.typeParameters; _i < _a.length; _i++) {
@@ -24792,25 +27076,34 @@ var ts;
}
}
}
- if (ts.isClassLike(node) || node.kind === 227) {
+ if (ts.isClassLike(node) || node.kind === 229) {
var thisType = getDeclaredTypeOfClassOrInterface(getSymbolOfNode(node)).thisType;
if (thisType && ts.contains(mappedTypes, thisType)) {
return true;
}
}
break;
- case 230:
- case 261:
- return false;
+ case 171:
+ if (ts.contains(mappedTypes, getDeclaredTypeOfTypeParameter(getSymbolOfNode(node.typeParameter)))) {
+ return true;
+ }
+ break;
+ case 278:
+ var func = node;
+ for (var _b = 0, _c = func.parameters; _b < _c.length; _b++) {
+ var p = _c[_b];
+ if (ts.contains(mappedTypes, getTypeOfNode(p))) {
+ return true;
+ }
+ }
+ break;
}
- node = node.parent;
- }
- return false;
+ });
}
function isTopLevelTypeAlias(symbol) {
if (symbol.declarations && symbol.declarations.length) {
var parentKind = symbol.declarations[0].parent.kind;
- return parentKind === 261 || parentKind === 231;
+ return parentKind === 264 || parentKind === 233;
}
return false;
}
@@ -24862,28 +27155,34 @@ var ts;
return info && createIndexInfo(instantiateType(info.type, mapper), info.isReadonly, info.declaration);
}
function isContextSensitive(node) {
- ts.Debug.assert(node.kind !== 149 || ts.isObjectLiteralMethod(node));
+ ts.Debug.assert(node.kind !== 150 || ts.isObjectLiteralMethod(node));
switch (node.kind) {
- case 184:
case 185:
+ case 186:
return isContextSensitiveFunctionLikeDeclaration(node);
- case 176:
+ case 177:
return ts.forEach(node.properties, isContextSensitive);
- case 175:
+ case 176:
return ts.forEach(node.elements, isContextSensitive);
- case 193:
+ case 194:
return isContextSensitive(node.whenTrue) ||
isContextSensitive(node.whenFalse);
- case 192:
+ case 193:
return node.operatorToken.kind === 53 &&
(isContextSensitive(node.left) || isContextSensitive(node.right));
- case 257:
+ case 260:
return isContextSensitive(node.initializer);
+ case 150:
case 149:
- case 148:
return isContextSensitiveFunctionLikeDeclaration(node);
- case 183:
+ case 184:
return isContextSensitive(node.expression);
+ case 253:
+ return ts.forEach(node.properties, isContextSensitive);
+ case 252:
+ return node.initializer && isContextSensitive(node.initializer);
+ case 255:
+ return node.expression && isContextSensitive(node.expression);
}
return false;
}
@@ -24894,7 +27193,7 @@ var ts;
if (ts.forEach(node.parameters, function (p) { return !p.type; })) {
return true;
}
- if (node.kind === 185) {
+ if (node.kind === 186) {
return false;
}
var parameter = ts.firstOrUndefined(node.parameters);
@@ -24912,9 +27211,12 @@ var ts;
result.properties = resolved.properties;
result.callSignatures = emptyArray;
result.constructSignatures = emptyArray;
- type = result;
+ return result;
}
}
+ else if (type.flags & 131072) {
+ return getIntersectionType(ts.map(type.types, getTypeWithoutSignatures));
+ }
return type;
}
function isTypeIdenticalTo(source, target) {
@@ -24933,7 +27235,7 @@ var ts;
return isTypeRelatedTo(source, target, assignableRelation);
}
function isTypeInstanceOf(source, target) {
- return source === target || isTypeSubtypeOf(source, target) && !isTypeIdenticalTo(source, target);
+ return getTargetType(source) === getTargetType(target) || isTypeSubtypeOf(source, target) && !isTypeIdenticalTo(source, target);
}
function isTypeComparableTo(source, target) {
return isTypeRelatedTo(source, target, comparableRelation);
@@ -24951,9 +27253,9 @@ var ts;
return checkTypeRelatedTo(source, target, comparableRelation, errorNode, headMessage, containingMessageChain);
}
function isSignatureAssignableTo(source, target, ignoreReturnTypes) {
- return compareSignaturesRelated(source, target, ignoreReturnTypes, false, undefined, compareTypesAssignable) !== 0;
+ return compareSignaturesRelated(source, target, false, ignoreReturnTypes, false, undefined, compareTypesAssignable) !== 0;
}
- function compareSignaturesRelated(source, target, ignoreReturnTypes, reportErrors, errorReporter, compareTypes) {
+ function compareSignaturesRelated(source, target, checkAsCallback, ignoreReturnTypes, reportErrors, errorReporter, compareTypes) {
if (source === target) {
return -1;
}
@@ -24984,9 +27286,15 @@ var ts;
var sourceParams = source.parameters;
var targetParams = target.parameters;
for (var i = 0; i < checkCount; i++) {
- var s = i < sourceMax ? getTypeOfParameter(sourceParams[i]) : getRestTypeOfSignature(source);
- var t = i < targetMax ? getTypeOfParameter(targetParams[i]) : getRestTypeOfSignature(target);
- var related = compareTypes(s, t, false) || compareTypes(t, s, reportErrors);
+ var sourceType = i < sourceMax ? getTypeOfParameter(sourceParams[i]) : getRestTypeOfSignature(source);
+ var targetType = i < targetMax ? getTypeOfParameter(targetParams[i]) : getRestTypeOfSignature(target);
+ var sourceSig = getSingleCallSignature(getNonNullableType(sourceType));
+ var targetSig = getSingleCallSignature(getNonNullableType(targetType));
+ var callbacks = sourceSig && targetSig && !sourceSig.typePredicate && !targetSig.typePredicate &&
+ (getFalsyFlags(sourceType) & 6144) === (getFalsyFlags(targetType) & 6144);
+ var related = callbacks ?
+ compareSignaturesRelated(targetSig, sourceSig, true, false, reportErrors, errorReporter, compareTypes) :
+ !checkAsCallback && compareTypes(sourceType, targetType, false) || compareTypes(targetType, sourceType, reportErrors);
if (!related) {
if (reportErrors) {
errorReporter(ts.Diagnostics.Types_of_parameters_0_and_1_are_incompatible, sourceParams[i < sourceMax ? i : sourceMax].name, targetParams[i < targetMax ? i : targetMax].name);
@@ -25013,7 +27321,8 @@ var ts;
}
}
else {
- result &= compareTypes(sourceReturnType, targetReturnType, reportErrors);
+ result &= checkAsCallback && compareTypes(targetReturnType, sourceReturnType, false) ||
+ compareTypes(sourceReturnType, targetReturnType, reportErrors);
}
}
return result;
@@ -25076,18 +27385,33 @@ var ts;
sourceNonRestParamCount;
}
}
+ function isEmptyResolvedType(t) {
+ return t.properties.length === 0 &&
+ t.callSignatures.length === 0 &&
+ t.constructSignatures.length === 0 &&
+ !t.stringIndexInfo &&
+ !t.numberIndexInfo;
+ }
+ function isEmptyObjectType(type) {
+ return type.flags & 32768 ? isEmptyResolvedType(resolveStructuredTypeMembers(type)) :
+ type.flags & 65536 ? ts.forEach(type.types, isEmptyObjectType) :
+ type.flags & 131072 ? !ts.forEach(type.types, function (t) { return !isEmptyObjectType(t); }) :
+ false;
+ }
function isEnumTypeRelatedTo(source, target, errorReporter) {
if (source === target) {
return true;
}
var id = source.id + "," + target.id;
- if (enumRelation[id] !== undefined) {
- return enumRelation[id];
+ var relation = enumRelation.get(id);
+ if (relation !== undefined) {
+ return relation;
}
if (source.symbol.name !== target.symbol.name ||
!(source.symbol.flags & 256) || !(target.symbol.flags & 256) ||
(source.flags & 65536) !== (target.flags & 65536)) {
- return enumRelation[id] = false;
+ enumRelation.set(id, false);
+ return false;
}
var targetEnumType = getTypeOfSymbol(target.symbol);
for (var _i = 0, _a = getPropertiesOfType(getTypeOfSymbol(source.symbol)); _i < _a.length; _i++) {
@@ -25098,11 +27422,13 @@ var ts;
if (errorReporter) {
errorReporter(ts.Diagnostics.Property_0_is_missing_in_type_1, property.name, typeToString(target, undefined, 128));
}
- return enumRelation[id] = false;
+ enumRelation.set(id, false);
+ return false;
}
}
}
- return enumRelation[id] = true;
+ enumRelation.set(id, true);
+ return true;
}
function isSimpleTypeRelatedTo(source, target, relation, errorReporter) {
if (target.flags & 8192)
@@ -25123,6 +27449,8 @@ var ts;
return true;
if (source.flags & 4096 && (!strictNullChecks || target.flags & 4096))
return true;
+ if (source.flags & 32768 && target.flags & 16777216)
+ return true;
if (relation === assignableRelation || relation === comparableRelation) {
if (source.flags & 1)
return true;
@@ -25154,13 +27482,13 @@ var ts;
}
if (source.flags & 32768 && target.flags & 32768) {
var id = relation !== identityRelation || source.id < target.id ? source.id + "," + target.id : target.id + "," + source.id;
- var related = relation[id];
+ var related = relation.get(id);
if (related !== undefined) {
return related === 1;
}
}
- if (source.flags & 507904 || target.flags & 507904) {
- return checkTypeRelatedTo(source, target, relation, undefined, undefined, undefined);
+ if (source.flags & 1032192 || target.flags & 1032192) {
+ return checkTypeRelatedTo(source, target, relation, undefined);
}
return false;
}
@@ -25214,10 +27542,27 @@ var ts;
if ((globalStringType === source && stringType === target) ||
(globalNumberType === source && numberType === target) ||
(globalBooleanType === source && booleanType === target) ||
- (getGlobalESSymbolType() === source && esSymbolType === target)) {
+ (getGlobalESSymbolType(false) === source && esSymbolType === target)) {
reportError(ts.Diagnostics._0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible, targetType, sourceType);
}
}
+ function isUnionOrIntersectionTypeWithoutNullableConstituents(type) {
+ if (!(type.flags & 196608)) {
+ return false;
+ }
+ var seenNonNullable = false;
+ for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
+ var t = _a[_i];
+ if (t.flags & 6144) {
+ continue;
+ }
+ if (seenNonNullable) {
+ return true;
+ }
+ seenNonNullable = true;
+ }
+ return false;
+ }
function isRelatedTo(source, target, reportErrors, headMessage) {
var result;
if (source.flags & 96 && source.flags & 1048576) {
@@ -25240,7 +27585,7 @@ var ts;
}
return 0;
}
- if (target.flags & 196608) {
+ if (isUnionOrIntersectionTypeWithoutNullableConstituents(target)) {
source = getRegularTypeOfObjectLiteral(source);
}
}
@@ -25256,91 +27601,24 @@ var ts;
return result;
}
}
- else if (target.flags & 65536) {
- if (result = typeRelatedToSomeType(source, target, reportErrors && !(source.flags & 8190) && !(target.flags & 8190))) {
- return result;
- }
- }
- else if (target.flags & 131072) {
- if (result = typeRelatedToEachType(source, target, reportErrors)) {
- return result;
- }
- }
- else if (source.flags & 131072) {
- if (result = someTypeRelatedToType(source, target, false)) {
- return result;
- }
- }
- if (target.flags & 16384) {
- if (getObjectFlags(source) & 32 && getConstraintTypeFromMappedType(source) === getIndexType(target)) {
- if (!source.declaration.questionToken) {
- var templateType = getTemplateTypeFromMappedType(source);
- var indexedAccessType = getIndexedAccessType(target, getTypeParameterFromMappedType(source));
- if (result = isRelatedTo(templateType, indexedAccessType, reportErrors)) {
- return result;
- }
- }
- }
- else {
- var constraint = getConstraintOfTypeParameter(target);
- if (constraint && constraint.flags & 262144) {
- if (result = isRelatedTo(source, constraint, reportErrors)) {
- return result;
- }
- }
- }
- }
- else if (target.flags & 262144) {
- if (source.flags & 262144) {
- if (result = isRelatedTo(target.type, source.type, false)) {
- return result;
- }
- }
- var constraint = getConstraintOfTypeParameter(target.type);
- if (constraint) {
- if (result = isRelatedTo(source, getIndexType(constraint), reportErrors)) {
- return result;
- }
- }
- }
- else if (target.flags & 524288) {
- if (source.flags & 524288 && source.indexType === target.indexType) {
- if (result = isRelatedTo(source.objectType, target.objectType, reportErrors)) {
- return result;
- }
- }
- }
- if (source.flags & 16384) {
- if (getObjectFlags(target) & 32 && getConstraintTypeFromMappedType(target) === getIndexType(source)) {
- var indexedAccessType = getIndexedAccessType(source, getTypeParameterFromMappedType(target));
- var templateType = getTemplateTypeFromMappedType(target);
- if (result = isRelatedTo(indexedAccessType, templateType, reportErrors)) {
+ else {
+ if (target.flags & 65536) {
+ if (result = typeRelatedToSomeType(source, target, reportErrors && !(source.flags & 8190) && !(target.flags & 8190))) {
return result;
}
}
- else {
- var constraint = getConstraintOfTypeParameter(source);
- if (!constraint || constraint.flags & 1) {
- constraint = emptyObjectType;
- }
- constraint = getTypeWithThisArgument(constraint, source);
- var reportConstraintErrors = reportErrors && constraint !== emptyObjectType;
- if (result = isRelatedTo(constraint, target, reportConstraintErrors)) {
- errorInfo = saveErrorInfo;
+ else if (target.flags & 131072) {
+ if (result = typeRelatedToEachType(source, target, reportErrors)) {
return result;
}
}
- }
- else {
- if (getObjectFlags(source) & 4 && getObjectFlags(target) & 4 && source.target === target.target) {
- if (result = typeArgumentsRelatedTo(source, target, reportErrors)) {
+ else if (source.flags & 131072) {
+ if (result = someTypeRelatedToType(source, target, false)) {
return result;
}
}
- var apparentSource = getApparentType(source);
- if (apparentSource.flags & (32768 | 131072) && target.flags & 32768) {
- var reportStructuralErrors = reportErrors && errorInfo === saveErrorInfo && !(source.flags & 8190);
- if (result = objectTypeRelatedTo(apparentSource, source, target, reportStructuralErrors)) {
+ if (source.flags & 1032192 || target.flags & 1032192) {
+ if (result = recursiveTypeRelatedTo(source, target, reportErrors)) {
errorInfo = saveErrorInfo;
return result;
}
@@ -25360,12 +27638,7 @@ var ts;
function isIdenticalTo(source, target) {
var result;
if (source.flags & 32768 && target.flags & 32768) {
- if (getObjectFlags(source) & 4 && getObjectFlags(target) & 4 && source.target === target.target) {
- if (result = typeArgumentsRelatedTo(source, target, false)) {
- return result;
- }
- }
- return objectTypeRelatedTo(source, source, target, false);
+ return recursiveTypeRelatedTo(source, target, false);
}
if (source.flags & 65536 && target.flags & 65536 ||
source.flags & 131072 && target.flags & 131072) {
@@ -25377,42 +27650,43 @@ var ts;
}
return 0;
}
- function isKnownProperty(type, name) {
+ function isKnownProperty(type, name, isComparingJsxAttributes) {
if (type.flags & 32768) {
var resolved = resolveStructuredTypeMembers(type);
- if ((relation === assignableRelation || relation === comparableRelation) && (type === globalObjectType || isEmptyObjectType(resolved)) ||
- resolved.stringIndexInfo ||
- (resolved.numberIndexInfo && isNumericLiteralName(name)) ||
- getPropertyOfType(type, name)) {
+ if (resolved.stringIndexInfo || resolved.numberIndexInfo && isNumericLiteralName(name) ||
+ getPropertyOfType(type, name) || isComparingJsxAttributes && !isUnhyphenatedJsxName(name)) {
return true;
}
}
else if (type.flags & 196608) {
for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
var t = _a[_i];
- if (isKnownProperty(t, name)) {
+ if (isKnownProperty(t, name, isComparingJsxAttributes)) {
return true;
}
}
}
return false;
}
- function isEmptyObjectType(t) {
- return t.properties.length === 0 &&
- t.callSignatures.length === 0 &&
- t.constructSignatures.length === 0 &&
- !t.stringIndexInfo &&
- !t.numberIndexInfo;
- }
function hasExcessProperties(source, target, reportErrors) {
if (maybeTypeOfKind(target, 32768) && !(getObjectFlags(target) & 512)) {
+ var isComparingJsxAttributes = !!(source.flags & 33554432);
+ if ((relation === assignableRelation || relation === comparableRelation) &&
+ (isTypeSubsetOf(globalObjectType, target) || (!isComparingJsxAttributes && isEmptyObjectType(target)))) {
+ return false;
+ }
for (var _i = 0, _a = getPropertiesOfObjectType(source); _i < _a.length; _i++) {
var prop = _a[_i];
- if (!isKnownProperty(target, prop.name)) {
+ if (!isKnownProperty(target, prop.name, isComparingJsxAttributes)) {
if (reportErrors) {
ts.Debug.assert(!!errorNode);
- errorNode = prop.valueDeclaration;
- reportError(ts.Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(prop), typeToString(target));
+ if (ts.isJsxAttributes(errorNode)) {
+ reportError(ts.Diagnostics.Property_0_does_not_exist_on_type_1, symbolToString(prop), typeToString(target));
+ }
+ else {
+ errorNode = prop.valueDeclaration;
+ reportError(ts.Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(prop), typeToString(target));
+ }
}
return true;
}
@@ -25438,20 +27712,42 @@ var ts;
if (target.flags & 65536 && containsType(targetTypes, source)) {
return -1;
}
- var len = targetTypes.length;
- for (var i = 0; i < len; i++) {
- var related = isRelatedTo(source, targetTypes[i], reportErrors && i === len - 1);
+ for (var _i = 0, targetTypes_1 = targetTypes; _i < targetTypes_1.length; _i++) {
+ var type = targetTypes_1[_i];
+ var related = isRelatedTo(source, type, false);
if (related) {
return related;
}
}
+ if (reportErrors) {
+ var discriminantType = findMatchingDiscriminantType(source, target);
+ isRelatedTo(source, discriminantType || targetTypes[targetTypes.length - 1], true);
+ }
return 0;
}
+ function findMatchingDiscriminantType(source, target) {
+ var sourceProperties = getPropertiesOfObjectType(source);
+ if (sourceProperties) {
+ for (var _i = 0, sourceProperties_1 = sourceProperties; _i < sourceProperties_1.length; _i++) {
+ var sourceProperty = sourceProperties_1[_i];
+ if (isDiscriminantProperty(target, sourceProperty.name)) {
+ var sourceType = getTypeOfSymbol(sourceProperty);
+ for (var _a = 0, _b = target.types; _a < _b.length; _a++) {
+ var type = _b[_a];
+ var targetType = getTypeOfPropertyOfType(type, sourceProperty.name);
+ if (targetType && isRelatedTo(sourceType, targetType)) {
+ return type;
+ }
+ }
+ }
+ }
+ }
+ }
function typeRelatedToEachType(source, target, reportErrors) {
var result = -1;
var targetTypes = target.types;
- for (var _i = 0, targetTypes_1 = targetTypes; _i < targetTypes_1.length; _i++) {
- var targetType = targetTypes_1[_i];
+ for (var _i = 0, targetTypes_2 = targetTypes; _i < targetTypes_2.length; _i++) {
+ var targetType = targetTypes_2[_i];
var related = isRelatedTo(source, targetType, reportErrors);
if (!related) {
return 0;
@@ -25504,15 +27800,15 @@ var ts;
}
return result;
}
- function objectTypeRelatedTo(source, originalSource, target, reportErrors) {
+ function recursiveTypeRelatedTo(source, target, reportErrors) {
if (overflow) {
return 0;
}
var id = relation !== identityRelation || source.id < target.id ? source.id + "," + target.id : target.id + "," + source.id;
- var related = relation[id];
+ var related = relation.get(id);
if (related !== undefined) {
if (reportErrors && related === 2) {
- relation[id] = 3;
+ relation.set(id, 3);
}
else {
return related === 1 ? -1 : 0;
@@ -25520,7 +27816,7 @@ var ts;
}
if (depth > 0) {
for (var i = 0; i < depth; i++) {
- if (maybeStack[i][id]) {
+ if (maybeStack[i].get(id)) {
return 1;
}
}
@@ -25538,71 +27834,165 @@ var ts;
sourceStack[depth] = source;
targetStack[depth] = target;
maybeStack[depth] = ts.createMap();
- maybeStack[depth][id] = 1;
+ maybeStack[depth].set(id, 1);
depth++;
var saveExpandingFlags = expandingFlags;
- if (!(expandingFlags & 1) && isDeeplyNestedGeneric(source, sourceStack, depth))
+ if (!(expandingFlags & 1) && isDeeplyNestedType(source, sourceStack, depth))
expandingFlags |= 1;
- if (!(expandingFlags & 2) && isDeeplyNestedGeneric(target, targetStack, depth))
+ if (!(expandingFlags & 2) && isDeeplyNestedType(target, targetStack, depth))
expandingFlags |= 2;
+ var result = expandingFlags !== 3 ? structuredTypeRelatedTo(source, target, reportErrors) : 1;
+ expandingFlags = saveExpandingFlags;
+ depth--;
+ if (result) {
+ var maybeCache = maybeStack[depth];
+ var destinationCache = (result === -1 || depth === 0) ? relation : maybeStack[depth - 1];
+ ts.copyEntries(maybeCache, destinationCache);
+ }
+ else {
+ relation.set(id, reportErrors ? 3 : 2);
+ }
+ return result;
+ }
+ function structuredTypeRelatedTo(source, target, reportErrors) {
var result;
- if (expandingFlags === 3) {
- result = 1;
+ var saveErrorInfo = errorInfo;
+ if (target.flags & 16384) {
+ if (getObjectFlags(source) & 32 && getConstraintTypeFromMappedType(source) === getIndexType(target)) {
+ if (!source.declaration.questionToken) {
+ var templateType = getTemplateTypeFromMappedType(source);
+ var indexedAccessType = getIndexedAccessType(target, getTypeParameterFromMappedType(source));
+ if (result = isRelatedTo(templateType, indexedAccessType, reportErrors)) {
+ return result;
+ }
+ }
+ }
}
- else if (isGenericMappedType(source) || isGenericMappedType(target)) {
- result = mappedTypeRelatedTo(source, target, reportErrors);
+ else if (target.flags & 262144) {
+ if (source.flags & 262144) {
+ if (result = isRelatedTo(target.type, source.type, false)) {
+ return result;
+ }
+ }
+ var constraint = getConstraintOfType(target.type);
+ if (constraint) {
+ if (result = isRelatedTo(source, getIndexType(constraint), reportErrors)) {
+ return result;
+ }
+ }
+ }
+ else if (target.flags & 524288) {
+ var constraint = getConstraintOfType(target);
+ if (constraint) {
+ if (result = isRelatedTo(source, constraint, reportErrors)) {
+ errorInfo = saveErrorInfo;
+ return result;
+ }
+ }
+ }
+ if (source.flags & 16384) {
+ if (getObjectFlags(target) & 32 && getConstraintTypeFromMappedType(target) === getIndexType(source)) {
+ var indexedAccessType = getIndexedAccessType(source, getTypeParameterFromMappedType(target));
+ var templateType = getTemplateTypeFromMappedType(target);
+ if (result = isRelatedTo(indexedAccessType, templateType, reportErrors)) {
+ errorInfo = saveErrorInfo;
+ return result;
+ }
+ }
+ else {
+ var constraint = getConstraintOfTypeParameter(source);
+ if (constraint || !(target.flags & 16777216)) {
+ if (!constraint || constraint.flags & 1) {
+ constraint = emptyObjectType;
+ }
+ constraint = getTypeWithThisArgument(constraint, source);
+ var reportConstraintErrors = reportErrors && constraint !== emptyObjectType;
+ if (result = isRelatedTo(constraint, target, reportConstraintErrors)) {
+ errorInfo = saveErrorInfo;
+ return result;
+ }
+ }
+ }
+ }
+ else if (source.flags & 524288) {
+ var constraint = getConstraintOfType(source);
+ if (constraint) {
+ if (result = isRelatedTo(constraint, target, reportErrors)) {
+ errorInfo = saveErrorInfo;
+ return result;
+ }
+ }
+ else if (target.flags & 524288 && source.indexType === target.indexType) {
+ if (result = isRelatedTo(source.objectType, target.objectType, reportErrors)) {
+ return result;
+ }
+ }
}
else {
- result = propertiesRelatedTo(source, target, reportErrors);
- if (result) {
- result &= signaturesRelatedTo(source, target, 0, reportErrors);
- if (result) {
- result &= signaturesRelatedTo(source, target, 1, reportErrors);
+ if (getObjectFlags(source) & 4 && getObjectFlags(target) & 4 && source.target === target.target) {
+ if (result = typeArgumentsRelatedTo(source, target, reportErrors)) {
+ return result;
+ }
+ }
+ var sourceIsPrimitive = !!(source.flags & 8190);
+ if (relation !== identityRelation) {
+ source = getApparentType(source);
+ }
+ if (source.flags & (32768 | 131072) && target.flags & 32768) {
+ var reportStructuralErrors = reportErrors && errorInfo === saveErrorInfo && !sourceIsPrimitive;
+ if (isGenericMappedType(source) || isGenericMappedType(target)) {
+ result = mappedTypeRelatedTo(source, target, reportStructuralErrors);
+ }
+ else {
+ result = propertiesRelatedTo(source, target, reportStructuralErrors);
if (result) {
- result &= indexTypesRelatedTo(source, originalSource, target, 0, reportErrors);
+ result &= signaturesRelatedTo(source, target, 0, reportStructuralErrors);
if (result) {
- result &= indexTypesRelatedTo(source, originalSource, target, 1, reportErrors);
+ result &= signaturesRelatedTo(source, target, 1, reportStructuralErrors);
+ if (result) {
+ result &= indexTypesRelatedTo(source, target, 0, sourceIsPrimitive, reportStructuralErrors);
+ if (result) {
+ result &= indexTypesRelatedTo(source, target, 1, sourceIsPrimitive, reportStructuralErrors);
+ }
+ }
}
}
}
+ if (result) {
+ errorInfo = saveErrorInfo;
+ return result;
+ }
}
}
- expandingFlags = saveExpandingFlags;
- depth--;
- if (result) {
- var maybeCache = maybeStack[depth];
- var destinationCache = (result === -1 || depth === 0) ? relation : maybeStack[depth - 1];
- ts.copyProperties(maybeCache, destinationCache);
- }
- else {
- relation[id] = reportErrors ? 3 : 2;
- }
- return result;
+ return 0;
}
function mappedTypeRelatedTo(source, target, reportErrors) {
if (isGenericMappedType(target)) {
if (isGenericMappedType(source)) {
- var result_2;
- if (relation === identityRelation) {
- var readonlyMatches = !source.declaration.readonlyToken === !target.declaration.readonlyToken;
- var optionalMatches = !source.declaration.questionToken === !target.declaration.questionToken;
- if (readonlyMatches && optionalMatches) {
- if (result_2 = isRelatedTo(getConstraintTypeFromMappedType(target), getConstraintTypeFromMappedType(source), reportErrors)) {
- return result_2 & isRelatedTo(getErasedTemplateTypeFromMappedType(source), getErasedTemplateTypeFromMappedType(target), reportErrors);
- }
- }
- }
- else {
- if (relation === comparableRelation || !source.declaration.questionToken || target.declaration.questionToken) {
- if (result_2 = isRelatedTo(getConstraintTypeFromMappedType(target), getConstraintTypeFromMappedType(source), reportErrors)) {
- return result_2 & isRelatedTo(getTemplateTypeFromMappedType(source), getTemplateTypeFromMappedType(target), reportErrors);
- }
+ var sourceReadonly = !!source.declaration.readonlyToken;
+ var sourceOptional = !!source.declaration.questionToken;
+ var targetReadonly = !!target.declaration.readonlyToken;
+ var targetOptional = !!target.declaration.questionToken;
+ var modifiersRelated = relation === identityRelation ?
+ sourceReadonly === targetReadonly && sourceOptional === targetOptional :
+ relation === comparableRelation || !sourceOptional || targetOptional;
+ if (modifiersRelated) {
+ var result_2;
+ if (result_2 = isRelatedTo(getConstraintTypeFromMappedType(target), getConstraintTypeFromMappedType(source), reportErrors)) {
+ var mapper = createTypeMapper([getTypeParameterFromMappedType(source)], [getTypeParameterFromMappedType(target)]);
+ return result_2 & isRelatedTo(instantiateType(getTemplateTypeFromMappedType(source), mapper), getTemplateTypeFromMappedType(target), reportErrors);
}
}
}
+ else if (target.declaration.questionToken && isEmptyObjectType(source)) {
+ return -1;
+ }
}
- else if (relation !== identityRelation && isEmptyObjectType(resolveStructuredTypeMembers(target))) {
- return -1;
+ else if (relation !== identityRelation) {
+ var resolved = resolveStructuredTypeMembers(target);
+ if (isEmptyResolvedType(resolved) || resolved.stringIndexInfo && resolved.stringIndexInfo.type.flags & 1) {
+ return -1;
+ }
}
return 0;
}
@@ -25613,22 +28003,28 @@ var ts;
var result = -1;
var properties = getPropertiesOfObjectType(target);
var requireOptionalProperties = relation === subtypeRelation && !(getObjectFlags(source) & 128);
- for (var _i = 0, properties_3 = properties; _i < properties_3.length; _i++) {
- var targetProp = properties_3[_i];
+ for (var _i = 0, properties_4 = properties; _i < properties_4.length; _i++) {
+ var targetProp = properties_4[_i];
var sourceProp = getPropertyOfType(source, targetProp.name);
if (sourceProp !== targetProp) {
if (!sourceProp) {
- if (!(targetProp.flags & 536870912) || requireOptionalProperties) {
+ if (!(targetProp.flags & 67108864) || requireOptionalProperties) {
if (reportErrors) {
reportError(ts.Diagnostics.Property_0_is_missing_in_type_1, symbolToString(targetProp), typeToString(source));
}
return 0;
}
}
- else if (!(targetProp.flags & 134217728)) {
+ else if (!(targetProp.flags & 16777216)) {
var sourcePropFlags = getDeclarationModifierFlagsFromSymbol(sourceProp);
var targetPropFlags = getDeclarationModifierFlagsFromSymbol(targetProp);
if (sourcePropFlags & 8 || targetPropFlags & 8) {
+ if (getCheckFlags(sourceProp) & 256) {
+ if (reportErrors) {
+ reportError(ts.Diagnostics.Property_0_has_conflicting_declarations_and_is_inaccessible_in_type_1, symbolToString(sourceProp), typeToString(source));
+ }
+ return 0;
+ }
if (sourceProp.valueDeclaration !== targetProp.valueDeclaration) {
if (reportErrors) {
if (sourcePropFlags & 8 && targetPropFlags & 8) {
@@ -25642,12 +28038,9 @@ var ts;
}
}
else if (targetPropFlags & 16) {
- var sourceDeclaredInClass = sourceProp.parent && sourceProp.parent.flags & 32;
- var sourceClass = sourceDeclaredInClass ? getDeclaredTypeOfSymbol(getParentOfSymbol(sourceProp)) : undefined;
- var targetClass = getDeclaredTypeOfSymbol(getParentOfSymbol(targetProp));
- if (!sourceClass || !hasBaseType(sourceClass, targetClass)) {
+ if (!isValidOverrideOf(sourceProp, targetProp)) {
if (reportErrors) {
- reportError(ts.Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2, symbolToString(targetProp), typeToString(sourceClass || source), typeToString(targetClass));
+ reportError(ts.Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2, symbolToString(targetProp), typeToString(getDeclaringClass(sourceProp) || source), typeToString(getDeclaringClass(targetProp) || target));
}
return 0;
}
@@ -25666,7 +28059,7 @@ var ts;
return 0;
}
result &= related;
- if (relation !== comparableRelation && sourceProp.flags & 536870912 && !(targetProp.flags & 536870912)) {
+ if (relation !== comparableRelation && sourceProp.flags & 67108864 && !(targetProp.flags & 67108864)) {
if (reportErrors) {
reportError(ts.Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2, symbolToString(targetProp), typeToString(source), typeToString(target));
}
@@ -25687,8 +28080,8 @@ var ts;
return 0;
}
var result = -1;
- for (var _i = 0, sourceProperties_1 = sourceProperties; _i < sourceProperties_1.length; _i++) {
- var sourceProp = sourceProperties_1[_i];
+ for (var _i = 0, sourceProperties_2 = sourceProperties; _i < sourceProperties_2.length; _i++) {
+ var sourceProp = sourceProperties_2[_i];
var targetProp = getPropertyOfObjectType(target, sourceProp.name);
if (!targetProp) {
return 0;
@@ -25744,7 +28137,7 @@ var ts;
return result;
}
function signatureRelatedTo(source, target, reportErrors) {
- return compareSignaturesRelated(source, target, false, reportErrors, reportError, isRelatedTo);
+ return compareSignaturesRelated(source, target, false, false, reportErrors, reportError, isRelatedTo);
}
function signaturesIdenticalTo(source, target, kind) {
var sourceSignatures = getSignaturesOfType(source, kind);
@@ -25753,7 +28146,7 @@ var ts;
return 0;
}
var result = -1;
- for (var i = 0, len = sourceSignatures.length; i < len; i++) {
+ for (var i = 0; i < sourceSignatures.length; i++) {
var related = compareSignaturesIdentical(sourceSignatures[i], targetSignatures[i], false, false, false, isRelatedTo);
if (!related) {
return 0;
@@ -25786,12 +28179,12 @@ var ts;
}
return related;
}
- function indexTypesRelatedTo(source, originalSource, target, kind, reportErrors) {
+ function indexTypesRelatedTo(source, target, kind, sourceIsPrimitive, reportErrors) {
if (relation === identityRelation) {
return indexTypesIdenticalTo(source, target, kind);
}
var targetInfo = getIndexInfoOfType(target, kind);
- if (!targetInfo || ((targetInfo.type.flags & 1) && !(originalSource.flags & 8190))) {
+ if (!targetInfo || targetInfo.type.flags & 1 && !sourceIsPrimitive) {
return -1;
}
var sourceInfo = getIndexInfoOfType(source, kind) ||
@@ -25849,6 +28242,37 @@ var ts;
return false;
}
}
+ function forEachProperty(prop, callback) {
+ if (getCheckFlags(prop) & 6) {
+ for (var _i = 0, _a = prop.containingType.types; _i < _a.length; _i++) {
+ var t = _a[_i];
+ var p = getPropertyOfType(t, prop.name);
+ var result = p && forEachProperty(p, callback);
+ if (result) {
+ return result;
+ }
+ }
+ return undefined;
+ }
+ return callback(prop);
+ }
+ function getDeclaringClass(prop) {
+ return prop.parent && prop.parent.flags & 32 ? getDeclaredTypeOfSymbol(getParentOfSymbol(prop)) : undefined;
+ }
+ function isPropertyInClassDerivedFrom(prop, baseClass) {
+ return forEachProperty(prop, function (sp) {
+ var sourceClass = getDeclaringClass(sp);
+ return sourceClass ? hasBaseType(sourceClass, baseClass) : false;
+ });
+ }
+ function isValidOverrideOf(sourceProp, targetProp) {
+ return !forEachProperty(targetProp, function (tp) { return getDeclarationModifierFlagsFromSymbol(tp) & 16 ?
+ !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false; });
+ }
+ function isClassDerivedFromDeclaringClasses(checkClass, prop) {
+ return forEachProperty(prop, function (p) { return getDeclarationModifierFlagsFromSymbol(p) & 16 ?
+ !hasBaseType(checkClass, getDeclaringClass(p)) : false; }) ? undefined : checkClass;
+ }
function isAbstractConstructorType(type) {
if (getObjectFlags(type) & 16) {
var symbol = type.symbol;
@@ -25861,16 +28285,18 @@ var ts;
}
return false;
}
- function isDeeplyNestedGeneric(type, stack, depth) {
- if (getObjectFlags(type) & (4 | 64) && depth >= 5) {
+ function isDeeplyNestedType(type, stack, depth) {
+ if (depth >= 5 && type.flags & 32768) {
var symbol = type.symbol;
- var count = 0;
- for (var i = 0; i < depth; i++) {
- var t = stack[i];
- if (getObjectFlags(t) & (4 | 64) && t.symbol === symbol) {
- count++;
- if (count >= 5)
- return true;
+ if (symbol) {
+ var count = 0;
+ for (var i = 0; i < depth; i++) {
+ var t = stack[i];
+ if (t.flags & 32768 && t.symbol === symbol) {
+ count++;
+ if (count >= 5)
+ return true;
+ }
}
}
}
@@ -25894,7 +28320,7 @@ var ts;
}
}
else {
- if ((sourceProp.flags & 536870912) !== (targetProp.flags & 536870912)) {
+ if ((sourceProp.flags & 67108864) !== (targetProp.flags & 67108864)) {
return 0;
}
}
@@ -25924,7 +28350,7 @@ var ts;
if (!(isMatchingSignature(source, target, partialMatch))) {
return 0;
}
- if ((source.typeParameters ? source.typeParameters.length : 0) !== (target.typeParameters ? target.typeParameters.length : 0)) {
+ if (ts.length(source.typeParameters) !== ts.length(target.typeParameters)) {
return 0;
}
source = getErasedSignature(source);
@@ -25962,8 +28388,8 @@ var ts;
return signature.hasRestParameter && parameterIndex >= signature.parameters.length - 1;
}
function isSupertypeOfEach(candidate, types) {
- for (var _i = 0, types_7 = types; _i < types_7.length; _i++) {
- var t = types_7[_i];
+ for (var _i = 0, types_10 = types; _i < types_10.length; _i++) {
+ var t = types_10[_i];
if (candidate !== t && !isTypeSubtypeOf(t, candidate))
return false;
}
@@ -25971,8 +28397,8 @@ var ts;
}
function literalTypesWithSameBaseType(types) {
var commonBaseType;
- for (var _i = 0, types_8 = types; _i < types_8.length; _i++) {
- var t = types_8[_i];
+ for (var _i = 0, types_11 = types; _i < types_11.length; _i++) {
+ var t = types_11[_i];
var baseType = getBaseTypeOfLiteralType(t);
if (!commonBaseType) {
commonBaseType = baseType;
@@ -26063,8 +28489,8 @@ var ts;
}
function getFalsyFlagsOfTypes(types) {
var result = 0;
- for (var _i = 0, types_9 = types; _i < types_9.length; _i++) {
- var t = types_9[_i];
+ for (var _i = 0, types_12 = types; _i < types_12.length; _i++) {
+ var t = types_12[_i];
result |= getFalsyFlags(t);
}
return result;
@@ -26093,7 +28519,7 @@ var ts;
types.push(undefinedType);
if (flags & 4096)
types.push(nullType);
- return getUnionType(types, true);
+ return getUnionType(types);
}
function removeDefinitelyFalsyTypes(type) {
return getFalsyFlags(type) & 7392 ?
@@ -26108,8 +28534,8 @@ var ts;
getSignaturesOfType(type, 0).length === 0 &&
getSignaturesOfType(type, 1).length === 0;
}
- function createTransientSymbol(source, type) {
- var symbol = createSymbol(source.flags | 67108864, source.name);
+ function createSymbolWithType(source, type) {
+ var symbol = createSymbol(source.flags, source.name);
symbol.declarations = source.declarations;
symbol.parent = source.parent;
symbol.type = type;
@@ -26125,9 +28551,8 @@ var ts;
var property = _a[_i];
var original = getTypeOfSymbol(property);
var updated = f(original);
- members[property.name] = updated === original ? property : createTransientSymbol(property, updated);
+ members.set(property.name, updated === original ? property : createSymbolWithType(property, updated));
}
- ;
return members;
}
function getRegularTypeOfObjectLiteral(type) {
@@ -26146,11 +28571,17 @@ var ts;
type.regularType = regularNew;
return regularNew;
}
+ function getWidenedProperty(prop) {
+ var original = getTypeOfSymbol(prop);
+ var widened = getWidenedType(original);
+ return widened === original ? prop : createSymbolWithType(prop, widened);
+ }
function getWidenedTypeOfObjectLiteral(type) {
- var members = transformTypeOfMembers(type, function (prop) {
- var widened = getWidenedType(prop);
- return prop === widened ? prop : widened;
- });
+ var members = ts.createMap();
+ for (var _i = 0, _a = getPropertiesOfObjectType(type); _i < _a.length; _i++) {
+ var prop = _a[_i];
+ members.set(prop.name, prop.flags & 4 ? getWidenedProperty(prop) : prop);
+ }
var stringIndexInfo = getIndexInfoOfType(type, 0);
var numberIndexInfo = getIndexInfoOfType(type, 1);
return createAnonymousType(type.symbol, members, emptyArray, emptyArray, stringIndexInfo && createIndexInfo(getWidenedType(stringIndexInfo.type), stringIndexInfo.isReadonly), numberIndexInfo && createIndexInfo(getWidenedType(numberIndexInfo.type), numberIndexInfo.isReadonly));
@@ -26211,25 +28642,25 @@ var ts;
var typeAsString = typeToString(getWidenedType(type));
var diagnostic;
switch (declaration.kind) {
+ case 148:
case 147:
- case 146:
diagnostic = ts.Diagnostics.Member_0_implicitly_has_an_1_type;
break;
- case 144:
+ case 145:
diagnostic = declaration.dotDotDotToken ?
ts.Diagnostics.Rest_parameter_0_implicitly_has_an_any_type :
ts.Diagnostics.Parameter_0_implicitly_has_an_1_type;
break;
- case 174:
+ case 175:
diagnostic = ts.Diagnostics.Binding_element_0_implicitly_has_an_1_type;
break;
- case 225:
+ case 227:
+ case 150:
case 149:
- case 148:
- case 151:
case 152:
- case 184:
+ case 153:
case 185:
+ case 186:
if (!declaration.name) {
error(declaration, ts.Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
return;
@@ -26242,7 +28673,7 @@ var ts;
error(declaration, diagnostic, ts.declarationNameToString(declaration.name), typeAsString);
}
function reportErrorsFromWidening(declaration, type) {
- if (produceDiagnostics && compilerOptions.noImplicitAny && type.flags & 2097152) {
+ if (produceDiagnostics && noImplicitAny && type.flags & 2097152) {
if (!reportWideningErrorsInType(type)) {
reportImplicitAnyError(declaration, type);
}
@@ -26268,13 +28699,14 @@ var ts;
callback(getTypeAtPosition(source, i), getTypeAtPosition(target, i));
}
}
- function createInferenceContext(signature, inferUnionTypes) {
+ function createInferenceContext(signature, inferUnionTypes, useAnyForNoInferences) {
var inferences = ts.map(signature.typeParameters, createTypeInferencesObject);
return {
signature: signature,
inferUnionTypes: inferUnionTypes,
inferences: inferences,
inferredTypes: new Array(signature.typeParameters.length),
+ useAnyForNoInferences: useAnyForNoInferences
};
}
function createTypeInferencesObject() {
@@ -26285,25 +28717,69 @@ var ts;
isFixed: false,
};
}
- function couldContainTypeParameters(type) {
+ function couldContainTypeVariables(type) {
var objectFlags = getObjectFlags(type);
- return !!(type.flags & 16384 ||
- objectFlags & 4 && ts.forEach(type.typeArguments, couldContainTypeParameters) ||
+ return !!(type.flags & 540672 ||
+ objectFlags & 4 && ts.forEach(type.typeArguments, couldContainTypeVariables) ||
objectFlags & 16 && type.symbol && type.symbol.flags & (8192 | 2048 | 32) ||
objectFlags & 32 ||
- type.flags & 196608 && couldUnionOrIntersectionContainTypeParameters(type));
+ type.flags & 196608 && couldUnionOrIntersectionContainTypeVariables(type));
}
- function couldUnionOrIntersectionContainTypeParameters(type) {
- if (type.couldContainTypeParameters === undefined) {
- type.couldContainTypeParameters = ts.forEach(type.types, couldContainTypeParameters);
+ function couldUnionOrIntersectionContainTypeVariables(type) {
+ if (type.couldContainTypeVariables === undefined) {
+ type.couldContainTypeVariables = ts.forEach(type.types, couldContainTypeVariables);
}
- return type.couldContainTypeParameters;
+ return type.couldContainTypeVariables;
}
function isTypeParameterAtTopLevel(type, typeParameter) {
return type === typeParameter || type.flags & 196608 && ts.forEach(type.types, function (t) { return isTypeParameterAtTopLevel(t, typeParameter); });
}
- function inferTypes(context, originalSource, originalTarget) {
- var typeParameters = context.signature.typeParameters;
+ function inferTypeForHomomorphicMappedType(source, target) {
+ var properties = getPropertiesOfType(source);
+ var indexInfo = getIndexInfoOfType(source, 0);
+ if (properties.length === 0 && !indexInfo) {
+ return undefined;
+ }
+ var typeVariable = getIndexedAccessType(getConstraintTypeFromMappedType(target).type, getTypeParameterFromMappedType(target));
+ var typeVariableArray = [typeVariable];
+ var typeInferences = createTypeInferencesObject();
+ var typeInferencesArray = [typeInferences];
+ var templateType = getTemplateTypeFromMappedType(target);
+ var readonlyMask = target.declaration.readonlyToken ? false : true;
+ var optionalMask = target.declaration.questionToken ? 0 : 67108864;
+ var members = createSymbolTable(properties);
+ for (var _i = 0, properties_5 = properties; _i < properties_5.length; _i++) {
+ var prop = properties_5[_i];
+ var inferredPropType = inferTargetType(getTypeOfSymbol(prop));
+ if (!inferredPropType) {
+ return undefined;
+ }
+ var inferredProp = createSymbol(4 | prop.flags & optionalMask, prop.name);
+ inferredProp.checkFlags = readonlyMask && isReadonlySymbol(prop) ? 8 : 0;
+ inferredProp.declarations = prop.declarations;
+ inferredProp.type = inferredPropType;
+ members.set(prop.name, inferredProp);
+ }
+ if (indexInfo) {
+ var inferredIndexType = inferTargetType(indexInfo.type);
+ if (!inferredIndexType) {
+ return undefined;
+ }
+ indexInfo = createIndexInfo(inferredIndexType, readonlyMask && indexInfo.isReadonly);
+ }
+ return createAnonymousType(undefined, members, emptyArray, emptyArray, indexInfo, undefined);
+ function inferTargetType(sourceType) {
+ typeInferences.primary = undefined;
+ typeInferences.secondary = undefined;
+ inferTypes(typeVariableArray, typeInferencesArray, sourceType, templateType);
+ var inferences = typeInferences.primary || typeInferences.secondary;
+ return inferences && getUnionType(inferences, true);
+ }
+ }
+ function inferTypesWithContext(context, originalSource, originalTarget) {
+ inferTypes(context.signature.typeParameters, context.inferences, originalSource, originalTarget);
+ }
+ function inferTypes(typeVariables, typeInferences, originalSource, originalTarget) {
var sourceStack;
var targetStack;
var depth = 0;
@@ -26319,7 +28795,7 @@ var ts;
return false;
}
function inferFromTypes(source, target) {
- if (!couldContainTypeParameters(target)) {
+ if (!couldContainTypeVariables(target)) {
return;
}
if (source.aliasSymbol && source.aliasTypeArguments && source.aliasSymbol === target.aliasSymbol) {
@@ -26358,13 +28834,13 @@ var ts;
target = removeTypesFromUnionOrIntersection(target, matchingTypes);
}
}
- if (target.flags & 16384) {
+ if (target.flags & 540672) {
if (source.flags & 8388608) {
return;
}
- for (var i = 0; i < typeParameters.length; i++) {
- if (target === typeParameters[i]) {
- var inferences = context.inferences[i];
+ for (var i = 0; i < typeVariables.length; i++) {
+ if (target === typeVariables[i]) {
+ var inferences = typeInferences[i];
if (!inferences.isFixed) {
var candidates = inferiority ?
inferences.secondary || (inferences.secondary = []) :
@@ -26372,7 +28848,7 @@ var ts;
if (!ts.contains(candidates, source)) {
candidates.push(source);
}
- if (!isTypeParameterAtTopLevel(originalTarget, target)) {
+ if (target.flags & 16384 && !isTypeParameterAtTopLevel(originalTarget, target)) {
inferences.topLevel = false;
}
}
@@ -26390,21 +28866,21 @@ var ts;
}
else if (target.flags & 196608) {
var targetTypes = target.types;
- var typeParameterCount = 0;
- var typeParameter = void 0;
- for (var _d = 0, targetTypes_2 = targetTypes; _d < targetTypes_2.length; _d++) {
- var t = targetTypes_2[_d];
- if (t.flags & 16384 && ts.contains(typeParameters, t)) {
- typeParameter = t;
- typeParameterCount++;
+ var typeVariableCount = 0;
+ var typeVariable = void 0;
+ for (var _d = 0, targetTypes_3 = targetTypes; _d < targetTypes_3.length; _d++) {
+ var t = targetTypes_3[_d];
+ if (t.flags & 540672 && ts.contains(typeVariables, t)) {
+ typeVariable = t;
+ typeVariableCount++;
}
else {
inferFromTypes(source, t);
}
}
- if (typeParameterCount === 1) {
+ if (typeVariableCount === 1) {
inferiority++;
- inferFromTypes(source, typeParameter);
+ inferFromTypes(source, typeVariable);
inferiority--;
}
}
@@ -26421,14 +28897,14 @@ var ts;
if (isInProcess(source, target)) {
return;
}
- if (isDeeplyNestedGeneric(source, sourceStack, depth) && isDeeplyNestedGeneric(target, targetStack, depth)) {
+ if (isDeeplyNestedType(source, sourceStack, depth) && isDeeplyNestedType(target, targetStack, depth)) {
return;
}
var key = source.id + "," + target.id;
- if (visited[key]) {
+ if (visited.get(key)) {
return;
}
- visited[key] = true;
+ visited.set(key, true);
if (depth === 0) {
sourceStack = [];
targetStack = [];
@@ -26444,9 +28920,16 @@ var ts;
function inferFromObjectTypes(source, target) {
if (getObjectFlags(target) & 32) {
var constraintType = getConstraintTypeFromMappedType(target);
- if (getObjectFlags(source) & 32) {
- inferFromTypes(getConstraintTypeFromMappedType(source), constraintType);
- inferFromTypes(getTemplateTypeFromMappedType(source), getTemplateTypeFromMappedType(target));
+ if (constraintType.flags & 262144) {
+ var index = ts.indexOf(typeVariables, constraintType.type);
+ if (index >= 0 && !typeInferences[index].isFixed) {
+ var inferredType = inferTypeForHomomorphicMappedType(source, target);
+ if (inferredType) {
+ inferiority++;
+ inferFromTypes(inferredType, typeVariables[index]);
+ inferiority--;
+ }
+ }
return;
}
if (constraintType.flags & 16384) {
@@ -26462,8 +28945,8 @@ var ts;
}
function inferFromProperties(source, target) {
var properties = getPropertiesOfObjectType(target);
- for (var _i = 0, properties_4 = properties; _i < properties_4.length; _i++) {
- var targetProp = properties_4[_i];
+ for (var _i = 0, properties_6 = properties; _i < properties_6.length; _i++) {
+ var targetProp = properties_6[_i];
var sourceProp = getPropertyOfObjectType(source, targetProp.name);
if (sourceProp) {
inferFromTypes(getTypeOfSymbol(sourceProp), getTypeOfSymbol(targetProp));
@@ -26513,8 +28996,8 @@ var ts;
}
}
function typeIdenticalToSomeType(type, types) {
- for (var _i = 0, types_10 = types; _i < types_10.length; _i++) {
- var t = types_10[_i];
+ for (var _i = 0, types_13 = types; _i < types_13.length; _i++) {
+ var t = types_13[_i];
if (isTypeIdenticalTo(t, type)) {
return true;
}
@@ -26555,7 +29038,13 @@ var ts;
inferenceSucceeded = !!unionOrSuperType;
}
else {
- inferredType = emptyObjectType;
+ var defaultType = getDefaultFromTypeParameter(context.signature.typeParameters[index]);
+ if (defaultType) {
+ inferredType = instantiateType(defaultType, combineTypeMappers(createBackreferenceMapper(context.signature.typeParameters, index), getInferenceMapper(context)));
+ }
+ else {
+ inferredType = context.useAnyForNoInferences ? anyType : emptyObjectType;
+ }
inferenceSucceeded = true;
}
context.inferredTypes[index] = inferredType;
@@ -26588,19 +29077,7 @@ var ts;
return links.resolvedSymbol;
}
function isInTypeQuery(node) {
- while (node) {
- switch (node.kind) {
- case 160:
- return true;
- case 70:
- case 141:
- node = node.parent;
- continue;
- default:
- return false;
- }
- }
- ts.Debug.fail("should not get here");
+ return !!ts.findAncestor(node, function (n) { return n.kind === 161 ? true : n.kind === 70 || n.kind === 142 ? false : "quit"; });
}
function getFlowCacheKey(node) {
if (node.kind === 70) {
@@ -26610,7 +29087,7 @@ var ts;
if (node.kind === 98) {
return "0";
}
- if (node.kind === 177) {
+ if (node.kind === 178) {
var key = getFlowCacheKey(node.expression);
return key && key + "." + node.name.text;
}
@@ -26621,7 +29098,7 @@ var ts;
case 70:
case 98:
return node;
- case 177:
+ case 178:
return getLeftmostIdentifierOrThis(node.expression);
}
return undefined;
@@ -26630,19 +29107,21 @@ var ts;
switch (source.kind) {
case 70:
return target.kind === 70 && getResolvedSymbol(source) === getResolvedSymbol(target) ||
- (target.kind === 223 || target.kind === 174) &&
+ (target.kind === 225 || target.kind === 175) &&
getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(source)) === getSymbolOfNode(target);
case 98:
return target.kind === 98;
- case 177:
- return target.kind === 177 &&
+ case 96:
+ return target.kind === 96;
+ case 178:
+ return target.kind === 178 &&
source.name.text === target.name.text &&
isMatchingReference(source.expression, target.expression);
}
return false;
}
function containsMatchingReference(source, target) {
- while (source.kind === 177) {
+ while (source.kind === 178) {
source = source.expression;
if (isMatchingReference(source, target)) {
return true;
@@ -26651,7 +29130,7 @@ var ts;
return false;
}
function containsMatchingReferenceDiscriminant(source, target) {
- return target.kind === 177 &&
+ return target.kind === 178 &&
containsMatchingReference(source, target.expression) &&
isDiscriminantProperty(getDeclaredTypeOfReference(target.expression), target.name.text);
}
@@ -26659,7 +29138,7 @@ var ts;
if (expr.kind === 70) {
return getTypeOfSymbol(getResolvedSymbol(expr));
}
- if (expr.kind === 177) {
+ if (expr.kind === 178) {
var type = getDeclaredTypeOfReference(expr.expression);
return type && getTypeOfPropertyOfType(type, expr.name.text);
}
@@ -26668,9 +29147,9 @@ var ts;
function isDiscriminantProperty(type, name) {
if (type && type.flags & 65536) {
var prop = getUnionOrIntersectionProperty(type, name);
- if (prop && prop.flags & 268435456) {
+ if (prop && getCheckFlags(prop) & 2) {
if (prop.isDiscriminantProperty === undefined) {
- prop.isDiscriminantProperty = prop.hasNonUniformType && isLiteralType(getTypeOfSymbol(prop));
+ prop.isDiscriminantProperty = prop.checkFlags & 32 && isLiteralType(getTypeOfSymbol(prop));
}
return prop.isDiscriminantProperty;
}
@@ -26689,7 +29168,7 @@ var ts;
}
}
}
- if (callExpression.expression.kind === 177 &&
+ if (callExpression.expression.kind === 178 &&
isOrContainsMatchingReference(reference, callExpression.expression.expression)) {
return true;
}
@@ -26728,8 +29207,8 @@ var ts;
}
function getTypeFactsOfTypes(types) {
var result = 0;
- for (var _i = 0, types_11 = types; _i < types_11.length; _i++) {
- var t = types_11[_i];
+ for (var _i = 0, types_14 = types; _i < types_14.length; _i++) {
+ var t = types_14[_i];
result |= getTypeFacts(t);
}
return result;
@@ -26737,7 +29216,7 @@ var ts;
function isFunctionObjectType(type) {
var resolved = resolveStructuredTypeMembers(type);
return !!(resolved.callSignatures.length || resolved.constructSignatures.length ||
- resolved.members["bind"] && isTypeSubtypeOf(type, globalFunctionType));
+ resolved.members.get("bind") && isTypeSubtypeOf(type, globalFunctionType));
}
function getTypeFacts(type) {
var flags = type.flags;
@@ -26780,9 +29259,11 @@ var ts;
if (flags & 512) {
return strictNullChecks ? 1981320 : 4193160;
}
- if (flags & 16384) {
- var constraint = getConstraintOfTypeParameter(type);
- return getTypeFacts(constraint || emptyObjectType);
+ if (flags & 16777216) {
+ return strictNullChecks ? 6166480 : 8378320;
+ }
+ if (flags & 540672) {
+ return getTypeFacts(getBaseConstraintOfType(type) || emptyObjectType);
}
if (flags & 196608) {
return getTypeFactsOfTypes(type.types);
@@ -26808,17 +29289,23 @@ var ts;
}
function getTypeOfDestructuredArrayElement(type, index) {
return isTupleLikeType(type) && getTypeOfPropertyOfType(type, "" + index) ||
- checkIteratedTypeOrElementType(type, undefined, false) ||
+ checkIteratedTypeOrElementType(type, undefined, false, false) ||
unknownType;
}
function getTypeOfDestructuredSpreadExpression(type) {
- return createArrayType(checkIteratedTypeOrElementType(type, undefined, false) || unknownType);
+ return createArrayType(checkIteratedTypeOrElementType(type, undefined, false, false) || unknownType);
}
function getAssignedTypeOfBinaryExpression(node) {
- return node.parent.kind === 175 || node.parent.kind === 257 ?
+ var isDestructuringDefaultAssignment = node.parent.kind === 176 && isDestructuringAssignmentTarget(node.parent) ||
+ node.parent.kind === 260 && isDestructuringAssignmentTarget(node.parent.parent);
+ return isDestructuringDefaultAssignment ?
getTypeWithDefault(getAssignedType(node), node.right) :
getTypeOfExpression(node.right);
}
+ function isDestructuringAssignmentTarget(parent) {
+ return parent.parent.kind === 193 && parent.parent.left === parent ||
+ parent.parent.kind === 215 && parent.parent.initializer === parent;
+ }
function getAssignedTypeOfArrayLiteralElement(node, element) {
return getTypeOfDestructuredArrayElement(getAssignedType(node), ts.indexOf(node.elements, element));
}
@@ -26834,21 +29321,21 @@ var ts;
function getAssignedType(node) {
var parent = node.parent;
switch (parent.kind) {
- case 212:
+ case 214:
return stringType;
- case 213:
- return checkRightHandSideOfForOf(parent.expression) || unknownType;
- case 192:
+ case 215:
+ return checkRightHandSideOfForOf(parent.expression, parent.awaitModifier) || unknownType;
+ case 193:
return getAssignedTypeOfBinaryExpression(parent);
- case 186:
+ case 187:
return undefinedType;
- case 175:
+ case 176:
return getAssignedTypeOfArrayLiteralElement(parent, node);
- case 196:
+ case 197:
return getAssignedTypeOfSpreadExpression(parent);
- case 257:
+ case 260:
return getAssignedTypeOfPropertyAssignment(parent);
- case 258:
+ case 261:
return getAssignedTypeOfShorthandPropertyAssignment(parent);
}
return unknownType;
@@ -26856,7 +29343,7 @@ var ts;
function getInitialTypeOfBindingElement(node) {
var pattern = node.parent;
var parentType = getInitialType(pattern.parent);
- var type = pattern.kind === 172 ?
+ var type = pattern.kind === 173 ?
getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) :
!node.dotDotDotToken ?
getTypeOfDestructuredArrayElement(parentType, ts.indexOf(pattern.elements, node)) :
@@ -26871,35 +29358,35 @@ var ts;
if (node.initializer) {
return getTypeOfInitializer(node.initializer);
}
- if (node.parent.parent.kind === 212) {
+ if (node.parent.parent.kind === 214) {
return stringType;
}
- if (node.parent.parent.kind === 213) {
- return checkRightHandSideOfForOf(node.parent.parent.expression) || unknownType;
+ if (node.parent.parent.kind === 215) {
+ return checkRightHandSideOfForOf(node.parent.parent.expression, node.parent.parent.awaitModifier) || unknownType;
}
return unknownType;
}
function getInitialType(node) {
- return node.kind === 223 ?
+ return node.kind === 225 ?
getInitialTypeOfVariableDeclaration(node) :
getInitialTypeOfBindingElement(node);
}
function getInitialOrAssignedType(node) {
- return node.kind === 223 || node.kind === 174 ?
+ return node.kind === 225 || node.kind === 175 ?
getInitialType(node) :
getAssignedType(node);
}
function isEmptyArrayAssignment(node) {
- return node.kind === 223 && node.initializer &&
+ return node.kind === 225 && node.initializer &&
isEmptyArrayLiteral(node.initializer) ||
- node.kind !== 174 && node.parent.kind === 192 &&
+ node.kind !== 175 && node.parent.kind === 193 &&
isEmptyArrayLiteral(node.parent.right);
}
function getReferenceCandidate(node) {
switch (node.kind) {
- case 183:
+ case 184:
return getReferenceCandidate(node.expression);
- case 192:
+ case 193:
switch (node.operatorToken.kind) {
case 57:
return getReferenceCandidate(node.left);
@@ -26911,13 +29398,13 @@ var ts;
}
function getReferenceRoot(node) {
var parent = node.parent;
- return parent.kind === 183 ||
- parent.kind === 192 && parent.operatorToken.kind === 57 && parent.left === node ||
- parent.kind === 192 && parent.operatorToken.kind === 25 && parent.right === node ?
+ return parent.kind === 184 ||
+ parent.kind === 193 && parent.operatorToken.kind === 57 && parent.left === node ||
+ parent.kind === 193 && parent.operatorToken.kind === 25 && parent.right === node ?
getReferenceRoot(parent) : node;
}
function getTypeOfSwitchClause(clause) {
- if (clause.kind === 253) {
+ if (clause.kind === 256) {
var caseType = getRegularTypeOfLiteralType(getTypeOfExpression(clause.expression));
return isUnitType(caseType) ? caseType : undefined;
}
@@ -26963,8 +29450,29 @@ var ts;
}
return f(type) ? type : neverType;
}
- function mapType(type, f) {
- return type.flags & 65536 ? getUnionType(ts.map(type.types, f)) : f(type);
+ function mapType(type, mapper) {
+ if (!(type.flags & 65536)) {
+ return mapper(type);
+ }
+ var types = type.types;
+ var mappedType;
+ var mappedTypes;
+ for (var _i = 0, types_15 = types; _i < types_15.length; _i++) {
+ var current = types_15[_i];
+ var t = mapper(current);
+ if (t) {
+ if (!mappedType) {
+ mappedType = t;
+ }
+ else if (!mappedTypes) {
+ mappedTypes = [mappedType, t];
+ }
+ else {
+ mappedTypes.push(t);
+ }
+ }
+ }
+ return mappedTypes ? getUnionType(mappedTypes) : mappedType;
}
function extractTypesOfKind(type, kind) {
return filterType(type, function (t) { return (t.flags & kind) !== 0; });
@@ -26998,7 +29506,7 @@ var ts;
return evolvingArrayTypes[elementType.id] || (evolvingArrayTypes[elementType.id] = createEvolvingArrayType(elementType));
}
function addEvolvingArrayElementType(evolvingArrayType, node) {
- var elementType = getBaseTypeOfLiteralType(getTypeOfExpression(node));
+ var elementType = getBaseTypeOfLiteralType(getContextFreeTypeOfExpression(node));
return isTypeSubsetOf(elementType, evolvingArrayType.elementType) ? evolvingArrayType : getEvolvingArrayType(getUnionType([evolvingArrayType.elementType, elementType]));
}
function createFinalArrayType(elementType) {
@@ -27019,8 +29527,8 @@ var ts;
}
function isEvolvingArrayTypeList(types) {
var hasEvolvingArrayType = false;
- for (var _i = 0, types_12 = types; _i < types_12.length; _i++) {
- var t = types_12[_i];
+ for (var _i = 0, types_16 = types; _i < types_16.length; _i++) {
+ var t = types_16[_i];
if (!(t.flags & 8192)) {
if (!(getObjectFlags(t) & 256)) {
return false;
@@ -27038,11 +29546,11 @@ var ts;
function isEvolvingArrayOperationTarget(node) {
var root = getReferenceRoot(node);
var parent = root.parent;
- var isLengthPushOrUnshift = parent.kind === 177 && (parent.name.text === "length" ||
- parent.parent.kind === 179 && ts.isPushOrUnshiftIdentifier(parent.name));
- var isElementAssignment = parent.kind === 178 &&
+ var isLengthPushOrUnshift = parent.kind === 178 && (parent.name.text === "length" ||
+ parent.parent.kind === 180 && ts.isPushOrUnshiftIdentifier(parent.name));
+ var isElementAssignment = parent.kind === 179 &&
parent.expression === root &&
- parent.parent.kind === 192 &&
+ parent.parent.kind === 193 &&
parent.parent.operatorToken.kind === 57 &&
parent.parent.left === parent &&
!ts.isAssignmentTarget(parent.parent) &&
@@ -27069,19 +29577,17 @@ var ts;
}
return false;
}
- function getFlowTypeOfReference(reference, declaredType, assumeInitialized, flowContainer) {
+ function getFlowTypeOfReference(reference, declaredType, initialType, flowContainer, couldBeUninitialized) {
+ if (initialType === void 0) { initialType = declaredType; }
var key;
- if (!reference.flowNode || assumeInitialized && !(declaredType.flags & 1033215)) {
+ if (!reference.flowNode || !couldBeUninitialized && !(declaredType.flags & 17810431)) {
return declaredType;
}
- var initialType = assumeInitialized ? declaredType :
- declaredType === autoType || declaredType === autoArrayType ? undefinedType :
- includeFalsyTypes(declaredType, 2048);
var visitedFlowStart = visitedFlowCount;
var evolvedType = getTypeFromFlowType(getTypeAtFlowNode(reference.flowNode));
visitedFlowCount = visitedFlowStart;
var resultType = getObjectFlags(evolvedType) & 256 && isEvolvingArrayOperationTarget(reference) ? anyArrayType : finalizeEvolvingArrayType(evolvedType);
- if (reference.parent.kind === 201 && getTypeWithFacts(resultType, 524288).flags & 8192) {
+ if (reference.parent.kind === 202 && getTypeWithFacts(resultType, 524288).flags & 8192) {
return declaredType;
}
return resultType;
@@ -27095,7 +29601,16 @@ var ts;
}
}
var type = void 0;
- if (flow.flags & 16) {
+ if (flow.flags & 4096) {
+ flow.locked = true;
+ type = getTypeAtFlowNode(flow.antecedent);
+ flow.locked = false;
+ }
+ else if (flow.flags & 2048) {
+ flow = flow.antecedent;
+ continue;
+ }
+ else if (flow.flags & 16) {
type = getTypeAtFlowAssignment(flow);
if (!type) {
flow = flow.antecedent;
@@ -27126,7 +29641,7 @@ var ts;
}
else if (flow.flags & 2) {
var container = flow.container;
- if (container && container !== flowContainer && reference.kind !== 177) {
+ if (container && container !== flowContainer && reference.kind !== 178 && reference.kind !== 98) {
flow = container.flowNode;
continue;
}
@@ -27169,7 +29684,7 @@ var ts;
}
function getTypeAtFlowArrayMutation(flow) {
var node = flow.node;
- var expr = node.kind === 179 ?
+ var expr = node.kind === 180 ?
node.expression.expression :
node.left.expression;
if (isMatchingReference(reference, getReferenceCandidate(expr))) {
@@ -27177,7 +29692,7 @@ var ts;
var type = getTypeFromFlowType(flowType);
if (getObjectFlags(type) & 256) {
var evolvedType_1 = type;
- if (node.kind === 179) {
+ if (node.kind === 180) {
for (var _i = 0, _a = node.arguments; _i < _a.length; _i++) {
var arg = _a[_i];
evolvedType_1 = addEvolvingArrayElementType(evolvedType_1, arg);
@@ -27229,6 +29744,9 @@ var ts;
var seenIncomplete = false;
for (var _i = 0, _a = flow.antecedents; _i < _a.length; _i++) {
var antecedent = _a[_i];
+ if (antecedent.flags & 2048 && antecedent.lock.locked) {
+ continue;
+ }
var flowType = getTypeAtFlowNode(antecedent);
var type = getTypeFromFlowType(flowType);
if (type === declaredType && declaredType === initialType) {
@@ -27252,8 +29770,9 @@ var ts;
if (!key) {
key = getFlowCacheKey(reference);
}
- if (cache[key]) {
- return cache[key];
+ var cached = cache.get(key);
+ if (cached) {
+ return cached;
}
for (var i = flowLoopStart; i < flowLoopCount; i++) {
if (flowLoopNodes[i] === flow && flowLoopKeys[i] === key && flowLoopTypes[i].length) {
@@ -27275,8 +29794,9 @@ var ts;
firstAntecedentType = flowType;
}
var type = getTypeFromFlowType(flowType);
- if (cache[key]) {
- return cache[key];
+ var cached_1 = cache.get(key);
+ if (cached_1) {
+ return cached_1;
}
if (!ts.contains(antecedentTypes, type)) {
antecedentTypes.push(type);
@@ -27292,10 +29812,11 @@ var ts;
if (isIncomplete(firstAntecedentType)) {
return createFlowType(result, true);
}
- return cache[key] = result;
+ cache.set(key, result);
+ return result;
}
function isMatchingReferenceDiscriminant(expr) {
- return expr.kind === 177 &&
+ return expr.kind === 178 &&
declaredType.flags & 65536 &&
isMatchingReference(reference, expr.expression) &&
isDiscriminantProperty(declaredType, expr.name.text);
@@ -27329,10 +29850,10 @@ var ts;
var operator_1 = expr.operatorToken.kind;
var left_1 = getReferenceCandidate(expr.left);
var right_1 = getReferenceCandidate(expr.right);
- if (left_1.kind === 187 && right_1.kind === 9) {
+ if (left_1.kind === 188 && right_1.kind === 9) {
return narrowTypeByTypeof(type, left_1, operator_1, right_1, assumeTrue);
}
- if (right_1.kind === 187 && left_1.kind === 9) {
+ if (right_1.kind === 188 && left_1.kind === 9) {
return narrowTypeByTypeof(type, right_1, operator_1, left_1, assumeTrue);
}
if (isMatchingReference(reference, left_1)) {
@@ -27378,7 +29899,7 @@ var ts;
assumeTrue ? 16384 : 131072;
return getTypeWithFacts(type, facts);
}
- if (type.flags & 33281) {
+ if (type.flags & 16810497) {
return type;
}
if (assumeTrue) {
@@ -27403,14 +29924,22 @@ var ts;
assumeTrue = !assumeTrue;
}
if (assumeTrue && !(type.flags & 65536)) {
- var targetType = typeofTypesByName[literal.text];
- if (targetType && isTypeSubtypeOf(targetType, type)) {
- return targetType;
+ var targetType = typeofTypesByName.get(literal.text);
+ if (targetType) {
+ if (isTypeSubtypeOf(targetType, type)) {
+ return targetType;
+ }
+ if (type.flags & 540672) {
+ var constraint = getBaseConstraintOfType(type) || anyType;
+ if (isTypeSubtypeOf(targetType, constraint)) {
+ return getIntersectionType([type, targetType]);
+ }
+ }
}
}
var facts = assumeTrue ?
- typeofEQFacts[literal.text] || 64 :
- typeofNEFacts[literal.text] || 8192;
+ typeofEQFacts.get(literal.text) || 64 :
+ typeofNEFacts.get(literal.text) || 8192;
return getTypeWithFacts(type, facts);
}
function narrowTypeBySwitchOnDiscriminant(type, switchStatement, clauseStart, clauseEnd) {
@@ -27479,10 +30008,9 @@ var ts;
return assignableType;
}
}
- var targetType = type.flags & 16384 ? getApparentType(type) : type;
return isTypeSubtypeOf(candidate, type) ? candidate :
isTypeAssignableTo(type, candidate) ? type :
- isTypeAssignableTo(candidate, targetType) ? candidate :
+ isTypeAssignableTo(candidate, type) ? candidate :
getIntersectionType([type, candidate]);
}
function narrowTypeByTypePredicate(type, callExpression, assumeTrue) {
@@ -27510,7 +30038,7 @@ var ts;
}
else {
var invokedExpression = ts.skipParentheses(callExpression.expression);
- if (invokedExpression.kind === 178 || invokedExpression.kind === 177) {
+ if (invokedExpression.kind === 179 || invokedExpression.kind === 178) {
var accessExpression = invokedExpression;
var possibleReference = ts.skipParentheses(accessExpression.expression);
if (isMatchingReference(reference, possibleReference)) {
@@ -27527,15 +30055,16 @@ var ts;
switch (expr.kind) {
case 70:
case 98:
- case 177:
+ case 96:
+ case 178:
return narrowTypeByTruthiness(type, expr, assumeTrue);
- case 179:
+ case 180:
return narrowTypeByTypePredicate(type, expr, assumeTrue);
- case 183:
+ case 184:
return narrowType(type, expr.expression, assumeTrue);
- case 192:
+ case 193:
return narrowTypeByBinaryExpression(type, expr, assumeTrue);
- case 190:
+ case 191:
if (expr.operator === 50) {
return narrowType(type, expr.operand, !assumeTrue);
}
@@ -27559,15 +30088,12 @@ var ts;
return getTypeOfSymbol(symbol);
}
function getControlFlowContainer(node) {
- while (true) {
- node = node.parent;
- if (ts.isFunctionLike(node) && !ts.getImmediatelyInvokedFunctionExpression(node) ||
- node.kind === 231 ||
- node.kind === 261 ||
- node.kind === 147) {
- return node;
- }
- }
+ return ts.findAncestor(node.parent, function (node) {
+ return ts.isFunctionLike(node) && !ts.getImmediatelyInvokedFunctionExpression(node) ||
+ node.kind === 233 ||
+ node.kind === 264 ||
+ node.kind === 148;
+ });
}
function isParameterAssigned(symbol) {
var func = ts.getRootDeclaration(symbol.valueDeclaration).parent;
@@ -27581,21 +30107,13 @@ var ts;
return symbol.isAssigned || false;
}
function hasParentWithAssignmentsMarked(node) {
- while (true) {
- node = node.parent;
- if (!node) {
- return false;
- }
- if (ts.isFunctionLike(node) && getNodeLinks(node).flags & 4194304) {
- return true;
- }
- }
+ return !!ts.findAncestor(node.parent, function (node) { return ts.isFunctionLike(node) && !!(getNodeLinks(node).flags & 4194304); });
}
function markParameterAssignments(node) {
if (node.kind === 70) {
if (ts.isAssignmentTarget(node)) {
var symbol = getResolvedSymbol(node);
- if (symbol.valueDeclaration && ts.getRootDeclaration(symbol.valueDeclaration).kind === 144) {
+ if (symbol.valueDeclaration && ts.getRootDeclaration(symbol.valueDeclaration).kind === 145) {
symbol.isAssigned = true;
}
}
@@ -27607,6 +30125,14 @@ var ts;
function isConstVariable(symbol) {
return symbol.flags & 3 && (getDeclarationNodeFlagsFromSymbol(symbol) & 2) !== 0 && getTypeOfSymbol(symbol) !== autoArrayType;
}
+ function removeOptionalityFromDeclaredType(declaredType, declaration) {
+ var annotationIncludesUndefined = strictNullChecks &&
+ declaration.kind === 145 &&
+ declaration.initializer &&
+ getFalsyFlags(declaredType) & 2048 &&
+ !(getFalsyFlags(checkExpression(declaration.initializer)) & 2048);
+ return annotationIncludesUndefined ? getTypeWithFacts(declaredType, 131072) : declaredType;
+ }
function checkIdentifier(node) {
var symbol = getResolvedSymbol(node);
if (symbol === unknownSymbol) {
@@ -27615,16 +30141,14 @@ var ts;
if (symbol === argumentsSymbol) {
var container = ts.getContainingFunction(node);
if (languageVersion < 2) {
- if (container.kind === 185) {
+ if (container.kind === 186) {
error(node, ts.Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression);
}
else if (ts.hasModifier(container, 256)) {
error(node, ts.Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method);
}
}
- if (node.flags & 524288) {
- getNodeLinks(container).flags |= 8192;
- }
+ getNodeLinks(container).flags |= 8192;
return getTypeOfSymbol(symbol);
}
if (symbol.flags & 8388608 && !isInTypeQuery(node) && !isConstEnumOrConstEnumOnlyModule(resolveAlias(symbol))) {
@@ -27633,7 +30157,7 @@ var ts;
var localOrExportSymbol = getExportSymbolOfValueSymbolIfExported(symbol);
if (localOrExportSymbol.flags & 32) {
var declaration_1 = localOrExportSymbol.valueDeclaration;
- if (declaration_1.kind === 226
+ if (declaration_1.kind === 228
&& ts.nodeIsDecorated(declaration_1)) {
var container = ts.getContainingClass(node);
while (container !== undefined) {
@@ -27645,11 +30169,11 @@ var ts;
container = ts.getContainingClass(container);
}
}
- else if (declaration_1.kind === 197) {
+ else if (declaration_1.kind === 198) {
var container = ts.getThisContainer(node, false);
while (container !== undefined) {
if (container.parent === declaration_1) {
- if (container.kind === 147 && ts.hasModifier(container, 32)) {
+ if (container.kind === 148 && ts.hasModifier(container, 32)) {
getNodeLinks(declaration_1).flags |= 8388608;
getNodeLinks(node).flags |= 16777216;
}
@@ -27661,6 +30185,7 @@ var ts;
}
checkCollisionWithCapturedSuperVariable(node, node);
checkCollisionWithCapturedThisVariable(node, node);
+ checkCollisionWithCapturedNewTargetVariable(node, node);
checkNestedBlockScopedBinding(node, symbol);
var type = getTypeOfSymbol(localOrExportSymbol);
var declaration = localOrExportSymbol.valueDeclaration;
@@ -27678,22 +30203,25 @@ var ts;
if (!(localOrExportSymbol.flags & 3) || assignmentKind === 1 || !declaration) {
return type;
}
- var isParameter = ts.getRootDeclaration(declaration).kind === 144;
+ var isParameter = ts.getRootDeclaration(declaration).kind === 145;
var declarationContainer = getControlFlowContainer(declaration);
var flowContainer = getControlFlowContainer(node);
var isOuterVariable = flowContainer !== declarationContainer;
- while (flowContainer !== declarationContainer && (flowContainer.kind === 184 ||
- flowContainer.kind === 185 || ts.isObjectLiteralOrClassExpressionMethod(flowContainer)) &&
+ while (flowContainer !== declarationContainer && (flowContainer.kind === 185 ||
+ flowContainer.kind === 186 || ts.isObjectLiteralOrClassExpressionMethod(flowContainer)) &&
(isConstVariable(localOrExportSymbol) || isParameter && !isParameterAssigned(localOrExportSymbol))) {
flowContainer = getControlFlowContainer(flowContainer);
}
var assumeInitialized = isParameter || isOuterVariable ||
- type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & 1) !== 0) ||
+ type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & 1) !== 0 || isInTypeQuery(node)) ||
ts.isInAmbientContext(declaration);
- var flowType = getFlowTypeOfReference(node, type, assumeInitialized, flowContainer);
+ var initialType = assumeInitialized ? (isParameter ? removeOptionalityFromDeclaredType(type, ts.getRootDeclaration(declaration)) : type) :
+ type === autoType || type === autoArrayType ? undefinedType :
+ includeFalsyTypes(type, 2048);
+ var flowType = getFlowTypeOfReference(node, type, initialType, flowContainer, !assumeInitialized);
if (type === autoType || type === autoArrayType) {
if (flowType === autoType || flowType === autoArrayType) {
- if (compilerOptions.noImplicitAny) {
+ if (noImplicitAny) {
error(declaration.name, ts.Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType));
error(node, ts.Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
}
@@ -27707,19 +30235,12 @@ var ts;
return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
}
function isInsideFunction(node, threshold) {
- var current = node;
- while (current && current !== threshold) {
- if (ts.isFunctionLike(current)) {
- return true;
- }
- current = current.parent;
- }
- return false;
+ return !!ts.findAncestor(node, function (n) { return n === threshold ? "quit" : ts.isFunctionLike(n); });
}
function checkNestedBlockScopedBinding(node, symbol) {
if (languageVersion >= 2 ||
(symbol.flags & (2 | 32)) === 0 ||
- symbol.valueDeclaration.parent.kind === 256) {
+ symbol.valueDeclaration.parent.kind === 259) {
return;
}
var container = ts.getEnclosingBlockScopeContainer(symbol.valueDeclaration);
@@ -27737,8 +30258,8 @@ var ts;
if (usedInFunction) {
getNodeLinks(current).flags |= 65536;
}
- if (container.kind === 211 &&
- ts.getAncestor(symbol.valueDeclaration, 224).parent === container &&
+ if (container.kind === 213 &&
+ ts.getAncestor(symbol.valueDeclaration, 226).parent === container &&
isAssignedInBodyOfForStatement(node, container)) {
getNodeLinks(symbol.valueDeclaration).flags |= 2097152;
}
@@ -27750,33 +30271,25 @@ var ts;
}
function isAssignedInBodyOfForStatement(node, container) {
var current = node;
- while (current.parent.kind === 183) {
+ while (current.parent.kind === 184) {
current = current.parent;
}
var isAssigned = false;
if (ts.isAssignmentTarget(current)) {
isAssigned = true;
}
- else if ((current.parent.kind === 190 || current.parent.kind === 191)) {
+ else if ((current.parent.kind === 191 || current.parent.kind === 192)) {
var expr = current.parent;
isAssigned = expr.operator === 42 || expr.operator === 43;
}
if (!isAssigned) {
return false;
}
- while (current !== container) {
- if (current === container.statement) {
- return true;
- }
- else {
- current = current.parent;
- }
- }
- return false;
+ return !!ts.findAncestor(current, function (n) { return n === container ? "quit" : n === container.statement; });
}
function captureLexicalThis(node, container) {
getNodeLinks(node).flags |= 2;
- if (container.kind === 147 || container.kind === 150) {
+ if (container.kind === 148 || container.kind === 151) {
var classNode = container.parent;
getNodeLinks(classNode).flags |= 4;
}
@@ -27807,42 +30320,45 @@ var ts;
var baseConstructorType = getBaseConstructorTypeOfClass(classInstanceType);
return baseConstructorType === nullWideningType;
}
+ function checkThisBeforeSuper(node, container, diagnosticMessage) {
+ var containingClassDecl = container.parent;
+ var baseTypeNode = ts.getClassExtendsHeritageClauseElement(containingClassDecl);
+ if (baseTypeNode && !classDeclarationExtendsNull(containingClassDecl)) {
+ var superCall = getSuperCallInConstructor(container);
+ if (!superCall || superCall.end > node.pos) {
+ error(node, diagnosticMessage);
+ }
+ }
+ }
function checkThisExpression(node) {
var container = ts.getThisContainer(node, true);
var needToCaptureLexicalThis = false;
- if (container.kind === 150) {
- var containingClassDecl = container.parent;
- var baseTypeNode = ts.getClassExtendsHeritageClauseElement(containingClassDecl);
- if (baseTypeNode && !classDeclarationExtendsNull(containingClassDecl)) {
- var superCall = getSuperCallInConstructor(container);
- if (!superCall || superCall.end > node.pos) {
- error(node, ts.Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class);
- }
- }
+ if (container.kind === 151) {
+ checkThisBeforeSuper(node, container, ts.Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class);
}
- if (container.kind === 185) {
+ if (container.kind === 186) {
container = ts.getThisContainer(container, false);
needToCaptureLexicalThis = (languageVersion < 2);
}
switch (container.kind) {
- case 230:
+ case 232:
error(node, ts.Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body);
break;
- case 229:
+ case 231:
error(node, ts.Diagnostics.this_cannot_be_referenced_in_current_location);
break;
- case 150:
+ case 151:
if (isInConstructorArgumentInitializer(node, container)) {
error(node, ts.Diagnostics.this_cannot_be_referenced_in_constructor_arguments);
}
break;
+ case 148:
case 147:
- case 146:
if (ts.getModifierFlags(container) & 32) {
error(node, ts.Diagnostics.this_cannot_be_referenced_in_a_static_property_initializer);
}
break;
- case 142:
+ case 143:
error(node, ts.Diagnostics.this_cannot_be_referenced_in_a_computed_property_name);
break;
}
@@ -27851,8 +30367,8 @@ var ts;
}
if (ts.isFunctionLike(container) &&
(!isInParameterInitializerBeforeContainingFunction(node) || ts.getThisParameter(container))) {
- if (container.kind === 184 &&
- ts.isInJavaScriptFile(container.parent) &&
+ if (container.kind === 185 &&
+ container.parent.kind === 193 &&
ts.getSpecialPropertyAssignmentKind(container.parent) === 3) {
var className = container.parent
.left
@@ -27871,7 +30387,7 @@ var ts;
if (ts.isClassLike(container.parent)) {
var symbol = getSymbolOfNode(container.parent);
var type = ts.hasModifier(container, 32) ? getTypeOfSymbol(symbol) : getDeclaredTypeOfSymbol(symbol).thisType;
- return getFlowTypeOfReference(node, type, true, undefined);
+ return getFlowTypeOfReference(node, type);
}
if (ts.isInJavaScriptFile(node)) {
var type = getTypeForThisExpressionFromJSDoc(container);
@@ -27879,34 +30395,29 @@ var ts;
return type;
}
}
- if (compilerOptions.noImplicitThis) {
+ if (noImplicitThis) {
error(node, ts.Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation);
}
return anyType;
}
function getTypeForThisExpressionFromJSDoc(node) {
var jsdocType = ts.getJSDocType(node);
- if (jsdocType && jsdocType.kind === 274) {
+ if (jsdocType && jsdocType.kind === 278) {
var jsDocFunctionType = jsdocType;
- if (jsDocFunctionType.parameters.length > 0 && jsDocFunctionType.parameters[0].type.kind === 277) {
+ if (jsDocFunctionType.parameters.length > 0 && jsDocFunctionType.parameters[0].type.kind === 281) {
return getTypeFromTypeNode(jsDocFunctionType.parameters[0].type);
}
}
}
function isInConstructorArgumentInitializer(node, constructorDecl) {
- for (var n = node; n && n !== constructorDecl; n = n.parent) {
- if (n.kind === 144) {
- return true;
- }
- }
- return false;
+ return !!ts.findAncestor(node, function (n) { return n === constructorDecl ? "quit" : n.kind === 145; });
}
function checkSuperExpression(node) {
- var isCallExpression = node.parent.kind === 179 && node.parent.expression === node;
+ var isCallExpression = node.parent.kind === 180 && node.parent.expression === node;
var container = ts.getSuperContainer(node, true);
var needToCaptureLexicalThis = false;
if (!isCallExpression) {
- while (container && container.kind === 185) {
+ while (container && container.kind === 186) {
container = ts.getSuperContainer(container, true);
needToCaptureLexicalThis = languageVersion < 2;
}
@@ -27914,17 +30425,14 @@ var ts;
var canUseSuperExpression = isLegalUsageOfSuperExpression(container);
var nodeCheckFlag = 0;
if (!canUseSuperExpression) {
- var current = node;
- while (current && current !== container && current.kind !== 142) {
- current = current.parent;
- }
- if (current && current.kind === 142) {
+ var current = ts.findAncestor(node, function (n) { return n === container ? "quit" : n.kind === 143; });
+ if (current && current.kind === 143) {
error(node, ts.Diagnostics.super_cannot_be_referenced_in_a_computed_property_name);
}
else if (isCallExpression) {
error(node, ts.Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors);
}
- else if (!container || !container.parent || !(ts.isClassLike(container.parent) || container.parent.kind === 176)) {
+ else if (!container || !container.parent || !(ts.isClassLike(container.parent) || container.parent.kind === 177)) {
error(node, ts.Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions);
}
else {
@@ -27932,6 +30440,9 @@ var ts;
}
return unknownType;
}
+ if (!isCallExpression && container.kind === 151) {
+ checkThisBeforeSuper(node, container, ts.Diagnostics.super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class);
+ }
if ((ts.getModifierFlags(container) & 32) || isCallExpression) {
nodeCheckFlag = 512;
}
@@ -27939,7 +30450,7 @@ var ts;
nodeCheckFlag = 256;
}
getNodeLinks(node).flags |= nodeCheckFlag;
- if (container.kind === 149 && ts.getModifierFlags(container) & 256) {
+ if (container.kind === 150 && ts.getModifierFlags(container) & 256) {
if (ts.isSuperProperty(node.parent) && ts.isAssignmentTarget(node.parent)) {
getNodeLinks(container).flags |= 4096;
}
@@ -27950,7 +30461,7 @@ var ts;
if (needToCaptureLexicalThis) {
captureLexicalThis(node.parent, container);
}
- if (container.parent.kind === 176) {
+ if (container.parent.kind === 177) {
if (languageVersion < 2) {
error(node, ts.Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher);
return unknownType;
@@ -27968,7 +30479,7 @@ var ts;
}
return unknownType;
}
- if (container.kind === 150 && isInConstructorArgumentInitializer(node, container)) {
+ if (container.kind === 151 && isInConstructorArgumentInitializer(node, container)) {
error(node, ts.Diagnostics.super_cannot_be_referenced_in_constructor_arguments);
return unknownType;
}
@@ -27980,32 +30491,50 @@ var ts;
return false;
}
if (isCallExpression) {
- return container.kind === 150;
+ return container.kind === 151;
}
else {
- if (ts.isClassLike(container.parent) || container.parent.kind === 176) {
+ if (ts.isClassLike(container.parent) || container.parent.kind === 177) {
if (ts.getModifierFlags(container) & 32) {
- return container.kind === 149 ||
- container.kind === 148 ||
- container.kind === 151 ||
- container.kind === 152;
+ return container.kind === 150 ||
+ container.kind === 149 ||
+ container.kind === 152 ||
+ container.kind === 153;
}
else {
- return container.kind === 149 ||
- container.kind === 148 ||
- container.kind === 151 ||
+ return container.kind === 150 ||
+ container.kind === 149 ||
container.kind === 152 ||
+ container.kind === 153 ||
+ container.kind === 148 ||
container.kind === 147 ||
- container.kind === 146 ||
- container.kind === 150;
+ container.kind === 151;
}
}
}
return false;
}
}
+ function getContainingObjectLiteral(func) {
+ return (func.kind === 150 ||
+ func.kind === 152 ||
+ func.kind === 153) && func.parent.kind === 177 ? func.parent :
+ func.kind === 185 && func.parent.kind === 260 ? func.parent.parent :
+ undefined;
+ }
+ function getThisTypeArgument(type) {
+ return getObjectFlags(type) & 4 && type.target === globalThisType ? type.typeArguments[0] : undefined;
+ }
+ function getThisTypeFromContextualType(type) {
+ return mapType(type, function (t) {
+ return t.flags & 131072 ? ts.forEach(t.types, getThisTypeArgument) : getThisTypeArgument(t);
+ });
+ }
function getContextualThisParameterType(func) {
- if (isContextSensitiveFunctionOrObjectLiteralMethod(func) && func.kind !== 185) {
+ if (func.kind === 186) {
+ return undefined;
+ }
+ if (isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
var contextualSignature = getContextualSignature(func);
if (contextualSignature) {
var thisParameter = contextualSignature.thisParameter;
@@ -28014,29 +30543,55 @@ var ts;
}
}
}
+ if (noImplicitThis) {
+ var containingLiteral = getContainingObjectLiteral(func);
+ if (containingLiteral) {
+ var contextualType = getApparentTypeOfContextualType(containingLiteral);
+ var literal = containingLiteral;
+ var type = contextualType;
+ while (type) {
+ var thisType = getThisTypeFromContextualType(type);
+ if (thisType) {
+ return instantiateType(thisType, getContextualMapper(containingLiteral));
+ }
+ if (literal.parent.kind !== 260) {
+ break;
+ }
+ literal = literal.parent.parent;
+ type = getApparentTypeOfContextualType(literal);
+ }
+ return contextualType ? getNonNullableType(contextualType) : checkExpressionCached(containingLiteral);
+ }
+ if (func.parent.kind === 193 && func.parent.operatorToken.kind === 57) {
+ var target = func.parent.left;
+ if (target.kind === 178 || target.kind === 179) {
+ return checkExpressionCached(target.expression);
+ }
+ }
+ }
return undefined;
}
function getContextuallyTypedParameterType(parameter) {
var func = parameter.parent;
if (isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
var iife = ts.getImmediatelyInvokedFunctionExpression(func);
- if (iife) {
+ if (iife && iife.arguments) {
var indexOfParameter = ts.indexOf(func.parameters, parameter);
- if (iife.arguments && indexOfParameter < iife.arguments.length) {
- if (parameter.dotDotDotToken) {
- var restTypes = [];
- for (var i = indexOfParameter; i < iife.arguments.length; i++) {
- restTypes.push(getWidenedLiteralType(checkExpression(iife.arguments[i])));
- }
- return createArrayType(getUnionType(restTypes));
- }
- var links = getNodeLinks(iife);
- var cached = links.resolvedSignature;
- links.resolvedSignature = anySignature;
- var type = getWidenedLiteralType(checkExpression(iife.arguments[indexOfParameter]));
- links.resolvedSignature = cached;
- return type;
- }
+ if (parameter.dotDotDotToken) {
+ var restTypes = [];
+ for (var i = indexOfParameter; i < iife.arguments.length; i++) {
+ restTypes.push(getWidenedLiteralType(checkExpression(iife.arguments[i])));
+ }
+ return restTypes.length ? createArrayType(getUnionType(restTypes)) : undefined;
+ }
+ var links = getNodeLinks(iife);
+ var cached = links.resolvedSignature;
+ links.resolvedSignature = anySignature;
+ var type = indexOfParameter < iife.arguments.length ?
+ getWidenedLiteralType(checkExpression(iife.arguments[indexOfParameter])) :
+ parameter.initializer ? undefined : undefinedWideningType;
+ links.resolvedSignature = cached;
+ return type;
}
var contextualSignature = getContextualSignature(func);
if (contextualSignature) {
@@ -28061,7 +30616,7 @@ var ts;
if (declaration.type) {
return getTypeFromTypeNode(declaration.type);
}
- if (declaration.kind === 144) {
+ if (declaration.kind === 145) {
var type = getContextuallyTypedParameterType(declaration);
if (type) {
return type;
@@ -28072,11 +30627,11 @@ var ts;
}
if (ts.isBindingPattern(declaration.parent)) {
var parentDeclaration = declaration.parent.parent;
- var name_19 = declaration.propertyName || declaration.name;
- if (ts.isVariableLike(parentDeclaration) &&
+ var name = declaration.propertyName || declaration.name;
+ if (parentDeclaration.kind !== 175 &&
parentDeclaration.type &&
- !ts.isBindingPattern(name_19)) {
- var text = ts.getTextOfPropertyName(name_19);
+ !ts.isBindingPattern(name)) {
+ var text = ts.getTextOfPropertyName(name);
if (text) {
return getTypeOfPropertyOfType(getTypeFromTypeNode(parentDeclaration.type), text);
}
@@ -28087,33 +30642,34 @@ var ts;
}
function getContextualTypeForReturnExpression(node) {
var func = ts.getContainingFunction(node);
- if (ts.isAsyncFunctionLike(func)) {
- var contextualReturnType = getContextualReturnType(func);
- if (contextualReturnType) {
- return getPromisedType(contextualReturnType);
+ if (func) {
+ var functionFlags = ts.getFunctionFlags(func);
+ if (functionFlags & 1) {
+ return undefined;
}
- return undefined;
- }
- if (func && !func.asteriskToken) {
- return getContextualReturnType(func);
+ var contextualReturnType = getContextualReturnType(func);
+ return functionFlags & 2
+ ? contextualReturnType && getAwaitedTypeOfPromise(contextualReturnType)
+ : contextualReturnType;
}
return undefined;
}
function getContextualTypeForYieldOperand(node) {
var func = ts.getContainingFunction(node);
if (func) {
+ var functionFlags = ts.getFunctionFlags(func);
var contextualReturnType = getContextualReturnType(func);
if (contextualReturnType) {
return node.asteriskToken
? contextualReturnType
- : getElementTypeOfIterableIterator(contextualReturnType);
+ : getIteratedTypeOfGenerator(contextualReturnType, (functionFlags & 2) !== 0);
}
}
return undefined;
}
function isInParameterInitializerBeforeContainingFunction(node) {
while (node.parent && !ts.isFunctionLike(node.parent)) {
- if (node.parent.kind === 144 && node.parent.initializer === node) {
+ if (node.parent.kind === 145 && node.parent.initializer === node) {
return true;
}
node = node.parent;
@@ -28122,8 +30678,8 @@ var ts;
}
function getContextualReturnType(functionDecl) {
if (functionDecl.type ||
- functionDecl.kind === 150 ||
- functionDecl.kind === 151 && ts.getSetAccessorTypeAnnotationNode(ts.getDeclarationOfKind(functionDecl.symbol, 152))) {
+ functionDecl.kind === 151 ||
+ functionDecl.kind === 152 && ts.getSetAccessorTypeAnnotationNode(ts.getDeclarationOfKind(functionDecl.symbol, 153))) {
return getReturnTypeOfSignature(getSignatureFromDeclaration(functionDecl));
}
var signature = getContextualSignatureForFunctionLikeDeclaration(functionDecl);
@@ -28142,7 +30698,7 @@ var ts;
return undefined;
}
function getContextualTypeForSubstitutionExpression(template, substitutionExpression) {
- if (template.parent.kind === 181) {
+ if (template.parent.kind === 182) {
return getContextualTypeForArgument(template.parent, substitutionExpression);
}
return undefined;
@@ -28172,38 +30728,14 @@ var ts;
}
return undefined;
}
- function applyToContextualType(type, mapper) {
- if (!(type.flags & 65536)) {
- return mapper(type);
- }
- var types = type.types;
- var mappedType;
- var mappedTypes;
- for (var _i = 0, types_13 = types; _i < types_13.length; _i++) {
- var current = types_13[_i];
- var t = mapper(current);
- if (t) {
- if (!mappedType) {
- mappedType = t;
- }
- else if (!mappedTypes) {
- mappedTypes = [mappedType, t];
- }
- else {
- mappedTypes.push(t);
- }
- }
- }
- return mappedTypes ? getUnionType(mappedTypes) : mappedType;
- }
function getTypeOfPropertyOfContextualType(type, name) {
- return applyToContextualType(type, function (t) {
+ return mapType(type, function (t) {
var prop = t.flags & 229376 ? getPropertyOfType(t, name) : undefined;
return prop ? getTypeOfSymbol(prop) : undefined;
});
}
function getIndexTypeOfContextualType(type, kind) {
- return applyToContextualType(type, function (t) { return getIndexTypeOfStructuredType(t, kind); });
+ return mapType(type, function (t) { return getIndexTypeOfStructuredType(t, kind); });
}
function contextualTypeIsTupleLikeType(type) {
return !!(type.flags & 65536 ? ts.forEach(type.types, isTupleLikeType) : isTupleLikeType(type));
@@ -28238,7 +30770,7 @@ var ts;
var index = ts.indexOf(arrayLiteral.elements, node);
return getTypeOfPropertyOfContextualType(type, "" + index)
|| getIndexTypeOfContextualType(type, 1)
- || (languageVersion >= 2 ? getElementTypeOfIterable(type, undefined) : undefined);
+ || getIteratedTypeOrElementType(type, undefined, false, false, false);
}
return undefined;
}
@@ -28247,19 +30779,16 @@ var ts;
return node === conditional.whenTrue || node === conditional.whenFalse ? getContextualType(conditional) : undefined;
}
function getContextualTypeForJsxAttribute(attribute) {
- var kind = attribute.kind;
- var jsxElement = attribute.parent;
- var attrsType = getJsxElementAttributesType(jsxElement);
- if (attribute.kind === 250) {
- if (!attrsType || isTypeAny(attrsType)) {
+ var attributesType = getContextualType(attribute.parent);
+ if (ts.isJsxAttribute(attribute)) {
+ if (!attributesType || isTypeAny(attributesType)) {
return undefined;
}
- return getTypeOfPropertyOfType(attrsType, attribute.name.text);
+ return getTypeOfPropertyOfType(attributesType, attribute.name.text);
}
- else if (attribute.kind === 251) {
- return attrsType;
+ else {
+ return attributesType;
}
- ts.Debug.fail("Expected JsxAttribute or JsxSpreadAttribute, got ts.SyntaxKind[" + kind + "]");
}
function getApparentTypeOfContextualType(node) {
var type = getContextualType(node);
@@ -28274,45 +30803,52 @@ var ts;
}
var parent = node.parent;
switch (parent.kind) {
- case 223:
- case 144:
+ case 225:
+ case 145:
+ case 148:
case 147:
- case 146:
- case 174:
+ case 175:
return getContextualTypeForInitializerExpression(node);
- case 185:
- case 216:
+ case 186:
+ case 218:
return getContextualTypeForReturnExpression(node);
- case 195:
+ case 196:
return getContextualTypeForYieldOperand(parent);
- case 179:
case 180:
+ case 181:
return getContextualTypeForArgument(parent, node);
- case 182:
- case 200:
+ case 183:
+ case 201:
return getTypeFromTypeNode(parent.type);
- case 192:
+ case 193:
return getContextualTypeForBinaryOperand(node);
- case 257:
- case 258:
+ case 260:
+ case 261:
return getContextualTypeForObjectLiteralElement(parent);
- case 175:
+ case 176:
return getContextualTypeForElementExpression(node);
- case 193:
+ case 194:
return getContextualTypeForConditionalOperand(node);
- case 202:
- ts.Debug.assert(parent.parent.kind === 194);
+ case 204:
+ ts.Debug.assert(parent.parent.kind === 195);
return getContextualTypeForSubstitutionExpression(parent.parent, node);
- case 183:
+ case 184:
return getContextualType(parent);
- case 252:
+ case 255:
return getContextualType(parent);
- case 250:
- case 251:
+ case 252:
+ case 254:
return getContextualTypeForJsxAttribute(parent);
+ case 250:
+ case 249:
+ return getAttributesTypeFromJsxOpeningLikeElement(parent);
}
return undefined;
}
+ function getContextualMapper(node) {
+ node = ts.findAncestor(node, function (n) { return !!n.contextualMapper; });
+ return node ? node.contextualMapper : identityMapper;
+ }
function getNonGenericSignature(type, node) {
var signatures = getSignaturesOfStructuredType(type, 0);
if (signatures.length === 1) {
@@ -28337,7 +30873,7 @@ var ts;
return sourceLength < targetParameterCount;
}
function isFunctionExpressionOrArrowFunction(node) {
- return node.kind === 184 || node.kind === 185;
+ return node.kind === 185 || node.kind === 186;
}
function getContextualSignatureForFunctionLikeDeclaration(node) {
return isFunctionExpressionOrArrowFunction(node) || ts.isObjectLiteralMethod(node)
@@ -28350,7 +30886,7 @@ var ts;
getApparentTypeOfContextualType(node);
}
function getContextualSignature(node) {
- ts.Debug.assert(node.kind !== 149 || ts.isObjectLiteralMethod(node));
+ ts.Debug.assert(node.kind !== 150 || ts.isObjectLiteralMethod(node));
var type = getContextualTypeForFunctionLikeDeclaration(node);
if (!type) {
return undefined;
@@ -28360,8 +30896,8 @@ var ts;
}
var signatureList;
var types = type.types;
- for (var _i = 0, types_14 = types; _i < types_14.length; _i++) {
- var current = types_14[_i];
+ for (var _i = 0, types_17 = types; _i < types_17.length; _i++) {
+ var current = types_17[_i];
var signature = getNonGenericSignature(current, node);
if (signature) {
if (!signatureList) {
@@ -28383,37 +30919,37 @@ var ts;
}
return result;
}
- function isInferentialContext(mapper) {
- return mapper && mapper.context;
- }
- function checkSpreadExpression(node, contextualMapper) {
- var arrayOrIterableType = checkExpressionCached(node.expression, contextualMapper);
- return checkIteratedTypeOrElementType(arrayOrIterableType, node.expression, false);
+ function checkSpreadExpression(node, checkMode) {
+ if (languageVersion < 2 && compilerOptions.downlevelIteration) {
+ checkExternalEmitHelpers(node, 1536);
+ }
+ var arrayOrIterableType = checkExpression(node.expression, checkMode);
+ return checkIteratedTypeOrElementType(arrayOrIterableType, node.expression, false, false);
}
function hasDefaultValue(node) {
- return (node.kind === 174 && !!node.initializer) ||
- (node.kind === 192 && node.operatorToken.kind === 57);
+ return (node.kind === 175 && !!node.initializer) ||
+ (node.kind === 193 && node.operatorToken.kind === 57);
}
- function checkArrayLiteral(node, contextualMapper) {
+ function checkArrayLiteral(node, checkMode) {
var elements = node.elements;
var hasSpreadElement = false;
var elementTypes = [];
var inDestructuringPattern = ts.isAssignmentTarget(node);
for (var _i = 0, elements_1 = elements; _i < elements_1.length; _i++) {
var e = elements_1[_i];
- if (inDestructuringPattern && e.kind === 196) {
- var restArrayType = checkExpression(e.expression, contextualMapper);
+ if (inDestructuringPattern && e.kind === 197) {
+ var restArrayType = checkExpression(e.expression, checkMode);
var restElementType = getIndexTypeOfType(restArrayType, 1) ||
- (languageVersion >= 2 ? getElementTypeOfIterable(restArrayType, undefined) : undefined);
+ getIteratedTypeOrElementType(restArrayType, undefined, false, false, false);
if (restElementType) {
elementTypes.push(restElementType);
}
}
else {
- var type = checkExpressionForMutableLocation(e, contextualMapper);
+ var type = checkExpressionForMutableLocation(e, checkMode);
elementTypes.push(type);
}
- hasSpreadElement = hasSpreadElement || e.kind === 196;
+ hasSpreadElement = hasSpreadElement || e.kind === 197;
}
if (!hasSpreadElement) {
if (inDestructuringPattern && elementTypes.length) {
@@ -28424,7 +30960,7 @@ var ts;
var contextualType = getApparentTypeOfContextualType(node);
if (contextualType && contextualTypeIsTupleLikeType(contextualType)) {
var pattern = contextualType.pattern;
- if (pattern && (pattern.kind === 173 || pattern.kind === 175)) {
+ if (pattern && (pattern.kind === 174 || pattern.kind === 176)) {
var patternElements = pattern.elements;
for (var i = elementTypes.length; i < patternElements.length; i++) {
var patternElement = patternElements[i];
@@ -28432,7 +30968,7 @@ var ts;
elementTypes.push(contextualType.typeArguments[i]);
}
else {
- if (patternElement.kind !== 198) {
+ if (patternElement.kind !== 199) {
error(patternElement, ts.Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value);
}
elementTypes.push(unknownType);
@@ -28449,7 +30985,7 @@ var ts;
strictNullChecks ? neverType : undefinedWideningType);
}
function isNumericName(name) {
- return name.kind === 142 ? isNumericComputedName(name) : isNumericLiteralName(name.text);
+ return name.kind === 143 ? isNumericComputedName(name) : isNumericLiteralName(name.text);
}
function isNumericComputedName(name) {
return isTypeAnyOrAllConstituentTypesHaveKind(checkComputedPropertyName(name), 340);
@@ -28486,7 +31022,7 @@ var ts;
var unionType = propTypes.length ? getUnionType(propTypes, true) : undefinedType;
return createIndexInfo(unionType, false);
}
- function checkObjectLiteral(node, contextualMapper) {
+ function checkObjectLiteral(node, checkMode) {
var inDestructuringPattern = ts.isAssignmentTarget(node);
checkGrammarObjectLiteralExpression(node, inDestructuringPattern);
var propertiesTable = ts.createMap();
@@ -28495,7 +31031,8 @@ var ts;
var propagatedFlags = 0;
var contextualType = getApparentTypeOfContextualType(node);
var contextualTypeHasPattern = contextualType && contextualType.pattern &&
- (contextualType.pattern.kind === 172 || contextualType.pattern.kind === 176);
+ (contextualType.pattern.kind === 173 || contextualType.pattern.kind === 177);
+ var isJSObjectLiteral = !contextualType && ts.isInJavaScriptFile(node);
var typeFlags = 0;
var patternWithComputedProperties = false;
var hasComputedStringProperty = false;
@@ -28504,27 +31041,27 @@ var ts;
for (var i = 0; i < node.properties.length; i++) {
var memberDecl = node.properties[i];
var member = memberDecl.symbol;
- if (memberDecl.kind === 257 ||
- memberDecl.kind === 258 ||
+ if (memberDecl.kind === 260 ||
+ memberDecl.kind === 261 ||
ts.isObjectLiteralMethod(memberDecl)) {
var type = void 0;
- if (memberDecl.kind === 257) {
- type = checkPropertyAssignment(memberDecl, contextualMapper);
+ if (memberDecl.kind === 260) {
+ type = checkPropertyAssignment(memberDecl, checkMode);
}
- else if (memberDecl.kind === 149) {
- type = checkObjectLiteralMethod(memberDecl, contextualMapper);
+ else if (memberDecl.kind === 150) {
+ type = checkObjectLiteralMethod(memberDecl, checkMode);
}
else {
- ts.Debug.assert(memberDecl.kind === 258);
- type = checkExpressionForMutableLocation(memberDecl.name, contextualMapper);
+ ts.Debug.assert(memberDecl.kind === 261);
+ type = checkExpressionForMutableLocation(memberDecl.name, checkMode);
}
typeFlags |= type.flags;
- var prop = createSymbol(4 | 67108864 | member.flags, member.name);
+ var prop = createSymbol(4 | member.flags, member.name);
if (inDestructuringPattern) {
- var isOptional = (memberDecl.kind === 257 && hasDefaultValue(memberDecl.initializer)) ||
- (memberDecl.kind === 258 && memberDecl.objectAssignmentInitializer);
+ var isOptional = (memberDecl.kind === 260 && hasDefaultValue(memberDecl.initializer)) ||
+ (memberDecl.kind === 261 && memberDecl.objectAssignmentInitializer);
if (isOptional) {
- prop.flags |= 536870912;
+ prop.flags |= 67108864;
}
if (ts.hasDynamicName(memberDecl)) {
patternWithComputedProperties = true;
@@ -28533,9 +31070,9 @@ var ts;
else if (contextualTypeHasPattern && !(getObjectFlags(contextualType) & 512)) {
var impliedProp = getPropertyOfType(contextualType, member.name);
if (impliedProp) {
- prop.flags |= impliedProp.flags & 536870912;
+ prop.flags |= impliedProp.flags & 67108864;
}
- else if (!compilerOptions.suppressExcessPropertyErrors) {
+ else if (!compilerOptions.suppressExcessPropertyErrors && !getIndexInfoOfType(contextualType, 0)) {
error(memberDecl.name, ts.Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(member), typeToString(contextualType));
}
}
@@ -28548,9 +31085,12 @@ var ts;
prop.target = member;
member = prop;
}
- else if (memberDecl.kind === 259) {
+ else if (memberDecl.kind === 262) {
+ if (languageVersion < 2) {
+ checkExternalEmitHelpers(memberDecl, 2);
+ }
if (propertiesArray.length > 0) {
- spread = getSpreadType(spread, createObjectLiteralType(), true);
+ spread = getSpreadType(spread, createObjectLiteralType());
propertiesArray = [];
propertiesTable = ts.createMap();
hasComputedStringProperty = false;
@@ -28558,17 +31098,17 @@ var ts;
typeFlags = 0;
}
var type = checkExpression(memberDecl.expression);
- if (!(type.flags & (32768 | 1))) {
+ if (!isValidSpreadType(type)) {
error(memberDecl, ts.Diagnostics.Spread_types_may_only_be_created_from_object_types);
return unknownType;
}
- spread = getSpreadType(spread, type, false);
+ spread = getSpreadType(spread, type);
offset = i + 1;
continue;
}
else {
- ts.Debug.assert(memberDecl.kind === 151 || memberDecl.kind === 152);
- checkAccessorDeclaration(memberDecl);
+ ts.Debug.assert(memberDecl.kind === 152 || memberDecl.kind === 153);
+ checkNodeDeferred(memberDecl);
}
if (ts.hasDynamicName(memberDecl)) {
if (isNumericName(memberDecl.name)) {
@@ -28579,34 +31119,36 @@ var ts;
}
}
else {
- propertiesTable[member.name] = member;
+ propertiesTable.set(member.name, member);
}
propertiesArray.push(member);
}
if (contextualTypeHasPattern) {
for (var _i = 0, _a = getPropertiesOfType(contextualType); _i < _a.length; _i++) {
var prop = _a[_i];
- if (!propertiesTable[prop.name]) {
- if (!(prop.flags & 536870912)) {
+ if (!propertiesTable.get(prop.name)) {
+ if (!(prop.flags & 67108864)) {
error(prop.valueDeclaration || prop.bindingElement, ts.Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value);
}
- propertiesTable[prop.name] = prop;
+ propertiesTable.set(prop.name, prop);
propertiesArray.push(prop);
}
}
}
if (spread !== emptyObjectType) {
if (propertiesArray.length > 0) {
- spread = getSpreadType(spread, createObjectLiteralType(), true);
+ spread = getSpreadType(spread, createObjectLiteralType());
+ }
+ if (spread.flags & 32768) {
+ spread.flags |= propagatedFlags;
+ spread.symbol = node.symbol;
}
- spread.flags |= propagatedFlags;
- spread.symbol = node.symbol;
return spread;
}
return createObjectLiteralType();
function createObjectLiteralType() {
- var stringIndexInfo = hasComputedStringProperty ? getObjectLiteralIndexInfo(node.properties, offset, propertiesArray, 0) : undefined;
- var numberIndexInfo = hasComputedNumberProperty ? getObjectLiteralIndexInfo(node.properties, offset, propertiesArray, 1) : undefined;
+ var stringIndexInfo = isJSObjectLiteral ? jsObjectLiteralIndexInfo : hasComputedStringProperty ? getObjectLiteralIndexInfo(node.properties, offset, propertiesArray, 0) : undefined;
+ var numberIndexInfo = hasComputedNumberProperty && !isJSObjectLiteral ? getObjectLiteralIndexInfo(node.properties, offset, propertiesArray, 1) : undefined;
var result = createAnonymousType(node.symbol, propertiesTable, emptyArray, emptyArray, stringIndexInfo, numberIndexInfo);
var freshObjectLiteralFlag = compilerOptions.suppressExcessPropertyErrors ? 0 : 1048576;
result.flags |= 4194304 | freshObjectLiteralFlag | (typeFlags & 14680064);
@@ -28623,9 +31165,14 @@ var ts;
return result;
}
}
+ function isValidSpreadType(type) {
+ return !!(type.flags & (1 | 4096 | 2048 | 16777216) ||
+ type.flags & 32768 && !isGenericMappedType(type) ||
+ type.flags & 196608 && !ts.forEach(type.types, function (t) { return !isValidSpreadType(t); }));
+ }
function checkJsxSelfClosingElement(node) {
checkJsxOpeningLikeElement(node);
- return jsxElementType || anyType;
+ return getJsxGlobalElementType() || anyType;
}
function checkJsxElement(node) {
checkJsxOpeningLikeElement(node.openingElement);
@@ -28638,85 +31185,105 @@ var ts;
for (var _i = 0, _a = node.children; _i < _a.length; _i++) {
var child = _a[_i];
switch (child.kind) {
- case 252:
+ case 255:
checkJsxExpression(child);
break;
- case 246:
+ case 248:
checkJsxElement(child);
break;
- case 247:
+ case 249:
checkJsxSelfClosingElement(child);
break;
}
}
- return jsxElementType || anyType;
+ return getJsxGlobalElementType() || anyType;
}
function isUnhyphenatedJsxName(name) {
return name.indexOf("-") < 0;
}
function isJsxIntrinsicIdentifier(tagName) {
- if (tagName.kind === 177 || tagName.kind === 98) {
+ if (tagName.kind === 178 || tagName.kind === 98) {
return false;
}
else {
return ts.isIntrinsicJsxName(tagName.text);
}
}
- function checkJsxAttribute(node, elementAttributesType, nameTable) {
- var correspondingPropType = undefined;
- if (elementAttributesType === emptyObjectType && isUnhyphenatedJsxName(node.name.text)) {
- error(node.parent, ts.Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, getJsxElementPropertiesName());
- }
- else if (elementAttributesType && !isTypeAny(elementAttributesType)) {
- var correspondingPropSymbol = getPropertyOfType(elementAttributesType, node.name.text);
- correspondingPropType = correspondingPropSymbol && getTypeOfSymbol(correspondingPropSymbol);
- if (isUnhyphenatedJsxName(node.name.text)) {
- var attributeType = getTypeOfPropertyOfType(elementAttributesType, ts.getTextOfPropertyName(node.name)) || getIndexTypeOfType(elementAttributesType, 0);
- if (attributeType) {
- correspondingPropType = attributeType;
+ function createJsxAttributesTypeFromAttributesProperty(openingLikeElement, filter, checkMode) {
+ var attributes = openingLikeElement.attributes;
+ var attributesTable = ts.createMap();
+ var spread = emptyObjectType;
+ var attributesArray = [];
+ for (var _i = 0, _a = attributes.properties; _i < _a.length; _i++) {
+ var attributeDecl = _a[_i];
+ var member = attributeDecl.symbol;
+ if (ts.isJsxAttribute(attributeDecl)) {
+ var exprType = attributeDecl.initializer ?
+ checkExpression(attributeDecl.initializer, checkMode) :
+ trueType;
+ var attributeSymbol = createSymbol(4 | 134217728 | member.flags, member.name);
+ attributeSymbol.declarations = member.declarations;
+ attributeSymbol.parent = member.parent;
+ if (member.valueDeclaration) {
+ attributeSymbol.valueDeclaration = member.valueDeclaration;
}
- else {
- if (!correspondingPropType) {
- error(node.name, ts.Diagnostics.Property_0_does_not_exist_on_type_1, node.name.text, typeToString(elementAttributesType));
- return unknownType;
- }
+ attributeSymbol.type = exprType;
+ attributeSymbol.target = member;
+ attributesTable.set(attributeSymbol.name, attributeSymbol);
+ attributesArray.push(attributeSymbol);
+ }
+ else {
+ ts.Debug.assert(attributeDecl.kind === 254);
+ if (attributesArray.length > 0) {
+ spread = getSpreadType(spread, createJsxAttributesType(attributes.symbol, attributesTable));
+ attributesArray = [];
+ attributesTable = ts.createMap();
+ }
+ var exprType = checkExpression(attributeDecl.expression);
+ if (!isValidSpreadType(exprType)) {
+ error(attributeDecl, ts.Diagnostics.Spread_types_may_only_be_created_from_object_types);
+ return anyType;
+ }
+ if (isTypeAny(exprType)) {
+ return anyType;
}
+ spread = getSpreadType(spread, exprType);
}
}
- var exprType;
- if (node.initializer) {
- exprType = checkExpression(node.initializer);
+ if (spread !== emptyObjectType) {
+ if (attributesArray.length > 0) {
+ spread = getSpreadType(spread, createJsxAttributesType(attributes.symbol, attributesTable));
+ attributesArray = [];
+ attributesTable = ts.createMap();
+ }
+ attributesArray = getPropertiesOfType(spread);
}
- else {
- exprType = booleanType;
+ attributesTable = ts.createMap();
+ if (attributesArray) {
+ ts.forEach(attributesArray, function (attr) {
+ if (!filter || filter(attr)) {
+ attributesTable.set(attr.name, attr);
+ }
+ });
}
- if (correspondingPropType) {
- checkTypeAssignableTo(exprType, correspondingPropType, node);
+ return createJsxAttributesType(attributes.symbol, attributesTable);
+ function createJsxAttributesType(symbol, attributesTable) {
+ var result = createAnonymousType(symbol, attributesTable, emptyArray, emptyArray, undefined, undefined);
+ var freshObjectLiteralFlag = compilerOptions.suppressExcessPropertyErrors ? 0 : 1048576;
+ result.flags |= 33554432 | 4194304 | freshObjectLiteralFlag;
+ result.objectFlags |= 128;
+ return result;
}
- nameTable[node.name.text] = true;
- return exprType;
}
- function checkJsxSpreadAttribute(node, elementAttributesType, nameTable) {
- var type = checkExpression(node.expression);
- var props = getPropertiesOfType(type);
- for (var _i = 0, props_2 = props; _i < props_2.length; _i++) {
- var prop = props_2[_i];
- if (!nameTable[prop.name]) {
- var targetPropSym = getPropertyOfType(elementAttributesType, prop.name);
- if (targetPropSym) {
- var msg = ts.chainDiagnosticMessages(undefined, ts.Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property, prop.name);
- checkTypeAssignableTo(getTypeOfSymbol(prop), getTypeOfSymbol(targetPropSym), node, undefined, msg);
- }
- nameTable[prop.name] = true;
- }
- }
- return type;
+ function checkJsxAttributes(node, checkMode) {
+ return createJsxAttributesTypeFromAttributesProperty(node.parent, undefined, checkMode);
}
function getJsxType(name) {
- if (jsxTypes[name] === undefined) {
- return jsxTypes[name] = getExportedTypeFromNamespace(JsxNames.JSX, name) || unknownType;
+ var jsxType = jsxTypes.get(name);
+ if (jsxType === undefined) {
+ jsxTypes.set(name, jsxType = getExportedTypeFromNamespace(JsxNames.JSX, name) || unknownType);
}
- return jsxTypes[name];
+ return jsxType;
}
function getIntrinsicTagSymbol(node) {
var links = getNodeLinks(node);
@@ -28737,7 +31304,7 @@ var ts;
return links.resolvedSymbol = unknownSymbol;
}
else {
- if (compilerOptions.noImplicitAny) {
+ if (noImplicitAny) {
error(node, ts.Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, JsxNames.IntrinsicElements);
}
return links.resolvedSymbol = unknownSymbol;
@@ -28781,23 +31348,86 @@ var ts;
return undefined;
}
}
- function getResolvedJsxType(node, elemType, elemClassType) {
- if (!elemType) {
- elemType = checkExpression(node.tagName);
+ function defaultTryGetJsxStatelessFunctionAttributesType(openingLikeElement, elementType, elemInstanceType, elementClassType) {
+ ts.Debug.assert(!(elementType.flags & 65536));
+ if (!elementClassType || !isTypeAssignableTo(elemInstanceType, elementClassType)) {
+ var jsxStatelessElementType = getJsxGlobalStatelessElementType();
+ if (jsxStatelessElementType) {
+ var callSignature = getResolvedJsxStatelessFunctionSignature(openingLikeElement, elementType, undefined);
+ if (callSignature !== unknownSignature) {
+ var callReturnType = callSignature && getReturnTypeOfSignature(callSignature);
+ var paramType = callReturnType && (callSignature.parameters.length === 0 ? emptyObjectType : getTypeOfSymbol(callSignature.parameters[0]));
+ if (callReturnType && isTypeAssignableTo(callReturnType, jsxStatelessElementType)) {
+ var intrinsicAttributes = getJsxType(JsxNames.IntrinsicAttributes);
+ if (intrinsicAttributes !== unknownType) {
+ paramType = intersectTypes(intrinsicAttributes, paramType);
+ }
+ return paramType;
+ }
+ }
+ }
+ }
+ return undefined;
+ }
+ function tryGetAllJsxStatelessFunctionAttributesType(openingLikeElement, elementType, elemInstanceType, elementClassType) {
+ ts.Debug.assert(!(elementType.flags & 65536));
+ if (!elementClassType || !isTypeAssignableTo(elemInstanceType, elementClassType)) {
+ var jsxStatelessElementType = getJsxGlobalStatelessElementType();
+ if (jsxStatelessElementType) {
+ var candidatesOutArray = [];
+ getResolvedJsxStatelessFunctionSignature(openingLikeElement, elementType, candidatesOutArray);
+ var result = void 0;
+ var allMatchingAttributesType = void 0;
+ for (var _i = 0, candidatesOutArray_1 = candidatesOutArray; _i < candidatesOutArray_1.length; _i++) {
+ var candidate = candidatesOutArray_1[_i];
+ var callReturnType = getReturnTypeOfSignature(candidate);
+ var paramType = callReturnType && (candidate.parameters.length === 0 ? emptyObjectType : getTypeOfSymbol(candidate.parameters[0]));
+ if (callReturnType && isTypeAssignableTo(callReturnType, jsxStatelessElementType)) {
+ var shouldBeCandidate = true;
+ for (var _a = 0, _b = openingLikeElement.attributes.properties; _a < _b.length; _a++) {
+ var attribute = _b[_a];
+ if (ts.isJsxAttribute(attribute) &&
+ isUnhyphenatedJsxName(attribute.name.text) &&
+ !getPropertyOfType(paramType, attribute.name.text)) {
+ shouldBeCandidate = false;
+ break;
+ }
+ }
+ if (shouldBeCandidate) {
+ result = intersectTypes(result, paramType);
+ }
+ allMatchingAttributesType = intersectTypes(allMatchingAttributesType, paramType);
+ }
+ }
+ if (!result) {
+ result = allMatchingAttributesType;
+ }
+ var intrinsicAttributes = getJsxType(JsxNames.IntrinsicAttributes);
+ if (intrinsicAttributes !== unknownType) {
+ result = intersectTypes(intrinsicAttributes, result);
+ }
+ return result;
+ }
+ }
+ return undefined;
+ }
+ function resolveCustomJsxElementAttributesType(openingLikeElement, shouldIncludeAllStatelessAttributesType, elementType, elementClassType) {
+ if (!elementType) {
+ elementType = checkExpression(openingLikeElement.tagName);
}
- if (elemType.flags & 65536) {
- var types = elemType.types;
- return getUnionType(ts.map(types, function (type) {
- return getResolvedJsxType(node, type, elemClassType);
+ if (elementType.flags & 65536) {
+ var types = elementType.types;
+ return getUnionType(types.map(function (type) {
+ return resolveCustomJsxElementAttributesType(openingLikeElement, shouldIncludeAllStatelessAttributesType, type, elementClassType);
}), true);
}
- if (elemType.flags & 2) {
+ if (elementType.flags & 2) {
return anyType;
}
- else if (elemType.flags & 32) {
+ else if (elementType.flags & 32) {
var intrinsicElementsType = getJsxType(JsxNames.IntrinsicElements);
if (intrinsicElementsType !== unknownType) {
- var stringLiteralTypeName = elemType.text;
+ var stringLiteralTypeName = elementType.text;
var intrinsicProp = getPropertyOfType(intrinsicElementsType, stringLiteralTypeName);
if (intrinsicProp) {
return getTypeOfSymbol(intrinsicProp);
@@ -28806,28 +31436,19 @@ var ts;
if (indexSignatureType) {
return indexSignatureType;
}
- error(node, ts.Diagnostics.Property_0_does_not_exist_on_type_1, stringLiteralTypeName, "JSX." + JsxNames.IntrinsicElements);
+ error(openingLikeElement, ts.Diagnostics.Property_0_does_not_exist_on_type_1, stringLiteralTypeName, "JSX." + JsxNames.IntrinsicElements);
}
return anyType;
}
- var elemInstanceType = getJsxElementInstanceType(node, elemType);
- if (!elemClassType || !isTypeAssignableTo(elemInstanceType, elemClassType)) {
- if (jsxElementType) {
- var callSignatures = elemType && getSignaturesOfType(elemType, 0);
- var callSignature = callSignatures && callSignatures.length > 0 && callSignatures[0];
- var callReturnType = callSignature && getReturnTypeOfSignature(callSignature);
- var paramType = callReturnType && (callSignature.parameters.length === 0 ? emptyObjectType : getTypeOfSymbol(callSignature.parameters[0]));
- if (callReturnType && isTypeAssignableTo(callReturnType, jsxElementType)) {
- var intrinsicAttributes = getJsxType(JsxNames.IntrinsicAttributes);
- if (intrinsicAttributes !== unknownType) {
- paramType = intersectTypes(intrinsicAttributes, paramType);
- }
- return paramType;
- }
- }
+ var elemInstanceType = getJsxElementInstanceType(openingLikeElement, elementType);
+ var statelessAttributesType = shouldIncludeAllStatelessAttributesType ?
+ tryGetAllJsxStatelessFunctionAttributesType(openingLikeElement, elementType, elemInstanceType, elementClassType) :
+ defaultTryGetJsxStatelessFunctionAttributesType(openingLikeElement, elementType, elemInstanceType, elementClassType);
+ if (statelessAttributesType) {
+ return statelessAttributesType;
}
- if (elemClassType) {
- checkTypeRelatedTo(elemInstanceType, elemClassType, assignableRelation, node, ts.Diagnostics.JSX_element_type_0_is_not_a_constructor_function_for_JSX_elements);
+ if (elementClassType) {
+ checkTypeRelatedTo(elemInstanceType, elementClassType, assignableRelation, openingLikeElement, ts.Diagnostics.JSX_element_type_0_is_not_a_constructor_function_for_JSX_elements);
}
if (isTypeAny(elemInstanceType)) {
return elemInstanceType;
@@ -28847,10 +31468,6 @@ var ts;
else if (isTypeAny(attributesType) || (attributesType === unknownType)) {
return attributesType;
}
- else if (attributesType.flags & 65536) {
- error(node.tagName, ts.Diagnostics.JSX_element_attributes_type_0_may_not_be_a_union_type, typeToString(attributesType));
- return anyType;
- }
else {
var apparentAttributesType = attributesType;
var intrinsicClassAttribs = getJsxType(JsxNames.IntrinsicClassAttributes);
@@ -28873,38 +31490,72 @@ var ts;
}
}
}
- function getJsxElementAttributesType(node) {
+ function getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node) {
+ ts.Debug.assert(isJsxIntrinsicIdentifier(node.tagName));
var links = getNodeLinks(node);
- if (!links.resolvedJsxType) {
- if (isJsxIntrinsicIdentifier(node.tagName)) {
- var symbol = getIntrinsicTagSymbol(node);
- if (links.jsxFlags & 1) {
- return links.resolvedJsxType = getTypeOfSymbol(symbol);
- }
- else if (links.jsxFlags & 2) {
- return links.resolvedJsxType = getIndexInfoOfSymbol(symbol, 0).type;
- }
- else {
- return links.resolvedJsxType = unknownType;
- }
+ if (!links.resolvedJsxElementAttributesType) {
+ var symbol = getIntrinsicTagSymbol(node);
+ if (links.jsxFlags & 1) {
+ return links.resolvedJsxElementAttributesType = getTypeOfSymbol(symbol);
+ }
+ else if (links.jsxFlags & 2) {
+ return links.resolvedJsxElementAttributesType = getIndexInfoOfSymbol(symbol, 0).type;
}
else {
- var elemClassType = getJsxGlobalElementClassType();
- return links.resolvedJsxType = getResolvedJsxType(node, undefined, elemClassType);
+ return links.resolvedJsxElementAttributesType = unknownType;
}
}
- return links.resolvedJsxType;
+ return links.resolvedJsxElementAttributesType;
+ }
+ function getCustomJsxElementAttributesType(node, shouldIncludeAllStatelessAttributesType) {
+ var links = getNodeLinks(node);
+ if (!links.resolvedJsxElementAttributesType) {
+ var elemClassType = getJsxGlobalElementClassType();
+ return links.resolvedJsxElementAttributesType = resolveCustomJsxElementAttributesType(node, shouldIncludeAllStatelessAttributesType, undefined, elemClassType);
+ }
+ return links.resolvedJsxElementAttributesType;
+ }
+ function getAllAttributesTypeFromJsxOpeningLikeElement(node) {
+ if (isJsxIntrinsicIdentifier(node.tagName)) {
+ return getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node);
+ }
+ else {
+ return getCustomJsxElementAttributesType(node, true);
+ }
+ }
+ function getAttributesTypeFromJsxOpeningLikeElement(node) {
+ if (isJsxIntrinsicIdentifier(node.tagName)) {
+ return getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node);
+ }
+ else {
+ return getCustomJsxElementAttributesType(node, false);
+ }
}
function getJsxAttributePropertySymbol(attrib) {
- var attributesType = getJsxElementAttributesType(attrib.parent);
+ var attributesType = getAttributesTypeFromJsxOpeningLikeElement(attrib.parent.parent);
var prop = getPropertyOfType(attributesType, attrib.name.text);
return prop || unknownSymbol;
}
function getJsxGlobalElementClassType() {
- if (!jsxElementClassType) {
- jsxElementClassType = getExportedTypeFromNamespace(JsxNames.JSX, JsxNames.ElementClass);
+ if (!deferredJsxElementClassType) {
+ deferredJsxElementClassType = getExportedTypeFromNamespace(JsxNames.JSX, JsxNames.ElementClass);
+ }
+ return deferredJsxElementClassType;
+ }
+ function getJsxGlobalElementType() {
+ if (!deferredJsxElementType) {
+ deferredJsxElementType = getExportedTypeFromNamespace(JsxNames.JSX, JsxNames.Element);
+ }
+ return deferredJsxElementType;
+ }
+ function getJsxGlobalStatelessElementType() {
+ if (!deferredJsxStatelessElementType) {
+ var jsxElementType = getJsxGlobalElementType();
+ if (jsxElementType) {
+ deferredJsxStatelessElementType = getUnionType([jsxElementType, nullType]);
+ }
}
- return jsxElementClassType;
+ return deferredJsxStatelessElementType;
}
function getJsxIntrinsicTagNames() {
var intrinsics = getJsxType(JsxNames.IntrinsicElements);
@@ -28914,8 +31565,8 @@ var ts;
if ((compilerOptions.jsx || 0) === 0) {
error(errorNode, ts.Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided);
}
- if (jsxElementType === undefined) {
- if (compilerOptions.noImplicitAny) {
+ if (getJsxGlobalElementType() === undefined) {
+ if (noImplicitAny) {
error(errorNode, ts.Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist);
}
}
@@ -28932,61 +31583,83 @@ var ts;
markAliasSymbolAsReferenced(reactSym);
}
}
- var targetAttributesType = getJsxElementAttributesType(node);
- var nameTable = ts.createMap();
- var sawSpreadedAny = false;
- for (var i = node.attributes.length - 1; i >= 0; i--) {
- if (node.attributes[i].kind === 250) {
- checkJsxAttribute((node.attributes[i]), targetAttributesType, nameTable);
- }
- else {
- ts.Debug.assert(node.attributes[i].kind === 251);
- var spreadType = checkJsxSpreadAttribute((node.attributes[i]), targetAttributesType, nameTable);
- if (isTypeAny(spreadType)) {
- sawSpreadedAny = true;
- }
- }
+ checkJsxAttributesAssignableToTagNameAttributes(node);
+ }
+ function checkJsxAttributesAssignableToTagNameAttributes(openingLikeElement) {
+ var targetAttributesType = isJsxIntrinsicIdentifier(openingLikeElement.tagName) ?
+ getIntrinsicAttributesTypeFromJsxOpeningLikeElement(openingLikeElement) :
+ getCustomJsxElementAttributesType(openingLikeElement, false);
+ var sourceAttributesType = createJsxAttributesTypeFromAttributesProperty(openingLikeElement, function (attribute) {
+ return isUnhyphenatedJsxName(attribute.name) || !!(getPropertyOfType(targetAttributesType, attribute.name));
+ });
+ if (targetAttributesType === emptyObjectType && (isTypeAny(sourceAttributesType) || sourceAttributesType.properties.length > 0)) {
+ error(openingLikeElement, ts.Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, getJsxElementPropertiesName());
}
- if (targetAttributesType && !sawSpreadedAny) {
- var targetProperties = getPropertiesOfType(targetAttributesType);
- for (var i = 0; i < targetProperties.length; i++) {
- if (!(targetProperties[i].flags & 536870912) &&
- !nameTable[targetProperties[i].name]) {
- error(node, ts.Diagnostics.Property_0_is_missing_in_type_1, targetProperties[i].name, typeToString(targetAttributesType));
- }
- }
+ else {
+ checkTypeAssignableTo(sourceAttributesType, targetAttributesType, openingLikeElement.attributes.properties.length > 0 ? openingLikeElement.attributes : openingLikeElement);
}
}
- function checkJsxExpression(node) {
+ function checkJsxExpression(node, checkMode) {
if (node.expression) {
- return checkExpression(node.expression);
+ var type = checkExpression(node.expression, checkMode);
+ if (node.dotDotDotToken && type !== anyType && !isArrayType(type)) {
+ error(node, ts.Diagnostics.JSX_spread_child_must_be_an_array_type, node.toString(), typeToString(type));
+ }
+ return type;
}
else {
return unknownType;
}
}
function getDeclarationKindFromSymbol(s) {
- return s.valueDeclaration ? s.valueDeclaration.kind : 147;
+ return s.valueDeclaration ? s.valueDeclaration.kind : 148;
}
function getDeclarationModifierFlagsFromSymbol(s) {
- return s.valueDeclaration ? ts.getCombinedModifierFlags(s.valueDeclaration) : s.flags & 134217728 ? 4 | 32 : 0;
+ if (s.valueDeclaration) {
+ var flags = ts.getCombinedModifierFlags(s.valueDeclaration);
+ return s.parent && s.parent.flags & 32 ? flags : flags & ~28;
+ }
+ if (getCheckFlags(s) & 6) {
+ var checkFlags = s.checkFlags;
+ var accessModifier = checkFlags & 256 ? 8 :
+ checkFlags & 64 ? 4 :
+ 16;
+ var staticModifier = checkFlags & 512 ? 32 : 0;
+ return accessModifier | staticModifier;
+ }
+ if (s.flags & 16777216) {
+ return 4 | 32;
+ }
+ return 0;
}
function getDeclarationNodeFlagsFromSymbol(s) {
return s.valueDeclaration ? ts.getCombinedNodeFlags(s.valueDeclaration) : 0;
}
- function checkClassPropertyAccess(node, left, type, prop) {
+ function isMethodLike(symbol) {
+ return !!(symbol.flags & 8192 || getCheckFlags(symbol) & 4);
+ }
+ function checkPropertyAccessibility(node, left, type, prop) {
var flags = getDeclarationModifierFlagsFromSymbol(prop);
- var declaringClass = getDeclaredTypeOfSymbol(getParentOfSymbol(prop));
- var errorNode = node.kind === 177 || node.kind === 223 ?
+ var errorNode = node.kind === 178 || node.kind === 225 ?
node.name :
node.right;
+ if (getCheckFlags(prop) & 256) {
+ error(errorNode, ts.Diagnostics.Property_0_has_conflicting_declarations_and_is_inaccessible_in_type_1, symbolToString(prop), typeToString(type));
+ return false;
+ }
if (left.kind === 96) {
- if (languageVersion < 2 && getDeclarationKindFromSymbol(prop) !== 149) {
- error(errorNode, ts.Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword);
- return false;
+ if (languageVersion < 2) {
+ var hasNonMethodDeclaration = forEachProperty(prop, function (p) {
+ var propKind = getDeclarationKindFromSymbol(p);
+ return propKind !== 150 && propKind !== 149;
+ });
+ if (hasNonMethodDeclaration) {
+ error(errorNode, ts.Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword);
+ return false;
+ }
}
if (flags & 128) {
- error(errorNode, ts.Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression, symbolToString(prop), typeToString(declaringClass));
+ error(errorNode, ts.Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression, symbolToString(prop), typeToString(getDeclaringClass(prop)));
return false;
}
}
@@ -28996,7 +31669,7 @@ var ts;
if (flags & 8) {
var declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop));
if (!isNodeWithinClass(node, declaringClassDeclaration)) {
- error(errorNode, ts.Diagnostics.Property_0_is_private_and_only_accessible_within_class_1, symbolToString(prop), typeToString(declaringClass));
+ error(errorNode, ts.Diagnostics.Property_0_is_private_and_only_accessible_within_class_1, symbolToString(prop), typeToString(getDeclaringClass(prop)));
return false;
}
return true;
@@ -29006,10 +31679,10 @@ var ts;
}
var enclosingClass = forEachEnclosingClass(node, function (enclosingDeclaration) {
var enclosingClass = getDeclaredTypeOfSymbol(getSymbolOfNode(enclosingDeclaration));
- return hasBaseType(enclosingClass, declaringClass) ? enclosingClass : undefined;
+ return isClassDerivedFromDeclaringClasses(enclosingClass, prop) ? enclosingClass : undefined;
});
if (!enclosingClass) {
- error(errorNode, ts.Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses, symbolToString(prop), typeToString(declaringClass));
+ error(errorNode, ts.Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses, symbolToString(prop), typeToString(getDeclaringClass(prop) || type));
return false;
}
if (flags & 32) {
@@ -29025,16 +31698,17 @@ var ts;
return true;
}
function checkNonNullExpression(node) {
- var type = checkExpression(node);
- if (strictNullChecks) {
- var kind = getFalsyFlags(type) & 6144;
- if (kind) {
- error(node, kind & 2048 ? kind & 4096 ?
- ts.Diagnostics.Object_is_possibly_null_or_undefined :
- ts.Diagnostics.Object_is_possibly_undefined :
- ts.Diagnostics.Object_is_possibly_null);
- }
- return getNonNullableType(type);
+ return checkNonNullType(checkExpression(node), node);
+ }
+ function checkNonNullType(type, errorNode) {
+ var kind = (strictNullChecks ? getFalsyFlags(type) : type.flags) & 6144;
+ if (kind) {
+ error(errorNode, kind & 2048 ? kind & 4096 ?
+ ts.Diagnostics.Object_is_possibly_null_or_undefined :
+ ts.Diagnostics.Object_is_possibly_undefined :
+ ts.Diagnostics.Object_is_possibly_null);
+ var t = getNonNullableType(type);
+ return t.flags & (6144 | 8192) ? unknownType : t;
}
return type;
}
@@ -29063,7 +31737,7 @@ var ts;
noUnusedIdentifiers &&
(prop.flags & 106500) &&
prop.valueDeclaration && (ts.getModifierFlags(prop.valueDeclaration) & 8)) {
- if (prop.flags & 16777216) {
+ if (getCheckFlags(prop) & 1) {
getSymbolLinks(prop).target.isReferenced = true;
}
else {
@@ -29071,6 +31745,15 @@ var ts;
}
}
}
+ function isInPropertyInitializer(node) {
+ while (node) {
+ if (node.parent && node.parent.kind === 148 && node.parent.initializer === node) {
+ return true;
+ }
+ node = node.parent;
+ }
+ return false;
+ }
function checkPropertyAccessExpressionOrQualifiedName(node, left, right) {
var type = checkNonNullExpression(left);
if (isTypeAny(type) || type === silentNeverType) {
@@ -29082,16 +31765,30 @@ var ts;
}
var prop = getPropertyOfType(apparentType, right.text);
if (!prop) {
+ var stringIndexType = getIndexTypeOfType(apparentType, 0);
+ if (stringIndexType) {
+ return stringIndexType;
+ }
if (right.text && !checkAndReportErrorForExtendingInterface(node)) {
reportNonexistentProperty(right, type.flags & 16384 && type.isThisType ? apparentType : type);
}
return unknownType;
}
+ if (prop.valueDeclaration) {
+ if (isInPropertyInitializer(node) &&
+ !isBlockScopedNameDeclaredBeforeUse(prop.valueDeclaration, right)) {
+ error(right, ts.Diagnostics.Block_scoped_variable_0_used_before_its_declaration, right.text);
+ }
+ if (prop.valueDeclaration.kind === 228 &&
+ node.parent && node.parent.kind !== 158 &&
+ !ts.isInAmbientContext(prop.valueDeclaration) &&
+ !isBlockScopedNameDeclaredBeforeUse(prop.valueDeclaration, right)) {
+ error(right, ts.Diagnostics.Class_0_used_before_its_declaration, right.text);
+ }
+ }
markPropertyAsReferenced(prop);
getNodeLinks(node).resolvedSymbol = prop;
- if (prop.parent && prop.parent.flags & 32) {
- checkClassPropertyAccess(node, left, apparentType, prop);
- }
+ checkPropertyAccessibility(node, left, apparentType, prop);
var propType = getTypeOfSymbol(prop);
var assignmentKind = ts.getAssignmentTargetKind(node);
if (assignmentKind) {
@@ -29100,30 +31797,30 @@ var ts;
return unknownType;
}
}
- if (node.kind !== 177 || assignmentKind === 1 ||
+ if (node.kind !== 178 || assignmentKind === 1 ||
!(prop.flags & (3 | 4 | 98304)) &&
!(prop.flags & 8192 && propType.flags & 65536)) {
return propType;
}
- var flowType = getFlowTypeOfReference(node, propType, true, undefined);
+ var flowType = getFlowTypeOfReference(node, propType);
return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
}
function isValidPropertyAccess(node, propertyName) {
- var left = node.kind === 177
+ var left = node.kind === 178
? node.expression
: node.left;
var type = checkExpression(left);
if (type !== unknownType && !isTypeAny(type)) {
var prop = getPropertyOfType(getWidenedType(type), propertyName);
- if (prop && prop.parent && prop.parent.flags & 32) {
- return checkClassPropertyAccess(node, left, type, prop);
+ if (prop) {
+ return checkPropertyAccessibility(node, left, type, prop);
}
}
return true;
}
function getForInVariableSymbol(node) {
var initializer = node.initializer;
- if (initializer.kind === 224) {
+ if (initializer.kind === 226) {
var variable = initializer.declarations[0];
if (variable && !ts.isBindingPattern(variable.name)) {
return getSymbolOfNode(variable);
@@ -29145,7 +31842,7 @@ var ts;
var child = expr;
var node = expr.parent;
while (node) {
- if (node.kind === 212 &&
+ if (node.kind === 214 &&
child === node.statement &&
getForInVariableSymbol(node) === symbol &&
hasNumericPropertyNames(getTypeOfExpression(node.expression))) {
@@ -29163,7 +31860,7 @@ var ts;
var indexExpression = node.argumentExpression;
if (!indexExpression) {
var sourceFile = ts.getSourceFileOfNode(node);
- if (node.parent.kind === 180 && node.parent.expression === node) {
+ if (node.parent.kind === 181 && node.parent.expression === node) {
var start = ts.skipTrivia(sourceFile.text, node.expression.end);
var end = node.end;
grammarErrorAtPos(sourceFile, start, end - start, ts.Diagnostics.new_T_cannot_be_used_to_create_an_array_Use_new_Array_T_instead);
@@ -29183,7 +31880,7 @@ var ts;
error(indexExpression, ts.Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal);
return unknownType;
}
- return getIndexedAccessType(objectType, indexType, node);
+ return checkIndexedAccessIndexType(getIndexedAccessType(objectType, indexType, node), node);
}
function checkThatExpressionIsProperSymbolReference(expression, expressionType, reportError) {
if (expressionType === unknownType) {
@@ -29203,7 +31900,7 @@ var ts;
if (!leftHandSideSymbol) {
return false;
}
- var globalESSymbol = getGlobalESSymbolConstructorSymbol();
+ var globalESSymbol = getGlobalESSymbolConstructorSymbol(true);
if (!globalESSymbol) {
return false;
}
@@ -29216,10 +31913,10 @@ var ts;
return true;
}
function resolveUntypedCall(node) {
- if (node.kind === 181) {
+ if (node.kind === 182) {
checkExpression(node.template);
}
- else if (node.kind !== 145) {
+ else if (node.kind !== 146) {
ts.forEach(node.arguments, function (argument) {
checkExpression(argument);
});
@@ -29238,22 +31935,22 @@ var ts;
var specializedIndex = -1;
var spliceIndex;
ts.Debug.assert(!result.length);
- for (var _i = 0, signatures_2 = signatures; _i < signatures_2.length; _i++) {
- var signature = signatures_2[_i];
+ for (var _i = 0, signatures_3 = signatures; _i < signatures_3.length; _i++) {
+ var signature = signatures_3[_i];
var symbol = signature.declaration && getSymbolOfNode(signature.declaration);
- var parent_8 = signature.declaration && signature.declaration.parent;
+ var parent = signature.declaration && signature.declaration.parent;
if (!lastSymbol || symbol === lastSymbol) {
- if (lastParent && parent_8 === lastParent) {
+ if (lastParent && parent === lastParent) {
index++;
}
else {
- lastParent = parent_8;
+ lastParent = parent;
index = cutoffIndex;
}
}
else {
index = cutoffIndex = result.length;
- lastParent = parent_8;
+ lastParent = parent;
}
lastSymbol = symbol;
if (signature.hasLiteralTypes) {
@@ -29270,7 +31967,7 @@ var ts;
function getSpreadArgumentIndex(args) {
for (var i = 0; i < args.length; i++) {
var arg = args[i];
- if (arg && arg.kind === 196) {
+ if (arg && arg.kind === 197) {
return i;
}
}
@@ -29283,11 +31980,14 @@ var ts;
var callIsIncomplete;
var isDecorator;
var spreadArgIndex = -1;
- if (node.kind === 181) {
+ if (ts.isJsxOpeningLikeElement(node)) {
+ return true;
+ }
+ if (node.kind === 182) {
var tagExpression = node;
argCount = args.length;
typeArguments = undefined;
- if (tagExpression.template.kind === 194) {
+ if (tagExpression.template.kind === 195) {
var templateExpression = tagExpression.template;
var lastSpan = ts.lastOrUndefined(templateExpression.templateSpans);
ts.Debug.assert(lastSpan !== undefined);
@@ -29299,7 +31999,7 @@ var ts;
callIsIncomplete = !!templateLiteral.isUnterminated;
}
}
- else if (node.kind === 145) {
+ else if (node.kind === 146) {
isDecorator = true;
typeArguments = undefined;
argCount = getEffectiveArgumentCount(node, undefined, signature);
@@ -29307,7 +32007,7 @@ var ts;
else {
var callExpression = node;
if (!callExpression.arguments) {
- ts.Debug.assert(callExpression.kind === 180);
+ ts.Debug.assert(callExpression.kind === 181);
return signature.minArgumentCount === 0;
}
argCount = signatureHelpTrailingComma ? args.length + 1 : args.length;
@@ -29315,8 +32015,10 @@ var ts;
typeArguments = callExpression.typeArguments;
spreadArgIndex = getSpreadArgumentIndex(args);
}
+ var numTypeParameters = ts.length(signature.typeParameters);
+ var minTypeArgumentCount = getMinTypeArgumentCount(signature.typeParameters);
var hasRightNumberOfTypeArgs = !typeArguments ||
- (signature.typeParameters && typeArguments.length === signature.typeParameters.length);
+ (typeArguments.length >= minTypeArgumentCount && typeArguments.length <= numTypeParameters);
if (!hasRightNumberOfTypeArgs) {
return false;
}
@@ -29340,9 +32042,9 @@ var ts;
return undefined;
}
function instantiateSignatureInContextOf(signature, contextualSignature, contextualMapper) {
- var context = createInferenceContext(signature, true);
+ var context = createInferenceContext(signature, true, false);
forEachMatchingParameterType(contextualSignature, signature, function (source, target) {
- inferTypes(context, instantiateType(source, contextualMapper), target);
+ inferTypesWithContext(context, instantiateType(source, contextualMapper), target);
});
return getSignatureInstantiation(signature, getInferredTypes(context));
}
@@ -29361,19 +32063,19 @@ var ts;
if (thisType) {
var thisArgumentNode = getThisArgumentOfCall(node);
var thisArgumentType = thisArgumentNode ? checkExpression(thisArgumentNode) : voidType;
- inferTypes(context, thisArgumentType, thisType);
+ inferTypesWithContext(context, thisArgumentType, thisType);
}
var argCount = getEffectiveArgumentCount(node, args, signature);
for (var i = 0; i < argCount; i++) {
var arg = getEffectiveArgument(node, args, i);
- if (arg === undefined || arg.kind !== 198) {
+ if (arg === undefined || arg.kind !== 199) {
var paramType = getTypeAtPosition(signature, i);
var argType = getEffectiveArgumentType(node, i);
if (argType === undefined) {
var mapper = excludeArgument && excludeArgument[i] !== undefined ? identityMapper : inferenceMapper;
argType = checkExpressionWithContextualType(arg, paramType, mapper);
}
- inferTypes(context, argType, paramType);
+ inferTypesWithContext(context, argType, paramType);
}
}
if (excludeArgument) {
@@ -29381,7 +32083,7 @@ var ts;
if (excludeArgument[i] === false) {
var arg = args[i];
var paramType = getTypeAtPosition(signature, i);
- inferTypes(context, checkExpressionWithContextualType(arg, paramType, inferenceMapper), paramType);
+ inferTypesWithContext(context, checkExpressionWithContextualType(arg, paramType, inferenceMapper), paramType);
}
}
}
@@ -29391,7 +32093,7 @@ var ts;
var typeParameters = signature.typeParameters;
var typeArgumentsAreAssignable = true;
var mapper;
- for (var i = 0; i < typeParameters.length; i++) {
+ for (var i = 0; i < typeArgumentNodes.length; i++) {
if (typeArgumentsAreAssignable) {
var constraint = getConstraintOfTypeParameter(typeParameters[i]);
if (constraint) {
@@ -29411,9 +32113,29 @@ var ts;
}
return typeArgumentsAreAssignable;
}
+ function checkApplicableSignatureForJsxOpeningLikeElement(node, signature, relation) {
+ var callIsIncomplete = node.attributes.end === node.end;
+ if (callIsIncomplete) {
+ return true;
+ }
+ var headMessage = ts.Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1;
+ var paramType = getTypeAtPosition(signature, 0);
+ var attributesType = checkExpressionWithContextualType(node.attributes, paramType, undefined);
+ var argProperties = getPropertiesOfType(attributesType);
+ for (var _i = 0, argProperties_1 = argProperties; _i < argProperties_1.length; _i++) {
+ var arg = argProperties_1[_i];
+ if (!getPropertyOfType(paramType, arg.name) && isUnhyphenatedJsxName(arg.name)) {
+ return false;
+ }
+ }
+ return checkTypeRelatedTo(attributesType, paramType, relation, undefined, headMessage);
+ }
function checkApplicableSignature(node, args, signature, relation, excludeArgument, reportErrors) {
+ if (ts.isJsxOpeningLikeElement(node)) {
+ return checkApplicableSignatureForJsxOpeningLikeElement(node, signature, relation);
+ }
var thisType = getThisTypeOfSignature(signature);
- if (thisType && thisType !== voidType && node.kind !== 180) {
+ if (thisType && thisType !== voidType && node.kind !== 181) {
var thisArgumentNode = getThisArgumentOfCall(node);
var thisArgumentType = thisArgumentNode ? checkExpression(thisArgumentNode) : voidType;
var errorNode = reportErrors ? (thisArgumentNode || node) : undefined;
@@ -29426,7 +32148,7 @@ var ts;
var argCount = getEffectiveArgumentCount(node, args, signature);
for (var i = 0; i < argCount; i++) {
var arg = getEffectiveArgument(node, args, i);
- if (arg === undefined || arg.kind !== 198) {
+ if (arg === undefined || arg.kind !== 199) {
var paramType = getTypeAtPosition(signature, i);
var argType = getEffectiveArgumentType(node, i);
if (argType === undefined) {
@@ -29441,51 +32163,54 @@ var ts;
return true;
}
function getThisArgumentOfCall(node) {
- if (node.kind === 179) {
+ if (node.kind === 180) {
var callee = node.expression;
- if (callee.kind === 177) {
+ if (callee.kind === 178) {
return callee.expression;
}
- else if (callee.kind === 178) {
+ else if (callee.kind === 179) {
return callee.expression;
}
}
}
function getEffectiveCallArguments(node) {
var args;
- if (node.kind === 181) {
+ if (node.kind === 182) {
var template = node.template;
args = [undefined];
- if (template.kind === 194) {
+ if (template.kind === 195) {
ts.forEach(template.templateSpans, function (span) {
args.push(span.expression);
});
}
}
- else if (node.kind === 145) {
+ else if (node.kind === 146) {
return undefined;
}
+ else if (ts.isJsxOpeningLikeElement(node)) {
+ args = node.attributes.properties.length > 0 ? [node.attributes] : emptyArray;
+ }
else {
args = node.arguments || emptyArray;
}
return args;
}
function getEffectiveArgumentCount(node, args, signature) {
- if (node.kind === 145) {
+ if (node.kind === 146) {
switch (node.parent.kind) {
- case 226:
- case 197:
+ case 228:
+ case 198:
return 1;
- case 147:
+ case 148:
return 2;
- case 149:
- case 151:
+ case 150:
case 152:
+ case 153:
if (languageVersion === 0) {
return 2;
}
return signature.parameters.length >= 3 ? 3 : 2;
- case 144:
+ case 145:
return 3;
}
}
@@ -29494,48 +32219,48 @@ var ts;
}
}
function getEffectiveDecoratorFirstArgumentType(node) {
- if (node.kind === 226) {
+ if (node.kind === 228) {
var classSymbol = getSymbolOfNode(node);
return getTypeOfSymbol(classSymbol);
}
- if (node.kind === 144) {
+ if (node.kind === 145) {
node = node.parent;
- if (node.kind === 150) {
+ if (node.kind === 151) {
var classSymbol = getSymbolOfNode(node);
return getTypeOfSymbol(classSymbol);
}
}
- if (node.kind === 147 ||
- node.kind === 149 ||
- node.kind === 151 ||
- node.kind === 152) {
+ if (node.kind === 148 ||
+ node.kind === 150 ||
+ node.kind === 152 ||
+ node.kind === 153) {
return getParentTypeOfClassElement(node);
}
ts.Debug.fail("Unsupported decorator target.");
return unknownType;
}
function getEffectiveDecoratorSecondArgumentType(node) {
- if (node.kind === 226) {
+ if (node.kind === 228) {
ts.Debug.fail("Class decorators should not have a second synthetic argument.");
return unknownType;
}
- if (node.kind === 144) {
+ if (node.kind === 145) {
node = node.parent;
- if (node.kind === 150) {
+ if (node.kind === 151) {
return anyType;
}
}
- if (node.kind === 147 ||
- node.kind === 149 ||
- node.kind === 151 ||
- node.kind === 152) {
+ if (node.kind === 148 ||
+ node.kind === 150 ||
+ node.kind === 152 ||
+ node.kind === 153) {
var element = node;
switch (element.name.kind) {
case 70:
case 8:
case 9:
return getLiteralTypeForText(32, element.name.text);
- case 142:
+ case 143:
var nameType = checkComputedPropertyName(element.name);
if (isTypeOfKind(nameType, 512)) {
return nameType;
@@ -29552,20 +32277,20 @@ var ts;
return unknownType;
}
function getEffectiveDecoratorThirdArgumentType(node) {
- if (node.kind === 226) {
+ if (node.kind === 228) {
ts.Debug.fail("Class decorators should not have a third synthetic argument.");
return unknownType;
}
- if (node.kind === 144) {
+ if (node.kind === 145) {
return numberType;
}
- if (node.kind === 147) {
+ if (node.kind === 148) {
ts.Debug.fail("Property decorators should not have a third synthetic argument.");
return unknownType;
}
- if (node.kind === 149 ||
- node.kind === 151 ||
- node.kind === 152) {
+ if (node.kind === 150 ||
+ node.kind === 152 ||
+ node.kind === 153) {
var propertyType = getTypeOfNode(node);
return createTypedPropertyDescriptorType(propertyType);
}
@@ -29586,26 +32311,26 @@ var ts;
return unknownType;
}
function getEffectiveArgumentType(node, argIndex) {
- if (node.kind === 145) {
+ if (node.kind === 146) {
return getEffectiveDecoratorArgumentType(node, argIndex);
}
- else if (argIndex === 0 && node.kind === 181) {
+ else if (argIndex === 0 && node.kind === 182) {
return getGlobalTemplateStringsArrayType();
}
return undefined;
}
function getEffectiveArgument(node, args, argIndex) {
- if (node.kind === 145 ||
- (argIndex === 0 && node.kind === 181)) {
+ if (node.kind === 146 ||
+ (argIndex === 0 && node.kind === 182)) {
return undefined;
}
return args[argIndex];
}
function getEffectiveArgumentErrorNode(node, argIndex, arg) {
- if (node.kind === 145) {
+ if (node.kind === 146) {
return node.expression;
}
- else if (argIndex === 0 && node.kind === 181) {
+ else if (argIndex === 0 && node.kind === 182) {
return node.template;
}
else {
@@ -29613,15 +32338,30 @@ var ts;
}
}
function resolveCall(node, signatures, candidatesOutArray, headMessage) {
- var isTaggedTemplate = node.kind === 181;
- var isDecorator = node.kind === 145;
+ var isTaggedTemplate = node.kind === 182;
+ var isDecorator = node.kind === 146;
+ var isJsxOpeningOrSelfClosingElement = ts.isJsxOpeningLikeElement(node);
var typeArguments;
- if (!isTaggedTemplate && !isDecorator) {
+ if (!isTaggedTemplate && !isDecorator && !isJsxOpeningOrSelfClosingElement) {
typeArguments = node.typeArguments;
if (node.expression.kind !== 96) {
ts.forEach(typeArguments, checkSourceElement);
}
}
+ if (signatures.length === 1) {
+ var declaration = signatures[0].declaration;
+ if (declaration && ts.isInJavaScriptFile(declaration) && !ts.hasJSDocParameterTags(declaration)) {
+ if (containsArgumentsReference(declaration)) {
+ var signatureWithRest = cloneSignature(signatures[0]);
+ var syntheticArgsSymbol = createSymbol(3, "args");
+ syntheticArgsSymbol.type = anyArrayType;
+ syntheticArgsSymbol.isRestParameter = true;
+ signatureWithRest.parameters = ts.concatenate(signatureWithRest.parameters, [syntheticArgsSymbol]);
+ signatureWithRest.hasRestParameter = true;
+ signatures = [signatureWithRest];
+ }
+ }
+ }
var candidates = candidatesOutArray || [];
reorderCandidates(signatures, candidates);
if (!candidates.length) {
@@ -29644,7 +32384,7 @@ var ts;
var candidateForTypeArgumentError;
var resultOfFailedInference;
var result;
- var signatureHelpTrailingComma = candidatesOutArray && node.kind === 179 && node.arguments.hasTrailingComma;
+ var signatureHelpTrailingComma = candidatesOutArray && node.kind === 180 && node.arguments.hasTrailingComma;
if (candidates.length > 1) {
result = chooseOverload(candidates, subtypeRelation, signatureHelpTrailingComma);
}
@@ -29658,6 +32398,9 @@ var ts;
return result;
}
if (candidateForArgumentError) {
+ if (isJsxOpeningOrSelfClosingElement) {
+ return candidateForArgumentError;
+ }
checkApplicableSignature(node, args, candidateForArgumentError, assignableRelation, undefined, true);
}
else if (candidateForTypeArgumentError) {
@@ -29673,7 +32416,7 @@ var ts;
if (headMessage) {
diagnosticChainHead = ts.chainDiagnosticMessages(diagnosticChainHead, headMessage);
}
- reportNoCommonSupertypeError(inferenceCandidates, node.expression || node.tag, diagnosticChainHead);
+ reportNoCommonSupertypeError(inferenceCandidates, node.tagName || node.expression || node.tag, diagnosticChainHead);
}
}
else {
@@ -29709,20 +32452,20 @@ var ts;
var candidate = void 0;
var typeArgumentsAreValid = void 0;
var inferenceContext = originalCandidate.typeParameters
- ? createInferenceContext(originalCandidate, false)
+ ? createInferenceContext(originalCandidate, false, ts.isInJavaScriptFile(node))
: undefined;
while (true) {
candidate = originalCandidate;
if (candidate.typeParameters) {
var typeArgumentTypes = void 0;
if (typeArguments) {
- typeArgumentTypes = ts.map(typeArguments, getTypeFromTypeNode);
+ typeArgumentTypes = fillMissingTypeArguments(ts.map(typeArguments, getTypeFromTypeNode), candidate.typeParameters, getMinTypeArgumentCount(candidate.typeParameters));
typeArgumentsAreValid = checkTypeArguments(candidate, typeArguments, typeArgumentTypes, false);
}
else {
inferTypeArguments(node, candidate, args, excludeArgument, inferenceContext);
- typeArgumentsAreValid = inferenceContext.failedTypeParameterIndex === undefined;
typeArgumentTypes = inferenceContext.inferredTypes;
+ typeArgumentsAreValid = inferenceContext.failedTypeParameterIndex === undefined;
}
if (!typeArgumentsAreValid) {
break;
@@ -29764,7 +32507,7 @@ var ts;
if (superType !== unknownType) {
var baseTypeNode = ts.getClassExtendsHeritageClauseElement(ts.getContainingClass(node));
if (baseTypeNode) {
- var baseConstructors = getInstantiatedConstructorsForTypeArguments(superType, baseTypeNode.typeArguments);
+ var baseConstructors = getInstantiatedConstructorsForTypeArguments(superType, baseTypeNode.typeArguments, baseTypeNode);
return resolveCall(node, baseConstructors, candidatesOutArray);
}
}
@@ -29875,12 +32618,13 @@ var ts;
if (containingClass) {
var containingType = getTypeOfNode(containingClass);
var baseTypes = getBaseTypes(containingType);
- if (baseTypes.length) {
+ while (baseTypes.length) {
var baseType = baseTypes[0];
if (modifiers & 16 &&
baseType.symbol === declaration.parent.symbol) {
return true;
}
+ baseTypes = getBaseTypes(baseType);
}
}
if (modifiers & 8) {
@@ -29912,16 +32656,16 @@ var ts;
}
function getDiagnosticHeadMessageForDecoratorResolution(node) {
switch (node.parent.kind) {
- case 226:
- case 197:
+ case 228:
+ case 198:
return ts.Diagnostics.Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression;
- case 144:
+ case 145:
return ts.Diagnostics.Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression;
- case 147:
+ case 148:
return ts.Diagnostics.Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression;
- case 149:
- case 151:
+ case 150:
case 152:
+ case 153:
return ts.Diagnostics.Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression;
}
}
@@ -29946,16 +32690,42 @@ var ts;
}
return resolveCall(node, callSignatures, candidatesOutArray, headMessage);
}
+ function getResolvedJsxStatelessFunctionSignature(openingLikeElement, elementType, candidatesOutArray) {
+ ts.Debug.assert(!(elementType.flags & 65536));
+ var callSignature = resolveStatelessJsxOpeningLikeElement(openingLikeElement, elementType, candidatesOutArray);
+ return callSignature;
+ }
+ function resolveStatelessJsxOpeningLikeElement(openingLikeElement, elementType, candidatesOutArray) {
+ if (elementType.flags & 65536) {
+ var types = elementType.types;
+ var result = void 0;
+ for (var _i = 0, types_18 = types; _i < types_18.length; _i++) {
+ var type = types_18[_i];
+ result = result || resolveStatelessJsxOpeningLikeElement(openingLikeElement, type, candidatesOutArray);
+ }
+ return result;
+ }
+ var callSignatures = elementType && getSignaturesOfType(elementType, 0);
+ if (callSignatures && callSignatures.length > 0) {
+ var callSignature = void 0;
+ callSignature = resolveCall(openingLikeElement, callSignatures, candidatesOutArray);
+ return callSignature;
+ }
+ return undefined;
+ }
function resolveSignature(node, candidatesOutArray) {
switch (node.kind) {
- case 179:
- return resolveCallExpression(node, candidatesOutArray);
case 180:
- return resolveNewExpression(node, candidatesOutArray);
+ return resolveCallExpression(node, candidatesOutArray);
case 181:
+ return resolveNewExpression(node, candidatesOutArray);
+ case 182:
return resolveTaggedTemplateExpression(node, candidatesOutArray);
- case 145:
+ case 146:
return resolveDecorator(node, candidatesOutArray);
+ case 250:
+ case 249:
+ return resolveStatelessJsxOpeningLikeElement(node, checkExpression(node.tagName), candidatesOutArray);
}
ts.Debug.fail("Branch in 'resolveSignature' should be unreachable.");
}
@@ -29986,20 +32756,23 @@ var ts;
if (node.expression.kind === 96) {
return voidType;
}
- if (node.kind === 180) {
+ if (node.kind === 181) {
var declaration = signature.declaration;
if (declaration &&
- declaration.kind !== 150 &&
- declaration.kind !== 154 &&
- declaration.kind !== 159 &&
+ declaration.kind !== 151 &&
+ declaration.kind !== 155 &&
+ declaration.kind !== 160 &&
!ts.isJSDocConstructSignature(declaration)) {
var funcSymbol = node.expression.kind === 70 ?
getResolvedSymbol(node.expression) :
checkExpression(node.expression).symbol;
- if (funcSymbol && funcSymbol.members && (funcSymbol.flags & 16 || ts.isDeclarationOfFunctionExpression(funcSymbol))) {
+ if (funcSymbol && ts.isDeclarationOfFunctionOrClassExpression(funcSymbol)) {
+ funcSymbol = getSymbolOfNode(funcSymbol.valueDeclaration.initializer);
+ }
+ if (funcSymbol && funcSymbol.members && funcSymbol.flags & 16) {
return getInferredClassType(funcSymbol);
}
- else if (compilerOptions.noImplicitAny) {
+ else if (noImplicitAny) {
error(node, ts.Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type);
}
return anyType;
@@ -30022,9 +32795,9 @@ var ts;
return false;
}
var targetDeclarationKind = resolvedRequire.flags & 16
- ? 225
+ ? 227
: resolvedRequire.flags & 3
- ? 223
+ ? 225
: 0;
if (targetDeclarationKind !== 0) {
var decl = ts.getDeclarationOfKind(resolvedRequire, targetDeclarationKind);
@@ -30050,6 +32823,22 @@ var ts;
function checkNonNullAssertion(node) {
return getNonNullableType(checkExpression(node.expression));
}
+ function checkMetaProperty(node) {
+ checkGrammarMetaProperty(node);
+ var container = ts.getNewTargetContainer(node);
+ if (!container) {
+ error(node, ts.Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target");
+ return unknownType;
+ }
+ else if (container.kind === 151) {
+ var symbol = getSymbolOfNode(container.parent);
+ return getTypeOfSymbol(symbol);
+ }
+ else {
+ var symbol = getSymbolOfNode(container);
+ return getTypeOfSymbol(symbol);
+ }
+ }
function getTypeOfParameter(symbol) {
var type = getTypeOfSymbol(symbol);
if (strictNullChecks) {
@@ -30065,13 +32854,16 @@ var ts;
pos < signature.parameters.length - 1 ? getTypeOfParameter(signature.parameters[pos]) : getRestTypeOfSignature(signature) :
pos < signature.parameters.length ? getTypeOfParameter(signature.parameters[pos]) : anyType;
}
- function assignContextualParameterTypes(signature, context, mapper) {
+ function getTypeOfFirstParameterOfSignature(signature) {
+ return signature.parameters.length > 0 ? getTypeAtPosition(signature, 0) : neverType;
+ }
+ function assignContextualParameterTypes(signature, context, mapper, checkMode) {
var len = signature.parameters.length - (signature.hasRestParameter ? 1 : 0);
- if (isInferentialContext(mapper)) {
+ if (checkMode === 2) {
for (var i = 0; i < len; i++) {
var declaration = signature.parameters[i].valueDeclaration;
if (declaration.type) {
- inferTypes(mapper.context, getTypeFromTypeNode(declaration.type), getTypeAtPosition(context, i));
+ inferTypesWithContext(mapper.context, getTypeFromTypeNode(declaration.type), getTypeAtPosition(context, i));
}
}
}
@@ -30079,23 +32871,23 @@ var ts;
var parameter = signature.thisParameter;
if (!parameter || parameter.valueDeclaration && !parameter.valueDeclaration.type) {
if (!parameter) {
- signature.thisParameter = createTransientSymbol(context.thisParameter, undefined);
+ signature.thisParameter = createSymbolWithType(context.thisParameter, undefined);
}
- assignTypeToParameterAndFixTypeParameters(signature.thisParameter, getTypeOfSymbol(context.thisParameter), mapper);
+ assignTypeToParameterAndFixTypeParameters(signature.thisParameter, getTypeOfSymbol(context.thisParameter), mapper, checkMode);
}
}
for (var i = 0; i < len; i++) {
var parameter = signature.parameters[i];
if (!parameter.valueDeclaration.type) {
var contextualParameterType = getTypeAtPosition(context, i);
- assignTypeToParameterAndFixTypeParameters(parameter, contextualParameterType, mapper);
+ assignTypeToParameterAndFixTypeParameters(parameter, contextualParameterType, mapper, checkMode);
}
}
if (signature.hasRestParameter && isRestParameterIndex(context, signature.parameters.length - 1)) {
var parameter = ts.lastOrUndefined(signature.parameters);
if (!parameter.valueDeclaration.type) {
var contextualParameterType = getTypeOfSymbol(ts.lastOrUndefined(context.parameters));
- assignTypeToParameterAndFixTypeParameters(parameter, contextualParameterType, mapper);
+ assignTypeToParameterAndFixTypeParameters(parameter, contextualParameterType, mapper, checkMode);
}
}
}
@@ -30112,19 +32904,19 @@ var ts;
}
}
}
- function assignTypeToParameterAndFixTypeParameters(parameter, contextualType, mapper) {
+ function assignTypeToParameterAndFixTypeParameters(parameter, contextualType, mapper, checkMode) {
var links = getSymbolLinks(parameter);
if (!links.type) {
links.type = instantiateType(contextualType, mapper);
if (links.type === emptyObjectType &&
- (parameter.valueDeclaration.name.kind === 172 ||
- parameter.valueDeclaration.name.kind === 173)) {
+ (parameter.valueDeclaration.name.kind === 173 ||
+ parameter.valueDeclaration.name.kind === 174)) {
links.type = getTypeFromBindingPattern(parameter.valueDeclaration.name);
}
assignBindingElementTypes(parameter.valueDeclaration);
}
- else if (isInferentialContext(mapper)) {
- inferTypes(mapper.context, links.type, instantiateType(contextualType, mapper));
+ else if (checkMode === 2) {
+ inferTypesWithContext(mapper.context, links.type, instantiateType(contextualType, mapper));
}
}
function getReturnTypeFromJSDocComment(func) {
@@ -30135,9 +32927,9 @@ var ts;
return undefined;
}
function createPromiseType(promisedType) {
- var globalPromiseType = getGlobalPromiseType();
+ var globalPromiseType = getGlobalPromiseType(true);
if (globalPromiseType !== emptyGenericType) {
- promisedType = getAwaitedType(promisedType);
+ promisedType = getAwaitedType(promisedType) || emptyObjectType;
return createTypeReference(globalPromiseType, [promisedType]);
}
return emptyObjectType;
@@ -30148,46 +32940,56 @@ var ts;
error(func, ts.Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option);
return unknownType;
}
+ else if (!getGlobalPromiseConstructorSymbol(true)) {
+ error(func, ts.Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
+ }
return promiseType;
}
- function getReturnTypeFromBody(func, contextualMapper) {
+ function getReturnTypeFromBody(func, checkMode) {
var contextualSignature = getContextualSignatureForFunctionLikeDeclaration(func);
if (!func.body) {
return unknownType;
}
- var isAsync = ts.isAsyncFunctionLike(func);
+ var functionFlags = ts.getFunctionFlags(func);
var type;
- if (func.body.kind !== 204) {
- type = checkExpressionCached(func.body, contextualMapper);
- if (isAsync) {
- type = checkAwaitedType(type, func, ts.Diagnostics.Return_expression_in_async_function_does_not_have_a_valid_callable_then_member);
+ if (func.body.kind !== 206) {
+ type = checkExpressionCached(func.body, checkMode);
+ if (functionFlags & 2) {
+ type = checkAwaitedType(type, func, ts.Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
}
}
else {
var types = void 0;
- var funcIsGenerator = !!func.asteriskToken;
- if (funcIsGenerator) {
- types = checkAndAggregateYieldOperandTypes(func, contextualMapper);
- if (types.length === 0) {
- var iterableIteratorAny = createIterableIteratorType(anyType);
- if (compilerOptions.noImplicitAny) {
+ if (functionFlags & 1) {
+ types = ts.concatenate(checkAndAggregateYieldOperandTypes(func, checkMode), checkAndAggregateReturnExpressionTypes(func, checkMode));
+ if (!types || types.length === 0) {
+ var iterableIteratorAny = functionFlags & 2
+ ? createAsyncIterableIteratorType(anyType)
+ : createIterableIteratorType(anyType);
+ if (noImplicitAny) {
error(func.asteriskToken, ts.Diagnostics.Generator_implicitly_has_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type, typeToString(iterableIteratorAny));
}
return iterableIteratorAny;
}
}
else {
- types = checkAndAggregateReturnExpressionTypes(func, contextualMapper);
+ types = checkAndAggregateReturnExpressionTypes(func, checkMode);
if (!types) {
- return isAsync ? createPromiseReturnType(func, neverType) : neverType;
+ return functionFlags & 2
+ ? createPromiseReturnType(func, neverType)
+ : neverType;
}
if (types.length === 0) {
- return isAsync ? createPromiseReturnType(func, voidType) : voidType;
+ return functionFlags & 2
+ ? createPromiseReturnType(func, voidType)
+ : voidType;
}
}
type = getUnionType(types, true);
- if (funcIsGenerator) {
- type = createIterableIteratorType(type);
+ if (functionFlags & 1) {
+ type = functionFlags & 2
+ ? createAsyncIterableIteratorType(type)
+ : createIterableIteratorType(type);
}
}
if (!contextualSignature) {
@@ -30199,16 +33001,24 @@ var ts;
type = getWidenedLiteralType(type);
}
var widenedType = getWidenedType(type);
- return isAsync ? createPromiseReturnType(func, widenedType) : widenedType;
+ return (functionFlags & 3) === 2
+ ? createPromiseReturnType(func, widenedType)
+ : widenedType;
}
- function checkAndAggregateYieldOperandTypes(func, contextualMapper) {
+ function checkAndAggregateYieldOperandTypes(func, checkMode) {
var aggregatedTypes = [];
+ var functionFlags = ts.getFunctionFlags(func);
ts.forEachYieldExpression(func.body, function (yieldExpression) {
var expr = yieldExpression.expression;
if (expr) {
- var type = checkExpressionCached(expr, contextualMapper);
+ var type = checkExpressionCached(expr, checkMode);
if (yieldExpression.asteriskToken) {
- type = checkElementTypeOfIterable(type, yieldExpression.expression);
+ type = checkIteratedTypeOrElementType(type, yieldExpression.expression, false, (functionFlags & 2) !== 0);
+ }
+ if (functionFlags & 2) {
+ type = checkAwaitedType(type, expr, yieldExpression.asteriskToken
+ ? ts.Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
+ : ts.Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
}
if (!ts.contains(aggregatedTypes, type)) {
aggregatedTypes.push(type);
@@ -30229,29 +33039,29 @@ var ts;
if (!switchTypes.length) {
return false;
}
- return eachTypeContainedIn(type, switchTypes);
+ return eachTypeContainedIn(mapType(type, getRegularTypeOfLiteralType), switchTypes);
}
function functionHasImplicitReturn(func) {
if (!(func.flags & 128)) {
return false;
}
var lastStatement = ts.lastOrUndefined(func.body.statements);
- if (lastStatement && lastStatement.kind === 218 && isExhaustiveSwitchStatement(lastStatement)) {
+ if (lastStatement && lastStatement.kind === 220 && isExhaustiveSwitchStatement(lastStatement)) {
return false;
}
return true;
}
- function checkAndAggregateReturnExpressionTypes(func, contextualMapper) {
- var isAsync = ts.isAsyncFunctionLike(func);
+ function checkAndAggregateReturnExpressionTypes(func, checkMode) {
+ var functionFlags = ts.getFunctionFlags(func);
var aggregatedTypes = [];
var hasReturnWithNoExpression = functionHasImplicitReturn(func);
var hasReturnOfTypeNever = false;
ts.forEachReturnStatement(func.body, function (returnStatement) {
var expr = returnStatement.expression;
if (expr) {
- var type = checkExpressionCached(expr, contextualMapper);
- if (isAsync) {
- type = checkAwaitedType(type, func, ts.Diagnostics.Return_expression_in_async_function_does_not_have_a_valid_callable_then_member);
+ var type = checkExpressionCached(expr, checkMode);
+ if (functionFlags & 2) {
+ type = checkAwaitedType(type, func, ts.Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
}
if (type.flags & 8192) {
hasReturnOfTypeNever = true;
@@ -30265,7 +33075,7 @@ var ts;
}
});
if (aggregatedTypes.length === 0 && !hasReturnWithNoExpression && (hasReturnOfTypeNever ||
- func.kind === 184 || func.kind === 185)) {
+ func.kind === 185 || func.kind === 186)) {
return undefined;
}
if (strictNullChecks && aggregatedTypes.length && hasReturnWithNoExpression) {
@@ -30282,7 +33092,7 @@ var ts;
if (returnType && maybeTypeOfKind(returnType, 1 | 1024)) {
return;
}
- if (ts.nodeIsMissing(func.body) || func.body.kind !== 204 || !functionHasImplicitReturn(func)) {
+ if (ts.nodeIsMissing(func.body) || func.body.kind !== 206 || !functionHasImplicitReturn(func)) {
return;
}
var hasExplicitReturn = func.flags & 256;
@@ -30308,20 +33118,20 @@ var ts;
error(func.type || func, ts.Diagnostics.Not_all_code_paths_return_a_value);
}
}
- function checkFunctionExpressionOrObjectLiteralMethod(node, contextualMapper) {
- ts.Debug.assert(node.kind !== 149 || ts.isObjectLiteralMethod(node));
+ function checkFunctionExpressionOrObjectLiteralMethod(node, checkMode) {
+ ts.Debug.assert(node.kind !== 150 || ts.isObjectLiteralMethod(node));
var hasGrammarError = checkGrammarFunctionLikeDeclaration(node);
- if (!hasGrammarError && node.kind === 184) {
+ if (!hasGrammarError && node.kind === 185) {
checkGrammarForGenerator(node);
}
- if (contextualMapper === identityMapper && isContextSensitive(node)) {
+ if (checkMode === 1 && isContextSensitive(node)) {
checkNodeDeferred(node);
return anyFunctionType;
}
var links = getNodeLinks(node);
var type = getTypeOfSymbol(node.symbol);
var contextSensitive = isContextSensitive(node);
- var mightFixTypeParameters = contextSensitive && isInferentialContext(contextualMapper);
+ var mightFixTypeParameters = contextSensitive && checkMode === 2;
if (mightFixTypeParameters || !(links.flags & 1024)) {
var contextualSignature = getContextualSignature(node);
var contextChecked = !!(links.flags & 1024);
@@ -30330,10 +33140,10 @@ var ts;
if (contextualSignature) {
var signature = getSignaturesOfType(type, 0)[0];
if (contextSensitive) {
- assignContextualParameterTypes(signature, contextualSignature, contextualMapper || identityMapper);
+ assignContextualParameterTypes(signature, contextualSignature, getContextualMapper(node), checkMode);
}
if (mightFixTypeParameters || !node.type && !signature.resolvedReturnType) {
- var returnType = getReturnTypeFromBody(node, contextualMapper);
+ var returnType = getReturnTypeFromBody(node, checkMode);
if (!signature.resolvedReturnType) {
signature.resolvedReturnType = returnType;
}
@@ -30345,31 +33155,35 @@ var ts;
}
}
}
- if (produceDiagnostics && node.kind !== 149) {
+ if (produceDiagnostics && node.kind !== 150) {
checkCollisionWithCapturedSuperVariable(node, node.name);
checkCollisionWithCapturedThisVariable(node, node.name);
+ checkCollisionWithCapturedNewTargetVariable(node, node.name);
}
return type;
}
function checkFunctionExpressionOrObjectLiteralMethodDeferred(node) {
- ts.Debug.assert(node.kind !== 149 || ts.isObjectLiteralMethod(node));
- var isAsync = ts.isAsyncFunctionLike(node);
- var returnOrPromisedType = node.type && (isAsync ? checkAsyncFunctionReturnType(node) : getTypeFromTypeNode(node.type));
- if (!node.asteriskToken) {
+ ts.Debug.assert(node.kind !== 150 || ts.isObjectLiteralMethod(node));
+ var functionFlags = ts.getFunctionFlags(node);
+ var returnOrPromisedType = node.type &&
+ ((functionFlags & 3) === 2 ?
+ checkAsyncFunctionReturnType(node) :
+ getTypeFromTypeNode(node.type));
+ if ((functionFlags & 1) === 0) {
checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnOrPromisedType);
}
if (node.body) {
if (!node.type) {
getReturnTypeOfSignature(getSignatureFromDeclaration(node));
}
- if (node.body.kind === 204) {
+ if (node.body.kind === 206) {
checkSourceElement(node.body);
}
else {
var exprType = checkExpression(node.body);
if (returnOrPromisedType) {
- if (isAsync) {
- var awaitedType = checkAwaitedType(exprType, node.body, ts.Diagnostics.Expression_body_for_async_arrow_function_does_not_have_a_valid_callable_then_member);
+ if ((functionFlags & 3) === 2) {
+ var awaitedType = checkAwaitedType(exprType, node.body, ts.Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
checkTypeAssignableTo(awaitedType, returnOrPromisedType, node.body);
}
else {
@@ -30388,19 +33202,19 @@ var ts;
return true;
}
function isReadonlySymbol(symbol) {
- return symbol.isReadonly ||
- symbol.flags & 4 && (getDeclarationModifierFlagsFromSymbol(symbol) & 64) !== 0 ||
- symbol.flags & 3 && (getDeclarationNodeFlagsFromSymbol(symbol) & 2) !== 0 ||
+ return !!(getCheckFlags(symbol) & 8 ||
+ symbol.flags & 4 && getDeclarationModifierFlagsFromSymbol(symbol) & 64 ||
+ symbol.flags & 3 && getDeclarationNodeFlagsFromSymbol(symbol) & 2 ||
symbol.flags & 98304 && !(symbol.flags & 65536) ||
- (symbol.flags & 8) !== 0;
+ symbol.flags & 8);
}
function isReferenceToReadonlyEntity(expr, symbol) {
if (isReadonlySymbol(symbol)) {
if (symbol.flags & 4 &&
- (expr.kind === 177 || expr.kind === 178) &&
+ (expr.kind === 178 || expr.kind === 179) &&
expr.expression.kind === 98) {
var func = ts.getContainingFunction(expr);
- if (!(func && func.kind === 150))
+ if (!(func && func.kind === 151))
return true;
return !(func.parent === symbol.valueDeclaration.parent || func === symbol.valueDeclaration.parent);
}
@@ -30409,13 +33223,13 @@ var ts;
return false;
}
function isReferenceThroughNamespaceImport(expr) {
- if (expr.kind === 177 || expr.kind === 178) {
+ if (expr.kind === 178 || expr.kind === 179) {
var node = ts.skipParentheses(expr.expression);
if (node.kind === 70) {
var symbol = getNodeLinks(node).resolvedSymbol;
if (symbol.flags & 8388608) {
var declaration = getDeclarationOfAliasSymbol(symbol);
- return declaration && declaration.kind === 237;
+ return declaration && declaration.kind === 239;
}
}
}
@@ -30423,7 +33237,7 @@ var ts;
}
function checkReferenceExpression(expr, invalidReferenceMessage) {
var node = ts.skipParentheses(expr);
- if (node.kind !== 70 && node.kind !== 177 && node.kind !== 178) {
+ if (node.kind !== 70 && node.kind !== 178 && node.kind !== 179) {
error(expr, invalidReferenceMessage);
return false;
}
@@ -30431,11 +33245,21 @@ var ts;
}
function checkDeleteExpression(node) {
checkExpression(node.expression);
+ var expr = ts.skipParentheses(node.expression);
+ if (expr.kind !== 178 && expr.kind !== 179) {
+ error(expr, ts.Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference);
+ return booleanType;
+ }
+ var links = getNodeLinks(expr);
+ var symbol = getExportSymbolOfValueSymbolIfExported(links.resolvedSymbol);
+ if (symbol && isReadonlySymbol(symbol)) {
+ error(expr, ts.Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property);
+ }
return booleanType;
}
function checkTypeOfExpression(node) {
checkExpression(node.expression);
- return stringType;
+ return typeofType;
}
function checkVoidExpression(node) {
checkExpression(node.expression);
@@ -30443,7 +33267,7 @@ var ts;
}
function checkAwaitExpression(node) {
if (produceDiagnostics) {
- if (!(node.flags & 524288)) {
+ if (!(node.flags & 16384)) {
grammarErrorOnFirstToken(node, ts.Diagnostics.await_expression_is_only_allowed_within_an_async_function);
}
if (isInParameterInitializerBeforeContainingFunction(node)) {
@@ -30451,7 +33275,7 @@ var ts;
}
}
var operandType = checkExpression(node.expression);
- return checkAwaitedType(operandType, node);
+ return checkAwaitedType(operandType, node, ts.Diagnostics.Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
}
function checkPrefixUnaryExpression(node) {
var operandType = checkExpression(node.operand);
@@ -30465,6 +33289,7 @@ var ts;
case 36:
case 37:
case 51:
+ checkNonNullType(operandType, node.operand);
if (maybeTypeOfKind(operandType, 512)) {
error(node.operand, ts.Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, ts.tokenToString(node.operator));
}
@@ -30476,7 +33301,7 @@ var ts;
booleanType;
case 42:
case 43:
- var ok = checkArithmeticOperandType(node.operand, getNonNullableType(operandType), ts.Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type);
+ var ok = checkArithmeticOperandType(node.operand, checkNonNullType(operandType, node.operand), ts.Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type);
if (ok) {
checkReferenceExpression(node.operand, ts.Diagnostics.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access);
}
@@ -30489,7 +33314,7 @@ var ts;
if (operandType === silentNeverType) {
return silentNeverType;
}
- var ok = checkArithmeticOperandType(node.operand, getNonNullableType(operandType), ts.Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type);
+ var ok = checkArithmeticOperandType(node.operand, checkNonNullType(operandType, node.operand), ts.Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_or_an_enum_type);
if (ok) {
checkReferenceExpression(node.operand, ts.Diagnostics.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access);
}
@@ -30501,8 +33326,8 @@ var ts;
}
if (type.flags & 196608) {
var types = type.types;
- for (var _i = 0, types_15 = types; _i < types_15.length; _i++) {
- var t = types_15[_i];
+ for (var _i = 0, types_19 = types; _i < types_19.length; _i++) {
+ var t = types_19[_i];
if (maybeTypeOfKind(t, kind)) {
return true;
}
@@ -30516,8 +33341,8 @@ var ts;
}
if (type.flags & 65536) {
var types = type.types;
- for (var _i = 0, types_16 = types; _i < types_16.length; _i++) {
- var t = types_16[_i];
+ for (var _i = 0, types_20 = types; _i < types_20.length; _i++) {
+ var t = types_20[_i];
if (!isTypeOfKind(t, kind)) {
return false;
}
@@ -30526,8 +33351,8 @@ var ts;
}
if (type.flags & 131072) {
var types = type.types;
- for (var _a = 0, types_17 = types; _a < types_17.length; _a++) {
- var t = types_17[_a];
+ for (var _a = 0, types_21 = types; _a < types_21.length; _a++) {
+ var t = types_21[_a];
if (isTypeOfKind(t, kind)) {
return true;
}
@@ -30548,7 +33373,10 @@ var ts;
if (isTypeOfKind(leftType, 8190)) {
error(left, ts.Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter);
}
- if (!(isTypeAny(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) {
+ if (!(isTypeAny(rightType) ||
+ getSignaturesOfType(rightType, 0).length ||
+ getSignaturesOfType(rightType, 1).length ||
+ isTypeSubtypeOf(rightType, globalFunctionType))) {
error(right, ts.Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type);
}
return booleanType;
@@ -30557,39 +33385,41 @@ var ts;
if (leftType === silentNeverType || rightType === silentNeverType) {
return silentNeverType;
}
+ leftType = checkNonNullType(leftType, left);
+ rightType = checkNonNullType(rightType, right);
if (!(isTypeComparableTo(leftType, stringType) || isTypeOfKind(leftType, 340 | 512))) {
error(left, ts.Diagnostics.The_left_hand_side_of_an_in_expression_must_be_of_type_any_string_number_or_symbol);
}
- if (!isTypeAnyOrAllConstituentTypesHaveKind(rightType, 32768 | 16384 | 524288)) {
+ if (!isTypeAnyOrAllConstituentTypesHaveKind(rightType, 32768 | 540672 | 16777216)) {
error(right, ts.Diagnostics.The_right_hand_side_of_an_in_expression_must_be_of_type_any_an_object_type_or_a_type_parameter);
}
return booleanType;
}
function checkObjectLiteralAssignment(node, sourceType) {
var properties = node.properties;
- for (var _i = 0, properties_5 = properties; _i < properties_5.length; _i++) {
- var p = properties_5[_i];
+ for (var _i = 0, properties_7 = properties; _i < properties_7.length; _i++) {
+ var p = properties_7[_i];
checkObjectLiteralDestructuringPropertyAssignment(sourceType, p, properties);
}
return sourceType;
}
function checkObjectLiteralDestructuringPropertyAssignment(objectLiteralType, property, allProperties) {
- if (property.kind === 257 || property.kind === 258) {
- var name_20 = property.name;
- if (name_20.kind === 142) {
- checkComputedPropertyName(name_20);
+ if (property.kind === 260 || property.kind === 261) {
+ var name = property.name;
+ if (name.kind === 143) {
+ checkComputedPropertyName(name);
}
- if (isComputedNonLiteralName(name_20)) {
+ if (isComputedNonLiteralName(name)) {
return undefined;
}
- var text = ts.getTextOfPropertyName(name_20);
+ var text = ts.getTextOfPropertyName(name);
var type = isTypeAny(objectLiteralType)
? objectLiteralType
: getTypeOfPropertyOfType(objectLiteralType, text) ||
isNumericLiteralName(text) && getIndexTypeOfType(objectLiteralType, 1) ||
getIndexTypeOfType(objectLiteralType, 0);
if (type) {
- if (property.kind === 258) {
+ if (property.kind === 261) {
return checkDestructuringAssignment(property, type);
}
else {
@@ -30597,10 +33427,13 @@ var ts;
}
}
else {
- error(name_20, ts.Diagnostics.Type_0_has_no_property_1_and_no_string_index_signature, typeToString(objectLiteralType), ts.declarationNameToString(name_20));
+ error(name, ts.Diagnostics.Type_0_has_no_property_1_and_no_string_index_signature, typeToString(objectLiteralType), ts.declarationNameToString(name));
}
}
- else if (property.kind === 259) {
+ else if (property.kind === 262) {
+ if (languageVersion < 5) {
+ checkExternalEmitHelpers(property, 4);
+ }
var nonRestNames = [];
if (allProperties) {
for (var i = 0; i < allProperties.length - 1; i++) {
@@ -30614,19 +33447,22 @@ var ts;
error(property, ts.Diagnostics.Property_assignment_expected);
}
}
- function checkArrayLiteralAssignment(node, sourceType, contextualMapper) {
- var elementType = checkIteratedTypeOrElementType(sourceType, node, false) || unknownType;
+ function checkArrayLiteralAssignment(node, sourceType, checkMode) {
+ if (languageVersion < 2 && compilerOptions.downlevelIteration) {
+ checkExternalEmitHelpers(node, 512);
+ }
+ var elementType = checkIteratedTypeOrElementType(sourceType, node, false, false) || unknownType;
var elements = node.elements;
for (var i = 0; i < elements.length; i++) {
- checkArrayLiteralDestructuringElementAssignment(node, sourceType, i, elementType, contextualMapper);
+ checkArrayLiteralDestructuringElementAssignment(node, sourceType, i, elementType, checkMode);
}
return sourceType;
}
- function checkArrayLiteralDestructuringElementAssignment(node, sourceType, elementIndex, elementType, contextualMapper) {
+ function checkArrayLiteralDestructuringElementAssignment(node, sourceType, elementIndex, elementType, checkMode) {
var elements = node.elements;
var element = elements[elementIndex];
- if (element.kind !== 198) {
- if (element.kind !== 196) {
+ if (element.kind !== 199) {
+ if (element.kind !== 197) {
var propName = "" + elementIndex;
var type = isTypeAny(sourceType)
? sourceType
@@ -30634,7 +33470,7 @@ var ts;
? getTypeOfPropertyOfType(sourceType, propName)
: elementType;
if (type) {
- return checkDestructuringAssignment(element, type, contextualMapper);
+ return checkDestructuringAssignment(element, type, checkMode);
}
else {
checkExpression(element);
@@ -30652,48 +33488,48 @@ var ts;
}
else {
var restExpression = element.expression;
- if (restExpression.kind === 192 && restExpression.operatorToken.kind === 57) {
+ if (restExpression.kind === 193 && restExpression.operatorToken.kind === 57) {
error(restExpression.operatorToken, ts.Diagnostics.A_rest_element_cannot_have_an_initializer);
}
else {
- return checkDestructuringAssignment(restExpression, createArrayType(elementType), contextualMapper);
+ return checkDestructuringAssignment(restExpression, createArrayType(elementType), checkMode);
}
}
}
}
return undefined;
}
- function checkDestructuringAssignment(exprOrAssignment, sourceType, contextualMapper) {
+ function checkDestructuringAssignment(exprOrAssignment, sourceType, checkMode) {
var target;
- if (exprOrAssignment.kind === 258) {
+ if (exprOrAssignment.kind === 261) {
var prop = exprOrAssignment;
if (prop.objectAssignmentInitializer) {
if (strictNullChecks &&
!(getFalsyFlags(checkExpression(prop.objectAssignmentInitializer)) & 2048)) {
sourceType = getTypeWithFacts(sourceType, 131072);
}
- checkBinaryLikeExpression(prop.name, prop.equalsToken, prop.objectAssignmentInitializer, contextualMapper);
+ checkBinaryLikeExpression(prop.name, prop.equalsToken, prop.objectAssignmentInitializer, checkMode);
}
target = exprOrAssignment.name;
}
else {
target = exprOrAssignment;
}
- if (target.kind === 192 && target.operatorToken.kind === 57) {
- checkBinaryExpression(target, contextualMapper);
+ if (target.kind === 193 && target.operatorToken.kind === 57) {
+ checkBinaryExpression(target, checkMode);
target = target.left;
}
- if (target.kind === 176) {
+ if (target.kind === 177) {
return checkObjectLiteralAssignment(target, sourceType);
}
- if (target.kind === 175) {
- return checkArrayLiteralAssignment(target, sourceType, contextualMapper);
+ if (target.kind === 176) {
+ return checkArrayLiteralAssignment(target, sourceType, checkMode);
}
- return checkReferenceAssignment(target, sourceType, contextualMapper);
+ return checkReferenceAssignment(target, sourceType, checkMode);
}
- function checkReferenceAssignment(target, sourceType, contextualMapper) {
- var targetType = checkExpression(target, contextualMapper);
- var error = target.parent.kind === 259 ?
+ function checkReferenceAssignment(target, sourceType, checkMode) {
+ var targetType = checkExpression(target, checkMode);
+ var error = target.parent.kind === 262 ?
ts.Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access :
ts.Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access;
if (checkReferenceExpression(target, error)) {
@@ -30707,35 +33543,35 @@ var ts;
case 70:
case 9:
case 11:
- case 181:
- case 194:
+ case 182:
+ case 195:
case 12:
case 8:
case 100:
case 85:
case 94:
- case 137:
- case 184:
- case 197:
+ case 138:
case 185:
- case 175:
+ case 198:
+ case 186:
case 176:
- case 187:
- case 201:
- case 247:
- case 246:
+ case 177:
+ case 188:
+ case 202:
+ case 249:
+ case 248:
return true;
- case 193:
+ case 194:
return isSideEffectFree(node.whenTrue) &&
isSideEffectFree(node.whenFalse);
- case 192:
+ case 193:
if (ts.isAssignmentOperator(node.operatorToken.kind)) {
return false;
}
return isSideEffectFree(node.left) &&
isSideEffectFree(node.right);
- case 190:
case 191:
+ case 192:
switch (node.operator) {
case 50:
case 36:
@@ -30744,9 +33580,9 @@ var ts;
return true;
}
return false;
- case 188:
- case 182:
- case 200:
+ case 189:
+ case 183:
+ case 201:
default:
return false;
}
@@ -30761,16 +33597,16 @@ var ts;
firstAssignableToSecond && !secondAssignableToFirst ? type2 :
getUnionType([type1, type2], true);
}
- function checkBinaryExpression(node, contextualMapper) {
- return checkBinaryLikeExpression(node.left, node.operatorToken, node.right, contextualMapper, node);
+ function checkBinaryExpression(node, checkMode) {
+ return checkBinaryLikeExpression(node.left, node.operatorToken, node.right, checkMode, node);
}
- function checkBinaryLikeExpression(left, operatorToken, right, contextualMapper, errorNode) {
+ function checkBinaryLikeExpression(left, operatorToken, right, checkMode, errorNode) {
var operator = operatorToken.kind;
- if (operator === 57 && (left.kind === 176 || left.kind === 175)) {
- return checkDestructuringAssignment(left, checkExpression(right, contextualMapper), contextualMapper);
+ if (operator === 57 && (left.kind === 177 || left.kind === 176)) {
+ return checkDestructuringAssignment(left, checkExpression(right, checkMode), checkMode);
}
- var leftType = checkExpression(left, contextualMapper);
- var rightType = checkExpression(right, contextualMapper);
+ var leftType = checkExpression(left, checkMode);
+ var rightType = checkExpression(right, checkMode);
switch (operator) {
case 38:
case 39:
@@ -30797,12 +33633,8 @@ var ts;
if (leftType === silentNeverType || rightType === silentNeverType) {
return silentNeverType;
}
- if (leftType.flags & 6144)
- leftType = rightType;
- if (rightType.flags & 6144)
- rightType = leftType;
- leftType = getNonNullableType(leftType);
- rightType = getNonNullableType(rightType);
+ leftType = checkNonNullType(leftType, left);
+ rightType = checkNonNullType(rightType, right);
var suggestedOperator = void 0;
if ((leftType.flags & 136) &&
(rightType.flags & 136) &&
@@ -30822,12 +33654,10 @@ var ts;
if (leftType === silentNeverType || rightType === silentNeverType) {
return silentNeverType;
}
- if (leftType.flags & 6144)
- leftType = rightType;
- if (rightType.flags & 6144)
- rightType = leftType;
- leftType = getNonNullableType(leftType);
- rightType = getNonNullableType(rightType);
+ if (!isTypeOfKind(leftType, 1 | 262178) && !isTypeOfKind(rightType, 1 | 262178)) {
+ leftType = checkNonNullType(leftType, left);
+ rightType = checkNonNullType(rightType, right);
+ }
var resultType = void 0;
if (isTypeOfKind(leftType, 340) && isTypeOfKind(rightType, 340)) {
resultType = numberType;
@@ -30856,8 +33686,8 @@ var ts;
case 29:
case 30:
if (checkForDisallowedESSymbolOperand(operator)) {
- leftType = getBaseTypeOfLiteralType(leftType);
- rightType = getBaseTypeOfLiteralType(rightType);
+ leftType = getBaseTypeOfLiteralType(checkNonNullType(leftType, left));
+ rightType = getBaseTypeOfLiteralType(checkNonNullType(rightType, right));
if (!isTypeComparableTo(leftType, rightType) && !isTypeComparableTo(rightType, leftType)) {
reportOperatorError();
}
@@ -30893,11 +33723,14 @@ var ts;
checkAssignmentOperator(rightType);
return getRegularTypeOfObjectLiteral(rightType);
case 25:
- if (!compilerOptions.allowUnreachableCode && isSideEffectFree(left)) {
+ if (!compilerOptions.allowUnreachableCode && isSideEffectFree(left) && !isEvalNode(right)) {
error(left, ts.Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects);
}
return rightType;
}
+ function isEvalNode(node) {
+ return node.kind === 70 && node.text === "eval";
+ }
function checkForDisallowedESSymbolOperand(operator) {
var offendingSymbolOperand = maybeTypeOfKind(leftType, 512) ? left :
maybeTypeOfKind(rightType, 512) ? right :
@@ -30951,7 +33784,7 @@ var ts;
}
function checkYieldExpression(node) {
if (produceDiagnostics) {
- if (!(node.flags & 131072) || isYieldExpressionInClass(node)) {
+ if (!(node.flags & 4096) || isYieldExpressionInClass(node)) {
grammarErrorOnFirstToken(node, ts.Diagnostics.A_yield_expression_is_only_allowed_in_a_generator_body);
}
if (isInParameterInitializerBeforeContainingFunction(node)) {
@@ -30960,30 +33793,45 @@ var ts;
}
if (node.expression) {
var func = ts.getContainingFunction(node);
- if (func && func.asteriskToken) {
+ var functionFlags = func && ts.getFunctionFlags(func);
+ if (node.asteriskToken) {
+ if (functionFlags & 2) {
+ if (languageVersion < 4) {
+ checkExternalEmitHelpers(node, 4096);
+ }
+ }
+ else if (languageVersion < 2 && compilerOptions.downlevelIteration) {
+ checkExternalEmitHelpers(node, 256);
+ }
+ }
+ if (functionFlags & 1) {
var expressionType = checkExpressionCached(node.expression, undefined);
var expressionElementType = void 0;
var nodeIsYieldStar = !!node.asteriskToken;
if (nodeIsYieldStar) {
- expressionElementType = checkElementTypeOfIterable(expressionType, node.expression);
+ expressionElementType = checkIteratedTypeOrElementType(expressionType, node.expression, false, (functionFlags & 2) !== 0);
}
if (func.type) {
- var signatureElementType = getElementTypeOfIterableIterator(getTypeFromTypeNode(func.type)) || anyType;
+ var signatureElementType = getIteratedTypeOfGenerator(getTypeFromTypeNode(func.type), (functionFlags & 2) !== 0) || anyType;
if (nodeIsYieldStar) {
- checkTypeAssignableTo(expressionElementType, signatureElementType, node.expression, undefined);
+ checkTypeAssignableTo(functionFlags & 2
+ ? getAwaitedType(expressionElementType, node.expression, ts.Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member)
+ : expressionElementType, signatureElementType, node.expression, undefined);
}
else {
- checkTypeAssignableTo(expressionType, signatureElementType, node.expression, undefined);
+ checkTypeAssignableTo(functionFlags & 2
+ ? getAwaitedType(expressionType, node.expression, ts.Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member)
+ : expressionType, signatureElementType, node.expression, undefined);
}
}
}
}
return anyType;
}
- function checkConditionalExpression(node, contextualMapper) {
+ function checkConditionalExpression(node, checkMode) {
checkExpression(node.condition);
- var type1 = checkExpression(node.whenTrue, contextualMapper);
- var type2 = checkExpression(node.whenFalse, contextualMapper);
+ var type1 = checkExpression(node.whenTrue, checkMode);
+ var type2 = checkExpression(node.whenFalse, checkMode);
return getBestChoiceType(type1, type2);
}
function checkLiteralExpression(node) {
@@ -31009,107 +33857,119 @@ var ts;
}
function checkExpressionWithContextualType(node, contextualType, contextualMapper) {
var saveContextualType = node.contextualType;
+ var saveContextualMapper = node.contextualMapper;
node.contextualType = contextualType;
- var result = checkExpression(node, contextualMapper);
+ node.contextualMapper = contextualMapper;
+ var checkMode = contextualMapper === identityMapper ? 1 :
+ contextualMapper ? 2 : 0;
+ var result = checkExpression(node, checkMode);
node.contextualType = saveContextualType;
+ node.contextualMapper = saveContextualMapper;
return result;
}
- function checkExpressionCached(node, contextualMapper) {
+ function checkExpressionCached(node, checkMode) {
var links = getNodeLinks(node);
if (!links.resolvedType) {
var saveFlowLoopStart = flowLoopStart;
flowLoopStart = flowLoopCount;
- links.resolvedType = checkExpression(node, contextualMapper);
+ links.resolvedType = checkExpression(node, checkMode);
flowLoopStart = saveFlowLoopStart;
}
return links.resolvedType;
}
function isTypeAssertion(node) {
node = ts.skipParentheses(node);
- return node.kind === 182 || node.kind === 200;
+ return node.kind === 183 || node.kind === 201;
}
function checkDeclarationInitializer(declaration) {
- var type = checkExpressionCached(declaration.initializer);
+ var type = getTypeOfExpression(declaration.initializer, true);
return ts.getCombinedNodeFlags(declaration) & 2 ||
ts.getCombinedModifierFlags(declaration) & 64 && !ts.isParameterPropertyDeclaration(declaration) ||
isTypeAssertion(declaration.initializer) ? type : getWidenedLiteralType(type);
}
function isLiteralContextualType(contextualType) {
if (contextualType) {
- if (contextualType.flags & 16384) {
- var apparentType = getApparentTypeOfTypeParameter(contextualType);
- if (apparentType.flags & (2 | 4 | 8 | 16)) {
+ if (contextualType.flags & 540672) {
+ var constraint = getBaseConstraintOfType(contextualType) || emptyObjectType;
+ if (constraint.flags & (2 | 4 | 8 | 16)) {
return true;
}
- contextualType = apparentType;
+ contextualType = constraint;
}
return maybeTypeOfKind(contextualType, (480 | 262144));
}
return false;
}
- function checkExpressionForMutableLocation(node, contextualMapper) {
- var type = checkExpression(node, contextualMapper);
+ function checkExpressionForMutableLocation(node, checkMode) {
+ var type = checkExpression(node, checkMode);
return isTypeAssertion(node) || isLiteralContextualType(getContextualType(node)) ? type : getWidenedLiteralType(type);
}
- function checkPropertyAssignment(node, contextualMapper) {
- if (node.name.kind === 142) {
+ function checkPropertyAssignment(node, checkMode) {
+ if (node.name.kind === 143) {
checkComputedPropertyName(node.name);
}
- return checkExpressionForMutableLocation(node.initializer, contextualMapper);
+ return checkExpressionForMutableLocation(node.initializer, checkMode);
}
- function checkObjectLiteralMethod(node, contextualMapper) {
+ function checkObjectLiteralMethod(node, checkMode) {
checkGrammarMethod(node);
- if (node.name.kind === 142) {
+ if (node.name.kind === 143) {
checkComputedPropertyName(node.name);
}
- var uninstantiatedType = checkFunctionExpressionOrObjectLiteralMethod(node, contextualMapper);
- return instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, contextualMapper);
+ var uninstantiatedType = checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
+ return instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, checkMode);
}
- function instantiateTypeWithSingleGenericCallSignature(node, type, contextualMapper) {
- if (isInferentialContext(contextualMapper)) {
+ function instantiateTypeWithSingleGenericCallSignature(node, type, checkMode) {
+ if (checkMode === 2) {
var signature = getSingleCallSignature(type);
if (signature && signature.typeParameters) {
var contextualType = getApparentTypeOfContextualType(node);
if (contextualType) {
var contextualSignature = getSingleCallSignature(contextualType);
if (contextualSignature && !contextualSignature.typeParameters) {
- return getOrCreateTypeFromSignature(instantiateSignatureInContextOf(signature, contextualSignature, contextualMapper));
+ return getOrCreateTypeFromSignature(instantiateSignatureInContextOf(signature, contextualSignature, getContextualMapper(node)));
}
}
}
}
return type;
}
- function getTypeOfExpression(node) {
- if (node.kind === 179 && node.expression.kind !== 96) {
+ function getTypeOfExpression(node, cache) {
+ if (node.kind === 180 && node.expression.kind !== 96 && !ts.isRequireCall(node, true)) {
var funcType = checkNonNullExpression(node.expression);
var signature = getSingleCallSignature(funcType);
if (signature && !signature.typeParameters) {
return getReturnTypeOfSignature(signature);
}
}
- return checkExpression(node);
+ return cache ? checkExpressionCached(node) : checkExpression(node);
}
- function checkExpression(node, contextualMapper) {
+ function getContextFreeTypeOfExpression(node) {
+ var saveContextualType = node.contextualType;
+ node.contextualType = anyType;
+ var type = getTypeOfExpression(node);
+ node.contextualType = saveContextualType;
+ return type;
+ }
+ function checkExpression(node, checkMode) {
var type;
- if (node.kind === 141) {
+ if (node.kind === 142) {
type = checkQualifiedName(node);
}
else {
- var uninstantiatedType = checkExpressionWorker(node, contextualMapper);
- type = instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, contextualMapper);
+ var uninstantiatedType = checkExpressionWorker(node, checkMode);
+ type = instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, checkMode);
}
if (isConstEnumObjectType(type)) {
- var ok = (node.parent.kind === 177 && node.parent.expression === node) ||
- (node.parent.kind === 178 && node.parent.expression === node) ||
- ((node.kind === 70 || node.kind === 141) && isInRightSideOfImportOrExportAssignment(node));
+ var ok = (node.parent.kind === 178 && node.parent.expression === node) ||
+ (node.parent.kind === 179 && node.parent.expression === node) ||
+ ((node.kind === 70 || node.kind === 142) && isInRightSideOfImportOrExportAssignment(node));
if (!ok) {
error(node, ts.Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment);
}
}
return type;
}
- function checkExpressionWorker(node, contextualMapper) {
+ function checkExpressionWorker(node, checkMode) {
switch (node.kind) {
case 70:
return checkIdentifier(node);
@@ -31124,66 +33984,70 @@ var ts;
case 100:
case 85:
return checkLiteralExpression(node);
- case 194:
+ case 195:
return checkTemplateExpression(node);
case 12:
return stringType;
case 11:
return globalRegExpType;
- case 175:
- return checkArrayLiteral(node, contextualMapper);
case 176:
- return checkObjectLiteral(node, contextualMapper);
+ return checkArrayLiteral(node, checkMode);
case 177:
- return checkPropertyAccessExpression(node);
+ return checkObjectLiteral(node, checkMode);
case 178:
- return checkIndexedAccess(node);
+ return checkPropertyAccessExpression(node);
case 179:
+ return checkIndexedAccess(node);
case 180:
- return checkCallExpression(node);
case 181:
+ return checkCallExpression(node);
+ case 182:
return checkTaggedTemplateExpression(node);
- case 183:
- return checkExpression(node.expression, contextualMapper);
- case 197:
- return checkClassExpression(node);
case 184:
+ return checkExpression(node.expression, checkMode);
+ case 198:
+ return checkClassExpression(node);
case 185:
- return checkFunctionExpressionOrObjectLiteralMethod(node, contextualMapper);
- case 187:
+ case 186:
+ return checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
+ case 188:
return checkTypeOfExpression(node);
- case 182:
- case 200:
- return checkAssertion(node);
+ case 183:
case 201:
+ return checkAssertion(node);
+ case 202:
return checkNonNullAssertion(node);
- case 186:
+ case 203:
+ return checkMetaProperty(node);
+ case 187:
return checkDeleteExpression(node);
- case 188:
- return checkVoidExpression(node);
case 189:
- return checkAwaitExpression(node);
+ return checkVoidExpression(node);
case 190:
- return checkPrefixUnaryExpression(node);
+ return checkAwaitExpression(node);
case 191:
- return checkPostfixUnaryExpression(node);
+ return checkPrefixUnaryExpression(node);
case 192:
- return checkBinaryExpression(node, contextualMapper);
+ return checkPostfixUnaryExpression(node);
case 193:
- return checkConditionalExpression(node, contextualMapper);
- case 196:
- return checkSpreadExpression(node, contextualMapper);
- case 198:
+ return checkBinaryExpression(node, checkMode);
+ case 194:
+ return checkConditionalExpression(node, checkMode);
+ case 197:
+ return checkSpreadExpression(node, checkMode);
+ case 199:
return undefinedWideningType;
- case 195:
+ case 196:
return checkYieldExpression(node);
- case 252:
- return checkJsxExpression(node);
- case 246:
+ case 255:
+ return checkJsxExpression(node, checkMode);
+ case 248:
return checkJsxElement(node);
- case 247:
+ case 249:
return checkJsxSelfClosingElement(node);
- case 248:
+ case 253:
+ return checkJsxAttributes(node, checkMode);
+ case 250:
ts.Debug.fail("Shouldn't ever directly check a JsxOpeningElement");
}
return unknownType;
@@ -31193,7 +34057,16 @@ var ts;
grammarErrorOnFirstToken(node.expression, ts.Diagnostics.Type_expected);
}
checkSourceElement(node.constraint);
- getConstraintOfTypeParameter(getDeclaredTypeOfTypeParameter(getSymbolOfNode(node)));
+ checkSourceElement(node.default);
+ var typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfNode(node));
+ if (!hasNonCircularBaseConstraint(typeParameter)) {
+ error(node.constraint, ts.Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(typeParameter));
+ }
+ var constraintType = getConstraintOfTypeParameter(typeParameter);
+ var defaultType = getDefaultFromTypeParameter(typeParameter);
+ if (constraintType && defaultType) {
+ checkTypeAssignableTo(defaultType, getTypeWithThisArgument(constraintType, defaultType), node.default, ts.Diagnostics.Type_0_does_not_satisfy_the_constraint_1);
+ }
if (produceDiagnostics) {
checkTypeNameIsReserved(node.name, ts.Diagnostics.Type_parameter_name_cannot_be_0);
}
@@ -31204,7 +34077,7 @@ var ts;
var func = ts.getContainingFunction(node);
if (ts.getModifierFlags(node) & 92) {
func = ts.getContainingFunction(node);
- if (!(func.kind === 150 && ts.nodeIsPresent(func.body))) {
+ if (!(func.kind === 151 && ts.nodeIsPresent(func.body))) {
error(node, ts.Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation);
}
}
@@ -31215,7 +34088,7 @@ var ts;
if (ts.indexOf(func.parameters, node) !== 0) {
error(node, ts.Diagnostics.A_this_parameter_must_be_the_first_parameter);
}
- if (func.kind === 150 || func.kind === 154 || func.kind === 159) {
+ if (func.kind === 151 || func.kind === 155 || func.kind === 160) {
error(node, ts.Diagnostics.A_constructor_cannot_have_a_this_parameter);
}
}
@@ -31223,14 +34096,6 @@ var ts;
error(node, ts.Diagnostics.A_rest_parameter_must_be_of_an_array_type);
}
}
- function isSyntacticallyValidGenerator(node) {
- if (!node.asteriskToken || !node.body) {
- return false;
- }
- return node.kind === 149 ||
- node.kind === 225 ||
- node.kind === 184;
- }
function getTypePredicateParameterIndex(parameterList, parameter) {
if (parameterList) {
for (var i = 0; i < parameterList.length; i++) {
@@ -31270,9 +34135,9 @@ var ts;
else if (parameterName) {
var hasReportedError = false;
for (var _i = 0, _a = parent.parameters; _i < _a.length; _i++) {
- var name_21 = _a[_i].name;
- if (ts.isBindingPattern(name_21) &&
- checkIfTypePredicateVariableIsDeclaredInBindingPattern(name_21, parameterName, typePredicate.parameterName)) {
+ var name = _a[_i].name;
+ if (ts.isBindingPattern(name) &&
+ checkIfTypePredicateVariableIsDeclaredInBindingPattern(name, parameterName, typePredicate.parameterName)) {
hasReportedError = true;
break;
}
@@ -31285,16 +34150,16 @@ var ts;
}
function getTypePredicateParent(node) {
switch (node.parent.kind) {
+ case 186:
+ case 154:
+ case 227:
case 185:
- case 153:
- case 225:
- case 184:
- case 158:
+ case 159:
+ case 150:
case 149:
- case 148:
- var parent_9 = node.parent;
- if (node === parent_9.type) {
- return parent_9;
+ var parent = node.parent;
+ if (node === parent.type) {
+ return parent;
}
}
}
@@ -31304,29 +34169,44 @@ var ts;
if (ts.isOmittedExpression(element)) {
continue;
}
- var name_22 = element.name;
- if (name_22.kind === 70 &&
- name_22.text === predicateVariableName) {
+ var name = element.name;
+ if (name.kind === 70 &&
+ name.text === predicateVariableName) {
error(predicateVariableNode, ts.Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern, predicateVariableName);
return true;
}
- else if (name_22.kind === 173 ||
- name_22.kind === 172) {
- if (checkIfTypePredicateVariableIsDeclaredInBindingPattern(name_22, predicateVariableNode, predicateVariableName)) {
+ else if (name.kind === 174 ||
+ name.kind === 173) {
+ if (checkIfTypePredicateVariableIsDeclaredInBindingPattern(name, predicateVariableNode, predicateVariableName)) {
return true;
}
}
}
}
function checkSignatureDeclaration(node) {
- if (node.kind === 155) {
+ if (node.kind === 156) {
checkGrammarIndexSignature(node);
}
- else if (node.kind === 158 || node.kind === 225 || node.kind === 159 ||
- node.kind === 153 || node.kind === 150 ||
- node.kind === 154) {
+ else if (node.kind === 159 || node.kind === 227 || node.kind === 160 ||
+ node.kind === 154 || node.kind === 151 ||
+ node.kind === 155) {
checkGrammarFunctionLikeDeclaration(node);
}
+ var functionFlags = ts.getFunctionFlags(node);
+ if ((functionFlags & 7) === 2 && languageVersion < 4) {
+ checkExternalEmitHelpers(node, 64);
+ if (languageVersion < 2) {
+ checkExternalEmitHelpers(node, 128);
+ }
+ }
+ if ((functionFlags & 5) === 1) {
+ if (functionFlags & 2 && languageVersion < 4) {
+ checkExternalEmitHelpers(node, 2048);
+ }
+ else if (languageVersion < 2) {
+ checkExternalEmitHelpers(node, 128);
+ }
+ }
checkTypeParameters(node.typeParameters);
ts.forEach(node.parameters, checkParameter);
if (node.type) {
@@ -31334,29 +34214,32 @@ var ts;
}
if (produceDiagnostics) {
checkCollisionWithArgumentsInGeneratedCode(node);
- if (compilerOptions.noImplicitAny && !node.type) {
+ if (noImplicitAny && !node.type) {
switch (node.kind) {
- case 154:
+ case 155:
error(node, ts.Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
break;
- case 153:
+ case 154:
error(node, ts.Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
break;
}
}
if (node.type) {
- if (languageVersion >= 2 && isSyntacticallyValidGenerator(node)) {
+ var functionFlags_1 = ts.getFunctionFlags(node);
+ if ((functionFlags_1 & 5) === 1) {
var returnType = getTypeFromTypeNode(node.type);
if (returnType === voidType) {
error(node.type, ts.Diagnostics.A_generator_cannot_have_a_void_type_annotation);
}
else {
- var generatorElementType = getElementTypeOfIterableIterator(returnType) || anyType;
- var iterableIteratorInstantiation = createIterableIteratorType(generatorElementType);
+ var generatorElementType = getIteratedTypeOfGenerator(returnType, (functionFlags_1 & 2) !== 0) || anyType;
+ var iterableIteratorInstantiation = functionFlags_1 & 2
+ ? createAsyncIterableIteratorType(generatorElementType)
+ : createIterableIteratorType(generatorElementType);
checkTypeAssignableTo(iterableIteratorInstantiation, returnType, node.type);
}
}
- else if (ts.isAsyncFunctionLike(node)) {
+ else if ((functionFlags_1 & 3) === 2) {
checkAsyncFunctionReturnType(node);
}
}
@@ -31370,7 +34253,7 @@ var ts;
var staticNames = ts.createMap();
for (var _i = 0, _a = node.members; _i < _a.length; _i++) {
var member = _a[_i];
- if (member.kind === 150) {
+ if (member.kind === 151) {
for (var _b = 0, _c = member.parameters; _b < _c.length; _b++) {
var param = _c[_b];
if (ts.isParameterPropertyDeclaration(param)) {
@@ -31379,36 +34262,65 @@ var ts;
}
}
else {
- var isStatic = ts.forEach(member.modifiers, function (m) { return m.kind === 114; });
+ var isStatic = ts.getModifierFlags(member) & 32;
var names = isStatic ? staticNames : instanceNames;
var memberName = member.name && ts.getPropertyNameForPropertyNameNode(member.name);
if (memberName) {
switch (member.kind) {
- case 151:
+ case 152:
addName(names, member.name, memberName, 1);
break;
- case 152:
+ case 153:
addName(names, member.name, memberName, 2);
break;
- case 147:
+ case 148:
addName(names, member.name, memberName, 3);
break;
+ case 150:
+ addName(names, member.name, memberName, 4);
+ break;
}
}
}
}
function addName(names, location, name, meaning) {
- var prev = names[name];
+ var prev = names.get(name);
if (prev) {
- if (prev & meaning) {
+ if (prev & 4) {
+ if (meaning !== 4) {
+ error(location, ts.Diagnostics.Duplicate_identifier_0, ts.getTextOfNode(location));
+ }
+ }
+ else if (prev & meaning) {
error(location, ts.Diagnostics.Duplicate_identifier_0, ts.getTextOfNode(location));
}
else {
- names[name] = prev | meaning;
+ names.set(name, prev | meaning);
}
}
else {
- names[name] = meaning;
+ names.set(name, meaning);
+ }
+ }
+ }
+ function checkClassForStaticPropertyNameConflicts(node) {
+ for (var _i = 0, _a = node.members; _i < _a.length; _i++) {
+ var member = _a[_i];
+ var memberNameNode = member.name;
+ var isStatic = ts.getModifierFlags(member) & 32;
+ if (isStatic && memberNameNode) {
+ var memberName = ts.getPropertyNameForPropertyNameNode(memberNameNode);
+ switch (memberName) {
+ case "name":
+ case "length":
+ case "caller":
+ case "arguments":
+ case "prototype":
+ var message = ts.Diagnostics.Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1;
+ var className = getNameOfSymbol(getSymbolOfNode(node));
+ error(memberNameNode, message, memberName, className);
+ break;
+ }
}
}
}
@@ -31416,7 +34328,7 @@ var ts;
var names = ts.createMap();
for (var _i = 0, _a = node.members; _i < _a.length; _i++) {
var member = _a[_i];
- if (member.kind == 146) {
+ if (member.kind === 147) {
var memberName = void 0;
switch (member.name.kind) {
case 9:
@@ -31427,18 +34339,18 @@ var ts;
default:
continue;
}
- if (names[memberName]) {
+ if (names.get(memberName)) {
error(member.symbol.valueDeclaration.name, ts.Diagnostics.Duplicate_identifier_0, memberName);
error(member.name, ts.Diagnostics.Duplicate_identifier_0, memberName);
}
else {
- names[memberName] = true;
+ names.set(memberName, true);
}
}
}
}
function checkTypeForDuplicateIndexSignatures(node) {
- if (node.kind === 227) {
+ if (node.kind === 229) {
var nodeSymbol = getSymbolOfNode(node);
if (nodeSymbol.declarations.length > 0 && nodeSymbol.declarations[0] !== node) {
return;
@@ -31453,7 +34365,7 @@ var ts;
var declaration = decl;
if (declaration.parameters.length === 1 && declaration.parameters[0].type) {
switch (declaration.parameters[0].type.kind) {
- case 134:
+ case 135:
if (!seenStringIndexer) {
seenStringIndexer = true;
}
@@ -31520,12 +34432,12 @@ var ts;
if (n.kind === 98) {
error(n, ts.Diagnostics.this_cannot_be_referenced_in_current_location);
}
- else if (n.kind !== 184 && n.kind !== 225) {
+ else if (n.kind !== 185 && n.kind !== 227) {
ts.forEachChild(n, markThisReferencesAsErrors);
}
}
function isInstancePropertyWithInitializer(n) {
- return n.kind === 147 &&
+ return n.kind === 148 &&
!(ts.getModifierFlags(n) & 32) &&
!!n.initializer;
}
@@ -31545,7 +34457,7 @@ var ts;
var superCallStatement = void 0;
for (var _i = 0, statements_3 = statements; _i < statements_3.length; _i++) {
var statement = statements_3[_i];
- if (statement.kind === 207 && ts.isSuperCall(statement.expression)) {
+ if (statement.kind === 209 && ts.isSuperCall(statement.expression)) {
superCallStatement = statement;
break;
}
@@ -31568,18 +34480,18 @@ var ts;
checkGrammarFunctionLikeDeclaration(node) || checkGrammarAccessor(node) || checkGrammarComputedPropertyName(node.name);
checkDecorators(node);
checkSignatureDeclaration(node);
- if (node.kind === 151) {
+ if (node.kind === 152) {
if (!ts.isInAmbientContext(node) && ts.nodeIsPresent(node.body) && (node.flags & 128)) {
if (!(node.flags & 256)) {
error(node.name, ts.Diagnostics.A_get_accessor_must_return_a_value);
}
}
}
- if (node.name.kind === 142) {
+ if (node.name.kind === 143) {
checkComputedPropertyName(node.name);
}
if (!ts.hasDynamicName(node)) {
- var otherKind = node.kind === 151 ? 152 : 151;
+ var otherKind = node.kind === 152 ? 153 : 152;
var otherAccessor = ts.getDeclarationOfKind(node.symbol, otherKind);
if (otherAccessor) {
if ((ts.getModifierFlags(node) & 28) !== (ts.getModifierFlags(otherAccessor) & 28)) {
@@ -31593,17 +34505,12 @@ var ts;
}
}
var returnType = getTypeOfAccessors(getSymbolOfNode(node));
- if (node.kind === 151) {
+ if (node.kind === 152) {
checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType);
}
}
- if (node.parent.kind !== 176) {
- checkSourceElement(node.body);
- registerForUnusedIdentifiersCheck(node);
- }
- else {
- checkNodeDeferred(node);
- }
+ checkSourceElement(node.body);
+ registerForUnusedIdentifiersCheck(node);
}
function checkAccessorDeclarationTypesIdentical(first, second, getAnnotatedType, message) {
var firstType = getAnnotatedType(first);
@@ -31612,14 +34519,11 @@ var ts;
error(first, message);
}
}
- function checkAccessorDeferred(node) {
- checkSourceElement(node.body);
- registerForUnusedIdentifiersCheck(node);
- }
function checkMissingDeclaration(node) {
checkDecorators(node);
}
function checkTypeArgumentConstraints(typeParameters, typeArgumentNodes) {
+ var minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
var typeArguments;
var mapper;
var result = true;
@@ -31627,7 +34531,7 @@ var ts;
var constraint = getConstraintOfTypeParameter(typeParameters[i]);
if (constraint) {
if (!typeArguments) {
- typeArguments = ts.map(typeArgumentNodes, getTypeFromTypeNode);
+ typeArguments = fillMissingTypeArguments(ts.map(typeArgumentNodes, getTypeFromTypeNode), typeParameters, minTypeArgumentCount);
mapper = createTypeMapper(typeParameters, typeArguments);
}
var typeArgument = typeArguments[i];
@@ -31678,25 +34582,42 @@ var ts;
function checkUnionOrIntersectionType(node) {
ts.forEach(node.types, checkSourceElement);
}
+ function checkIndexedAccessIndexType(type, accessNode) {
+ if (!(type.flags & 524288)) {
+ return type;
+ }
+ var objectType = type.objectType;
+ var indexType = type.indexType;
+ if (isTypeAssignableTo(indexType, getIndexType(objectType))) {
+ return type;
+ }
+ if (maybeTypeOfKind(objectType, 540672) && isTypeOfKind(indexType, 340)) {
+ var constraint = getBaseConstraintOfType(objectType);
+ if (constraint && getIndexInfoOfType(constraint, 1)) {
+ return type;
+ }
+ }
+ error(accessNode, ts.Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
+ return type;
+ }
function checkIndexedAccessType(node) {
- getTypeFromIndexedAccessTypeNode(node);
+ checkIndexedAccessIndexType(getTypeFromIndexedAccessTypeNode(node), node);
}
function checkMappedType(node) {
checkSourceElement(node.typeParameter);
checkSourceElement(node.type);
var type = getTypeFromMappedTypeNode(node);
var constraintType = getConstraintTypeFromMappedType(type);
- var keyType = constraintType.flags & 16384 ? getApparentTypeOfTypeParameter(constraintType) : constraintType;
- checkTypeAssignableTo(keyType, stringType, node.typeParameter.constraint);
+ checkTypeAssignableTo(constraintType, stringType, node.typeParameter.constraint);
}
function isPrivateWithinAmbient(node) {
return (ts.getModifierFlags(node) & 8) && ts.isInAmbientContext(node);
}
function getEffectiveDeclarationFlags(n, flagsToCheck) {
var flags = ts.getCombinedModifierFlags(n);
- if (n.parent.kind !== 227 &&
- n.parent.kind !== 226 &&
- n.parent.kind !== 197 &&
+ if (n.parent.kind !== 229 &&
+ n.parent.kind !== 228 &&
+ n.parent.kind !== 198 &&
ts.isInAmbientContext(n)) {
if (!(flags & 2)) {
flags |= 1;
@@ -31773,7 +34694,7 @@ var ts;
if (subsequentNode.kind === node.kind) {
var errorNode_1 = subsequentNode.name || subsequentNode;
if (node.name && subsequentNode.name && node.name.text === subsequentNode.name.text) {
- var reportError = (node.kind === 149 || node.kind === 148) &&
+ var reportError = (node.kind === 150 || node.kind === 149) &&
(ts.getModifierFlags(node) & 32) !== (ts.getModifierFlags(subsequentNode) & 32);
if (reportError) {
var diagnostic = ts.getModifierFlags(node) & 32 ? ts.Diagnostics.Function_overload_must_be_static : ts.Diagnostics.Function_overload_must_not_be_static;
@@ -31802,15 +34723,15 @@ var ts;
}
var duplicateFunctionDeclaration = false;
var multipleConstructorImplementation = false;
- for (var _i = 0, declarations_4 = declarations; _i < declarations_4.length; _i++) {
- var current = declarations_4[_i];
+ for (var _i = 0, declarations_5 = declarations; _i < declarations_5.length; _i++) {
+ var current = declarations_5[_i];
var node = current;
var inAmbientContext = ts.isInAmbientContext(node);
- var inAmbientContextOrInterface = node.parent.kind === 227 || node.parent.kind === 161 || inAmbientContext;
+ var inAmbientContextOrInterface = node.parent.kind === 229 || node.parent.kind === 162 || inAmbientContext;
if (inAmbientContextOrInterface) {
previousDeclaration = undefined;
}
- if (node.kind === 225 || node.kind === 149 || node.kind === 148 || node.kind === 150) {
+ if (node.kind === 227 || node.kind === 150 || node.kind === 149 || node.kind === 151) {
var currentNodeFlags = getEffectiveDeclarationFlags(node, flagsToCheck);
someNodeFlags |= currentNodeFlags;
allNodeFlags &= currentNodeFlags;
@@ -31861,8 +34782,8 @@ var ts;
if (bodyDeclaration) {
var signatures = getSignaturesOfSymbol(symbol);
var bodySignature = getSignatureFromDeclaration(bodyDeclaration);
- for (var _a = 0, signatures_3 = signatures; _a < signatures_3.length; _a++) {
- var signature = signatures_3[_a];
+ for (var _a = 0, signatures_4 = signatures; _a < signatures_4.length; _a++) {
+ var signature = signatures_4[_a];
if (!isImplementationCompatibleWithOverload(bodySignature, signature)) {
error(signature.declaration, ts.Diagnostics.Overload_signature_is_not_compatible_with_function_implementation);
break;
@@ -31921,16 +34842,16 @@ var ts;
}
function getDeclarationSpaces(d) {
switch (d.kind) {
- case 227:
+ case 229:
return 2097152;
- case 230:
+ case 232:
return ts.isAmbientModule(d) || ts.getModuleInstanceState(d) !== 0
? 4194304 | 1048576
: 4194304;
- case 226:
- case 229:
+ case 228:
+ case 231:
return 2097152 | 1048576;
- case 234:
+ case 236:
var result_3 = 0;
var target = resolveAlias(getSymbolOfNode(d));
ts.forEach(target.declarations, function (d) { result_3 |= getDeclarationSpaces(d); });
@@ -31940,87 +34861,92 @@ var ts;
}
}
}
- function checkNonThenableType(type, location, message) {
- type = getWidenedType(type);
- if (!isTypeAny(type) && !isTypeNever(type) && isTypeAssignableTo(type, getGlobalThenableType())) {
- if (location) {
- if (!message) {
- message = ts.Diagnostics.Operand_for_await_does_not_have_a_valid_callable_then_member;
- }
- error(location, message);
- }
- return unknownType;
- }
- return type;
+ function getAwaitedTypeOfPromise(type, errorNode, diagnosticMessage) {
+ var promisedType = getPromisedTypeOfPromise(type, errorNode);
+ return promisedType && getAwaitedType(promisedType, errorNode, diagnosticMessage);
}
- function getPromisedType(promise) {
+ function getPromisedTypeOfPromise(promise, errorNode) {
if (isTypeAny(promise)) {
return undefined;
}
- if (getObjectFlags(promise) & 4) {
- if (promise.target === tryGetGlobalPromiseType()
- || promise.target === getGlobalPromiseLikeType()) {
- return promise.typeArguments[0];
- }
+ var typeAsPromise = promise;
+ if (typeAsPromise.promisedTypeOfPromise) {
+ return typeAsPromise.promisedTypeOfPromise;
}
- var globalPromiseLikeType = getInstantiatedGlobalPromiseLikeType();
- if (globalPromiseLikeType === emptyObjectType || !isTypeAssignableTo(promise, globalPromiseLikeType)) {
- return undefined;
+ if (isReferenceToType(promise, getGlobalPromiseType(false))) {
+ return typeAsPromise.promisedTypeOfPromise = promise.typeArguments[0];
}
var thenFunction = getTypeOfPropertyOfType(promise, "then");
- if (!thenFunction || isTypeAny(thenFunction)) {
+ if (isTypeAny(thenFunction)) {
return undefined;
}
- var thenSignatures = getSignaturesOfType(thenFunction, 0);
+ var thenSignatures = thenFunction ? getSignaturesOfType(thenFunction, 0) : emptyArray;
if (thenSignatures.length === 0) {
+ if (errorNode) {
+ error(errorNode, ts.Diagnostics.A_promise_must_have_a_then_method);
+ }
return undefined;
}
- var onfulfilledParameterType = getTypeWithFacts(getUnionType(ts.map(thenSignatures, getTypeOfFirstParameterOfSignature)), 131072);
+ var onfulfilledParameterType = getTypeWithFacts(getUnionType(ts.map(thenSignatures, getTypeOfFirstParameterOfSignature)), 524288);
if (isTypeAny(onfulfilledParameterType)) {
return undefined;
}
var onfulfilledParameterSignatures = getSignaturesOfType(onfulfilledParameterType, 0);
if (onfulfilledParameterSignatures.length === 0) {
+ if (errorNode) {
+ error(errorNode, ts.Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback);
+ }
return undefined;
}
- return getUnionType(ts.map(onfulfilledParameterSignatures, getTypeOfFirstParameterOfSignature), true);
+ return typeAsPromise.promisedTypeOfPromise = getUnionType(ts.map(onfulfilledParameterSignatures, getTypeOfFirstParameterOfSignature), true);
}
- function getTypeOfFirstParameterOfSignature(signature) {
- return signature.parameters.length > 0 ? getTypeAtPosition(signature, 0) : neverType;
+ function checkAwaitedType(type, errorNode, diagnosticMessage) {
+ return getAwaitedType(type, errorNode, diagnosticMessage) || unknownType;
}
- function getAwaitedType(type) {
- return checkAwaitedType(type, undefined, undefined);
- }
- function checkAwaitedType(type, location, message) {
- return checkAwaitedTypeWorker(type);
- function checkAwaitedTypeWorker(type) {
- if (type.flags & 65536) {
- var types = [];
- for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
- var constituentType = _a[_i];
- types.push(checkAwaitedTypeWorker(constituentType));
- }
- return getUnionType(types, true);
+ function getAwaitedType(type, errorNode, diagnosticMessage) {
+ var typeAsAwaitable = type;
+ if (typeAsAwaitable.awaitedTypeOfType) {
+ return typeAsAwaitable.awaitedTypeOfType;
+ }
+ if (isTypeAny(type)) {
+ return typeAsAwaitable.awaitedTypeOfType = type;
+ }
+ if (type.flags & 65536) {
+ var types = void 0;
+ for (var _i = 0, _a = type.types; _i < _a.length; _i++) {
+ var constituentType = _a[_i];
+ types = ts.append(types, getAwaitedType(constituentType, errorNode, diagnosticMessage));
}
- else {
- var promisedType = getPromisedType(type);
- if (promisedType === undefined) {
- return checkNonThenableType(type, location, message);
- }
- else {
- if (type.id === promisedType.id || ts.indexOf(awaitedTypeStack, promisedType.id) >= 0) {
- if (location) {
- error(location, ts.Diagnostics._0_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method, symbolToString(type.symbol));
- }
- return unknownType;
- }
- awaitedTypeStack.push(type.id);
- var awaitedType = checkAwaitedTypeWorker(promisedType);
- awaitedTypeStack.pop();
- return awaitedType;
+ if (!types) {
+ return undefined;
+ }
+ return typeAsAwaitable.awaitedTypeOfType = getUnionType(types, true);
+ }
+ var promisedType = getPromisedTypeOfPromise(type);
+ if (promisedType) {
+ if (type.id === promisedType.id || ts.indexOf(awaitedTypeStack, promisedType.id) >= 0) {
+ if (errorNode) {
+ error(errorNode, ts.Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
}
+ return undefined;
+ }
+ awaitedTypeStack.push(type.id);
+ var awaitedType = getAwaitedType(promisedType, errorNode, diagnosticMessage);
+ awaitedTypeStack.pop();
+ if (!awaitedType) {
+ return undefined;
}
+ return typeAsAwaitable.awaitedTypeOfType = awaitedType;
}
+ var thenFunction = getTypeOfPropertyOfType(type, "then");
+ if (thenFunction && getSignaturesOfType(thenFunction, 0).length > 0) {
+ if (errorNode) {
+ ts.Debug.assert(!!diagnosticMessage);
+ error(errorNode, diagnosticMessage);
+ }
+ return undefined;
+ }
+ return typeAsAwaitable.awaitedTypeOfType = type;
}
function checkAsyncFunctionReturnType(node) {
var returnType = getTypeFromTypeNode(node.type);
@@ -32028,8 +34954,8 @@ var ts;
if (returnType === unknownType) {
return unknownType;
}
- var globalPromiseType = getGlobalPromiseType();
- if (globalPromiseType !== emptyGenericType && globalPromiseType !== getTargetType(returnType)) {
+ var globalPromiseType = getGlobalPromiseType(true);
+ if (globalPromiseType !== emptyGenericType && !isReferenceToType(returnType, globalPromiseType)) {
error(node.type, ts.Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type);
return unknownType;
}
@@ -32047,10 +34973,15 @@ var ts;
var promiseConstructorSymbol = resolveEntityName(promiseConstructorName, 107455, true);
var promiseConstructorType = promiseConstructorSymbol ? getTypeOfSymbol(promiseConstructorSymbol) : unknownType;
if (promiseConstructorType === unknownType) {
- error(node.type, ts.Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, ts.entityNameToString(promiseConstructorName));
+ if (promiseConstructorName.kind === 70 && promiseConstructorName.text === "Promise" && getTargetType(returnType) === getGlobalPromiseType(false)) {
+ error(node.type, ts.Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
+ }
+ else {
+ error(node.type, ts.Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, ts.entityNameToString(promiseConstructorName));
+ }
return unknownType;
}
- var globalPromiseConstructorLikeType = getGlobalPromiseConstructorLikeType();
+ var globalPromiseConstructorLikeType = getGlobalPromiseConstructorLikeType(true);
if (globalPromiseConstructorLikeType === emptyObjectType) {
error(node.type, ts.Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, ts.entityNameToString(promiseConstructorName));
return unknownType;
@@ -32065,7 +34996,7 @@ var ts;
return unknownType;
}
}
- return checkAwaitedType(returnType, node, ts.Diagnostics.An_async_function_or_method_must_have_a_valid_awaitable_return_type);
+ return checkAwaitedType(returnType, node, ts.Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
}
function checkDecorator(node) {
var signature = getResolvedSignature(node);
@@ -32077,22 +35008,22 @@ var ts;
var headMessage = getDiagnosticHeadMessageForDecoratorResolution(node);
var errorInfo;
switch (node.parent.kind) {
- case 226:
+ case 228:
var classSymbol = getSymbolOfNode(node.parent);
var classConstructorType = getTypeOfSymbol(classSymbol);
expectedReturnType = getUnionType([classConstructorType, voidType]);
break;
- case 144:
+ case 145:
expectedReturnType = voidType;
errorInfo = ts.chainDiagnosticMessages(errorInfo, ts.Diagnostics.The_return_type_of_a_parameter_decorator_function_must_be_either_void_or_any);
break;
- case 147:
+ case 148:
expectedReturnType = voidType;
errorInfo = ts.chainDiagnosticMessages(errorInfo, ts.Diagnostics.The_return_type_of_a_property_decorator_function_must_be_either_void_or_any);
break;
- case 149:
- case 151:
+ case 150:
case 152:
+ case 153:
var methodType = getTypeOfNode(node.parent);
var descriptorType = createTypedPropertyDescriptorType(methodType);
expectedReturnType = getUnionType([descriptorType, voidType]);
@@ -32111,6 +35042,9 @@ var ts;
markAliasSymbolAsReferenced(rootSymbol);
}
}
+ function getParameterTypeNodeForDecoratorCheck(node) {
+ return node.dotDotDotToken ? ts.getRestParameterElementType(node.type) : node.type;
+ }
function checkDecorators(node) {
if (!node.decorators) {
return;
@@ -32121,28 +35055,36 @@ var ts;
if (!compilerOptions.experimentalDecorators) {
error(node, ts.Diagnostics.Experimental_support_for_decorators_is_a_feature_that_is_subject_to_change_in_a_future_release_Set_the_experimentalDecorators_option_to_remove_this_warning);
}
+ var firstDecorator = node.decorators[0];
+ checkExternalEmitHelpers(firstDecorator, 8);
+ if (node.kind === 145) {
+ checkExternalEmitHelpers(firstDecorator, 32);
+ }
if (compilerOptions.emitDecoratorMetadata) {
+ checkExternalEmitHelpers(firstDecorator, 16);
switch (node.kind) {
- case 226:
+ case 228:
var constructor = ts.getFirstConstructorWithBody(node);
if (constructor) {
for (var _i = 0, _a = constructor.parameters; _i < _a.length; _i++) {
var parameter = _a[_i];
- markTypeNodeAsReferenced(parameter.type);
+ markTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
}
}
break;
- case 149:
- case 151:
+ case 150:
case 152:
+ case 153:
for (var _b = 0, _c = node.parameters; _b < _c.length; _b++) {
var parameter = _c[_b];
- markTypeNodeAsReferenced(parameter.type);
+ markTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
}
markTypeNodeAsReferenced(node.type);
break;
- case 147:
- case 144:
+ case 148:
+ markTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(node));
+ break;
+ case 145:
markTypeNodeAsReferenced(node.type);
break;
}
@@ -32154,6 +35096,7 @@ var ts;
checkFunctionOrMethodDeclaration(node) || checkGrammarForGenerator(node);
checkCollisionWithCapturedSuperVariable(node, node.name);
checkCollisionWithCapturedThisVariable(node, node.name);
+ checkCollisionWithCapturedNewTargetVariable(node, node.name);
checkCollisionWithRequireExportsInGeneratedCode(node, node.name);
checkCollisionWithGlobalPromiseInGeneratedCode(node, node.name);
}
@@ -32161,8 +35104,8 @@ var ts;
function checkFunctionOrMethodDeclaration(node) {
checkDecorators(node);
checkSignatureDeclaration(node);
- var isAsync = ts.isAsyncFunctionLike(node);
- if (node.name && node.name.kind === 142) {
+ var functionFlags = ts.getFunctionFlags(node);
+ if (node.name && node.name.kind === 143) {
checkComputedPropertyName(node.name);
}
if (!ts.hasDynamicName(node)) {
@@ -32180,15 +35123,17 @@ var ts;
}
}
checkSourceElement(node.body);
- if (!node.asteriskToken) {
- var returnOrPromisedType = node.type && (isAsync ? checkAsyncFunctionReturnType(node) : getTypeFromTypeNode(node.type));
+ if ((functionFlags & 1) === 0) {
+ var returnOrPromisedType = node.type && (functionFlags & 2
+ ? checkAsyncFunctionReturnType(node)
+ : getTypeFromTypeNode(node.type));
checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnOrPromisedType);
}
if (produceDiagnostics && !node.type) {
- if (compilerOptions.noImplicitAny && ts.nodeIsMissing(node.body) && !isPrivateWithinAmbient(node)) {
+ if (noImplicitAny && ts.nodeIsMissing(node.body) && !isPrivateWithinAmbient(node)) {
reportImplicitAnyError(node, anyType);
}
- if (node.asteriskToken && ts.nodeIsPresent(node.body)) {
+ if (functionFlags & 1 && ts.nodeIsPresent(node.body)) {
getReturnTypeOfSignature(getSignatureFromDeclaration(node));
}
}
@@ -32204,56 +35149,54 @@ var ts;
for (var _i = 0, deferredUnusedIdentifierNodes_1 = deferredUnusedIdentifierNodes; _i < deferredUnusedIdentifierNodes_1.length; _i++) {
var node = deferredUnusedIdentifierNodes_1[_i];
switch (node.kind) {
- case 261:
- case 230:
+ case 264:
+ case 232:
checkUnusedModuleMembers(node);
break;
- case 226:
- case 197:
+ case 228:
+ case 198:
checkUnusedClassMembers(node);
checkUnusedTypeParameters(node);
break;
- case 227:
+ case 229:
checkUnusedTypeParameters(node);
break;
- case 204:
- case 232:
- case 211:
- case 212:
+ case 206:
+ case 234:
case 213:
+ case 214:
+ case 215:
checkUnusedLocalsAndParameters(node);
break;
- case 150:
- case 184:
- case 225:
- case 185:
- case 149:
case 151:
+ case 185:
+ case 227:
+ case 186:
+ case 150:
case 152:
+ case 153:
if (node.body) {
checkUnusedLocalsAndParameters(node);
}
checkUnusedTypeParameters(node);
break;
- case 148:
- case 153:
+ case 149:
case 154:
case 155:
- case 158:
+ case 156:
case 159:
+ case 160:
checkUnusedTypeParameters(node);
break;
}
- ;
}
}
}
function checkUnusedLocalsAndParameters(node) {
- if (node.parent.kind !== 227 && noUnusedIdentifiers && !ts.isInAmbientContext(node)) {
- var _loop_3 = function (key) {
- var local = node.locals[key];
+ if (node.parent.kind !== 229 && noUnusedIdentifiers && !ts.isInAmbientContext(node)) {
+ node.locals.forEach(function (local) {
if (!local.isReferenced) {
- if (local.valueDeclaration && ts.getRootDeclaration(local.valueDeclaration).kind === 144) {
+ if (local.valueDeclaration && ts.getRootDeclaration(local.valueDeclaration).kind === 145) {
var parameter = ts.getRootDeclaration(local.valueDeclaration);
if (compilerOptions.noUnusedParameters &&
!ts.isParameterPropertyDeclaration(parameter) &&
@@ -32266,22 +35209,28 @@ var ts;
ts.forEach(local.declarations, function (d) { return errorUnusedLocal(d.name || d, local.name); });
}
}
- };
- for (var key in node.locals) {
- _loop_3(key);
- }
+ });
+ }
+ }
+ function isRemovedPropertyFromObjectSpread(node) {
+ if (ts.isBindingElement(node) && ts.isObjectBindingPattern(node.parent)) {
+ var lastElement = ts.lastOrUndefined(node.parent.elements);
+ return lastElement !== node && !!lastElement.dotDotDotToken;
}
+ return false;
}
function errorUnusedLocal(node, name) {
if (isIdentifierThatStartsWithUnderScore(node)) {
var declaration = ts.getRootDeclaration(node.parent);
- if (declaration.kind === 223 &&
- (declaration.parent.parent.kind === 212 ||
- declaration.parent.parent.kind === 213)) {
+ if (declaration.kind === 225 &&
+ (declaration.parent.parent.kind === 214 ||
+ declaration.parent.parent.kind === 215)) {
return;
}
}
- error(node, ts.Diagnostics._0_is_declared_but_never_used, name);
+ if (!isRemovedPropertyFromObjectSpread(node.kind === 70 ? node.parent : node)) {
+ error(node, ts.Diagnostics._0_is_declared_but_never_used, name);
+ }
}
function parameterNameStartsWithUnderscore(parameterName) {
return parameterName && isIdentifierThatStartsWithUnderScore(parameterName);
@@ -32294,12 +35243,12 @@ var ts;
if (node.members) {
for (var _i = 0, _a = node.members; _i < _a.length; _i++) {
var member = _a[_i];
- if (member.kind === 149 || member.kind === 147) {
+ if (member.kind === 150 || member.kind === 148) {
if (!member.symbol.isReferenced && ts.getModifierFlags(member) & 8) {
error(member.name, ts.Diagnostics._0_is_declared_but_never_used, member.symbol.name);
}
}
- else if (member.kind === 150) {
+ else if (member.kind === 151) {
for (var _b = 0, _c = member.parameters; _b < _c.length; _b++) {
var parameter = _c[_b];
if (!parameter.symbol.isReferenced && ts.getModifierFlags(parameter) & 8) {
@@ -32330,21 +35279,20 @@ var ts;
}
function checkUnusedModuleMembers(node) {
if (compilerOptions.noUnusedLocals && !ts.isInAmbientContext(node)) {
- for (var key in node.locals) {
- var local = node.locals[key];
+ node.locals.forEach(function (local) {
if (!local.isReferenced && !local.exportSymbol) {
for (var _i = 0, _a = local.declarations; _i < _a.length; _i++) {
var declaration = _a[_i];
if (!ts.isAmbientModule(declaration)) {
- error(declaration.name, ts.Diagnostics._0_is_declared_but_never_used, local.name);
+ errorUnusedLocal(declaration.name, local.name);
}
}
}
- }
+ });
}
}
function checkBlock(node) {
- if (node.kind === 204) {
+ if (node.kind === 206) {
checkGrammarStatementInAmbientContext(node);
}
ts.forEach(node.statements, checkSourceElement);
@@ -32366,19 +35314,19 @@ var ts;
if (!(identifier && identifier.text === name)) {
return false;
}
- if (node.kind === 147 ||
- node.kind === 146 ||
+ if (node.kind === 148 ||
+ node.kind === 147 ||
+ node.kind === 150 ||
node.kind === 149 ||
- node.kind === 148 ||
- node.kind === 151 ||
- node.kind === 152) {
+ node.kind === 152 ||
+ node.kind === 153) {
return false;
}
if (ts.isInAmbientContext(node)) {
return false;
}
var root = ts.getRootDeclaration(node);
- if (root.kind === 144 && ts.nodeIsMissing(root.parent.body)) {
+ if (root.kind === 145 && ts.nodeIsMissing(root.parent.body)) {
return false;
}
return true;
@@ -32388,9 +35336,13 @@ var ts;
potentialThisCollisions.push(node);
}
}
+ function checkCollisionWithCapturedNewTargetVariable(node, name) {
+ if (needCollisionCheckForIdentifier(node, name, "_newTarget")) {
+ potentialNewTargetCollisions.push(node);
+ }
+ }
function checkIfThisIsCapturedInEnclosingScope(node) {
- var current = node;
- while (current) {
+ ts.findAncestor(node, function (current) {
if (getNodeCheckFlags(current) & 4) {
var isDeclaration_1 = node.kind !== 70;
if (isDeclaration_1) {
@@ -32399,10 +35351,23 @@ var ts;
else {
error(node, ts.Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference);
}
- return;
+ return true;
}
- current = current.parent;
- }
+ });
+ }
+ function checkIfNewTargetIsCapturedInEnclosingScope(node) {
+ ts.findAncestor(node, function (current) {
+ if (getNodeCheckFlags(current) & 8) {
+ var isDeclaration_2 = node.kind !== 70;
+ if (isDeclaration_2) {
+ error(node.name, ts.Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference);
+ }
+ else {
+ error(node, ts.Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference);
+ }
+ return true;
+ }
+ });
}
function checkCollisionWithCapturedSuperVariable(node, name) {
if (!needCollisionCheckForIdentifier(node, name, "_super")) {
@@ -32413,8 +35378,8 @@ var ts;
return;
}
if (ts.getClassExtendsHeritageClauseElement(enclosingClass)) {
- var isDeclaration_2 = node.kind !== 70;
- if (isDeclaration_2) {
+ var isDeclaration_3 = node.kind !== 70;
+ if (isDeclaration_3) {
error(node, ts.Diagnostics.Duplicate_identifier_super_Compiler_uses_super_to_capture_base_class_reference);
}
else {
@@ -32429,23 +35394,23 @@ var ts;
if (!needCollisionCheckForIdentifier(node, name, "require") && !needCollisionCheckForIdentifier(node, name, "exports")) {
return;
}
- if (node.kind === 230 && ts.getModuleInstanceState(node) !== 1) {
+ if (node.kind === 232 && ts.getModuleInstanceState(node) !== 1) {
return;
}
var parent = getDeclarationContainer(node);
- if (parent.kind === 261 && ts.isExternalOrCommonJsModule(parent)) {
+ if (parent.kind === 264 && ts.isExternalOrCommonJsModule(parent)) {
error(name, ts.Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module, ts.declarationNameToString(name), ts.declarationNameToString(name));
}
}
function checkCollisionWithGlobalPromiseInGeneratedCode(node, name) {
- if (!needCollisionCheckForIdentifier(node, name, "Promise")) {
+ if (languageVersion >= 4 || !needCollisionCheckForIdentifier(node, name, "Promise")) {
return;
}
- if (node.kind === 230 && ts.getModuleInstanceState(node) !== 1) {
+ if (node.kind === 232 && ts.getModuleInstanceState(node) !== 1) {
return;
}
var parent = getDeclarationContainer(node);
- if (parent.kind === 261 && ts.isExternalOrCommonJsModule(parent) && parent.flags & 8192) {
+ if (parent.kind === 264 && ts.isExternalOrCommonJsModule(parent) && parent.flags & 1024) {
error(name, ts.Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions, ts.declarationNameToString(name), ts.declarationNameToString(name));
}
}
@@ -32453,7 +35418,7 @@ var ts;
if ((ts.getCombinedNodeFlags(node) & 3) !== 0 || ts.isParameterDeclaration(node)) {
return;
}
- if (node.kind === 223 && !node.initializer) {
+ if (node.kind === 225 && !node.initializer) {
return;
}
var symbol = getSymbolOfNode(node);
@@ -32463,25 +35428,25 @@ var ts;
localDeclarationSymbol !== symbol &&
localDeclarationSymbol.flags & 2) {
if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 3) {
- var varDeclList = ts.getAncestor(localDeclarationSymbol.valueDeclaration, 224);
- var container = varDeclList.parent.kind === 205 && varDeclList.parent.parent
+ var varDeclList = ts.getAncestor(localDeclarationSymbol.valueDeclaration, 226);
+ var container = varDeclList.parent.kind === 207 && varDeclList.parent.parent
? varDeclList.parent.parent
: undefined;
var namesShareScope = container &&
- (container.kind === 204 && ts.isFunctionLike(container.parent) ||
- container.kind === 231 ||
- container.kind === 230 ||
- container.kind === 261);
+ (container.kind === 206 && ts.isFunctionLike(container.parent) ||
+ container.kind === 233 ||
+ container.kind === 232 ||
+ container.kind === 264);
if (!namesShareScope) {
- var name_23 = symbolToString(localDeclarationSymbol);
- error(node, ts.Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name_23, name_23);
+ var name = symbolToString(localDeclarationSymbol);
+ error(node, ts.Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name);
}
}
}
}
}
function checkParameterInitializer(node) {
- if (ts.getRootDeclaration(node).kind !== 144) {
+ if (ts.getRootDeclaration(node).kind !== 145) {
return;
}
var func = ts.getContainingFunction(node);
@@ -32490,7 +35455,7 @@ var ts;
if (ts.isTypeNode(n) || ts.isDeclarationName(n)) {
return;
}
- if (n.kind === 177) {
+ if (n.kind === 178) {
return visit(n.expression);
}
else if (n.kind === 70) {
@@ -32504,21 +35469,21 @@ var ts;
}
var enclosingContainer = ts.getEnclosingBlockScopeContainer(symbol.valueDeclaration);
if (enclosingContainer === func) {
- if (symbol.valueDeclaration.kind === 144) {
+ if (symbol.valueDeclaration.kind === 145 ||
+ symbol.valueDeclaration.kind === 175) {
if (symbol.valueDeclaration.pos < node.pos) {
return;
}
- var current = n;
- while (current !== node.initializer) {
- if (ts.isFunctionLike(current.parent)) {
- return;
- }
- if (current.parent.kind === 147 &&
- !(ts.hasModifier(current.parent, 32)) &&
- ts.isClassLike(current.parent.parent)) {
- return;
+ if (ts.findAncestor(n, function (current) {
+ if (current === node.initializer) {
+ return "quit";
}
- current = current.parent;
+ return ts.isFunctionLike(current.parent) ||
+ (current.parent.kind === 148 &&
+ !(ts.hasModifier(current.parent, 32)) &&
+ ts.isClassLike(current.parent.parent));
+ })) {
+ return;
}
}
error(n, ts.Diagnostics.Initializer_of_parameter_0_cannot_reference_identifier_1_declared_after_it, ts.declarationNameToString(node.name), ts.declarationNameToString(n));
@@ -32535,34 +35500,40 @@ var ts;
function checkVariableLikeDeclaration(node) {
checkDecorators(node);
checkSourceElement(node.type);
- if (node.name.kind === 142) {
+ if (node.name.kind === 143) {
checkComputedPropertyName(node.name);
if (node.initializer) {
checkExpressionCached(node.initializer);
}
}
- if (node.kind === 174) {
- if (node.propertyName && node.propertyName.kind === 142) {
+ if (node.kind === 175) {
+ if (node.parent.kind === 173 && languageVersion < 5) {
+ checkExternalEmitHelpers(node, 4);
+ }
+ if (node.propertyName && node.propertyName.kind === 143) {
checkComputedPropertyName(node.propertyName);
}
- var parent_10 = node.parent.parent;
- var parentType = getTypeForBindingElementParent(parent_10);
- var name_24 = node.propertyName || node.name;
- var property = getPropertyOfType(parentType, ts.getTextOfPropertyName(name_24));
+ var parent = node.parent.parent;
+ var parentType = getTypeForBindingElementParent(parent);
+ var name = node.propertyName || node.name;
+ var property = getPropertyOfType(parentType, ts.getTextOfPropertyName(name));
markPropertyAsReferenced(property);
- if (parent_10.initializer && property && getParentOfSymbol(property)) {
- checkClassPropertyAccess(parent_10, parent_10.initializer, parentType, property);
+ if (parent.initializer && property) {
+ checkPropertyAccessibility(parent, parent.initializer, parentType, property);
}
}
if (ts.isBindingPattern(node.name)) {
+ if (node.name.kind === 174 && languageVersion < 2 && compilerOptions.downlevelIteration) {
+ checkExternalEmitHelpers(node, 512);
+ }
ts.forEach(node.name.elements, checkSourceElement);
}
- if (node.initializer && ts.getRootDeclaration(node).kind === 144 && ts.nodeIsMissing(ts.getContainingFunction(node).body)) {
+ if (node.initializer && ts.getRootDeclaration(node).kind === 145 && ts.nodeIsMissing(ts.getContainingFunction(node).body)) {
error(node, ts.Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation);
return;
}
if (ts.isBindingPattern(node.name)) {
- if (node.initializer && node.parent.parent.kind !== 212) {
+ if (node.initializer && node.parent.parent.kind !== 214) {
checkTypeAssignableTo(checkExpressionCached(node.initializer), getWidenedTypeForVariableLikeDeclaration(node), node, undefined);
checkParameterInitializer(node);
}
@@ -32571,7 +35542,7 @@ var ts;
var symbol = getSymbolOfNode(node);
var type = convertAutoToAny(getTypeOfVariableOrParameterOrProperty(symbol));
if (node === symbol.valueDeclaration) {
- if (node.initializer && node.parent.parent.kind !== 212) {
+ if (node.initializer && node.parent.parent.kind !== 214) {
checkTypeAssignableTo(checkExpressionCached(node.initializer), type, node, undefined);
checkParameterInitializer(node);
}
@@ -32589,20 +35560,21 @@ var ts;
error(node.name, ts.Diagnostics.All_declarations_of_0_must_have_identical_modifiers, ts.declarationNameToString(node.name));
}
}
- if (node.kind !== 147 && node.kind !== 146) {
+ if (node.kind !== 148 && node.kind !== 147) {
checkExportsOnMergedDeclarations(node);
- if (node.kind === 223 || node.kind === 174) {
+ if (node.kind === 225 || node.kind === 175) {
checkVarDeclaredNamesNotShadowed(node);
}
checkCollisionWithCapturedSuperVariable(node, node.name);
checkCollisionWithCapturedThisVariable(node, node.name);
+ checkCollisionWithCapturedNewTargetVariable(node, node.name);
checkCollisionWithRequireExportsInGeneratedCode(node, node.name);
checkCollisionWithGlobalPromiseInGeneratedCode(node, node.name);
}
}
function areDeclarationFlagsIdentical(left, right) {
- if ((left.kind === 144 && right.kind === 223) ||
- (left.kind === 223 && right.kind === 144)) {
+ if ((left.kind === 145 && right.kind === 225) ||
+ (left.kind === 225 && right.kind === 145)) {
return true;
}
if (ts.hasQuestionToken(left) !== ts.hasQuestionToken(right)) {
@@ -32629,8 +35601,8 @@ var ts;
ts.forEach(node.declarationList.declarations, checkSourceElement);
}
function checkGrammarDisallowedModifiersOnObjectLiteralExpressionMethod(node) {
- if (node.modifiers && node.parent.kind === 176) {
- if (ts.isAsyncFunctionLike(node)) {
+ if (node.modifiers && node.parent.kind === 177) {
+ if (ts.getFunctionFlags(node) & 2) {
if (node.modifiers.length > 1) {
return grammarErrorOnFirstToken(node, ts.Diagnostics.Modifiers_cannot_appear_here);
}
@@ -32648,7 +35620,7 @@ var ts;
checkGrammarStatementInAmbientContext(node);
checkExpression(node.expression);
checkSourceElement(node.thenStatement);
- if (node.thenStatement.kind === 206) {
+ if (node.thenStatement.kind === 208) {
error(node.thenStatement, ts.Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement);
}
checkSourceElement(node.elseStatement);
@@ -32665,12 +35637,12 @@ var ts;
}
function checkForStatement(node) {
if (!checkGrammarStatementInAmbientContext(node)) {
- if (node.initializer && node.initializer.kind === 224) {
+ if (node.initializer && node.initializer.kind === 226) {
checkGrammarVariableDeclarationList(node.initializer);
}
}
if (node.initializer) {
- if (node.initializer.kind === 224) {
+ if (node.initializer.kind === 226) {
ts.forEach(node.initializer.declarations, checkVariableDeclaration);
}
else {
@@ -32688,13 +35660,23 @@ var ts;
}
function checkForOfStatement(node) {
checkGrammarForInOrForOfStatement(node);
- if (node.initializer.kind === 224) {
+ if (node.kind === 215) {
+ if (node.awaitModifier) {
+ if (languageVersion < 4) {
+ checkExternalEmitHelpers(node, 8192);
+ }
+ }
+ else if (languageVersion < 2 && compilerOptions.downlevelIteration) {
+ checkExternalEmitHelpers(node, 256);
+ }
+ }
+ if (node.initializer.kind === 226) {
checkForInOrForOfVariableDeclaration(node);
}
else {
var varExpr = node.initializer;
- var iteratedType = checkRightHandSideOfForOf(node.expression);
- if (varExpr.kind === 175 || varExpr.kind === 176) {
+ var iteratedType = checkRightHandSideOfForOf(node.expression, node.awaitModifier);
+ if (varExpr.kind === 176 || varExpr.kind === 177) {
checkDestructuringAssignment(varExpr, iteratedType || unknownType);
}
else {
@@ -32713,7 +35695,7 @@ var ts;
function checkForInStatement(node) {
checkGrammarForInOrForOfStatement(node);
var rightType = checkNonNullExpression(node.expression);
- if (node.initializer.kind === 224) {
+ if (node.initializer.kind === 226) {
var variable = node.initializer.declarations[0];
if (variable && ts.isBindingPattern(variable.name)) {
error(variable.name, ts.Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
@@ -32723,7 +35705,7 @@ var ts;
else {
var varExpr = node.initializer;
var leftType = checkExpression(varExpr);
- if (varExpr.kind === 175 || varExpr.kind === 176) {
+ if (varExpr.kind === 176 || varExpr.kind === 177) {
error(varExpr, ts.Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
}
else if (!isTypeAssignableTo(getIndexTypeOrString(rightType), leftType)) {
@@ -32733,7 +35715,7 @@ var ts;
checkReferenceExpression(varExpr, ts.Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access);
}
}
- if (!isTypeAnyOrAllConstituentTypesHaveKind(rightType, 32768 | 16384 | 524288)) {
+ if (!isTypeAnyOrAllConstituentTypesHaveKind(rightType, 32768 | 540672 | 16777216)) {
error(node.expression, ts.Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter);
}
checkSourceElement(node.statement);
@@ -32748,161 +35730,199 @@ var ts;
checkVariableDeclaration(decl);
}
}
- function checkRightHandSideOfForOf(rhsExpression) {
+ function checkRightHandSideOfForOf(rhsExpression, awaitModifier) {
var expressionType = checkNonNullExpression(rhsExpression);
- return checkIteratedTypeOrElementType(expressionType, rhsExpression, true);
+ return checkIteratedTypeOrElementType(expressionType, rhsExpression, true, awaitModifier !== undefined);
}
- function checkIteratedTypeOrElementType(inputType, errorNode, allowStringInput) {
+ function checkIteratedTypeOrElementType(inputType, errorNode, allowStringInput, allowAsyncIterable) {
if (isTypeAny(inputType)) {
return inputType;
}
- if (languageVersion >= 2) {
- return checkElementTypeOfIterable(inputType, errorNode);
+ return getIteratedTypeOrElementType(inputType, errorNode, allowStringInput, allowAsyncIterable, true) || anyType;
+ }
+ function getIteratedTypeOrElementType(inputType, errorNode, allowStringInput, allowAsyncIterable, checkAssignability) {
+ var uplevelIteration = languageVersion >= 2;
+ var downlevelIteration = !uplevelIteration && compilerOptions.downlevelIteration;
+ if (uplevelIteration || downlevelIteration || allowAsyncIterable) {
+ var iteratedType = getIteratedTypeOfIterable(inputType, uplevelIteration ? errorNode : undefined, allowAsyncIterable, allowAsyncIterable, checkAssignability);
+ if (iteratedType || uplevelIteration) {
+ return iteratedType;
+ }
}
+ var arrayType = inputType;
+ var reportedError = false;
+ var hasStringConstituent = false;
if (allowStringInput) {
- return checkElementTypeOfArrayOrString(inputType, errorNode);
- }
- if (isArrayLikeType(inputType)) {
- var indexType = getIndexTypeOfType(inputType, 1);
- if (indexType) {
- return indexType;
+ if (arrayType.flags & 65536) {
+ var arrayTypes = inputType.types;
+ var filteredTypes = ts.filter(arrayTypes, function (t) { return !(t.flags & 262178); });
+ if (filteredTypes !== arrayTypes) {
+ arrayType = getUnionType(filteredTypes, true);
+ }
+ }
+ else if (arrayType.flags & 262178) {
+ arrayType = neverType;
+ }
+ hasStringConstituent = arrayType !== inputType;
+ if (hasStringConstituent) {
+ if (languageVersion < 1) {
+ if (errorNode) {
+ error(errorNode, ts.Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher);
+ reportedError = true;
+ }
+ }
+ if (arrayType.flags & 8192) {
+ return stringType;
+ }
}
}
- if (errorNode) {
- error(errorNode, ts.Diagnostics.Type_0_is_not_an_array_type, typeToString(inputType));
+ if (!isArrayLikeType(arrayType)) {
+ if (errorNode && !reportedError) {
+ var diagnostic = !allowStringInput || hasStringConstituent
+ ? downlevelIteration
+ ? ts.Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator
+ : ts.Diagnostics.Type_0_is_not_an_array_type
+ : downlevelIteration
+ ? ts.Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator
+ : ts.Diagnostics.Type_0_is_not_an_array_type_or_a_string_type;
+ error(errorNode, diagnostic, typeToString(arrayType));
+ }
+ return hasStringConstituent ? stringType : undefined;
}
- return unknownType;
- }
- function checkElementTypeOfIterable(iterable, errorNode) {
- var elementType = getElementTypeOfIterable(iterable, errorNode);
- if (errorNode && elementType) {
- checkTypeAssignableTo(iterable, createIterableType(elementType), errorNode);
+ var arrayElementType = getIndexTypeOfType(arrayType, 1);
+ if (hasStringConstituent && arrayElementType) {
+ if (arrayElementType.flags & 262178) {
+ return stringType;
+ }
+ return getUnionType([arrayElementType, stringType], true);
}
- return elementType || anyType;
+ return arrayElementType;
}
- function getElementTypeOfIterable(type, errorNode) {
+ function getIteratedTypeOfIterable(type, errorNode, isAsyncIterable, allowNonAsyncIterables, checkAssignability) {
if (isTypeAny(type)) {
return undefined;
}
var typeAsIterable = type;
- if (!typeAsIterable.iterableElementType) {
- if ((getObjectFlags(type) & 4) && type.target === getGlobalIterableType()) {
- typeAsIterable.iterableElementType = type.typeArguments[0];
+ if (isAsyncIterable ? typeAsIterable.iteratedTypeOfAsyncIterable : typeAsIterable.iteratedTypeOfIterable) {
+ return isAsyncIterable ? typeAsIterable.iteratedTypeOfAsyncIterable : typeAsIterable.iteratedTypeOfIterable;
+ }
+ if (isAsyncIterable) {
+ if (isReferenceToType(type, getGlobalAsyncIterableType(false)) ||
+ isReferenceToType(type, getGlobalAsyncIterableIteratorType(false))) {
+ return typeAsIterable.iteratedTypeOfAsyncIterable = type.typeArguments[0];
}
- else {
- var iteratorFunction = getTypeOfPropertyOfType(type, ts.getPropertyNameForKnownSymbolName("iterator"));
- if (isTypeAny(iteratorFunction)) {
- return undefined;
- }
- var iteratorFunctionSignatures = iteratorFunction ? getSignaturesOfType(iteratorFunction, 0) : emptyArray;
- if (iteratorFunctionSignatures.length === 0) {
- if (errorNode) {
- error(errorNode, ts.Diagnostics.Type_must_have_a_Symbol_iterator_method_that_returns_an_iterator);
- }
- return undefined;
- }
- typeAsIterable.iterableElementType = getElementTypeOfIterator(getUnionType(ts.map(iteratorFunctionSignatures, getReturnTypeOfSignature), true), errorNode);
+ }
+ if (!isAsyncIterable || allowNonAsyncIterables) {
+ if (isReferenceToType(type, getGlobalIterableType(false)) ||
+ isReferenceToType(type, getGlobalIterableIteratorType(false))) {
+ return isAsyncIterable
+ ? typeAsIterable.iteratedTypeOfAsyncIterable = type.typeArguments[0]
+ : typeAsIterable.iteratedTypeOfIterable = type.typeArguments[0];
}
}
- return typeAsIterable.iterableElementType;
- }
- function getElementTypeOfIterator(type, errorNode) {
- if (isTypeAny(type)) {
- return undefined;
+ var iteratorMethodSignatures;
+ var mayBeIterable = false;
+ if (isAsyncIterable) {
+ var iteratorMethod = getTypeOfPropertyOfType(type, ts.getPropertyNameForKnownSymbolName("asyncIterator"));
+ if (isTypeAny(iteratorMethod)) {
+ return undefined;
+ }
+ iteratorMethodSignatures = iteratorMethod && getSignaturesOfType(iteratorMethod, 0);
}
- var typeAsIterator = type;
- if (!typeAsIterator.iteratorElementType) {
- if ((getObjectFlags(type) & 4) && type.target === getGlobalIteratorType()) {
- typeAsIterator.iteratorElementType = type.typeArguments[0];
+ if (!isAsyncIterable || (allowNonAsyncIterables && !ts.some(iteratorMethodSignatures))) {
+ var iteratorMethod = getTypeOfPropertyOfType(type, ts.getPropertyNameForKnownSymbolName("iterator"));
+ if (isTypeAny(iteratorMethod)) {
+ return undefined;
}
- else {
- var iteratorNextFunction = getTypeOfPropertyOfType(type, "next");
- if (isTypeAny(iteratorNextFunction)) {
- return undefined;
- }
- var iteratorNextFunctionSignatures = iteratorNextFunction ? getSignaturesOfType(iteratorNextFunction, 0) : emptyArray;
- if (iteratorNextFunctionSignatures.length === 0) {
- if (errorNode) {
- error(errorNode, ts.Diagnostics.An_iterator_must_have_a_next_method);
- }
- return undefined;
- }
- var iteratorNextResult = getUnionType(ts.map(iteratorNextFunctionSignatures, getReturnTypeOfSignature), true);
- if (isTypeAny(iteratorNextResult)) {
- return undefined;
- }
- var iteratorNextValue = getTypeOfPropertyOfType(iteratorNextResult, "value");
- if (!iteratorNextValue) {
- if (errorNode) {
- error(errorNode, ts.Diagnostics.The_type_returned_by_the_next_method_of_an_iterator_must_have_a_value_property);
- }
- return undefined;
- }
- typeAsIterator.iteratorElementType = iteratorNextValue;
+ iteratorMethodSignatures = iteratorMethod && getSignaturesOfType(iteratorMethod, 0);
+ mayBeIterable = true;
+ }
+ if (ts.some(iteratorMethodSignatures)) {
+ var iteratorMethodReturnType = getUnionType(ts.map(iteratorMethodSignatures, getReturnTypeOfSignature), true);
+ var iteratedType = getIteratedTypeOfIterator(iteratorMethodReturnType, errorNode, false);
+ if (checkAssignability && errorNode && iteratedType) {
+ checkTypeAssignableTo(type, mayBeIterable
+ ? createIterableType(iteratedType)
+ : createAsyncIterableType(iteratedType), errorNode);
}
+ return isAsyncIterable
+ ? typeAsIterable.iteratedTypeOfAsyncIterable = iteratedType
+ : typeAsIterable.iteratedTypeOfIterable = iteratedType;
+ }
+ if (errorNode) {
+ error(errorNode, isAsyncIterable
+ ? ts.Diagnostics.Type_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator
+ : ts.Diagnostics.Type_must_have_a_Symbol_iterator_method_that_returns_an_iterator);
}
- return typeAsIterator.iteratorElementType;
+ return undefined;
}
- function getElementTypeOfIterableIterator(type) {
+ function getIteratedTypeOfIterator(type, errorNode, isAsyncIterator) {
if (isTypeAny(type)) {
return undefined;
}
- if ((getObjectFlags(type) & 4) && type.target === getGlobalIterableIteratorType()) {
- return type.typeArguments[0];
+ var typeAsIterator = type;
+ if (isAsyncIterator ? typeAsIterator.iteratedTypeOfAsyncIterator : typeAsIterator.iteratedTypeOfIterator) {
+ return isAsyncIterator ? typeAsIterator.iteratedTypeOfAsyncIterator : typeAsIterator.iteratedTypeOfIterator;
}
- return getElementTypeOfIterable(type, undefined) ||
- getElementTypeOfIterator(type, undefined);
- }
- function checkElementTypeOfArrayOrString(arrayOrStringType, errorNode) {
- ts.Debug.assert(languageVersion < 2);
- var arrayType = arrayOrStringType;
- if (arrayOrStringType.flags & 65536) {
- var arrayTypes = arrayOrStringType.types;
- var filteredTypes = ts.filter(arrayTypes, function (t) { return !(t.flags & 262178); });
- if (filteredTypes !== arrayTypes) {
- arrayType = getUnionType(filteredTypes, true);
- }
+ var getIteratorType = isAsyncIterator ? getGlobalAsyncIteratorType : getGlobalIteratorType;
+ if (isReferenceToType(type, getIteratorType(false))) {
+ return isAsyncIterator
+ ? typeAsIterator.iteratedTypeOfAsyncIterator = type.typeArguments[0]
+ : typeAsIterator.iteratedTypeOfIterator = type.typeArguments[0];
}
- else if (arrayOrStringType.flags & 262178) {
- arrayType = neverType;
+ var nextMethod = getTypeOfPropertyOfType(type, "next");
+ if (isTypeAny(nextMethod)) {
+ return undefined;
}
- var hasStringConstituent = arrayOrStringType !== arrayType;
- var reportedError = false;
- if (hasStringConstituent) {
- if (languageVersion < 1) {
- error(errorNode, ts.Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher);
- reportedError = true;
- }
- if (arrayType.flags & 8192) {
- return stringType;
+ var nextMethodSignatures = nextMethod ? getSignaturesOfType(nextMethod, 0) : emptyArray;
+ if (nextMethodSignatures.length === 0) {
+ if (errorNode) {
+ error(errorNode, isAsyncIterator
+ ? ts.Diagnostics.An_async_iterator_must_have_a_next_method
+ : ts.Diagnostics.An_iterator_must_have_a_next_method);
}
+ return undefined;
}
- if (!isArrayLikeType(arrayType)) {
- if (!reportedError) {
- var diagnostic = hasStringConstituent
- ? ts.Diagnostics.Type_0_is_not_an_array_type
- : ts.Diagnostics.Type_0_is_not_an_array_type_or_a_string_type;
- error(errorNode, diagnostic, typeToString(arrayType));
+ var nextResult = getUnionType(ts.map(nextMethodSignatures, getReturnTypeOfSignature), true);
+ if (isTypeAny(nextResult)) {
+ return undefined;
+ }
+ if (isAsyncIterator) {
+ nextResult = getAwaitedTypeOfPromise(nextResult, errorNode, ts.Diagnostics.The_type_returned_by_the_next_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_property);
+ if (isTypeAny(nextResult)) {
+ return undefined;
}
- return hasStringConstituent ? stringType : unknownType;
}
- var arrayElementType = getIndexTypeOfType(arrayType, 1) || unknownType;
- if (hasStringConstituent) {
- if (arrayElementType.flags & 262178) {
- return stringType;
+ var nextValue = nextResult && getTypeOfPropertyOfType(nextResult, "value");
+ if (!nextValue) {
+ if (errorNode) {
+ error(errorNode, isAsyncIterator
+ ? ts.Diagnostics.The_type_returned_by_the_next_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_property
+ : ts.Diagnostics.The_type_returned_by_the_next_method_of_an_iterator_must_have_a_value_property);
}
- return getUnionType([arrayElementType, stringType], true);
+ return undefined;
}
- return arrayElementType;
+ return isAsyncIterator
+ ? typeAsIterator.iteratedTypeOfAsyncIterator = nextValue
+ : typeAsIterator.iteratedTypeOfIterator = nextValue;
+ }
+ function getIteratedTypeOfGenerator(returnType, isAsyncGenerator) {
+ if (isTypeAny(returnType)) {
+ return undefined;
+ }
+ return getIteratedTypeOfIterable(returnType, undefined, isAsyncGenerator, false, false)
+ || getIteratedTypeOfIterator(returnType, undefined, isAsyncGenerator);
}
function checkBreakOrContinueStatement(node) {
checkGrammarStatementInAmbientContext(node) || checkGrammarBreakOrContinueStatement(node);
}
function isGetAccessorWithAnnotatedSetAccessor(node) {
- return !!(node.kind === 151 && ts.getSetAccessorTypeAnnotationNode(ts.getDeclarationOfKind(node.symbol, 152)));
+ return !!(node.kind === 152 && ts.getSetAccessorTypeAnnotationNode(ts.getDeclarationOfKind(node.symbol, 153)));
}
function isUnwrappedReturnTypeVoidOrAny(func, returnType) {
- var unwrappedReturnType = ts.isAsyncFunctionLike(func) ? getPromisedType(returnType) : returnType;
+ var unwrappedReturnType = (ts.getFunctionFlags(func) & 3) === 2
+ ? getPromisedTypeOfPromise(returnType)
+ : returnType;
return unwrappedReturnType && maybeTypeOfKind(unwrappedReturnType, 1024 | 1);
}
function checkReturnStatement(node) {
@@ -32918,40 +35938,41 @@ var ts;
var returnType = getReturnTypeOfSignature(signature);
if (strictNullChecks || node.expression || returnType.flags & 8192) {
var exprType = node.expression ? checkExpressionCached(node.expression) : undefinedType;
- if (func.asteriskToken) {
+ var functionFlags = ts.getFunctionFlags(func);
+ if (functionFlags & 1) {
return;
}
- if (func.kind === 152) {
+ if (func.kind === 153) {
if (node.expression) {
- error(node.expression, ts.Diagnostics.Setters_cannot_return_a_value);
+ error(node, ts.Diagnostics.Setters_cannot_return_a_value);
}
}
- else if (func.kind === 150) {
- if (node.expression && !checkTypeAssignableTo(exprType, returnType, node.expression)) {
- error(node.expression, ts.Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class);
+ else if (func.kind === 151) {
+ if (node.expression && !checkTypeAssignableTo(exprType, returnType, node)) {
+ error(node, ts.Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class);
}
}
else if (func.type || isGetAccessorWithAnnotatedSetAccessor(func)) {
- if (ts.isAsyncFunctionLike(func)) {
- var promisedType = getPromisedType(returnType);
- var awaitedType = checkAwaitedType(exprType, node.expression || node, ts.Diagnostics.Return_expression_in_async_function_does_not_have_a_valid_callable_then_member);
+ if (functionFlags & 2) {
+ var promisedType = getPromisedTypeOfPromise(returnType);
+ var awaitedType = checkAwaitedType(exprType, node, ts.Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
if (promisedType) {
- checkTypeAssignableTo(awaitedType, promisedType, node.expression || node);
+ checkTypeAssignableTo(awaitedType, promisedType, node);
}
}
else {
- checkTypeAssignableTo(exprType, returnType, node.expression || node);
+ checkTypeAssignableTo(exprType, returnType, node);
}
}
}
- else if (func.kind !== 150 && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeVoidOrAny(func, returnType)) {
+ else if (func.kind !== 151 && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeVoidOrAny(func, returnType)) {
error(node, ts.Diagnostics.Not_all_code_paths_return_a_value);
}
}
}
function checkWithStatement(node) {
if (!checkGrammarStatementInAmbientContext(node)) {
- if (node.flags & 524288) {
+ if (node.flags & 16384) {
grammarErrorOnFirstToken(node, ts.Diagnostics.with_statements_are_not_allowed_in_an_async_function_block);
}
}
@@ -32970,7 +35991,7 @@ var ts;
var expressionType = checkExpression(node.expression);
var expressionIsLiteral = isLiteralType(expressionType);
ts.forEach(node.caseBlock.clauses, function (clause) {
- if (clause.kind === 254 && !hasDuplicateDefaultClause) {
+ if (clause.kind === 257 && !hasDuplicateDefaultClause) {
if (firstDefaultClause === undefined) {
firstDefaultClause = clause;
}
@@ -32982,7 +36003,7 @@ var ts;
hasDuplicateDefaultClause = true;
}
}
- if (produceDiagnostics && clause.kind === 253) {
+ if (produceDiagnostics && clause.kind === 256) {
var caseClause = clause;
var caseType = checkExpression(caseClause.expression);
var caseIsLiteral = isLiteralType(caseType);
@@ -33003,18 +36024,16 @@ var ts;
}
function checkLabeledStatement(node) {
if (!checkGrammarStatementInAmbientContext(node)) {
- var current = node.parent;
- while (current) {
+ ts.findAncestor(node.parent, function (current) {
if (ts.isFunctionLike(current)) {
- break;
+ return "quit";
}
- if (current.kind === 219 && current.label.text === node.label.text) {
+ if (current.kind === 221 && current.label.text === node.label.text) {
var sourceFile = ts.getSourceFileOfNode(node);
grammarErrorOnNode(node.label, ts.Diagnostics.Duplicate_label_0, ts.getTextOfNodeFromSourceText(sourceFile.text, node.label));
- break;
+ return true;
}
- current = current.parent;
- }
+ });
}
checkSourceElement(node.statement);
}
@@ -33041,14 +36060,14 @@ var ts;
grammarErrorOnFirstToken(catchClause.variableDeclaration.initializer, ts.Diagnostics.Catch_clause_variable_cannot_have_an_initializer);
}
else {
- var blockLocals = catchClause.block.locals;
- if (blockLocals) {
- for (var caughtName in catchClause.locals) {
- var blockLocal = blockLocals[caughtName];
+ var blockLocals_1 = catchClause.block.locals;
+ if (blockLocals_1) {
+ ts.forEachKey(catchClause.locals, function (caughtName) {
+ var blockLocal = blockLocals_1.get(caughtName);
if (blockLocal && (blockLocal.flags & 2) !== 0) {
grammarErrorOnNode(blockLocal.valueDeclaration, ts.Diagnostics.Cannot_redeclare_identifier_0_in_catch_clause, caughtName);
}
- }
+ });
}
}
}
@@ -33096,12 +36115,13 @@ var ts;
if (!indexType) {
return;
}
- if (indexKind === 1 && !isNumericName(prop.valueDeclaration.name)) {
+ var propDeclaration = prop.valueDeclaration;
+ if (indexKind === 1 && !(propDeclaration ? isNumericName(propDeclaration.name) : isNumericLiteralName(prop.name))) {
return;
}
var errorNode;
- if (prop.valueDeclaration.name.kind === 142 || prop.parent === containingType.symbol) {
- errorNode = prop.valueDeclaration;
+ if (propDeclaration && (propDeclaration.name.kind === 143 || prop.parent === containingType.symbol)) {
+ errorNode = propDeclaration;
}
else if (indexDeclaration) {
errorNode = indexDeclaration;
@@ -33126,15 +36146,23 @@ var ts;
case "string":
case "symbol":
case "void":
+ case "object":
error(name, message, name.text);
}
}
function checkTypeParameters(typeParameterDeclarations) {
if (typeParameterDeclarations) {
- for (var i = 0, n = typeParameterDeclarations.length; i < n; i++) {
+ var seenDefault = false;
+ for (var i = 0; i < typeParameterDeclarations.length; i++) {
var node = typeParameterDeclarations[i];
checkTypeParameter(node);
if (produceDiagnostics) {
+ if (node.default) {
+ seenDefault = true;
+ }
+ else if (seenDefault) {
+ error(node, ts.Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters);
+ }
for (var j = 0; j < i; j++) {
if (typeParameterDeclarations[j].symbol === node.symbol) {
error(node.name, ts.Diagnostics.Duplicate_identifier_0, ts.declarationNameToString(node.name));
@@ -33144,22 +36172,56 @@ var ts;
}
}
}
- function checkTypeParameterListsIdentical(node, symbol) {
+ function checkTypeParameterListsIdentical(symbol) {
if (symbol.declarations.length === 1) {
return;
}
- var firstDecl;
- for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
- var declaration = _a[_i];
- if (declaration.kind === 226 || declaration.kind === 227) {
- if (!firstDecl) {
- firstDecl = declaration;
+ var links = getSymbolLinks(symbol);
+ if (!links.typeParametersChecked) {
+ links.typeParametersChecked = true;
+ var declarations = getClassOrInterfaceDeclarationsOfSymbol(symbol);
+ if (declarations.length <= 1) {
+ return;
+ }
+ var type = getDeclaredTypeOfSymbol(symbol);
+ if (!areTypeParametersIdentical(declarations, type.localTypeParameters)) {
+ var name = symbolToString(symbol);
+ for (var _i = 0, declarations_6 = declarations; _i < declarations_6.length; _i++) {
+ var declaration = declarations_6[_i];
+ error(declaration.name, ts.Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name);
}
- else if (!areTypeParametersIdentical(firstDecl.typeParameters, node.typeParameters)) {
- error(node.name, ts.Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, node.name.text);
+ }
+ }
+ }
+ function areTypeParametersIdentical(declarations, typeParameters) {
+ var maxTypeArgumentCount = ts.length(typeParameters);
+ var minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
+ for (var _i = 0, declarations_7 = declarations; _i < declarations_7.length; _i++) {
+ var declaration = declarations_7[_i];
+ var numTypeParameters = ts.length(declaration.typeParameters);
+ if (numTypeParameters < minTypeArgumentCount || numTypeParameters > maxTypeArgumentCount) {
+ return false;
+ }
+ for (var i = 0; i < numTypeParameters; i++) {
+ var source = declaration.typeParameters[i];
+ var target = typeParameters[i];
+ if (source.name.text !== target.symbol.name) {
+ return false;
+ }
+ var sourceConstraint = source.constraint && getTypeFromTypeNode(source.constraint);
+ var targetConstraint = getConstraintFromTypeParameter(target);
+ if ((sourceConstraint || targetConstraint) &&
+ (!sourceConstraint || !targetConstraint || !isTypeIdenticalTo(sourceConstraint, targetConstraint))) {
+ return false;
+ }
+ var sourceDefault = source.default && getTypeFromTypeNode(source.default);
+ var targetDefault = getDefaultFromTypeParameter(target);
+ if (sourceDefault && targetDefault && !isTypeIdenticalTo(sourceDefault, targetDefault)) {
+ return false;
}
}
}
+ return true;
}
function checkClassExpression(node) {
checkClassLikeDeclaration(node);
@@ -33179,11 +36241,12 @@ var ts;
registerForUnusedIdentifiersCheck(node);
}
function checkClassLikeDeclaration(node) {
- checkGrammarClassDeclarationHeritageClauses(node);
+ checkGrammarClassLikeDeclaration(node);
checkDecorators(node);
if (node.name) {
checkTypeNameIsReserved(node.name, ts.Diagnostics.Class_name_cannot_be_0);
checkCollisionWithCapturedThisVariable(node, node.name);
+ checkCollisionWithCapturedNewTargetVariable(node, node.name);
checkCollisionWithRequireExportsInGeneratedCode(node, node.name);
checkCollisionWithGlobalPromiseInGeneratedCode(node, node.name);
}
@@ -33193,19 +36256,26 @@ var ts;
var type = getDeclaredTypeOfSymbol(symbol);
var typeWithThis = getTypeWithThisArgument(type);
var staticType = getTypeOfSymbol(symbol);
- checkTypeParameterListsIdentical(node, symbol);
+ checkTypeParameterListsIdentical(symbol);
checkClassForDuplicateDeclarations(node);
+ if (!ts.isInAmbientContext(node)) {
+ checkClassForStaticPropertyNameConflicts(node);
+ }
var baseTypeNode = ts.getClassExtendsHeritageClauseElement(node);
if (baseTypeNode) {
+ if (languageVersion < 2) {
+ checkExternalEmitHelpers(baseTypeNode.parent, 1);
+ }
var baseTypes = getBaseTypes(type);
if (baseTypes.length && produceDiagnostics) {
var baseType_1 = baseTypes[0];
- var staticBaseType = getBaseConstructorTypeOfClass(type);
+ var baseConstructorType = getBaseConstructorTypeOfClass(type);
+ var staticBaseType = getApparentType(baseConstructorType);
checkBaseTypeAccessibility(staticBaseType, baseTypeNode);
checkSourceElement(baseTypeNode.expression);
if (baseTypeNode.typeArguments) {
ts.forEach(baseTypeNode.typeArguments, checkSourceElement);
- for (var _i = 0, _a = getConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments); _i < _a.length; _i++) {
+ for (var _i = 0, _a = getConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode); _i < _a.length; _i++) {
var constructor = _a[_i];
if (!checkTypeArgumentConstraints(constructor.typeParameters, baseTypeNode.typeArguments)) {
break;
@@ -33214,15 +36284,11 @@ var ts;
}
checkTypeAssignableTo(typeWithThis, getTypeWithThisArgument(baseType_1, type.thisType), node.name || node, ts.Diagnostics.Class_0_incorrectly_extends_base_class_1);
checkTypeAssignableTo(staticType, getTypeWithoutSignatures(staticBaseType), node.name || node, ts.Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1);
- if (baseType_1.symbol.valueDeclaration &&
- !ts.isInAmbientContext(baseType_1.symbol.valueDeclaration) &&
- baseType_1.symbol.valueDeclaration.kind === 226) {
- if (!isBlockScopedNameDeclaredBeforeUse(baseType_1.symbol.valueDeclaration, node)) {
- error(baseTypeNode, ts.Diagnostics.A_class_must_be_declared_after_its_base_class);
- }
+ if (baseConstructorType.flags & 540672 && !isMixinConstructorType(staticType)) {
+ error(node.name || node, ts.Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any);
}
- if (!(staticBaseType.symbol && staticBaseType.symbol.flags & 32)) {
- var constructors = getInstantiatedConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments);
+ if (!(staticBaseType.symbol && staticBaseType.symbol.flags & 32) && !(baseConstructorType.flags & 540672)) {
+ var constructors = getInstantiatedConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode);
if (ts.forEach(constructors, function (sig) { return getReturnTypeOfSignature(sig) !== baseType_1; })) {
error(baseTypeNode.expression, ts.Diagnostics.Base_constructors_must_all_have_the_same_return_type);
}
@@ -33241,8 +36307,7 @@ var ts;
if (produceDiagnostics) {
var t = getTypeFromTypeNode(typeRefNode);
if (t !== unknownType) {
- var declaredType = getObjectFlags(t) & 4 ? t.target : t;
- if (getObjectFlags(declaredType) & 3) {
+ if (isValidBaseType(t)) {
checkTypeAssignableTo(typeWithThis, getTypeWithThisArgument(t, type.thisType), node.name || node, ts.Diagnostics.Class_0_incorrectly_implements_interface_1);
}
else {
@@ -33270,17 +36335,22 @@ var ts;
}
}
function getTargetSymbol(s) {
- return s.flags & 16777216 ? getSymbolLinks(s).target : s;
+ return getCheckFlags(s) & 1 ? s.target : s;
}
function getClassLikeDeclarationOfSymbol(symbol) {
return ts.forEach(symbol.declarations, function (d) { return ts.isClassLike(d) ? d : undefined; });
}
+ function getClassOrInterfaceDeclarationsOfSymbol(symbol) {
+ return ts.filter(symbol.declarations, function (d) {
+ return d.kind === 228 || d.kind === 229;
+ });
+ }
function checkKindsOfPropertyMemberOverrides(type, baseType) {
- var baseProperties = getPropertiesOfObjectType(baseType);
+ var baseProperties = getPropertiesOfType(baseType);
for (var _i = 0, baseProperties_1 = baseProperties; _i < baseProperties_1.length; _i++) {
var baseProperty = baseProperties_1[_i];
var base = getTargetSymbol(baseProperty);
- if (base.flags & 134217728) {
+ if (base.flags & 16777216) {
continue;
}
var derived = getTargetSymbol(getPropertyOfObjectType(type, base.name));
@@ -33290,7 +36360,7 @@ var ts;
if (derived === base) {
var derivedClassDecl = getClassLikeDeclarationOfSymbol(type.symbol);
if (baseDeclarationFlags & 128 && (!derivedClassDecl || !(ts.getModifierFlags(derivedClassDecl) & 128))) {
- if (derivedClassDecl.kind === 197) {
+ if (derivedClassDecl.kind === 198) {
error(derivedClassDecl, ts.Diagnostics.Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1, symbolToString(baseProperty), typeToString(baseType));
}
else {
@@ -33300,66 +36370,37 @@ var ts;
}
else {
var derivedDeclarationFlags = getDeclarationModifierFlagsFromSymbol(derived);
- if ((baseDeclarationFlags & 8) || (derivedDeclarationFlags & 8)) {
+ if (baseDeclarationFlags & 8 || derivedDeclarationFlags & 8) {
continue;
}
if ((baseDeclarationFlags & 32) !== (derivedDeclarationFlags & 32)) {
continue;
}
- if ((base.flags & derived.flags & 8192) || ((base.flags & 98308) && (derived.flags & 98308))) {
+ if (isMethodLike(base) && isMethodLike(derived) || base.flags & 98308 && derived.flags & 98308) {
continue;
}
var errorMessage = void 0;
- if (base.flags & 8192) {
+ if (isMethodLike(base)) {
if (derived.flags & 98304) {
errorMessage = ts.Diagnostics.Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_accessor;
}
else {
- ts.Debug.assert((derived.flags & 4) !== 0);
errorMessage = ts.Diagnostics.Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_property;
}
}
else if (base.flags & 4) {
- ts.Debug.assert((derived.flags & 8192) !== 0);
errorMessage = ts.Diagnostics.Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function;
}
else {
- ts.Debug.assert((base.flags & 98304) !== 0);
- ts.Debug.assert((derived.flags & 8192) !== 0);
errorMessage = ts.Diagnostics.Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_function;
}
- error(derived.valueDeclaration.name, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type));
+ error(derived.valueDeclaration.name || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type));
}
}
}
}
function isAccessor(kind) {
- return kind === 151 || kind === 152;
- }
- function areTypeParametersIdentical(list1, list2) {
- if (!list1 && !list2) {
- return true;
- }
- if (!list1 || !list2 || list1.length !== list2.length) {
- return false;
- }
- for (var i = 0, len = list1.length; i < len; i++) {
- var tp1 = list1[i];
- var tp2 = list2[i];
- if (tp1.name.text !== tp2.name.text) {
- return false;
- }
- if (!tp1.constraint && !tp2.constraint) {
- continue;
- }
- if (!tp1.constraint || !tp2.constraint) {
- return false;
- }
- if (!isTypeIdenticalTo(getTypeFromTypeNode(tp1.constraint), getTypeFromTypeNode(tp2.constraint))) {
- return false;
- }
- }
- return true;
+ return kind === 152 || kind === 153;
}
function checkInheritedPropertiesAreIdentical(type, typeNode) {
var baseTypes = getBaseTypes(type);
@@ -33367,16 +36408,16 @@ var ts;
return true;
}
var seen = ts.createMap();
- ts.forEach(resolveDeclaredMembers(type).declaredProperties, function (p) { seen[p.name] = { prop: p, containingType: type }; });
+ ts.forEach(resolveDeclaredMembers(type).declaredProperties, function (p) { seen.set(p.name, { prop: p, containingType: type }); });
var ok = true;
for (var _i = 0, baseTypes_2 = baseTypes; _i < baseTypes_2.length; _i++) {
var base = baseTypes_2[_i];
- var properties = getPropertiesOfObjectType(getTypeWithThisArgument(base, type.thisType));
- for (var _a = 0, properties_6 = properties; _a < properties_6.length; _a++) {
- var prop = properties_6[_a];
- var existing = seen[prop.name];
+ var properties = getPropertiesOfType(getTypeWithThisArgument(base, type.thisType));
+ for (var _a = 0, properties_8 = properties; _a < properties_8.length; _a++) {
+ var prop = properties_8[_a];
+ var existing = seen.get(prop.name);
if (!existing) {
- seen[prop.name] = { prop: prop, containingType: base };
+ seen.set(prop.name, { prop: prop, containingType: base });
}
else {
var isInheritedProperty = existing.containingType !== type;
@@ -33400,8 +36441,8 @@ var ts;
checkTypeNameIsReserved(node.name, ts.Diagnostics.Interface_name_cannot_be_0);
checkExportsOnMergedDeclarations(node);
var symbol = getSymbolOfNode(node);
- checkTypeParameterListsIdentical(node, symbol);
- var firstInterfaceDecl = ts.getDeclarationOfKind(symbol, 227);
+ checkTypeParameterListsIdentical(symbol);
+ var firstInterfaceDecl = ts.getDeclarationOfKind(symbol, 229);
if (node === firstInterfaceDecl) {
var type = getDeclaredTypeOfSymbol(symbol);
var typeWithThis = getTypeWithThisArgument(type);
@@ -33497,7 +36538,7 @@ var ts;
return value;
function evalConstant(e) {
switch (e.kind) {
- case 190:
+ case 191:
var value_1 = evalConstant(e.operand);
if (value_1 === undefined) {
return undefined;
@@ -33508,7 +36549,7 @@ var ts;
case 51: return ~value_1;
}
return undefined;
- case 192:
+ case 193:
var left = evalConstant(e.left);
if (left === undefined) {
return undefined;
@@ -33532,12 +36573,13 @@ var ts;
}
return undefined;
case 8:
+ checkGrammarNumericLiteral(e);
return +e.text;
- case 183:
+ case 184:
return evalConstant(e.expression);
case 70:
+ case 179:
case 178:
- case 177:
var member = initializer.parent;
var currentType = getTypeOfSymbol(getSymbolOfNode(member.parent));
var enumType_1;
@@ -33548,7 +36590,7 @@ var ts;
}
else {
var expression = void 0;
- if (e.kind === 178) {
+ if (e.kind === 179) {
if (e.argumentExpression === undefined ||
e.argumentExpression.kind !== 9) {
return undefined;
@@ -33565,7 +36607,7 @@ var ts;
if (current.kind === 70) {
break;
}
- else if (current.kind === 177) {
+ else if (current.kind === 178) {
current = current.expression;
}
else {
@@ -33605,6 +36647,7 @@ var ts;
checkGrammarDecorators(node) || checkGrammarModifiers(node);
checkTypeNameIsReserved(node.name, ts.Diagnostics.Enum_name_cannot_be_0);
checkCollisionWithCapturedThisVariable(node, node.name);
+ checkCollisionWithCapturedNewTargetVariable(node, node.name);
checkCollisionWithRequireExportsInGeneratedCode(node, node.name);
checkCollisionWithGlobalPromiseInGeneratedCode(node, node.name);
checkExportsOnMergedDeclarations(node);
@@ -33625,7 +36668,7 @@ var ts;
}
var seenEnumMissingInitialInitializer_1 = false;
ts.forEach(enumSymbol.declarations, function (declaration) {
- if (declaration.kind !== 229) {
+ if (declaration.kind !== 231) {
return false;
}
var enumDeclaration = declaration;
@@ -33646,10 +36689,10 @@ var ts;
}
function getFirstNonAmbientClassOrFunctionDeclaration(symbol) {
var declarations = symbol.declarations;
- for (var _i = 0, declarations_5 = declarations; _i < declarations_5.length; _i++) {
- var declaration = declarations_5[_i];
- if ((declaration.kind === 226 ||
- (declaration.kind === 225 && ts.nodeIsPresent(declaration.body))) &&
+ for (var _i = 0, declarations_8 = declarations; _i < declarations_8.length; _i++) {
+ var declaration = declarations_8[_i];
+ if ((declaration.kind === 228 ||
+ (declaration.kind === 227 && ts.nodeIsPresent(declaration.body))) &&
!ts.isInAmbientContext(declaration)) {
return declaration;
}
@@ -33708,7 +36751,7 @@ var ts;
error(node.name, ts.Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged);
}
}
- var mergedClass = ts.getDeclarationOfKind(symbol, 226);
+ var mergedClass = ts.getDeclarationOfKind(symbol, 228);
if (mergedClass &&
inSameLexicalScope(node, mergedClass)) {
getNodeLinks(node).flags |= 32768;
@@ -33716,7 +36759,7 @@ var ts;
}
if (isAmbientExternalModule) {
if (ts.isExternalModuleAugmentation(node)) {
- var checkBody = isGlobalAugmentation || (getSymbolOfNode(node).flags & 33554432);
+ var checkBody = isGlobalAugmentation || (getSymbolOfNode(node).flags & 134217728);
if (checkBody && node.body) {
for (var _i = 0, _a = node.body.statements; _i < _a.length; _i++) {
var statement = _a[_i];
@@ -33751,42 +36794,42 @@ var ts;
}
function checkModuleAugmentationElement(node, isGlobalAugmentation) {
switch (node.kind) {
- case 205:
+ case 207:
for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
var decl = _a[_i];
checkModuleAugmentationElement(decl, isGlobalAugmentation);
}
break;
- case 240:
- case 241:
+ case 242:
+ case 243:
grammarErrorOnFirstToken(node, ts.Diagnostics.Exports_and_export_assignments_are_not_permitted_in_module_augmentations);
break;
- case 234:
- case 235:
+ case 236:
+ case 237:
grammarErrorOnFirstToken(node, ts.Diagnostics.Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_module);
break;
- case 174:
- case 223:
- var name_25 = node.name;
- if (ts.isBindingPattern(name_25)) {
- for (var _b = 0, _c = name_25.elements; _b < _c.length; _b++) {
+ case 175:
+ case 225:
+ var name = node.name;
+ if (ts.isBindingPattern(name)) {
+ for (var _b = 0, _c = name.elements; _b < _c.length; _b++) {
var el = _c[_b];
checkModuleAugmentationElement(el, isGlobalAugmentation);
}
break;
}
- case 226:
- case 229:
- case 225:
+ case 228:
+ case 231:
case 227:
+ case 229:
+ case 232:
case 230:
- case 228:
if (isGlobalAugmentation) {
return;
}
var symbol = getSymbolOfNode(node);
if (symbol) {
- var reportError = !(symbol.flags & 33554432);
+ var reportError = !(symbol.flags & 134217728);
if (!reportError) {
reportError = ts.isExternalModuleAugmentation(symbol.parent.declarations[0]);
}
@@ -33798,12 +36841,12 @@ var ts;
switch (node.kind) {
case 70:
return node;
- case 141:
+ case 142:
do {
node = node.left;
} while (node.kind !== 70);
return node;
- case 177:
+ case 178:
do {
node = node.expression;
} while (node.kind !== 70);
@@ -33816,9 +36859,9 @@ var ts;
error(moduleName, ts.Diagnostics.String_literal_expected);
return false;
}
- var inAmbientExternalModule = node.parent.kind === 231 && ts.isAmbientModule(node.parent.parent);
- if (node.parent.kind !== 261 && !inAmbientExternalModule) {
- error(moduleName, node.kind === 241 ?
+ var inAmbientExternalModule = node.parent.kind === 233 && ts.isAmbientModule(node.parent.parent);
+ if (node.parent.kind !== 264 && !inAmbientExternalModule) {
+ error(moduleName, node.kind === 243 ?
ts.Diagnostics.Export_declarations_are_not_permitted_in_a_namespace :
ts.Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module);
return false;
@@ -33839,7 +36882,7 @@ var ts;
(symbol.flags & 793064 ? 793064 : 0) |
(symbol.flags & 1920 ? 1920 : 0);
if (target.flags & excludedMeanings) {
- var message = node.kind === 243 ?
+ var message = node.kind === 245 ?
ts.Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 :
ts.Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0;
error(node, message, symbolToString(symbol));
@@ -33866,7 +36909,7 @@ var ts;
checkImportBinding(importClause);
}
if (importClause.namedBindings) {
- if (importClause.namedBindings.kind === 237) {
+ if (importClause.namedBindings.kind === 239) {
checkImportBinding(importClause.namedBindings);
}
else {
@@ -33917,8 +36960,10 @@ var ts;
if (!node.moduleSpecifier || checkExternalImportOrExportDeclaration(node)) {
if (node.exportClause) {
ts.forEach(node.exportClause.elements, checkExportSpecifier);
- var inAmbientExternalModule = node.parent.kind === 231 && ts.isAmbientModule(node.parent.parent);
- if (node.parent.kind !== 261 && !inAmbientExternalModule) {
+ var inAmbientExternalModule = node.parent.kind === 233 && ts.isAmbientModule(node.parent.parent);
+ var inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 233 &&
+ !node.moduleSpecifier && ts.isInAmbientContext(node);
+ if (node.parent.kind !== 264 && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) {
error(node, ts.Diagnostics.Export_declarations_are_not_permitted_in_a_namespace);
}
}
@@ -33931,7 +36976,7 @@ var ts;
}
}
function checkGrammarModuleElementContext(node, errorMessage) {
- var isInAppropriateContext = node.parent.kind === 261 || node.parent.kind === 231 || node.parent.kind === 230;
+ var isInAppropriateContext = node.parent.kind === 264 || node.parent.kind === 233 || node.parent.kind === 232;
if (!isInAppropriateContext) {
grammarErrorOnFirstToken(node, errorMessage);
}
@@ -33954,9 +36999,14 @@ var ts;
if (checkGrammarModuleElementContext(node, ts.Diagnostics.An_export_assignment_can_only_be_used_in_a_module)) {
return;
}
- var container = node.parent.kind === 261 ? node.parent : node.parent.parent;
- if (container.kind === 230 && !ts.isAmbientModule(container)) {
- error(node, ts.Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace);
+ var container = node.parent.kind === 264 ? node.parent : node.parent.parent;
+ if (container.kind === 232 && !ts.isAmbientModule(container)) {
+ if (node.isExportEquals) {
+ error(node, ts.Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace);
+ }
+ else {
+ error(node, ts.Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
+ }
return;
}
if (!checkGrammarDecorators(node) && !checkGrammarModifiers(node) && ts.getModifierFlags(node) !== 0) {
@@ -33979,18 +37029,13 @@ var ts;
}
}
function hasExportedMembers(moduleSymbol) {
- for (var id in moduleSymbol.exports) {
- if (id !== "export=") {
- return true;
- }
- }
- return false;
+ return ts.forEachEntry(moduleSymbol.exports, function (_, id) { return id !== "export="; });
}
function checkExternalModuleExports(node) {
var moduleSymbol = getSymbolOfNode(node);
var links = getSymbolLinks(moduleSymbol);
if (!links.exportsChecked) {
- var exportEqualsSymbol = moduleSymbol.exports["export="];
+ var exportEqualsSymbol = moduleSymbol.exports.get("export=");
if (exportEqualsSymbol && hasExportedMembers(moduleSymbol)) {
var declaration = getDeclarationOfAliasSymbol(exportEqualsSymbol) || exportEqualsSymbol.valueDeclaration;
if (!isTopLevelInExternalModuleAugmentation(declaration)) {
@@ -33998,31 +37043,31 @@ var ts;
}
}
var exports = getExportsOfModule(moduleSymbol);
- for (var id in exports) {
+ exports && exports.forEach(function (_a, id) {
+ var declarations = _a.declarations, flags = _a.flags;
if (id === "__export") {
- continue;
+ return;
}
- var _a = exports[id], declarations = _a.declarations, flags = _a.flags;
if (flags & (1920 | 64 | 384)) {
- continue;
+ return;
}
var exportedDeclarationsCount = ts.countWhere(declarations, isNotOverload);
if (flags & 524288 && exportedDeclarationsCount <= 2) {
- continue;
+ return;
}
if (exportedDeclarationsCount > 1) {
- for (var _i = 0, declarations_6 = declarations; _i < declarations_6.length; _i++) {
- var declaration = declarations_6[_i];
+ for (var _i = 0, declarations_9 = declarations; _i < declarations_9.length; _i++) {
+ var declaration = declarations_9[_i];
if (isNotOverload(declaration)) {
diagnostics.add(ts.createDiagnosticForNode(declaration, ts.Diagnostics.Cannot_redeclare_exported_variable_0, id));
}
}
}
- }
+ });
links.exportsChecked = true;
}
function isNotOverload(declaration) {
- return (declaration.kind !== 225 && declaration.kind !== 149) ||
+ return (declaration.kind !== 227 && declaration.kind !== 150) ||
!!declaration.body;
}
}
@@ -34033,123 +37078,123 @@ var ts;
var kind = node.kind;
if (cancellationToken) {
switch (kind) {
- case 230:
- case 226:
+ case 232:
+ case 228:
+ case 229:
case 227:
- case 225:
cancellationToken.throwIfCancellationRequested();
}
}
switch (kind) {
- case 143:
- return checkTypeParameter(node);
case 144:
+ return checkTypeParameter(node);
+ case 145:
return checkParameter(node);
+ case 148:
case 147:
- case 146:
return checkPropertyDeclaration(node);
- case 158:
case 159:
- case 153:
+ case 160:
case 154:
- return checkSignatureDeclaration(node);
case 155:
return checkSignatureDeclaration(node);
+ case 156:
+ return checkSignatureDeclaration(node);
+ case 150:
case 149:
- case 148:
return checkMethodDeclaration(node);
- case 150:
- return checkConstructorDeclaration(node);
case 151:
+ return checkConstructorDeclaration(node);
case 152:
+ case 153:
return checkAccessorDeclaration(node);
- case 157:
+ case 158:
return checkTypeReferenceNode(node);
- case 156:
+ case 157:
return checkTypePredicate(node);
- case 160:
- return checkTypeQuery(node);
case 161:
- return checkTypeLiteral(node);
+ return checkTypeQuery(node);
case 162:
- return checkArrayType(node);
+ return checkTypeLiteral(node);
case 163:
- return checkTupleType(node);
+ return checkArrayType(node);
case 164:
+ return checkTupleType(node);
case 165:
- return checkUnionOrIntersectionType(node);
case 166:
- case 168:
- return checkSourceElement(node.type);
+ return checkUnionOrIntersectionType(node);
+ case 167:
case 169:
- return checkIndexedAccessType(node);
+ return checkSourceElement(node.type);
case 170:
+ return checkIndexedAccessType(node);
+ case 171:
return checkMappedType(node);
- case 225:
+ case 227:
return checkFunctionDeclaration(node);
- case 204:
- case 231:
+ case 206:
+ case 233:
return checkBlock(node);
- case 205:
- return checkVariableStatement(node);
case 207:
- return checkExpressionStatement(node);
- case 208:
- return checkIfStatement(node);
+ return checkVariableStatement(node);
case 209:
- return checkDoStatement(node);
+ return checkExpressionStatement(node);
case 210:
- return checkWhileStatement(node);
+ return checkIfStatement(node);
case 211:
- return checkForStatement(node);
+ return checkDoStatement(node);
case 212:
- return checkForInStatement(node);
+ return checkWhileStatement(node);
case 213:
- return checkForOfStatement(node);
+ return checkForStatement(node);
case 214:
+ return checkForInStatement(node);
case 215:
- return checkBreakOrContinueStatement(node);
+ return checkForOfStatement(node);
case 216:
- return checkReturnStatement(node);
case 217:
- return checkWithStatement(node);
+ return checkBreakOrContinueStatement(node);
case 218:
- return checkSwitchStatement(node);
+ return checkReturnStatement(node);
case 219:
- return checkLabeledStatement(node);
+ return checkWithStatement(node);
case 220:
- return checkThrowStatement(node);
+ return checkSwitchStatement(node);
case 221:
- return checkTryStatement(node);
+ return checkLabeledStatement(node);
+ case 222:
+ return checkThrowStatement(node);
case 223:
+ return checkTryStatement(node);
+ case 225:
return checkVariableDeclaration(node);
- case 174:
+ case 175:
return checkBindingElement(node);
- case 226:
+ case 228:
return checkClassDeclaration(node);
- case 227:
+ case 229:
return checkInterfaceDeclaration(node);
- case 228:
+ case 230:
return checkTypeAliasDeclaration(node);
- case 229:
+ case 231:
return checkEnumDeclaration(node);
- case 230:
+ case 232:
return checkModuleDeclaration(node);
- case 235:
+ case 237:
return checkImportDeclaration(node);
- case 234:
+ case 236:
return checkImportEqualsDeclaration(node);
- case 241:
+ case 243:
return checkExportDeclaration(node);
- case 240:
+ case 242:
return checkExportAssignment(node);
- case 206:
+ case 208:
checkGrammarStatementInAmbientContext(node);
return;
- case 222:
+ case 224:
checkGrammarStatementInAmbientContext(node);
return;
- case 244:
+ case 246:
return checkMissingDeclaration(node);
}
}
@@ -34162,17 +37207,17 @@ var ts;
for (var _i = 0, deferredNodes_1 = deferredNodes; _i < deferredNodes_1.length; _i++) {
var node = deferredNodes_1[_i];
switch (node.kind) {
- case 184:
case 185:
+ case 186:
+ case 150:
case 149:
- case 148:
checkFunctionExpressionOrObjectLiteralMethodDeferred(node);
break;
- case 151:
case 152:
- checkAccessorDeferred(node);
+ case 153:
+ checkAccessorDeclaration(node);
break;
- case 197:
+ case 198:
checkClassExpressionDeferred(node);
break;
}
@@ -34192,6 +37237,7 @@ var ts;
}
checkGrammarSourceFile(node);
potentialThisCollisions.length = 0;
+ potentialNewTargetCollisions.length = 0;
deferredNodes = [];
deferredUnusedIdentifierNodes = produceDiagnostics && noUnusedIdentifiers ? [] : undefined;
ts.forEach(node.statements, checkSourceElement);
@@ -34211,6 +37257,10 @@ var ts;
ts.forEach(potentialThisCollisions, checkIfThisIsCapturedInEnclosingScope);
potentialThisCollisions.length = 0;
}
+ if (potentialNewTargetCollisions.length) {
+ ts.forEach(potentialNewTargetCollisions, checkIfNewTargetIsCapturedInEnclosingScope);
+ potentialNewTargetCollisions.length = 0;
+ }
links.flags |= 1;
}
}
@@ -34255,7 +37305,7 @@ var ts;
function isInsideWithStatementBody(node) {
if (node) {
while (node.parent) {
- if (node.parent.kind === 217 && node.parent.statement === node) {
+ if (node.parent.kind === 219 && node.parent.statement === node) {
return true;
}
node = node.parent;
@@ -34264,11 +37314,11 @@ var ts;
return false;
}
function getSymbolsInScope(location, meaning) {
- var symbols = ts.createMap();
- var memberFlags = 0;
if (isInsideWithStatementBody(location)) {
return [];
}
+ var symbols = ts.createMap();
+ var memberFlags = 0;
populateSymbols();
return symbolsToArray(symbols);
function populateSymbols() {
@@ -34277,28 +37327,28 @@ var ts;
copySymbols(location.locals, meaning);
}
switch (location.kind) {
- case 261:
+ case 264:
if (!ts.isExternalOrCommonJsModule(location)) {
break;
}
- case 230:
+ case 232:
copySymbols(getSymbolOfNode(location).exports, meaning & 8914931);
break;
- case 229:
+ case 231:
copySymbols(getSymbolOfNode(location).exports, meaning & 8);
break;
- case 197:
+ case 198:
var className = location.name;
if (className) {
copySymbol(location.symbol, meaning);
}
- case 226:
- case 227:
+ case 228:
+ case 229:
if (!(memberFlags & 32)) {
copySymbols(getSymbolOfNode(location).members, meaning & 793064);
}
break;
- case 184:
+ case 185:
var funcName = location.name;
if (funcName) {
copySymbol(location.symbol, meaning);
@@ -34316,17 +37366,16 @@ var ts;
function copySymbol(symbol, meaning) {
if (symbol.flags & meaning) {
var id = symbol.name;
- if (!symbols[id]) {
- symbols[id] = symbol;
+ if (!symbols.has(id)) {
+ symbols.set(id, symbol);
}
}
}
function copySymbols(source, meaning) {
if (meaning) {
- for (var id in source) {
- var symbol = source[id];
+ source.forEach(function (symbol) {
copySymbol(symbol, meaning);
- }
+ });
}
}
}
@@ -34337,27 +37386,27 @@ var ts;
}
function isTypeDeclaration(node) {
switch (node.kind) {
- case 143:
- case 226:
- case 227:
+ case 144:
case 228:
case 229:
+ case 230:
+ case 231:
return true;
}
}
function isTypeReferenceIdentifier(entityName) {
var node = entityName;
- while (node.parent && node.parent.kind === 141) {
+ while (node.parent && node.parent.kind === 142) {
node = node.parent;
}
- return node.parent && (node.parent.kind === 157 || node.parent.kind === 272);
+ return node.parent && (node.parent.kind === 158 || node.parent.kind === 276);
}
function isHeritageClauseElementIdentifier(entityName) {
var node = entityName;
- while (node.parent && node.parent.kind === 177) {
+ while (node.parent && node.parent.kind === 178) {
node = node.parent;
}
- return node.parent && node.parent.kind === 199;
+ return node.parent && node.parent.kind === 200;
}
function forEachEnclosingClass(node, callback) {
var result;
@@ -34374,13 +37423,13 @@ var ts;
return !!forEachEnclosingClass(node, function (n) { return n === classDeclaration; });
}
function getLeftSideOfImportEqualsOrExportAssignment(nodeOnRightSide) {
- while (nodeOnRightSide.parent.kind === 141) {
+ while (nodeOnRightSide.parent.kind === 142) {
nodeOnRightSide = nodeOnRightSide.parent;
}
- if (nodeOnRightSide.parent.kind === 234) {
+ if (nodeOnRightSide.parent.kind === 236) {
return nodeOnRightSide.parent.moduleReference === nodeOnRightSide && nodeOnRightSide.parent;
}
- if (nodeOnRightSide.parent.kind === 240) {
+ if (nodeOnRightSide.parent.kind === 242) {
return nodeOnRightSide.parent.expression === nodeOnRightSide && nodeOnRightSide.parent;
}
return undefined;
@@ -34388,27 +37437,35 @@ var ts;
function isInRightSideOfImportOrExportAssignment(node) {
return getLeftSideOfImportEqualsOrExportAssignment(node) !== undefined;
}
+ function getSpecialPropertyAssignmentSymbolFromEntityName(entityName) {
+ var specialPropertyAssignmentKind = ts.getSpecialPropertyAssignmentKind(entityName.parent.parent);
+ switch (specialPropertyAssignmentKind) {
+ case 1:
+ case 3:
+ return getSymbolOfNode(entityName.parent);
+ case 4:
+ case 2:
+ case 5:
+ return getSymbolOfNode(entityName.parent.parent);
+ }
+ }
function getSymbolOfEntityNameOrPropertyAccessExpression(entityName) {
if (ts.isDeclarationName(entityName)) {
return getSymbolOfNode(entityName.parent);
}
- if (ts.isInJavaScriptFile(entityName) && entityName.parent.kind === 177) {
- var specialPropertyAssignmentKind = ts.getSpecialPropertyAssignmentKind(entityName.parent.parent);
- switch (specialPropertyAssignmentKind) {
- case 1:
- case 3:
- return getSymbolOfNode(entityName.parent);
- case 4:
- case 2:
- return getSymbolOfNode(entityName.parent.parent);
- default:
+ if (ts.isInJavaScriptFile(entityName) &&
+ entityName.parent.kind === 178 &&
+ entityName.parent === entityName.parent.parent.left) {
+ var specialPropertyAssignmentSymbol = getSpecialPropertyAssignmentSymbolFromEntityName(entityName);
+ if (specialPropertyAssignmentSymbol) {
+ return specialPropertyAssignmentSymbol;
}
}
- if (entityName.parent.kind === 240 && ts.isEntityNameExpression(entityName)) {
+ if (entityName.parent.kind === 242 && ts.isEntityNameExpression(entityName)) {
return resolveEntityName(entityName, 107455 | 793064 | 1920 | 8388608);
}
- if (entityName.kind !== 177 && isInRightSideOfImportOrExportAssignment(entityName)) {
- var importEqualsDeclaration = ts.getAncestor(entityName, 234);
+ if (entityName.kind !== 178 && isInRightSideOfImportOrExportAssignment(entityName)) {
+ var importEqualsDeclaration = ts.getAncestor(entityName, 236);
ts.Debug.assert(importEqualsDeclaration !== undefined);
return getSymbolOfPartOfRightHandSideOfImportEquals(entityName, true);
}
@@ -34417,7 +37474,7 @@ var ts;
}
if (isHeritageClauseElementIdentifier(entityName)) {
var meaning = 0;
- if (entityName.parent.kind === 199) {
+ if (entityName.parent.kind === 200) {
meaning = 793064;
if (ts.isExpressionWithTypeArgumentsInClassExtendsClause(entityName.parent)) {
meaning |= 107455;
@@ -34427,9 +37484,12 @@ var ts;
meaning = 1920;
}
meaning |= 8388608;
- return resolveEntityName(entityName, meaning);
+ var entityNameSymbol = resolveEntityName(entityName, meaning);
+ if (entityNameSymbol) {
+ return entityNameSymbol;
+ }
}
- else if (ts.isPartOfExpression(entityName)) {
+ if (ts.isPartOfExpression(entityName)) {
if (ts.nodeIsMissing(entityName)) {
return undefined;
}
@@ -34439,14 +37499,14 @@ var ts;
}
return resolveEntityName(entityName, 107455, false, true);
}
- else if (entityName.kind === 177) {
+ else if (entityName.kind === 178) {
var symbol = getNodeLinks(entityName).resolvedSymbol;
if (!symbol) {
checkPropertyAccessExpression(entityName);
}
return getNodeLinks(entityName).resolvedSymbol;
}
- else if (entityName.kind === 141) {
+ else if (entityName.kind === 142) {
var symbol = getNodeLinks(entityName).resolvedSymbol;
if (!symbol) {
checkQualifiedName(entityName);
@@ -34455,19 +37515,19 @@ var ts;
}
}
else if (isTypeReferenceIdentifier(entityName)) {
- var meaning = (entityName.parent.kind === 157 || entityName.parent.kind === 272) ? 793064 : 1920;
+ var meaning = (entityName.parent.kind === 158 || entityName.parent.kind === 276) ? 793064 : 1920;
return resolveEntityName(entityName, meaning, false, true);
}
- else if (entityName.parent.kind === 250) {
+ else if (entityName.parent.kind === 252) {
return getJsxAttributePropertySymbol(entityName.parent);
}
- if (entityName.parent.kind === 156) {
+ if (entityName.parent.kind === 157) {
return resolveEntityName(entityName, 1);
}
return undefined;
}
function getSymbolAtLocation(node) {
- if (node.kind === 261) {
+ if (node.kind === 264) {
return ts.isExternalModule(node) ? getMergedSymbol(node.symbol) : undefined;
}
if (isInsideWithStatementBody(node)) {
@@ -34483,8 +37543,8 @@ var ts;
if (isInRightSideOfImportOrExportAssignment(node)) {
return getSymbolOfEntityNameOrPropertyAccessExpression(node);
}
- else if (node.parent.kind === 174 &&
- node.parent.parent.kind === 172 &&
+ else if (node.parent.kind === 175 &&
+ node.parent.parent.kind === 173 &&
node === node.parent.propertyName) {
var typeOfPattern = getTypeOfNode(node.parent.parent);
var propertyDeclaration = typeOfPattern && getPropertyOfType(typeOfPattern, node.text);
@@ -34495,8 +37555,8 @@ var ts;
}
switch (node.kind) {
case 70:
- case 177:
- case 141:
+ case 178:
+ case 142:
return getSymbolOfEntityNameOrPropertyAccessExpression(node);
case 98:
var container = ts.getThisContainer(node, false);
@@ -34509,18 +37569,18 @@ var ts;
case 96:
var type = ts.isPartOfExpression(node) ? getTypeOfExpression(node) : getTypeFromTypeNode(node);
return type.symbol;
- case 167:
+ case 168:
return getTypeFromTypeNode(node).symbol;
case 122:
var constructorDeclaration = node.parent;
- if (constructorDeclaration && constructorDeclaration.kind === 150) {
+ if (constructorDeclaration && constructorDeclaration.kind === 151) {
return constructorDeclaration.parent.symbol;
}
return undefined;
case 9:
if ((ts.isExternalModuleImportEqualsDeclaration(node.parent.parent) &&
ts.getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node) ||
- ((node.parent.kind === 235 || node.parent.kind === 241) &&
+ ((node.parent.kind === 237 || node.parent.kind === 243) &&
node.parent.moduleSpecifier === node)) {
return resolveExternalModuleName(node, node);
}
@@ -34528,7 +37588,7 @@ var ts;
return resolveExternalModuleName(node, node);
}
case 8:
- if (node.parent.kind === 178 && node.parent.argumentExpression === node) {
+ if (node.parent.kind === 179 && node.parent.argumentExpression === node) {
var objectType = getTypeOfExpression(node.parent.expression);
if (objectType === unknownType)
return undefined;
@@ -34542,7 +37602,7 @@ var ts;
return undefined;
}
function getShorthandAssignmentValueSymbol(location) {
- if (location && location.kind === 258) {
+ if (location && location.kind === 261) {
return resolveEntityName(location.name, 107455 | 8388608);
}
return undefined;
@@ -34557,13 +37617,22 @@ var ts;
return unknownType;
}
if (ts.isPartOfTypeNode(node)) {
- return getTypeFromTypeNode(node);
+ var typeFromTypeNode = getTypeFromTypeNode(node);
+ if (typeFromTypeNode && ts.isExpressionWithTypeArgumentsInClassImplementsClause(node)) {
+ var containingClass = ts.getContainingClass(node);
+ var classType = getTypeOfNode(containingClass);
+ typeFromTypeNode = getTypeWithThisArgument(typeFromTypeNode, classType.thisType);
+ }
+ return typeFromTypeNode;
}
if (ts.isPartOfExpression(node)) {
return getRegularTypeOfExpression(node);
}
if (ts.isExpressionWithTypeArgumentsInClassExtendsClause(node)) {
- return getBaseTypes(getDeclaredTypeOfSymbol(getSymbolOfNode(node.parent.parent)))[0];
+ var classNode = ts.getContainingClass(node);
+ var classType = getDeclaredTypeOfSymbol(getSymbolOfNode(classNode));
+ var baseType = getBaseTypes(classType)[0];
+ return baseType && getTypeWithThisArgument(baseType, classType.thisType);
}
if (isTypeDeclaration(node)) {
var symbol = getSymbolOfNode(node);
@@ -34592,22 +37661,22 @@ var ts;
return unknownType;
}
function getTypeOfArrayLiteralOrObjectLiteralDestructuringAssignment(expr) {
- ts.Debug.assert(expr.kind === 176 || expr.kind === 175);
- if (expr.parent.kind === 213) {
- var iteratedType = checkRightHandSideOfForOf(expr.parent.expression);
+ ts.Debug.assert(expr.kind === 177 || expr.kind === 176);
+ if (expr.parent.kind === 215) {
+ var iteratedType = checkRightHandSideOfForOf(expr.parent.expression, expr.parent.awaitModifier);
return checkDestructuringAssignment(expr, iteratedType || unknownType);
}
- if (expr.parent.kind === 192) {
+ if (expr.parent.kind === 193) {
var iteratedType = getTypeOfExpression(expr.parent.right);
return checkDestructuringAssignment(expr, iteratedType || unknownType);
}
- if (expr.parent.kind === 257) {
+ if (expr.parent.kind === 260) {
var typeOfParentObjectLiteral = getTypeOfArrayLiteralOrObjectLiteralDestructuringAssignment(expr.parent.parent);
return checkObjectLiteralDestructuringPropertyAssignment(typeOfParentObjectLiteral || unknownType, expr.parent);
}
- ts.Debug.assert(expr.parent.kind === 175);
+ ts.Debug.assert(expr.parent.kind === 176);
var typeOfArrayLiteral = getTypeOfArrayLiteralOrObjectLiteralDestructuringAssignment(expr.parent);
- var elementType = checkIteratedTypeOrElementType(typeOfArrayLiteral || unknownType, expr.parent, false) || unknownType;
+ var elementType = checkIteratedTypeOrElementType(typeOfArrayLiteral || unknownType, expr.parent, false, false) || unknownType;
return checkArrayLiteralDestructuringElementAssignment(expr.parent, typeOfArrayLiteral, ts.indexOf(expr.parent.elements, expr), elementType || unknownType);
}
function getPropertySymbolOfDestructuringAssignment(location) {
@@ -34631,29 +37700,32 @@ var ts;
var propsByName = createSymbolTable(getPropertiesOfType(type));
if (getSignaturesOfType(type, 0).length || getSignaturesOfType(type, 1).length) {
ts.forEach(getPropertiesOfType(globalFunctionType), function (p) {
- if (!propsByName[p.name]) {
- propsByName[p.name] = p;
+ if (!propsByName.has(p.name)) {
+ propsByName.set(p.name, p);
}
});
}
return getNamedMembers(propsByName);
}
function getRootSymbols(symbol) {
- if (symbol.flags & 268435456) {
+ if (getCheckFlags(symbol) & 6) {
var symbols_3 = [];
- var name_26 = symbol.name;
+ var name_2 = symbol.name;
ts.forEach(getSymbolLinks(symbol).containingType.types, function (t) {
- var symbol = getPropertyOfType(t, name_26);
+ var symbol = getPropertyOfType(t, name_2);
if (symbol) {
symbols_3.push(symbol);
}
});
return symbols_3;
}
- else if (symbol.flags & 67108864) {
+ else if (symbol.flags & 134217728) {
if (symbol.leftSpread) {
var links = symbol;
- return [links.leftSpread, links.rightSpread];
+ return getRootSymbols(links.leftSpread).concat(getRootSymbols(links.rightSpread));
+ }
+ if (symbol.syntheticOrigin) {
+ return getRootSymbols(symbol.syntheticOrigin);
}
var target = void 0;
var next = symbol;
@@ -34670,7 +37742,8 @@ var ts;
if (!ts.isGeneratedIdentifier(node)) {
node = ts.getParseTreeNode(node, ts.isIdentifier);
if (node) {
- return getReferencedValueSymbol(node) === argumentsSymbol;
+ var isPropertyName_1 = node.parent.kind === 178 && node.parent.name === node;
+ return !isPropertyName_1 && getReferencedValueSymbol(node) === argumentsSymbol;
}
}
return false;
@@ -34686,7 +37759,7 @@ var ts;
if (symbolLinks.exportsSomeValue === undefined) {
symbolLinks.exportsSomeValue = hasExportAssignment
? !!(moduleSymbol.flags & 107455)
- : ts.forEachProperty(getExportsOfModule(moduleSymbol), isValue);
+ : ts.forEachEntry(getExportsOfModule(moduleSymbol), isValue);
}
return symbolLinks.exportsSomeValue;
function isValue(s) {
@@ -34710,19 +37783,15 @@ var ts;
}
symbol = exportSymbol;
}
- var parentSymbol = getParentOfSymbol(symbol);
- if (parentSymbol) {
- if (parentSymbol.flags & 512 && parentSymbol.valueDeclaration.kind === 261) {
- var symbolFile = parentSymbol.valueDeclaration;
+ var parentSymbol_1 = getParentOfSymbol(symbol);
+ if (parentSymbol_1) {
+ if (parentSymbol_1.flags & 512 && parentSymbol_1.valueDeclaration.kind === 264) {
+ var symbolFile = parentSymbol_1.valueDeclaration;
var referenceFile = ts.getSourceFileOfNode(node);
var symbolIsUmdExport = symbolFile !== referenceFile;
return symbolIsUmdExport ? undefined : symbolFile;
}
- for (var n = node.parent; n; n = n.parent) {
- if (ts.isModuleOrEnumDeclaration(n) && getSymbolOfNode(n) === parentSymbol) {
- return n;
- }
- }
+ return ts.findAncestor(node.parent, function (n) { return ts.isModuleOrEnumDeclaration(n) && getSymbolOfNode(n) === parentSymbol_1; });
}
}
}
@@ -34750,7 +37819,7 @@ var ts;
else if (nodeLinks_1.flags & 131072) {
var isDeclaredInLoop = nodeLinks_1.flags & 262144;
var inLoopInitializer = ts.isIterationStatement(container, false);
- var inLoopBodyBlock = container.kind === 204 && ts.isIterationStatement(container.parent, false);
+ var inLoopBodyBlock = container.kind === 206 && ts.isIterationStatement(container.parent, false);
links.isDeclarationWithCollidingName = !ts.isBlockScopedContainerTopLevel(container) && (!isDeclaredInLoop || (!inLoopInitializer && !inLoopBodyBlock));
}
else {
@@ -34785,21 +37854,17 @@ var ts;
return false;
}
function isValueAliasDeclaration(node) {
- node = ts.getParseTreeNode(node);
- if (node === undefined) {
- return true;
- }
switch (node.kind) {
- case 234:
case 236:
- case 237:
+ case 238:
case 239:
- case 243:
- return isAliasResolvedToValue(getSymbolOfNode(node) || unknownSymbol);
case 241:
+ case 245:
+ return isAliasResolvedToValue(getSymbolOfNode(node) || unknownSymbol);
+ case 243:
var exportClause = node.exportClause;
return exportClause && ts.forEach(exportClause.elements, isValueAliasDeclaration);
- case 240:
+ case 242:
return node.expression
&& node.expression.kind === 70
? isAliasResolvedToValue(getSymbolOfNode(node) || unknownSymbol)
@@ -34809,7 +37874,7 @@ var ts;
}
function isTopLevelValueImportEqualsWithEntityName(node) {
node = ts.getParseTreeNode(node, ts.isImportEqualsDeclaration);
- if (node === undefined || node.parent.kind !== 261 || !ts.isInternalModuleImportEqualsDeclaration(node)) {
+ if (node === undefined || node.parent.kind !== 264 || !ts.isInternalModuleImportEqualsDeclaration(node)) {
return false;
}
var isValue = isAliasResolvedToValue(getSymbolOfNode(node));
@@ -34827,10 +37892,6 @@ var ts;
return isConstEnumSymbol(s) || s.constEnumOnlyModule;
}
function isReferencedAliasDeclaration(node, checkChildren) {
- node = ts.getParseTreeNode(node);
- if (node === undefined) {
- return true;
- }
if (ts.isAliasSymbolDeclaration(node)) {
var symbol = getSymbolOfNode(node);
if (symbol && getSymbolLinks(symbol).referenced) {
@@ -34851,16 +37912,30 @@ var ts;
}
return false;
}
+ function isRequiredInitializedParameter(parameter) {
+ return strictNullChecks &&
+ !isOptionalParameter(parameter) &&
+ parameter.initializer &&
+ !(ts.getModifierFlags(parameter) & 92);
+ }
function getNodeCheckFlags(node) {
- node = ts.getParseTreeNode(node);
- return node ? getNodeLinks(node).flags : undefined;
+ return getNodeLinks(node).flags;
}
function getEnumMemberValue(node) {
computeEnumMemberValues(node.parent);
return getNodeLinks(node).enumMemberValue;
}
+ function canHaveConstantValue(node) {
+ switch (node.kind) {
+ case 263:
+ case 178:
+ case 179:
+ return true;
+ }
+ return false;
+ }
function getConstantValue(node) {
- if (node.kind === 260) {
+ if (node.kind === 263) {
return getEnumMemberValue(node);
}
var symbol = getNodeLinks(node).resolvedSymbol;
@@ -34876,15 +37951,17 @@ var ts;
}
function getTypeReferenceSerializationKind(typeName, location) {
var valueSymbol = resolveEntityName(typeName, 107455, true, false, location);
- var globalPromiseSymbol = tryGetGlobalPromiseConstructorSymbol();
- if (globalPromiseSymbol && valueSymbol === globalPromiseSymbol) {
- return ts.TypeReferenceSerializationKind.Promise;
- }
- var constructorType = valueSymbol ? getTypeOfSymbol(valueSymbol) : undefined;
- if (constructorType && isConstructorType(constructorType)) {
- return ts.TypeReferenceSerializationKind.TypeWithConstructSignatureAndValue;
- }
var typeSymbol = resolveEntityName(typeName, 793064, true, false, location);
+ if (valueSymbol && valueSymbol === typeSymbol) {
+ var globalPromiseSymbol = getGlobalPromiseConstructorSymbol(false);
+ if (globalPromiseSymbol && valueSymbol === globalPromiseSymbol) {
+ return ts.TypeReferenceSerializationKind.Promise;
+ }
+ var constructorType = getTypeOfSymbol(valueSymbol);
+ if (constructorType && isConstructorType(constructorType)) {
+ return ts.TypeReferenceSerializationKind.TypeWithConstructSignatureAndValue;
+ }
+ }
if (!typeSymbol) {
return ts.TypeReferenceSerializationKind.ObjectType;
}
@@ -34928,6 +38005,9 @@ var ts;
var type = symbol && !(symbol.flags & (2048 | 131072))
? getWidenedLiteralType(getTypeOfSymbol(symbol))
: unknownType;
+ if (flags & 4096) {
+ type = includeFalsyTypes(type, 2048);
+ }
getSymbolDisplayBuilder().buildTypeDisplay(type, writer, enclosingDeclaration, flags);
}
function writeReturnTypeOfSignatureDeclaration(signatureDeclaration, enclosingDeclaration, flags, writer) {
@@ -34942,10 +38022,13 @@ var ts;
var classType = getDeclaredTypeOfSymbol(getSymbolOfNode(node));
resolveBaseTypesOfClass(classType);
var baseType = classType.resolvedBaseTypes.length ? classType.resolvedBaseTypes[0] : unknownType;
+ if (!baseType.symbol) {
+ writer.reportIllegalExtends();
+ }
getSymbolDisplayBuilder().buildTypeDisplay(baseType, writer, enclosingDeclaration, flags);
}
function hasGlobalName(name) {
- return !!globals[name];
+ return globals.has(name);
}
function getReferencedValueSymbol(reference, startInDeclarationContainer) {
var resolvedSymbol = getNodeLinks(reference).resolvedSymbol;
@@ -34954,9 +38037,9 @@ var ts;
}
var location = reference;
if (startInDeclarationContainer) {
- var parent_11 = reference.parent;
- if (ts.isDeclaration(parent_11) && reference === parent_11.name) {
- location = getDeclarationContainer(parent_11);
+ var parent = reference.parent;
+ if (ts.isDeclaration(parent) && reference === parent.name) {
+ location = getDeclarationContainer(parent);
}
}
return resolveName(location, reference.text, 107455 | 1048576 | 8388608, undefined, undefined);
@@ -34989,34 +38072,46 @@ var ts;
var fileToDirective;
if (resolvedTypeReferenceDirectives) {
fileToDirective = ts.createFileMap();
- for (var key in resolvedTypeReferenceDirectives) {
- var resolvedDirective = resolvedTypeReferenceDirectives[key];
+ resolvedTypeReferenceDirectives.forEach(function (resolvedDirective, key) {
if (!resolvedDirective) {
- continue;
+ return;
}
var file = host.getSourceFile(resolvedDirective.resolvedFileName);
fileToDirective.set(file.path, key);
- }
+ });
}
return {
getReferencedExportContainer: getReferencedExportContainer,
getReferencedImportDeclaration: getReferencedImportDeclaration,
getReferencedDeclarationWithCollidingName: getReferencedDeclarationWithCollidingName,
isDeclarationWithCollidingName: isDeclarationWithCollidingName,
- isValueAliasDeclaration: isValueAliasDeclaration,
+ isValueAliasDeclaration: function (node) {
+ node = ts.getParseTreeNode(node);
+ return node ? isValueAliasDeclaration(node) : true;
+ },
hasGlobalName: hasGlobalName,
- isReferencedAliasDeclaration: isReferencedAliasDeclaration,
- getNodeCheckFlags: getNodeCheckFlags,
+ isReferencedAliasDeclaration: function (node, checkChildren) {
+ node = ts.getParseTreeNode(node);
+ return node ? isReferencedAliasDeclaration(node, checkChildren) : true;
+ },
+ getNodeCheckFlags: function (node) {
+ node = ts.getParseTreeNode(node);
+ return node ? getNodeCheckFlags(node) : undefined;
+ },
isTopLevelValueImportEqualsWithEntityName: isTopLevelValueImportEqualsWithEntityName,
isDeclarationVisible: isDeclarationVisible,
isImplementationOfOverload: isImplementationOfOverload,
+ isRequiredInitializedParameter: isRequiredInitializedParameter,
writeTypeOfDeclaration: writeTypeOfDeclaration,
writeReturnTypeOfSignatureDeclaration: writeReturnTypeOfSignatureDeclaration,
writeTypeOfExpression: writeTypeOfExpression,
writeBaseConstructorTypeOfClass: writeBaseConstructorTypeOfClass,
isSymbolAccessible: isSymbolAccessible,
isEntityNameVisible: isEntityNameVisible,
- getConstantValue: getConstantValue,
+ getConstantValue: function (node) {
+ node = ts.getParseTreeNode(node, canHaveConstantValue);
+ return node ? getConstantValue(node) : undefined;
+ },
collectLinkedAliases: collectLinkedAliases,
getReferencedValueDeclaration: getReferencedValueDeclaration,
getTypeReferenceSerializationKind: getTypeReferenceSerializationKind,
@@ -35034,7 +38129,7 @@ var ts;
if (!fileToDirective) {
return undefined;
}
- var meaning = (node.kind === 177) || (node.kind === 70 && isInTypeQuery(node))
+ var meaning = (node.kind === 178) || (node.kind === 70 && isInTypeQuery(node))
? 107455 | 1048576
: 793064 | 1920;
var symbol = resolveEntityName(node, meaning, true);
@@ -35069,15 +38164,15 @@ var ts;
}
var current = symbol;
while (true) {
- var parent_12 = getParentOfSymbol(current);
- if (parent_12) {
- current = parent_12;
+ var parent = getParentOfSymbol(current);
+ if (parent) {
+ current = parent;
}
else {
break;
}
}
- if (current.valueDeclaration && current.valueDeclaration.kind === 261 && current.flags & 512) {
+ if (current.valueDeclaration && current.valueDeclaration.kind === 264 && current.flags & 512) {
return false;
}
for (var _i = 0, _a = symbol.declarations; _i < _a.length; _i++) {
@@ -35096,7 +38191,7 @@ var ts;
if (!moduleSymbol) {
return undefined;
}
- return ts.getDeclarationOfKind(moduleSymbol, 261);
+ return ts.getDeclarationOfKind(moduleSymbol, 264);
}
function initializeTypeChecker() {
for (var _i = 0, _a = host.getSourceFiles(); _i < _a.length; _i++) {
@@ -35104,8 +38199,6 @@ var ts;
ts.bindSourceFile(file, compilerOptions);
}
var augmentations;
- var requestedExternalEmitHelpers = 0;
- var firstFileRequestingExternalHelpers;
for (var _b = 0, _c = host.getSourceFiles(); _b < _c.length; _b++) {
var file = _c[_b];
if (!ts.isExternalOrCommonJsModule(file)) {
@@ -35119,20 +38212,11 @@ var ts;
}
if (file.symbol && file.symbol.globalExports) {
var source = file.symbol.globalExports;
- for (var id in source) {
- if (!(id in globals)) {
- globals[id] = source[id];
+ source.forEach(function (sourceSymbol, id) {
+ if (!globals.has(id)) {
+ globals.set(id, sourceSymbol);
}
- }
- }
- if ((compilerOptions.isolatedModules || ts.isExternalModule(file)) && !file.isDeclarationFile) {
- var fileRequestedExternalEmitHelpers = file.flags & 64512;
- if (fileRequestedExternalEmitHelpers) {
- requestedExternalEmitHelpers |= fileRequestedExternalEmitHelpers;
- if (firstFileRequestingExternalHelpers === undefined) {
- firstFileRequestingExternalHelpers = file;
- }
- }
+ });
}
}
if (augmentations) {
@@ -35146,116 +38230,80 @@ var ts;
}
addToSymbolTable(globals, builtinGlobals, ts.Diagnostics.Declaration_name_conflicts_with_built_in_global_identifier_0);
getSymbolLinks(undefinedSymbol).type = undefinedWideningType;
- getSymbolLinks(argumentsSymbol).type = getGlobalType("IArguments");
+ getSymbolLinks(argumentsSymbol).type = getGlobalType("IArguments", 0, true);
getSymbolLinks(unknownSymbol).type = unknownType;
- globalArrayType = getGlobalType("Array", 1);
- globalObjectType = getGlobalType("Object");
- globalFunctionType = getGlobalType("Function");
- globalStringType = getGlobalType("String");
- globalNumberType = getGlobalType("Number");
- globalBooleanType = getGlobalType("Boolean");
- globalRegExpType = getGlobalType("RegExp");
- jsxElementType = getExportedTypeFromNamespace("JSX", JsxNames.Element);
- getGlobalClassDecoratorType = ts.memoize(function () { return getGlobalType("ClassDecorator"); });
- getGlobalPropertyDecoratorType = ts.memoize(function () { return getGlobalType("PropertyDecorator"); });
- getGlobalMethodDecoratorType = ts.memoize(function () { return getGlobalType("MethodDecorator"); });
- getGlobalParameterDecoratorType = ts.memoize(function () { return getGlobalType("ParameterDecorator"); });
- getGlobalTypedPropertyDescriptorType = ts.memoize(function () { return getGlobalType("TypedPropertyDescriptor", 1); });
- getGlobalESSymbolConstructorSymbol = ts.memoize(function () { return getGlobalValueSymbol("Symbol"); });
- getGlobalPromiseType = ts.memoize(function () { return getGlobalType("Promise", 1); });
- tryGetGlobalPromiseType = ts.memoize(function () { return getGlobalSymbol("Promise", 793064, undefined) && getGlobalPromiseType(); });
- getGlobalPromiseLikeType = ts.memoize(function () { return getGlobalType("PromiseLike", 1); });
- getInstantiatedGlobalPromiseLikeType = ts.memoize(createInstantiatedPromiseLikeType);
- getGlobalPromiseConstructorSymbol = ts.memoize(function () { return getGlobalValueSymbol("Promise"); });
- tryGetGlobalPromiseConstructorSymbol = ts.memoize(function () { return getGlobalSymbol("Promise", 107455, undefined) && getGlobalPromiseConstructorSymbol(); });
- getGlobalPromiseConstructorLikeType = ts.memoize(function () { return getGlobalType("PromiseConstructorLike"); });
- getGlobalThenableType = ts.memoize(createThenableType);
- getGlobalTemplateStringsArrayType = ts.memoize(function () { return getGlobalType("TemplateStringsArray"); });
- if (languageVersion >= 2) {
- getGlobalESSymbolType = ts.memoize(function () { return getGlobalType("Symbol"); });
- getGlobalIterableType = ts.memoize(function () { return getGlobalType("Iterable", 1); });
- getGlobalIteratorType = ts.memoize(function () { return getGlobalType("Iterator", 1); });
- getGlobalIterableIteratorType = ts.memoize(function () { return getGlobalType("IterableIterator", 1); });
- }
- else {
- getGlobalESSymbolType = ts.memoize(function () { return emptyObjectType; });
- getGlobalIterableType = ts.memoize(function () { return emptyGenericType; });
- getGlobalIteratorType = ts.memoize(function () { return emptyGenericType; });
- getGlobalIterableIteratorType = ts.memoize(function () { return emptyGenericType; });
- }
+ globalArrayType = getGlobalType("Array", 1, true);
+ globalObjectType = getGlobalType("Object", 0, true);
+ globalFunctionType = getGlobalType("Function", 0, true);
+ globalStringType = getGlobalType("String", 0, true);
+ globalNumberType = getGlobalType("Number", 0, true);
+ globalBooleanType = getGlobalType("Boolean", 0, true);
+ globalRegExpType = getGlobalType("RegExp", 0, true);
anyArrayType = createArrayType(anyType);
autoArrayType = createArrayType(autoType);
- var symbol = getGlobalSymbol("ReadonlyArray", 793064, undefined);
- globalReadonlyArrayType = symbol && getTypeOfGlobalSymbol(symbol, 1);
+ globalReadonlyArrayType = getGlobalTypeOrUndefined("ReadonlyArray", 1);
anyReadonlyArrayType = globalReadonlyArrayType ? createTypeFromGenericGlobalType(globalReadonlyArrayType, [anyType]) : anyArrayType;
- if (compilerOptions.importHelpers && firstFileRequestingExternalHelpers) {
- var helpersModule = resolveExternalModule(firstFileRequestingExternalHelpers, ts.externalHelpersModuleNameText, ts.Diagnostics.Cannot_find_module_0, undefined);
- if (helpersModule) {
- var exports = helpersModule.exports;
- if (requestedExternalEmitHelpers & 1024 && languageVersion < 2) {
- verifyHelperSymbol(exports, "__extends", 107455);
- }
- if (requestedExternalEmitHelpers & 16384 &&
- (languageVersion < 5 || compilerOptions.jsx === 2)) {
- verifyHelperSymbol(exports, "__assign", 107455);
- }
- if (languageVersion < 5 && requestedExternalEmitHelpers & 32768) {
- verifyHelperSymbol(exports, "__rest", 107455);
- }
- if (requestedExternalEmitHelpers & 2048) {
- verifyHelperSymbol(exports, "__decorate", 107455);
- if (compilerOptions.emitDecoratorMetadata) {
- verifyHelperSymbol(exports, "__metadata", 107455);
- }
- }
- if (requestedExternalEmitHelpers & 4096) {
- verifyHelperSymbol(exports, "__param", 107455);
- }
- if (requestedExternalEmitHelpers & 8192) {
- verifyHelperSymbol(exports, "__awaiter", 107455);
- if (languageVersion < 2) {
- verifyHelperSymbol(exports, "__generator", 107455);
+ globalThisType = getGlobalTypeOrUndefined("ThisType", 1);
+ }
+ function checkExternalEmitHelpers(location, helpers) {
+ if ((requestedExternalEmitHelpers & helpers) !== helpers && compilerOptions.importHelpers) {
+ var sourceFile = ts.getSourceFileOfNode(location);
+ if (ts.isEffectiveExternalModule(sourceFile, compilerOptions) && !ts.isInAmbientContext(location)) {
+ var helpersModule = resolveHelpersModule(sourceFile, location);
+ if (helpersModule !== unknownSymbol) {
+ var uncheckedHelpers = helpers & ~requestedExternalEmitHelpers;
+ for (var helper = 1; helper <= 8192; helper <<= 1) {
+ if (uncheckedHelpers & helper) {
+ var name = getHelperName(helper);
+ var symbol = getSymbol(helpersModule.exports, ts.escapeIdentifier(name), 107455);
+ if (!symbol) {
+ error(location, ts.Diagnostics.This_syntax_requires_an_imported_helper_named_1_but_module_0_has_no_exported_member_1, ts.externalHelpersModuleNameText, name);
+ }
+ }
}
}
+ requestedExternalEmitHelpers |= helpers;
}
}
}
- function verifyHelperSymbol(symbols, name, meaning) {
- var symbol = getSymbol(symbols, ts.escapeIdentifier(name), meaning);
- if (!symbol) {
- error(undefined, ts.Diagnostics.Module_0_has_no_exported_member_1, ts.externalHelpersModuleNameText, name);
+ function getHelperName(helper) {
+ switch (helper) {
+ case 1: return "__extends";
+ case 2: return "__assign";
+ case 4: return "__rest";
+ case 8: return "__decorate";
+ case 16: return "__metadata";
+ case 32: return "__param";
+ case 64: return "__awaiter";
+ case 128: return "__generator";
+ case 256: return "__values";
+ case 512: return "__read";
+ case 1024: return "__spread";
+ case 2048: return "__asyncGenerator";
+ case 4096: return "__asyncDelegator";
+ case 8192: return "__asyncValues";
+ default: ts.Debug.fail("Unrecognized helper.");
}
}
- function createInstantiatedPromiseLikeType() {
- var promiseLikeType = getGlobalPromiseLikeType();
- if (promiseLikeType !== emptyGenericType) {
- return createTypeReference(promiseLikeType, [anyType]);
+ function resolveHelpersModule(node, errorNode) {
+ if (!externalHelpersModule) {
+ externalHelpersModule = resolveExternalModule(node, ts.externalHelpersModuleNameText, ts.Diagnostics.This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found, errorNode) || unknownSymbol;
}
- return emptyObjectType;
- }
- function createThenableType() {
- var thenPropertySymbol = createSymbol(67108864 | 4, "then");
- getSymbolLinks(thenPropertySymbol).type = globalFunctionType;
- var thenableType = createObjectType(16);
- thenableType.properties = [thenPropertySymbol];
- thenableType.members = createSymbolTable(thenableType.properties);
- thenableType.callSignatures = [];
- thenableType.constructSignatures = [];
- return thenableType;
+ return externalHelpersModule;
}
function checkGrammarDecorators(node) {
if (!node.decorators) {
return false;
}
if (!ts.nodeCanBeDecorated(node)) {
- if (node.kind === 149 && !ts.nodeIsPresent(node.body)) {
+ if (node.kind === 150 && !ts.nodeIsPresent(node.body)) {
return grammarErrorOnFirstToken(node, ts.Diagnostics.A_decorator_can_only_decorate_a_method_implementation_not_an_overload);
}
else {
return grammarErrorOnFirstToken(node, ts.Diagnostics.Decorators_are_not_valid_here);
}
}
- else if (node.kind === 151 || node.kind === 152) {
+ else if (node.kind === 152 || node.kind === 153) {
var accessors = ts.getAllAccessorDeclarations(node.parent.members, node);
if (accessors.firstAccessor.decorators && node === accessors.secondAccessor) {
return grammarErrorOnFirstToken(node, ts.Diagnostics.Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name);
@@ -35273,16 +38321,16 @@ var ts;
for (var _i = 0, _a = node.modifiers; _i < _a.length; _i++) {
var modifier = _a[_i];
if (modifier.kind !== 130) {
- if (node.kind === 146 || node.kind === 148) {
+ if (node.kind === 147 || node.kind === 149) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_type_member, ts.tokenToString(modifier.kind));
}
- if (node.kind === 155) {
+ if (node.kind === 156) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_an_index_signature, ts.tokenToString(modifier.kind));
}
}
switch (modifier.kind) {
case 75:
- if (node.kind !== 229 && node.parent.kind === 226) {
+ if (node.kind !== 231 && node.parent.kind === 228) {
return grammarErrorOnNode(node, ts.Diagnostics.A_class_member_cannot_have_the_0_keyword, ts.tokenToString(75));
}
break;
@@ -35308,7 +38356,7 @@ var ts;
else if (flags & 256) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_must_precede_1_modifier, text, "async");
}
- else if (node.parent.kind === 231 || node.parent.kind === 261) {
+ else if (node.parent.kind === 233 || node.parent.kind === 264) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, text);
}
else if (flags & 128) {
@@ -35331,10 +38379,10 @@ var ts;
else if (flags & 256) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_must_precede_1_modifier, "static", "async");
}
- else if (node.parent.kind === 231 || node.parent.kind === 261) {
+ else if (node.parent.kind === 233 || node.parent.kind === 264) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, "static");
}
- else if (node.kind === 144) {
+ else if (node.kind === 145) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_parameter, "static");
}
else if (flags & 128) {
@@ -35347,7 +38395,7 @@ var ts;
if (flags & 64) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_already_seen, "readonly");
}
- else if (node.kind !== 147 && node.kind !== 146 && node.kind !== 155 && node.kind !== 144) {
+ else if (node.kind !== 148 && node.kind !== 147 && node.kind !== 156 && node.kind !== 145) {
return grammarErrorOnNode(modifier, ts.Diagnostics.readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature);
}
flags |= 64;
@@ -35366,10 +38414,10 @@ var ts;
else if (flags & 256) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_must_precede_1_modifier, "export", "async");
}
- else if (node.parent.kind === 226) {
+ else if (node.parent.kind === 228) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_class_element, "export");
}
- else if (node.kind === 144) {
+ else if (node.kind === 145) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_parameter, "export");
}
flags |= 1;
@@ -35381,13 +38429,13 @@ var ts;
else if (flags & 256) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
}
- else if (node.parent.kind === 226) {
+ else if (node.parent.kind === 228) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_class_element, "declare");
}
- else if (node.kind === 144) {
+ else if (node.kind === 145) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_parameter, "declare");
}
- else if (ts.isInAmbientContext(node.parent) && node.parent.kind === 231) {
+ else if (ts.isInAmbientContext(node.parent) && node.parent.kind === 233) {
return grammarErrorOnNode(modifier, ts.Diagnostics.A_declare_modifier_cannot_be_used_in_an_already_ambient_context);
}
flags |= 2;
@@ -35397,14 +38445,14 @@ var ts;
if (flags & 128) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_already_seen, "abstract");
}
- if (node.kind !== 226) {
- if (node.kind !== 149 &&
- node.kind !== 147 &&
- node.kind !== 151 &&
- node.kind !== 152) {
+ if (node.kind !== 228) {
+ if (node.kind !== 150 &&
+ node.kind !== 148 &&
+ node.kind !== 152 &&
+ node.kind !== 153) {
return grammarErrorOnNode(modifier, ts.Diagnostics.abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration);
}
- if (!(node.parent.kind === 226 && ts.getModifierFlags(node.parent) & 128)) {
+ if (!(node.parent.kind === 228 && ts.getModifierFlags(node.parent) & 128)) {
return grammarErrorOnNode(modifier, ts.Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class);
}
if (flags & 32) {
@@ -35423,7 +38471,7 @@ var ts;
else if (flags & 2 || ts.isInAmbientContext(node.parent)) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
}
- else if (node.kind === 144) {
+ else if (node.kind === 145) {
return grammarErrorOnNode(modifier, ts.Diagnostics._0_modifier_cannot_appear_on_a_parameter, "async");
}
flags |= 256;
@@ -35431,7 +38479,7 @@ var ts;
break;
}
}
- if (node.kind === 150) {
+ if (node.kind === 151) {
if (flags & 32) {
return grammarErrorOnNode(lastStatic, ts.Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "static");
}
@@ -35446,13 +38494,13 @@ var ts;
}
return;
}
- else if ((node.kind === 235 || node.kind === 234) && flags & 2) {
+ else if ((node.kind === 237 || node.kind === 236) && flags & 2) {
return grammarErrorOnNode(lastDeclare, ts.Diagnostics.A_0_modifier_cannot_be_used_with_an_import_declaration, "declare");
}
- else if (node.kind === 144 && (flags & 92) && ts.isBindingPattern(node.name)) {
+ else if (node.kind === 145 && (flags & 92) && ts.isBindingPattern(node.name)) {
return grammarErrorOnNode(node, ts.Diagnostics.A_parameter_property_may_not_be_declared_using_a_binding_pattern);
}
- else if (node.kind === 144 && (flags & 92) && node.dotDotDotToken) {
+ else if (node.kind === 145 && (flags & 92) && node.dotDotDotToken) {
return grammarErrorOnNode(node, ts.Diagnostics.A_parameter_property_cannot_be_declared_using_a_rest_parameter);
}
if (flags & 256) {
@@ -35468,37 +38516,37 @@ var ts;
}
function shouldReportBadModifier(node) {
switch (node.kind) {
- case 151:
case 152:
- case 150:
+ case 153:
+ case 151:
+ case 148:
case 147:
- case 146:
+ case 150:
case 149:
- case 148:
- case 155:
- case 230:
- case 235:
- case 234:
- case 241:
- case 240:
- case 184:
+ case 156:
+ case 232:
+ case 237:
+ case 236:
+ case 243:
+ case 242:
case 185:
- case 144:
+ case 186:
+ case 145:
return false;
default:
- if (node.parent.kind === 231 || node.parent.kind === 261) {
+ if (node.parent.kind === 233 || node.parent.kind === 264) {
return false;
}
switch (node.kind) {
- case 225:
- return nodeHasAnyModifiersExcept(node, 119);
- case 226:
- return nodeHasAnyModifiersExcept(node, 116);
case 227:
- case 205:
+ return nodeHasAnyModifiersExcept(node, 119);
case 228:
- return true;
+ return nodeHasAnyModifiersExcept(node, 116);
case 229:
+ case 207:
+ case 230:
+ return true;
+ case 231:
return nodeHasAnyModifiersExcept(node, 75);
default:
ts.Debug.fail();
@@ -35511,14 +38559,11 @@ var ts;
}
function checkGrammarAsyncModifier(node, asyncModifier) {
switch (node.kind) {
- case 149:
- case 225:
- case 184:
+ case 150:
+ case 227:
case 185:
- if (!node.asteriskToken) {
- return false;
- }
- break;
+ case 186:
+ return false;
}
return grammarErrorOnNode(asyncModifier, ts.Diagnostics._0_modifier_cannot_be_used_here, "async");
}
@@ -35575,8 +38620,12 @@ var ts;
return checkGrammarDecorators(node) || checkGrammarModifiers(node) || checkGrammarTypeParameterList(node.typeParameters, file) ||
checkGrammarParameterList(node.parameters) || checkGrammarArrowFunction(node, file);
}
+ function checkGrammarClassLikeDeclaration(node) {
+ var file = ts.getSourceFileOfNode(node);
+ return checkGrammarClassDeclarationHeritageClauses(node) || checkGrammarTypeParameterList(node.typeParameters, file);
+ }
function checkGrammarArrowFunction(node, file) {
- if (node.kind === 185) {
+ if (node.kind === 186) {
var arrowFunction = node;
var startLine = ts.getLineAndCharacterOfPosition(file, arrowFunction.equalsGreaterThanToken.pos).line;
var endLine = ts.getLineAndCharacterOfPosition(file, arrowFunction.equalsGreaterThanToken.end).line;
@@ -35611,7 +38660,7 @@ var ts;
if (!parameter.type) {
return grammarErrorOnNode(parameter.name, ts.Diagnostics.An_index_signature_parameter_must_have_a_type_annotation);
}
- if (parameter.type.kind !== 134 && parameter.type.kind !== 132) {
+ if (parameter.type.kind !== 135 && parameter.type.kind !== 132) {
return grammarErrorOnNode(parameter.name, ts.Diagnostics.An_index_signature_parameter_type_must_be_string_or_number);
}
if (!node.type) {
@@ -35638,7 +38687,7 @@ var ts;
var sourceFile = ts.getSourceFileOfNode(node);
for (var _i = 0, args_4 = args; _i < args_4.length; _i++) {
var arg = args_4[_i];
- if (arg.kind === 198) {
+ if (arg.kind === 199) {
return grammarErrorAtPos(sourceFile, arg.pos, 0, ts.Diagnostics.Argument_expression_expected);
}
}
@@ -35708,28 +38757,25 @@ var ts;
return false;
}
function checkGrammarComputedPropertyName(node) {
- if (node.kind !== 142) {
+ if (node.kind !== 143) {
return false;
}
var computedPropertyName = node;
- if (computedPropertyName.expression.kind === 192 && computedPropertyName.expression.operatorToken.kind === 25) {
+ if (computedPropertyName.expression.kind === 193 && computedPropertyName.expression.operatorToken.kind === 25) {
return grammarErrorOnNode(computedPropertyName.expression, ts.Diagnostics.A_comma_expression_is_not_allowed_in_a_computed_property_name);
}
}
function checkGrammarForGenerator(node) {
if (node.asteriskToken) {
- ts.Debug.assert(node.kind === 225 ||
- node.kind === 184 ||
- node.kind === 149);
+ ts.Debug.assert(node.kind === 227 ||
+ node.kind === 185 ||
+ node.kind === 150);
if (ts.isInAmbientContext(node)) {
return grammarErrorOnNode(node.asteriskToken, ts.Diagnostics.Generators_are_not_allowed_in_an_ambient_context);
}
if (!node.body) {
return grammarErrorOnNode(node.asteriskToken, ts.Diagnostics.An_overload_signature_cannot_be_declared_as_a_generator);
}
- if (languageVersion < 2) {
- return grammarErrorOnNode(node.asteriskToken, ts.Diagnostics.Generators_are_only_available_when_targeting_ECMAScript_2015_or_higher);
- }
}
}
function checkGrammarForInvalidQuestionMark(questionToken, message) {
@@ -35745,87 +38791,87 @@ var ts;
var GetOrSetAccessor = GetAccessor | SetAccessor;
for (var _i = 0, _a = node.properties; _i < _a.length; _i++) {
var prop = _a[_i];
- if (prop.kind === 259) {
+ if (prop.kind === 262) {
continue;
}
- var name_27 = prop.name;
- if (name_27.kind === 142) {
- checkGrammarComputedPropertyName(name_27);
+ var name = prop.name;
+ if (name.kind === 143) {
+ checkGrammarComputedPropertyName(name);
}
- if (prop.kind === 258 && !inDestructuring && prop.objectAssignmentInitializer) {
+ if (prop.kind === 261 && !inDestructuring && prop.objectAssignmentInitializer) {
return grammarErrorOnNode(prop.equalsToken, ts.Diagnostics.can_only_be_used_in_an_object_literal_property_inside_a_destructuring_assignment);
}
if (prop.modifiers) {
for (var _b = 0, _c = prop.modifiers; _b < _c.length; _b++) {
var mod = _c[_b];
- if (mod.kind !== 119 || prop.kind !== 149) {
+ if (mod.kind !== 119 || prop.kind !== 150) {
grammarErrorOnNode(mod, ts.Diagnostics._0_modifier_cannot_be_used_here, ts.getTextOfNode(mod));
}
}
}
var currentKind = void 0;
- if (prop.kind === 257 || prop.kind === 258) {
+ if (prop.kind === 260 || prop.kind === 261) {
checkGrammarForInvalidQuestionMark(prop.questionToken, ts.Diagnostics.An_object_member_cannot_be_declared_optional);
- if (name_27.kind === 8) {
- checkGrammarNumericLiteral(name_27);
+ if (name.kind === 8) {
+ checkGrammarNumericLiteral(name);
}
currentKind = Property;
}
- else if (prop.kind === 149) {
+ else if (prop.kind === 150) {
currentKind = Property;
}
- else if (prop.kind === 151) {
+ else if (prop.kind === 152) {
currentKind = GetAccessor;
}
- else if (prop.kind === 152) {
+ else if (prop.kind === 153) {
currentKind = SetAccessor;
}
else {
ts.Debug.fail("Unexpected syntax kind:" + prop.kind);
}
- var effectiveName = ts.getPropertyNameForPropertyNameNode(name_27);
+ var effectiveName = ts.getPropertyNameForPropertyNameNode(name);
if (effectiveName === undefined) {
continue;
}
- if (!seen[effectiveName]) {
- seen[effectiveName] = currentKind;
+ var existingKind = seen.get(effectiveName);
+ if (!existingKind) {
+ seen.set(effectiveName, currentKind);
}
else {
- var existingKind = seen[effectiveName];
if (currentKind === Property && existingKind === Property) {
- grammarErrorOnNode(name_27, ts.Diagnostics.Duplicate_identifier_0, ts.getTextOfNode(name_27));
+ grammarErrorOnNode(name, ts.Diagnostics.Duplicate_identifier_0, ts.getTextOfNode(name));
}
else if ((currentKind & GetOrSetAccessor) && (existingKind & GetOrSetAccessor)) {
if (existingKind !== GetOrSetAccessor && currentKind !== existingKind) {
- seen[effectiveName] = currentKind | existingKind;
+ seen.set(effectiveName, currentKind | existingKind);
}
else {
- return grammarErrorOnNode(name_27, ts.Diagnostics.An_object_literal_cannot_have_multiple_get_Slashset_accessors_with_the_same_name);
+ return grammarErrorOnNode(name, ts.Diagnostics.An_object_literal_cannot_have_multiple_get_Slashset_accessors_with_the_same_name);
}
}
else {
- return grammarErrorOnNode(name_27, ts.Diagnostics.An_object_literal_cannot_have_property_and_accessor_with_the_same_name);
+ return grammarErrorOnNode(name, ts.Diagnostics.An_object_literal_cannot_have_property_and_accessor_with_the_same_name);
}
}
}
}
function checkGrammarJsxElement(node) {
var seen = ts.createMap();
- for (var _i = 0, _a = node.attributes; _i < _a.length; _i++) {
+ for (var _i = 0, _a = node.attributes.properties; _i < _a.length; _i++) {
var attr = _a[_i];
- if (attr.kind === 251) {
+ if (attr.kind === 254) {
continue;
}
var jsxAttr = attr;
- var name_28 = jsxAttr.name;
- if (!seen[name_28.text]) {
- seen[name_28.text] = true;
+ var name = jsxAttr.name;
+ if (!seen.get(name.text)) {
+ seen.set(name.text, true);
}
else {
- return grammarErrorOnNode(name_28, ts.Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name);
+ return grammarErrorOnNode(name, ts.Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name);
}
var initializer = jsxAttr.initializer;
- if (initializer && initializer.kind === 252 && !initializer.expression) {
+ if (initializer && initializer.kind === 255 && !initializer.expression) {
return grammarErrorOnNode(jsxAttr.initializer, ts.Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression);
}
}
@@ -35834,7 +38880,12 @@ var ts;
if (checkGrammarStatementInAmbientContext(forInOrOfStatement)) {
return true;
}
- if (forInOrOfStatement.initializer.kind === 224) {
+ if (forInOrOfStatement.kind === 215 && forInOrOfStatement.awaitModifier) {
+ if ((forInOrOfStatement.flags & 16384) === 0) {
+ return grammarErrorOnNode(forInOrOfStatement.awaitModifier, ts.Diagnostics.A_for_await_of_statement_is_only_allowed_within_an_async_function_or_async_generator);
+ }
+ }
+ if (forInOrOfStatement.initializer.kind === 226) {
var variableList = forInOrOfStatement.initializer;
if (!checkGrammarVariableDeclarationList(variableList)) {
var declarations = variableList.declarations;
@@ -35842,20 +38893,20 @@ var ts;
return false;
}
if (declarations.length > 1) {
- var diagnostic = forInOrOfStatement.kind === 212
+ var diagnostic = forInOrOfStatement.kind === 214
? ts.Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement
: ts.Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement;
return grammarErrorOnFirstToken(variableList.declarations[1], diagnostic);
}
var firstDeclaration = declarations[0];
if (firstDeclaration.initializer) {
- var diagnostic = forInOrOfStatement.kind === 212
+ var diagnostic = forInOrOfStatement.kind === 214
? ts.Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer
: ts.Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer;
return grammarErrorOnNode(firstDeclaration.name, diagnostic);
}
if (firstDeclaration.type) {
- var diagnostic = forInOrOfStatement.kind === 212
+ var diagnostic = forInOrOfStatement.kind === 214
? ts.Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation
: ts.Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation;
return grammarErrorOnNode(firstDeclaration, diagnostic);
@@ -35875,15 +38926,18 @@ var ts;
else if (accessor.body === undefined && !(ts.getModifierFlags(accessor) & 128)) {
return grammarErrorAtPos(ts.getSourceFileOfNode(accessor), accessor.end - 1, ";".length, ts.Diagnostics._0_expected, "{");
}
+ else if (accessor.body && ts.getModifierFlags(accessor) & 128) {
+ return grammarErrorOnNode(accessor, ts.Diagnostics.An_abstract_accessor_cannot_have_an_implementation);
+ }
else if (accessor.typeParameters) {
return grammarErrorOnNode(accessor.name, ts.Diagnostics.An_accessor_cannot_have_type_parameters);
}
else if (!doesAccessorHaveCorrectParameterCount(accessor)) {
- return grammarErrorOnNode(accessor.name, kind === 151 ?
+ return grammarErrorOnNode(accessor.name, kind === 152 ?
ts.Diagnostics.A_get_accessor_cannot_have_parameters :
ts.Diagnostics.A_set_accessor_must_have_exactly_one_parameter);
}
- else if (kind === 152) {
+ else if (kind === 153) {
if (accessor.type) {
return grammarErrorOnNode(accessor.name, ts.Diagnostics.A_set_accessor_cannot_have_a_return_type_annotation);
}
@@ -35902,10 +38956,10 @@ var ts;
}
}
function doesAccessorHaveCorrectParameterCount(accessor) {
- return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 151 ? 0 : 1);
+ return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 152 ? 0 : 1);
}
function getAccessorThisParameter(accessor) {
- if (accessor.parameters.length === (accessor.kind === 151 ? 1 : 2)) {
+ if (accessor.parameters.length === (accessor.kind === 152 ? 1 : 2)) {
return ts.getThisParameter(accessor);
}
}
@@ -35920,7 +38974,7 @@ var ts;
checkGrammarForGenerator(node)) {
return true;
}
- if (node.parent.kind === 176) {
+ if (node.parent.kind === 177) {
if (checkGrammarForInvalidQuestionMark(node.questionToken, ts.Diagnostics.An_object_member_cannot_be_declared_optional)) {
return true;
}
@@ -35936,10 +38990,10 @@ var ts;
return checkGrammarForNonSymbolComputedProperty(node.name, ts.Diagnostics.A_computed_property_name_in_a_method_overload_must_directly_refer_to_a_built_in_symbol);
}
}
- else if (node.parent.kind === 227) {
+ else if (node.parent.kind === 229) {
return checkGrammarForNonSymbolComputedProperty(node.name, ts.Diagnostics.A_computed_property_name_in_an_interface_must_directly_refer_to_a_built_in_symbol);
}
- else if (node.parent.kind === 161) {
+ else if (node.parent.kind === 162) {
return checkGrammarForNonSymbolComputedProperty(node.name, ts.Diagnostics.A_computed_property_name_in_a_type_literal_must_directly_refer_to_a_built_in_symbol);
}
}
@@ -35950,9 +39004,9 @@ var ts;
return grammarErrorOnNode(node, ts.Diagnostics.Jump_target_cannot_cross_function_boundary);
}
switch (current.kind) {
- case 219:
+ case 221:
if (node.label && current.label.text === node.label.text) {
- var isMisplacedContinueLabel = node.kind === 214
+ var isMisplacedContinueLabel = node.kind === 216
&& !ts.isIterationStatement(current.statement, true);
if (isMisplacedContinueLabel) {
return grammarErrorOnNode(node, ts.Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement);
@@ -35960,8 +39014,8 @@ var ts;
return false;
}
break;
- case 218:
- if (node.kind === 215 && !node.label) {
+ case 220:
+ if (node.kind === 217 && !node.label) {
return false;
}
break;
@@ -35974,13 +39028,13 @@ var ts;
current = current.parent;
}
if (node.label) {
- var message = node.kind === 215
+ var message = node.kind === 217
? ts.Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement
: ts.Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement;
return grammarErrorOnNode(node, message);
}
else {
- var message = node.kind === 215
+ var message = node.kind === 217
? ts.Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement
: ts.Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement;
return grammarErrorOnNode(node, message);
@@ -35992,7 +39046,7 @@ var ts;
if (node !== ts.lastOrUndefined(elements)) {
return grammarErrorOnNode(node, ts.Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
}
- if (node.name.kind === 173 || node.name.kind === 172) {
+ if (node.name.kind === 174 || node.name.kind === 173) {
return grammarErrorOnNode(node.name, ts.Diagnostics.A_rest_element_cannot_contain_a_binding_pattern);
}
if (node.initializer) {
@@ -36002,11 +39056,11 @@ var ts;
}
function isStringOrNumberLiteralExpression(expr) {
return expr.kind === 9 || expr.kind === 8 ||
- expr.kind === 190 && expr.operator === 37 &&
+ expr.kind === 191 && expr.operator === 37 &&
expr.operand.kind === 8;
}
function checkGrammarVariableDeclaration(node) {
- if (node.parent.parent.kind !== 212 && node.parent.parent.kind !== 213) {
+ if (node.parent.parent.kind !== 214 && node.parent.parent.kind !== 215) {
if (ts.isInAmbientContext(node)) {
if (node.initializer) {
if (ts.isConst(node) && !node.type) {
@@ -36033,9 +39087,29 @@ var ts;
}
}
}
+ if (compilerOptions.module !== ts.ModuleKind.ES2015 && compilerOptions.module !== ts.ModuleKind.System && !compilerOptions.noEmit &&
+ !ts.isInAmbientContext(node.parent.parent) && ts.hasModifier(node.parent.parent, 1)) {
+ checkESModuleMarker(node.name);
+ }
var checkLetConstNames = (ts.isLet(node) || ts.isConst(node));
return checkLetConstNames && checkGrammarNameInLetOrConstDeclarations(node.name);
}
+ function checkESModuleMarker(name) {
+ if (name.kind === 70) {
+ if (ts.unescapeIdentifier(name.text) === "__esModule") {
+ return grammarErrorOnNode(name, ts.Diagnostics.Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules);
+ }
+ }
+ else {
+ var elements = name.elements;
+ for (var _i = 0, elements_2 = elements; _i < elements_2.length; _i++) {
+ var element = elements_2[_i];
+ if (!ts.isOmittedExpression(element)) {
+ return checkESModuleMarker(element.name);
+ }
+ }
+ }
+ }
function checkGrammarNameInLetOrConstDeclarations(name) {
if (name.kind === 70) {
if (name.originalKeywordKind === 109) {
@@ -36044,8 +39118,8 @@ var ts;
}
else {
var elements = name.elements;
- for (var _i = 0, elements_2 = elements; _i < elements_2.length; _i++) {
- var element = elements_2[_i];
+ for (var _i = 0, elements_3 = elements; _i < elements_3.length; _i++) {
+ var element = elements_3[_i];
if (!ts.isOmittedExpression(element)) {
checkGrammarNameInLetOrConstDeclarations(element.name);
}
@@ -36063,15 +39137,15 @@ var ts;
}
function allowLetAndConstDeclarations(parent) {
switch (parent.kind) {
- case 208:
- case 209:
case 210:
- case 217:
case 211:
case 212:
+ case 219:
case 213:
+ case 214:
+ case 215:
return false;
- case 219:
+ case 221:
return allowLetAndConstDeclarations(parent.parent);
}
return true;
@@ -36086,6 +39160,13 @@ var ts;
}
}
}
+ function checkGrammarMetaProperty(node) {
+ if (node.keywordToken === 93) {
+ if (node.name.text !== "target") {
+ return grammarErrorOnNode(node.name, ts.Diagnostics._0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2, node.name.text, ts.tokenToString(node.keywordToken), "target");
+ }
+ }
+ }
function hasParseDiagnostics(sourceFile) {
return sourceFile.parseDiagnostics.length > 0;
}
@@ -36126,7 +39207,7 @@ var ts;
return true;
}
}
- else if (node.parent.kind === 227) {
+ else if (node.parent.kind === 229) {
if (checkGrammarForNonSymbolComputedProperty(node.name, ts.Diagnostics.A_computed_property_name_in_an_interface_must_directly_refer_to_a_built_in_symbol)) {
return true;
}
@@ -36134,7 +39215,7 @@ var ts;
return grammarErrorOnNode(node.initializer, ts.Diagnostics.An_interface_property_cannot_have_an_initializer);
}
}
- else if (node.parent.kind === 161) {
+ else if (node.parent.kind === 162) {
if (checkGrammarForNonSymbolComputedProperty(node.name, ts.Diagnostics.A_computed_property_name_in_a_type_literal_must_directly_refer_to_a_built_in_symbol)) {
return true;
}
@@ -36147,13 +39228,13 @@ var ts;
}
}
function checkGrammarTopLevelElementForRequiredDeclareModifier(node) {
- if (node.kind === 227 ||
- node.kind === 228 ||
+ if (node.kind === 229 ||
+ node.kind === 230 ||
+ node.kind === 237 ||
+ node.kind === 236 ||
+ node.kind === 243 ||
+ node.kind === 242 ||
node.kind === 235 ||
- node.kind === 234 ||
- node.kind === 241 ||
- node.kind === 240 ||
- node.kind === 233 ||
ts.getModifierFlags(node) & (2 | 1 | 512)) {
return false;
}
@@ -36162,7 +39243,7 @@ var ts;
function checkGrammarTopLevelElementsForRequiredDeclareModifier(file) {
for (var _i = 0, _a = file.statements; _i < _a.length; _i++) {
var decl = _a[_i];
- if (ts.isDeclaration(decl) || decl.kind === 205) {
+ if (ts.isDeclaration(decl) || decl.kind === 207) {
if (checkGrammarTopLevelElementForRequiredDeclareModifier(decl)) {
return true;
}
@@ -36181,7 +39262,7 @@ var ts;
if (!links.hasReportedStatementInAmbientContext && ts.isFunctionLike(node.parent)) {
return getNodeLinks(node).hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, ts.Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts);
}
- if (node.parent.kind === 204 || node.parent.kind === 231 || node.parent.kind === 261) {
+ if (node.parent.kind === 206 || node.parent.kind === 233 || node.parent.kind === 264) {
var links_1 = getNodeLinks(node.parent);
if (!links_1.hasReportedStatementInAmbientContext) {
return links_1.hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, ts.Diagnostics.Statements_are_not_allowed_in_ambient_contexts);
@@ -36192,8 +39273,22 @@ var ts;
}
}
function checkGrammarNumericLiteral(node) {
- if (node.isOctalLiteral && languageVersion >= 1) {
- return grammarErrorOnNode(node, ts.Diagnostics.Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher);
+ if (node.numericLiteralFlags & 4) {
+ var diagnosticMessage = void 0;
+ if (languageVersion >= 1) {
+ diagnosticMessage = ts.Diagnostics.Octal_literals_are_not_available_when_targeting_ECMAScript_5_and_higher_Use_the_syntax_0;
+ }
+ else if (ts.isChildOfNodeWithKind(node, 172)) {
+ diagnosticMessage = ts.Diagnostics.Octal_literal_types_must_use_ES2015_syntax_Use_the_syntax_0;
+ }
+ else if (ts.isChildOfNodeWithKind(node, 263)) {
+ diagnosticMessage = ts.Diagnostics.Octal_literals_are_not_allowed_in_enums_members_initializer_Use_the_syntax_0;
+ }
+ if (diagnosticMessage) {
+ var withMinus = ts.isPrefixUnaryExpression(node.parent) && node.parent.operator === 37;
+ var literal = (withMinus ? "-" : "") + "0o" + node.text;
+ return grammarErrorOnNode(withMinus ? node.parent : node, diagnosticMessage, literal);
+ }
}
}
function grammarErrorAfterFirstToken(node, message, arg0, arg1, arg2) {
@@ -36206,11 +39301,11 @@ var ts;
}
function getAmbientModules() {
var result = [];
- for (var sym in globals) {
+ globals.forEach(function (global, sym) {
if (ambientModuleSymbolRegex.test(sym)) {
- result.push(globals[sym]);
+ result.push(global);
}
- }
+ });
return result;
}
}
@@ -36218,55 +39313,359 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- ;
- var nodeEdgeTraversalMap = ts.createMap((_a = {},
- _a[141] = [
- { name: "left", test: ts.isEntityName },
- { name: "right", test: ts.isIdentifier }
- ],
- _a[145] = [
- { name: "expression", test: ts.isLeftHandSideExpression }
- ],
- _a[182] = [
- { name: "type", test: ts.isTypeNode },
- { name: "expression", test: ts.isUnaryExpression }
- ],
- _a[200] = [
- { name: "expression", test: ts.isExpression },
- { name: "type", test: ts.isTypeNode }
- ],
- _a[201] = [
- { name: "expression", test: ts.isLeftHandSideExpression }
- ],
- _a[229] = [
- { name: "decorators", test: ts.isDecorator },
- { name: "modifiers", test: ts.isModifier },
- { name: "name", test: ts.isIdentifier },
- { name: "members", test: ts.isEnumMember }
- ],
- _a[230] = [
- { name: "decorators", test: ts.isDecorator },
- { name: "modifiers", test: ts.isModifier },
- { name: "name", test: ts.isModuleName },
- { name: "body", test: ts.isModuleBody }
- ],
- _a[231] = [
- { name: "statements", test: ts.isStatement }
- ],
- _a[234] = [
- { name: "decorators", test: ts.isDecorator },
- { name: "modifiers", test: ts.isModifier },
- { name: "name", test: ts.isIdentifier },
- { name: "moduleReference", test: ts.isModuleReference }
- ],
- _a[245] = [
- { name: "expression", test: ts.isExpression, optional: true }
- ],
- _a[260] = [
- { name: "name", test: ts.isPropertyName },
- { name: "initializer", test: ts.isExpression, optional: true, parenthesize: ts.parenthesizeExpressionForList }
- ],
- _a));
+ function visitNode(node, visitor, test, lift) {
+ if (node === undefined || visitor === undefined) {
+ return node;
+ }
+ ts.aggregateTransformFlags(node);
+ var visited = visitor(node);
+ if (visited === node) {
+ return node;
+ }
+ var visitedNode;
+ if (visited === undefined) {
+ return undefined;
+ }
+ else if (ts.isArray(visited)) {
+ visitedNode = (lift || extractSingleNode)(visited);
+ }
+ else {
+ visitedNode = visited;
+ }
+ ts.Debug.assertNode(visitedNode, test);
+ ts.aggregateTransformFlags(visitedNode);
+ return visitedNode;
+ }
+ ts.visitNode = visitNode;
+ function visitNodes(nodes, visitor, test, start, count) {
+ if (nodes === undefined || visitor === undefined) {
+ return nodes;
+ }
+ var updated;
+ var length = nodes.length;
+ if (start === undefined || start < 0) {
+ start = 0;
+ }
+ if (count === undefined || count > length - start) {
+ count = length - start;
+ }
+ if (start > 0 || count < length) {
+ updated = ts.createNodeArray([], nodes.hasTrailingComma && start + count === length);
+ }
+ for (var i = 0; i < count; i++) {
+ var node = nodes[i + start];
+ ts.aggregateTransformFlags(node);
+ var visited = node !== undefined ? visitor(node) : undefined;
+ if (updated !== undefined || visited === undefined || visited !== node) {
+ if (updated === undefined) {
+ updated = ts.createNodeArray(nodes.slice(0, i), nodes.hasTrailingComma);
+ ts.setTextRange(updated, nodes);
+ }
+ if (visited) {
+ if (ts.isArray(visited)) {
+ for (var _i = 0, visited_1 = visited; _i < visited_1.length; _i++) {
+ var visitedNode = visited_1[_i];
+ ts.Debug.assertNode(visitedNode, test);
+ ts.aggregateTransformFlags(visitedNode);
+ updated.push(visitedNode);
+ }
+ }
+ else {
+ ts.Debug.assertNode(visited, test);
+ ts.aggregateTransformFlags(visited);
+ updated.push(visited);
+ }
+ }
+ }
+ }
+ return updated || nodes;
+ }
+ ts.visitNodes = visitNodes;
+ function visitLexicalEnvironment(statements, visitor, context, start, ensureUseStrict) {
+ context.startLexicalEnvironment();
+ statements = visitNodes(statements, visitor, ts.isStatement, start);
+ if (ensureUseStrict && !ts.startsWithUseStrict(statements)) {
+ statements = ts.setTextRange(ts.createNodeArray([ts.createStatement(ts.createLiteral("use strict"))].concat(statements)), statements);
+ }
+ var declarations = context.endLexicalEnvironment();
+ return ts.setTextRange(ts.createNodeArray(ts.concatenate(statements, declarations)), statements);
+ }
+ ts.visitLexicalEnvironment = visitLexicalEnvironment;
+ function visitParameterList(nodes, visitor, context, nodesVisitor) {
+ if (nodesVisitor === void 0) { nodesVisitor = visitNodes; }
+ context.startLexicalEnvironment();
+ var updated = nodesVisitor(nodes, visitor, ts.isParameterDeclaration);
+ context.suspendLexicalEnvironment();
+ return updated;
+ }
+ ts.visitParameterList = visitParameterList;
+ function visitFunctionBody(node, visitor, context) {
+ context.resumeLexicalEnvironment();
+ var updated = visitNode(node, visitor, ts.isConciseBody);
+ var declarations = context.endLexicalEnvironment();
+ if (ts.some(declarations)) {
+ var block = ts.convertToFunctionBody(updated);
+ var statements = ts.mergeLexicalEnvironment(block.statements, declarations);
+ return ts.updateBlock(block, statements);
+ }
+ return updated;
+ }
+ ts.visitFunctionBody = visitFunctionBody;
+ function visitEachChild(node, visitor, context, nodesVisitor, tokenVisitor) {
+ if (nodesVisitor === void 0) { nodesVisitor = visitNodes; }
+ if (node === undefined) {
+ return undefined;
+ }
+ var kind = node.kind;
+ if ((kind > 0 && kind <= 141) || kind === 168) {
+ return node;
+ }
+ switch (node.kind) {
+ case 205:
+ case 208:
+ case 199:
+ case 224:
+ case 297:
+ case 246:
+ return node;
+ case 142:
+ return ts.updateQualifiedName(node, visitNode(node.left, visitor, ts.isEntityName), visitNode(node.right, visitor, ts.isIdentifier));
+ case 143:
+ return ts.updateComputedPropertyName(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 159:
+ return ts.updateFunctionTypeNode(node, nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 160:
+ return ts.updateConstructorTypeNode(node, nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 154:
+ return ts.updateCallSignatureDeclaration(node, nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 155:
+ return ts.updateConstructSignatureDeclaration(node, nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 149:
+ return ts.updateMethodSignature(node, nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.questionToken, tokenVisitor, ts.isToken));
+ case 156:
+ return ts.updateIndexSignatureDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 145:
+ return ts.updateParameter(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.dotDotDotToken, tokenVisitor, ts.isToken), visitNode(node.name, visitor, ts.isBindingName), visitNode(node.questionToken, tokenVisitor, ts.isToken), visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.initializer, visitor, ts.isExpression));
+ case 146:
+ return ts.updateDecorator(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 158:
+ return ts.updateTypeReferenceNode(node, visitNode(node.typeName, visitor, ts.isEntityName), nodesVisitor(node.typeArguments, visitor, ts.isTypeNode));
+ case 157:
+ return ts.updateTypePredicateNode(node, visitNode(node.parameterName, visitor), visitNode(node.type, visitor, ts.isTypeNode));
+ case 161:
+ return ts.updateTypeQueryNode(node, visitNode(node.exprName, visitor, ts.isEntityName));
+ case 162:
+ return ts.updateTypeLiteralNode(node, nodesVisitor(node.members, visitor));
+ case 163:
+ return ts.updateArrayTypeNode(node, visitNode(node.elementType, visitor, ts.isTypeNode));
+ case 164:
+ return ts.updateTypleTypeNode(node, nodesVisitor(node.elementTypes, visitor, ts.isTypeNode));
+ case 165:
+ case 166:
+ return ts.updateUnionOrIntersectionTypeNode(node, nodesVisitor(node.types, visitor, ts.isTypeNode));
+ case 167:
+ throw ts.Debug.fail("not implemented.");
+ case 169:
+ return ts.updateTypeOperatorNode(node, visitNode(node.type, visitor, ts.isTypeNode));
+ case 170:
+ return ts.updateIndexedAccessTypeNode(node, visitNode(node.objectType, visitor, ts.isTypeNode), visitNode(node.indexType, visitor, ts.isTypeNode));
+ case 171:
+ return ts.updateMappedTypeNode(node, visitNode(node.readonlyToken, tokenVisitor, ts.isToken), visitNode(node.typeParameter, visitor, ts.isTypeParameter), visitNode(node.questionToken, tokenVisitor, ts.isToken), visitNode(node.type, visitor, ts.isTypeNode));
+ case 172:
+ return ts.updateLiteralTypeNode(node, visitNode(node.literal, visitor, ts.isExpression));
+ case 144:
+ return ts.updateTypeParameterDeclaration(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.constraint, visitor, ts.isTypeNode), visitNode(node.default, visitor, ts.isTypeNode));
+ case 147:
+ return ts.updatePropertySignature(node, visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.questionToken, tokenVisitor, ts.isToken), visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.initializer, visitor, ts.isExpression));
+ case 148:
+ return ts.updateProperty(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.initializer, visitor, ts.isExpression));
+ case 150:
+ return ts.updateMethod(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.asteriskToken, tokenVisitor, ts.isToken), visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.questionToken, tokenVisitor, ts.isToken), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitFunctionBody(node.body, visitor, context));
+ case 151:
+ return ts.updateConstructor(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitFunctionBody(node.body, visitor, context));
+ case 152:
+ return ts.updateGetAccessor(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitFunctionBody(node.body, visitor, context));
+ case 153:
+ return ts.updateSetAccessor(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitFunctionBody(node.body, visitor, context));
+ case 173:
+ return ts.updateObjectBindingPattern(node, nodesVisitor(node.elements, visitor, ts.isBindingElement));
+ case 174:
+ return ts.updateArrayBindingPattern(node, nodesVisitor(node.elements, visitor, ts.isArrayBindingElement));
+ case 175:
+ return ts.updateBindingElement(node, visitNode(node.dotDotDotToken, tokenVisitor, ts.isToken), visitNode(node.propertyName, visitor, ts.isPropertyName), visitNode(node.name, visitor, ts.isBindingName), visitNode(node.initializer, visitor, ts.isExpression));
+ case 176:
+ return ts.updateArrayLiteral(node, nodesVisitor(node.elements, visitor, ts.isExpression));
+ case 177:
+ return ts.updateObjectLiteral(node, nodesVisitor(node.properties, visitor, ts.isObjectLiteralElementLike));
+ case 178:
+ return ts.updatePropertyAccess(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.name, visitor, ts.isIdentifier));
+ case 179:
+ return ts.updateElementAccess(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.argumentExpression, visitor, ts.isExpression));
+ case 180:
+ return ts.updateCall(node, visitNode(node.expression, visitor, ts.isExpression), nodesVisitor(node.typeArguments, visitor, ts.isTypeNode), nodesVisitor(node.arguments, visitor, ts.isExpression));
+ case 181:
+ return ts.updateNew(node, visitNode(node.expression, visitor, ts.isExpression), nodesVisitor(node.typeArguments, visitor, ts.isTypeNode), nodesVisitor(node.arguments, visitor, ts.isExpression));
+ case 182:
+ return ts.updateTaggedTemplate(node, visitNode(node.tag, visitor, ts.isExpression), visitNode(node.template, visitor, ts.isTemplateLiteral));
+ case 183:
+ return ts.updateTypeAssertion(node, visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.expression, visitor, ts.isExpression));
+ case 184:
+ return ts.updateParen(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 185:
+ return ts.updateFunctionExpression(node, nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.asteriskToken, tokenVisitor, ts.isToken), visitNode(node.name, visitor, ts.isIdentifier), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitFunctionBody(node.body, visitor, context));
+ case 186:
+ return ts.updateArrowFunction(node, nodesVisitor(node.modifiers, visitor, ts.isModifier), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitFunctionBody(node.body, visitor, context));
+ case 187:
+ return ts.updateDelete(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 188:
+ return ts.updateTypeOf(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 189:
+ return ts.updateVoid(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 190:
+ return ts.updateAwait(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 193:
+ return ts.updateBinary(node, visitNode(node.left, visitor, ts.isExpression), visitNode(node.right, visitor, ts.isExpression));
+ case 191:
+ return ts.updatePrefix(node, visitNode(node.operand, visitor, ts.isExpression));
+ case 192:
+ return ts.updatePostfix(node, visitNode(node.operand, visitor, ts.isExpression));
+ case 194:
+ return ts.updateConditional(node, visitNode(node.condition, visitor, ts.isExpression), visitNode(node.whenTrue, visitor, ts.isExpression), visitNode(node.whenFalse, visitor, ts.isExpression));
+ case 195:
+ return ts.updateTemplateExpression(node, visitNode(node.head, visitor, ts.isTemplateHead), nodesVisitor(node.templateSpans, visitor, ts.isTemplateSpan));
+ case 196:
+ return ts.updateYield(node, visitNode(node.asteriskToken, tokenVisitor, ts.isToken), visitNode(node.expression, visitor, ts.isExpression));
+ case 197:
+ return ts.updateSpread(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 198:
+ return ts.updateClassExpression(node, nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), nodesVisitor(node.heritageClauses, visitor, ts.isHeritageClause), nodesVisitor(node.members, visitor, ts.isClassElement));
+ case 200:
+ return ts.updateExpressionWithTypeArguments(node, nodesVisitor(node.typeArguments, visitor, ts.isTypeNode), visitNode(node.expression, visitor, ts.isExpression));
+ case 201:
+ return ts.updateAsExpression(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.type, visitor, ts.isTypeNode));
+ case 202:
+ return ts.updateNonNullExpression(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 204:
+ return ts.updateTemplateSpan(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.literal, visitor, ts.isTemplateMiddleOrTemplateTail));
+ case 206:
+ return ts.updateBlock(node, nodesVisitor(node.statements, visitor, ts.isStatement));
+ case 207:
+ return ts.updateVariableStatement(node, nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.declarationList, visitor, ts.isVariableDeclarationList));
+ case 209:
+ return ts.updateStatement(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 210:
+ return ts.updateIf(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.thenStatement, visitor, ts.isStatement, ts.liftToBlock), visitNode(node.elseStatement, visitor, ts.isStatement, ts.liftToBlock));
+ case 211:
+ return ts.updateDo(node, visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock), visitNode(node.expression, visitor, ts.isExpression));
+ case 212:
+ return ts.updateWhile(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 213:
+ return ts.updateFor(node, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.condition, visitor, ts.isExpression), visitNode(node.incrementor, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 214:
+ return ts.updateForIn(node, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 215:
+ return ts.updateForOf(node, node.awaitModifier, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 216:
+ return ts.updateContinue(node, visitNode(node.label, visitor, ts.isIdentifier));
+ case 217:
+ return ts.updateBreak(node, visitNode(node.label, visitor, ts.isIdentifier));
+ case 218:
+ return ts.updateReturn(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 219:
+ return ts.updateWith(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 220:
+ return ts.updateSwitch(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.caseBlock, visitor, ts.isCaseBlock));
+ case 221:
+ return ts.updateLabel(node, visitNode(node.label, visitor, ts.isIdentifier), visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
+ case 222:
+ return ts.updateThrow(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 223:
+ return ts.updateTry(node, visitNode(node.tryBlock, visitor, ts.isBlock), visitNode(node.catchClause, visitor, ts.isCatchClause), visitNode(node.finallyBlock, visitor, ts.isBlock));
+ case 225:
+ return ts.updateVariableDeclaration(node, visitNode(node.name, visitor, ts.isBindingName), visitNode(node.type, visitor, ts.isTypeNode), visitNode(node.initializer, visitor, ts.isExpression));
+ case 226:
+ return ts.updateVariableDeclarationList(node, nodesVisitor(node.declarations, visitor, ts.isVariableDeclaration));
+ case 227:
+ return ts.updateFunctionDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.asteriskToken, tokenVisitor, ts.isToken), visitNode(node.name, visitor, ts.isIdentifier), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context, nodesVisitor), visitNode(node.type, visitor, ts.isTypeNode), visitFunctionBody(node.body, visitor, context));
+ case 228:
+ return ts.updateClassDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier), nodesVisitor(node.typeParameters, visitor, ts.isTypeParameter), nodesVisitor(node.heritageClauses, visitor, ts.isHeritageClause), nodesVisitor(node.members, visitor, ts.isClassElement));
+ case 231:
+ return ts.updateEnumDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier), nodesVisitor(node.members, visitor, ts.isEnumMember));
+ case 232:
+ return ts.updateModuleDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.body, visitor, ts.isModuleBody));
+ case 233:
+ return ts.updateModuleBlock(node, nodesVisitor(node.statements, visitor, ts.isStatement));
+ case 234:
+ return ts.updateCaseBlock(node, nodesVisitor(node.clauses, visitor, ts.isCaseOrDefaultClause));
+ case 236:
+ return ts.updateImportEqualsDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.moduleReference, visitor, ts.isModuleReference));
+ case 237:
+ return ts.updateImportDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.importClause, visitor, ts.isImportClause), visitNode(node.moduleSpecifier, visitor, ts.isExpression));
+ case 238:
+ return ts.updateImportClause(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.namedBindings, visitor, ts.isNamedImportBindings));
+ case 239:
+ return ts.updateNamespaceImport(node, visitNode(node.name, visitor, ts.isIdentifier));
+ case 240:
+ return ts.updateNamedImports(node, nodesVisitor(node.elements, visitor, ts.isImportSpecifier));
+ case 241:
+ return ts.updateImportSpecifier(node, visitNode(node.propertyName, visitor, ts.isIdentifier), visitNode(node.name, visitor, ts.isIdentifier));
+ case 242:
+ return ts.updateExportAssignment(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.expression, visitor, ts.isExpression));
+ case 243:
+ return ts.updateExportDeclaration(node, nodesVisitor(node.decorators, visitor, ts.isDecorator), nodesVisitor(node.modifiers, visitor, ts.isModifier), visitNode(node.exportClause, visitor, ts.isNamedExports), visitNode(node.moduleSpecifier, visitor, ts.isExpression));
+ case 244:
+ return ts.updateNamedExports(node, nodesVisitor(node.elements, visitor, ts.isExportSpecifier));
+ case 245:
+ return ts.updateExportSpecifier(node, visitNode(node.propertyName, visitor, ts.isIdentifier), visitNode(node.name, visitor, ts.isIdentifier));
+ case 247:
+ return ts.updateExternalModuleReference(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 248:
+ return ts.updateJsxElement(node, visitNode(node.openingElement, visitor, ts.isJsxOpeningElement), nodesVisitor(node.children, visitor, ts.isJsxChild), visitNode(node.closingElement, visitor, ts.isJsxClosingElement));
+ case 253:
+ return ts.updateJsxAttributes(node, nodesVisitor(node.properties, visitor, ts.isJsxAttributeLike));
+ case 249:
+ return ts.updateJsxSelfClosingElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression), visitNode(node.attributes, visitor, ts.isJsxAttributes));
+ case 250:
+ return ts.updateJsxOpeningElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression), visitNode(node.attributes, visitor, ts.isJsxAttributes));
+ case 251:
+ return ts.updateJsxClosingElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression));
+ case 252:
+ return ts.updateJsxAttribute(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.initializer, visitor, ts.isStringLiteralOrJsxExpression));
+ case 254:
+ return ts.updateJsxSpreadAttribute(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 255:
+ return ts.updateJsxExpression(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 256:
+ return ts.updateCaseClause(node, visitNode(node.expression, visitor, ts.isExpression), nodesVisitor(node.statements, visitor, ts.isStatement));
+ case 257:
+ return ts.updateDefaultClause(node, nodesVisitor(node.statements, visitor, ts.isStatement));
+ case 258:
+ return ts.updateHeritageClause(node, nodesVisitor(node.types, visitor, ts.isExpressionWithTypeArguments));
+ case 259:
+ return ts.updateCatchClause(node, visitNode(node.variableDeclaration, visitor, ts.isVariableDeclaration), visitNode(node.block, visitor, ts.isBlock));
+ case 260:
+ return ts.updatePropertyAssignment(node, visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.initializer, visitor, ts.isExpression));
+ case 261:
+ return ts.updateShorthandPropertyAssignment(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.objectAssignmentInitializer, visitor, ts.isExpression));
+ case 262:
+ return ts.updateSpreadAssignment(node, visitNode(node.expression, visitor, ts.isExpression));
+ case 263:
+ return ts.updateEnumMember(node, visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.initializer, visitor, ts.isExpression));
+ case 264:
+ return ts.updateSourceFileNode(node, visitLexicalEnvironment(node.statements, visitor, context));
+ case 295:
+ return ts.updatePartiallyEmittedExpression(node, visitNode(node.expression, visitor, ts.isExpression));
+ default:
+ return node;
+ }
+ }
+ ts.visitEachChild = visitEachChild;
+ function extractSingleNode(nodes) {
+ ts.Debug.assert(nodes.length <= 1, "Too many nodes written to output.");
+ return ts.singleOrUndefined(nodes);
+ }
+})(ts || (ts = {}));
+(function (ts) {
function reduceNode(node, f, initial) {
return node ? f(initial, node) : initial;
}
@@ -36280,41 +39679,45 @@ var ts;
var reduceNodes = cbNodeArray ? reduceNodeArray : ts.reduceLeft;
var cbNodes = cbNodeArray || cbNode;
var kind = node.kind;
- if ((kind > 0 && kind <= 140)) {
+ if ((kind > 0 && kind <= 141)) {
return initial;
}
- if ((kind >= 156 && kind <= 171)) {
+ if ((kind >= 157 && kind <= 172)) {
return initial;
}
var result = initial;
switch (node.kind) {
- case 203:
- case 206:
- case 198:
- case 222:
- case 293:
+ case 205:
+ case 208:
+ case 199:
+ case 224:
+ case 294:
break;
case 142:
+ result = reduceNode(node.left, cbNode, result);
+ result = reduceNode(node.right, cbNode, result);
+ break;
+ case 143:
result = reduceNode(node.expression, cbNode, result);
break;
- case 144:
+ case 145:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 145:
+ case 146:
result = reduceNode(node.expression, cbNode, result);
break;
- case 147:
+ case 148:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 149:
+ case 150:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
@@ -36323,12 +39726,12 @@ var ts;
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 150:
+ case 151:
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNodes(node.parameters, cbNodes, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 151:
+ case 152:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
@@ -36336,51 +39739,55 @@ var ts;
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 152:
+ case 153:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNodes(node.parameters, cbNodes, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 172:
case 173:
+ case 174:
result = reduceNodes(node.elements, cbNodes, result);
break;
- case 174:
+ case 175:
result = reduceNode(node.propertyName, cbNode, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 175:
+ case 176:
result = reduceNodes(node.elements, cbNodes, result);
break;
- case 176:
+ case 177:
result = reduceNodes(node.properties, cbNodes, result);
break;
- case 177:
+ case 178:
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.name, cbNode, result);
break;
- case 178:
+ case 179:
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.argumentExpression, cbNode, result);
break;
- case 179:
+ case 180:
result = reduceNode(node.expression, cbNode, result);
result = reduceNodes(node.typeArguments, cbNodes, result);
result = reduceNodes(node.arguments, cbNodes, result);
break;
- case 180:
+ case 181:
result = reduceNode(node.expression, cbNode, result);
result = reduceNodes(node.typeArguments, cbNodes, result);
result = reduceNodes(node.arguments, cbNodes, result);
break;
- case 181:
+ case 182:
result = reduceNode(node.tag, cbNode, result);
result = reduceNode(node.template, cbNode, result);
break;
- case 184:
+ case 183:
+ result = reduceNode(node.type, cbNode, result);
+ result = reduceNode(node.expression, cbNode, result);
+ break;
+ case 185:
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNodes(node.typeParameters, cbNodes, result);
@@ -36388,117 +39795,124 @@ var ts;
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 185:
+ case 186:
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNodes(node.typeParameters, cbNodes, result);
result = reduceNodes(node.parameters, cbNodes, result);
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 183:
- case 186:
+ case 184:
case 187:
case 188:
case 189:
- case 195:
+ case 190:
case 196:
- case 201:
+ case 197:
+ case 202:
result = reduceNode(node.expression, cbNode, result);
break;
- case 190:
case 191:
+ case 192:
result = reduceNode(node.operand, cbNode, result);
break;
- case 192:
+ case 193:
result = reduceNode(node.left, cbNode, result);
result = reduceNode(node.right, cbNode, result);
break;
- case 193:
+ case 194:
result = reduceNode(node.condition, cbNode, result);
result = reduceNode(node.whenTrue, cbNode, result);
result = reduceNode(node.whenFalse, cbNode, result);
break;
- case 194:
+ case 195:
result = reduceNode(node.head, cbNode, result);
result = reduceNodes(node.templateSpans, cbNodes, result);
break;
- case 197:
+ case 198:
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
result = reduceNodes(node.typeParameters, cbNodes, result);
result = reduceNodes(node.heritageClauses, cbNodes, result);
result = reduceNodes(node.members, cbNodes, result);
break;
- case 199:
+ case 200:
result = reduceNode(node.expression, cbNode, result);
result = reduceNodes(node.typeArguments, cbNodes, result);
break;
+ case 201:
+ result = reduceNode(node.expression, cbNode, result);
+ result = reduceNode(node.type, cbNode, result);
+ break;
case 202:
result = reduceNode(node.expression, cbNode, result);
- result = reduceNode(node.literal, cbNode, result);
break;
case 204:
+ result = reduceNode(node.expression, cbNode, result);
+ result = reduceNode(node.literal, cbNode, result);
+ break;
+ case 206:
result = reduceNodes(node.statements, cbNodes, result);
break;
- case 205:
+ case 207:
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.declarationList, cbNode, result);
break;
- case 207:
+ case 209:
result = reduceNode(node.expression, cbNode, result);
break;
- case 208:
+ case 210:
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.thenStatement, cbNode, result);
result = reduceNode(node.elseStatement, cbNode, result);
break;
- case 209:
+ case 211:
result = reduceNode(node.statement, cbNode, result);
result = reduceNode(node.expression, cbNode, result);
break;
- case 210:
- case 217:
+ case 212:
+ case 219:
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.statement, cbNode, result);
break;
- case 211:
+ case 213:
result = reduceNode(node.initializer, cbNode, result);
result = reduceNode(node.condition, cbNode, result);
result = reduceNode(node.incrementor, cbNode, result);
result = reduceNode(node.statement, cbNode, result);
break;
- case 212:
- case 213:
+ case 214:
+ case 215:
result = reduceNode(node.initializer, cbNode, result);
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.statement, cbNode, result);
break;
- case 216:
- case 220:
+ case 218:
+ case 222:
result = reduceNode(node.expression, cbNode, result);
break;
- case 218:
+ case 220:
result = reduceNode(node.expression, cbNode, result);
result = reduceNode(node.caseBlock, cbNode, result);
break;
- case 219:
+ case 221:
result = reduceNode(node.label, cbNode, result);
result = reduceNode(node.statement, cbNode, result);
break;
- case 221:
+ case 223:
result = reduceNode(node.tryBlock, cbNode, result);
result = reduceNode(node.catchClause, cbNode, result);
result = reduceNode(node.finallyBlock, cbNode, result);
break;
- case 223:
+ case 225:
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 224:
+ case 226:
result = reduceNodes(node.declarations, cbNodes, result);
break;
- case 225:
+ case 227:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
@@ -36507,7 +39921,7 @@ var ts;
result = reduceNode(node.type, cbNode, result);
result = reduceNode(node.body, cbNode, result);
break;
- case 226:
+ case 228:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.name, cbNode, result);
@@ -36515,455 +39929,145 @@ var ts;
result = reduceNodes(node.heritageClauses, cbNodes, result);
result = reduceNodes(node.members, cbNodes, result);
break;
+ case 231:
+ result = reduceNodes(node.decorators, cbNodes, result);
+ result = reduceNodes(node.modifiers, cbNodes, result);
+ result = reduceNode(node.name, cbNode, result);
+ result = reduceNodes(node.members, cbNodes, result);
+ break;
case 232:
+ result = reduceNodes(node.decorators, cbNodes, result);
+ result = reduceNodes(node.modifiers, cbNodes, result);
+ result = reduceNode(node.name, cbNode, result);
+ result = reduceNode(node.body, cbNode, result);
+ break;
+ case 233:
+ result = reduceNodes(node.statements, cbNodes, result);
+ break;
+ case 234:
result = reduceNodes(node.clauses, cbNodes, result);
break;
- case 235:
+ case 236:
+ result = reduceNodes(node.decorators, cbNodes, result);
+ result = reduceNodes(node.modifiers, cbNodes, result);
+ result = reduceNode(node.name, cbNode, result);
+ result = reduceNode(node.moduleReference, cbNode, result);
+ break;
+ case 237:
result = reduceNodes(node.decorators, cbNodes, result);
result = reduceNodes(node.modifiers, cbNodes, result);
result = reduceNode(node.importClause, cbNode, result);
result = reduceNode(node.moduleSpecifier, cbNode, result);
break;
- case 236:
+ case 238:
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.namedBindings, cbNode, result);
break;
- case 237:
+ case 239:
result = reduceNode(node.name, cbNode, result);
break;
- case 238:
- case 242:
+ case 240:
+ case 244:
result = reduceNodes(node.elements, cbNodes, result);
break;
- case 239:
- case 243:
+ case 241:
+ case 245:
result = reduceNode(node.propertyName, cbNode, result);
result = reduceNode(node.name, cbNode, result);
break;
- case 240:
+ case 242:
result = ts.reduceLeft(node.decorators, cbNode, result);
result = ts.reduceLeft(node.modifiers, cbNode, result);
result = reduceNode(node.expression, cbNode, result);
break;
- case 241:
+ case 243:
result = ts.reduceLeft(node.decorators, cbNode, result);
result = ts.reduceLeft(node.modifiers, cbNode, result);
result = reduceNode(node.exportClause, cbNode, result);
result = reduceNode(node.moduleSpecifier, cbNode, result);
break;
- case 246:
+ case 247:
+ result = reduceNode(node.expression, cbNode, result);
+ break;
+ case 248:
result = reduceNode(node.openingElement, cbNode, result);
result = ts.reduceLeft(node.children, cbNode, result);
result = reduceNode(node.closingElement, cbNode, result);
break;
- case 247:
- case 248:
+ case 249:
+ case 250:
result = reduceNode(node.tagName, cbNode, result);
- result = reduceNodes(node.attributes, cbNodes, result);
+ result = reduceNode(node.attributes, cbNode, result);
break;
- case 249:
+ case 253:
+ result = reduceNodes(node.properties, cbNodes, result);
+ break;
+ case 251:
result = reduceNode(node.tagName, cbNode, result);
break;
- case 250:
+ case 252:
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 251:
+ case 254:
result = reduceNode(node.expression, cbNode, result);
break;
- case 252:
+ case 255:
result = reduceNode(node.expression, cbNode, result);
break;
- case 253:
+ case 256:
result = reduceNode(node.expression, cbNode, result);
- case 254:
+ case 257:
result = reduceNodes(node.statements, cbNodes, result);
break;
- case 255:
+ case 258:
result = reduceNodes(node.types, cbNodes, result);
break;
- case 256:
+ case 259:
result = reduceNode(node.variableDeclaration, cbNode, result);
result = reduceNode(node.block, cbNode, result);
break;
- case 257:
+ case 260:
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.initializer, cbNode, result);
break;
- case 258:
+ case 261:
result = reduceNode(node.name, cbNode, result);
result = reduceNode(node.objectAssignmentInitializer, cbNode, result);
break;
- case 259:
+ case 262:
result = reduceNode(node.expression, cbNode, result);
break;
- case 261:
+ case 263:
+ result = reduceNode(node.name, cbNode, result);
+ result = reduceNode(node.initializer, cbNode, result);
+ break;
+ case 264:
result = reduceNodes(node.statements, cbNodes, result);
break;
- case 294:
+ case 295:
result = reduceNode(node.expression, cbNode, result);
break;
default:
- var edgeTraversalPath = nodeEdgeTraversalMap[kind];
- if (edgeTraversalPath) {
- for (var _i = 0, edgeTraversalPath_1 = edgeTraversalPath; _i < edgeTraversalPath_1.length; _i++) {
- var edge = edgeTraversalPath_1[_i];
- var value = node[edge.name];
- if (value !== undefined) {
- result = ts.isArray(value)
- ? reduceNodes(value, cbNodes, result)
- : cbNode(result, value);
- }
- }
- }
break;
}
return result;
}
ts.reduceEachChild = reduceEachChild;
- function visitNode(node, visitor, test, optional, lift, parenthesize, parentNode) {
- if (node === undefined || visitor === undefined) {
- return node;
- }
- aggregateTransformFlags(node);
- var visited = visitor(node);
- if (visited === node) {
- return node;
- }
- var visitedNode;
- if (visited === undefined) {
- if (!optional) {
- Debug.failNotOptional();
- }
- return undefined;
- }
- else if (ts.isArray(visited)) {
- visitedNode = (lift || extractSingleNode)(visited);
- }
- else {
- visitedNode = visited;
- }
- if (parenthesize !== undefined) {
- visitedNode = parenthesize(visitedNode, parentNode);
- }
- Debug.assertNode(visitedNode, test);
- aggregateTransformFlags(visitedNode);
- return visitedNode;
- }
- ts.visitNode = visitNode;
- function visitNodes(nodes, visitor, test, start, count, parenthesize, parentNode) {
- if (nodes === undefined) {
- return undefined;
- }
- var updated;
- var length = nodes.length;
- if (start === undefined || start < 0) {
- start = 0;
- }
- if (count === undefined || count > length - start) {
- count = length - start;
- }
- if (start > 0 || count < length) {
- updated = ts.createNodeArray([], undefined, nodes.hasTrailingComma && start + count === length);
- }
- for (var i = 0; i < count; i++) {
- var node = nodes[i + start];
- aggregateTransformFlags(node);
- var visited = node !== undefined ? visitor(node) : undefined;
- if (updated !== undefined || visited === undefined || visited !== node) {
- if (updated === undefined) {
- updated = ts.createNodeArray(nodes.slice(0, i), nodes, nodes.hasTrailingComma);
- }
- if (visited) {
- if (ts.isArray(visited)) {
- for (var _i = 0, visited_1 = visited; _i < visited_1.length; _i++) {
- var visitedNode = visited_1[_i];
- visitedNode = parenthesize
- ? parenthesize(visitedNode, parentNode)
- : visitedNode;
- Debug.assertNode(visitedNode, test);
- aggregateTransformFlags(visitedNode);
- updated.push(visitedNode);
- }
- }
- else {
- var visitedNode = parenthesize
- ? parenthesize(visited, parentNode)
- : visited;
- Debug.assertNode(visitedNode, test);
- aggregateTransformFlags(visitedNode);
- updated.push(visitedNode);
- }
- }
- }
- }
- return updated || nodes;
- }
- ts.visitNodes = visitNodes;
- function visitLexicalEnvironment(statements, visitor, context, start, ensureUseStrict) {
- context.startLexicalEnvironment();
- statements = visitNodes(statements, visitor, ts.isStatement, start);
- if (ensureUseStrict && !ts.startsWithUseStrict(statements)) {
- statements = ts.createNodeArray([ts.createStatement(ts.createLiteral("use strict"))].concat(statements), statements);
- }
- var declarations = context.endLexicalEnvironment();
- return ts.createNodeArray(ts.concatenate(statements, declarations), statements);
- }
- ts.visitLexicalEnvironment = visitLexicalEnvironment;
- function visitParameterList(nodes, visitor, context) {
- context.startLexicalEnvironment();
- var updated = visitNodes(nodes, visitor, ts.isParameterDeclaration);
- context.suspendLexicalEnvironment();
- return updated;
- }
- ts.visitParameterList = visitParameterList;
- function visitFunctionBody(node, visitor, context) {
- context.resumeLexicalEnvironment();
- var updated = visitNode(node, visitor, ts.isConciseBody);
- var declarations = context.endLexicalEnvironment();
- if (ts.some(declarations)) {
- var block = ts.convertToFunctionBody(updated);
- var statements = mergeLexicalEnvironment(block.statements, declarations);
- return ts.updateBlock(block, statements);
- }
- return updated;
- }
- ts.visitFunctionBody = visitFunctionBody;
- function visitEachChild(node, visitor, context) {
- if (node === undefined) {
- return undefined;
- }
- var kind = node.kind;
- if ((kind > 0 && kind <= 140)) {
- return node;
- }
- if ((kind >= 156 && kind <= 171)) {
- return node;
- }
- switch (node.kind) {
- case 203:
- case 206:
- case 198:
- case 222:
- return node;
- case 142:
- return ts.updateComputedPropertyName(node, visitNode(node.expression, visitor, ts.isExpression));
- case 144:
- return ts.updateParameter(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), node.dotDotDotToken, visitNode(node.name, visitor, ts.isBindingName), visitNode(node.type, visitor, ts.isTypeNode, true), visitNode(node.initializer, visitor, ts.isExpression, true));
- case 147:
- return ts.updateProperty(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.type, visitor, ts.isTypeNode, true), visitNode(node.initializer, visitor, ts.isExpression, true));
- case 149:
- return ts.updateMethod(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context), visitNode(node.type, visitor, ts.isTypeNode, true), visitFunctionBody(node.body, visitor, context));
- case 150:
- return ts.updateConstructor(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitParameterList(node.parameters, visitor, context), visitFunctionBody(node.body, visitor, context));
- case 151:
- return ts.updateGetAccessor(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitParameterList(node.parameters, visitor, context), visitNode(node.type, visitor, ts.isTypeNode, true), visitFunctionBody(node.body, visitor, context));
- case 152:
- return ts.updateSetAccessor(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitParameterList(node.parameters, visitor, context), visitFunctionBody(node.body, visitor, context));
- case 172:
- return ts.updateObjectBindingPattern(node, visitNodes(node.elements, visitor, ts.isBindingElement));
- case 173:
- return ts.updateArrayBindingPattern(node, visitNodes(node.elements, visitor, ts.isArrayBindingElement));
- case 174:
- return ts.updateBindingElement(node, node.dotDotDotToken, visitNode(node.propertyName, visitor, ts.isPropertyName, true), visitNode(node.name, visitor, ts.isBindingName), visitNode(node.initializer, visitor, ts.isExpression, true));
- case 175:
- return ts.updateArrayLiteral(node, visitNodes(node.elements, visitor, ts.isExpression));
- case 176:
- return ts.updateObjectLiteral(node, visitNodes(node.properties, visitor, ts.isObjectLiteralElementLike));
- case 177:
- return ts.updatePropertyAccess(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.name, visitor, ts.isIdentifier));
- case 178:
- return ts.updateElementAccess(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.argumentExpression, visitor, ts.isExpression));
- case 179:
- return ts.updateCall(node, visitNode(node.expression, visitor, ts.isExpression), visitNodes(node.typeArguments, visitor, ts.isTypeNode), visitNodes(node.arguments, visitor, ts.isExpression));
- case 180:
- return ts.updateNew(node, visitNode(node.expression, visitor, ts.isExpression), visitNodes(node.typeArguments, visitor, ts.isTypeNode), visitNodes(node.arguments, visitor, ts.isExpression));
- case 181:
- return ts.updateTaggedTemplate(node, visitNode(node.tag, visitor, ts.isExpression), visitNode(node.template, visitor, ts.isTemplateLiteral));
- case 183:
- return ts.updateParen(node, visitNode(node.expression, visitor, ts.isExpression));
- case 184:
- return ts.updateFunctionExpression(node, visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context), visitNode(node.type, visitor, ts.isTypeNode, true), visitFunctionBody(node.body, visitor, context));
- case 185:
- return ts.updateArrowFunction(node, visitNodes(node.modifiers, visitor, ts.isModifier), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context), visitNode(node.type, visitor, ts.isTypeNode, true), visitFunctionBody(node.body, visitor, context));
- case 186:
- return ts.updateDelete(node, visitNode(node.expression, visitor, ts.isExpression));
- case 187:
- return ts.updateTypeOf(node, visitNode(node.expression, visitor, ts.isExpression));
- case 188:
- return ts.updateVoid(node, visitNode(node.expression, visitor, ts.isExpression));
- case 189:
- return ts.updateAwait(node, visitNode(node.expression, visitor, ts.isExpression));
- case 192:
- return ts.updateBinary(node, visitNode(node.left, visitor, ts.isExpression), visitNode(node.right, visitor, ts.isExpression));
- case 190:
- return ts.updatePrefix(node, visitNode(node.operand, visitor, ts.isExpression));
- case 191:
- return ts.updatePostfix(node, visitNode(node.operand, visitor, ts.isExpression));
- case 193:
- return ts.updateConditional(node, visitNode(node.condition, visitor, ts.isExpression), visitNode(node.whenTrue, visitor, ts.isExpression), visitNode(node.whenFalse, visitor, ts.isExpression));
- case 194:
- return ts.updateTemplateExpression(node, visitNode(node.head, visitor, ts.isTemplateHead), visitNodes(node.templateSpans, visitor, ts.isTemplateSpan));
- case 195:
- return ts.updateYield(node, visitNode(node.expression, visitor, ts.isExpression));
- case 196:
- return ts.updateSpread(node, visitNode(node.expression, visitor, ts.isExpression));
- case 197:
- return ts.updateClassExpression(node, visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier, true), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitNodes(node.heritageClauses, visitor, ts.isHeritageClause), visitNodes(node.members, visitor, ts.isClassElement));
- case 199:
- return ts.updateExpressionWithTypeArguments(node, visitNodes(node.typeArguments, visitor, ts.isTypeNode), visitNode(node.expression, visitor, ts.isExpression));
- case 202:
- return ts.updateTemplateSpan(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.literal, visitor, ts.isTemplateMiddleOrTemplateTail));
- case 204:
- return ts.updateBlock(node, visitNodes(node.statements, visitor, ts.isStatement));
- case 205:
- return ts.updateVariableStatement(node, visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.declarationList, visitor, ts.isVariableDeclarationList));
- case 207:
- return ts.updateStatement(node, visitNode(node.expression, visitor, ts.isExpression));
- case 208:
- return ts.updateIf(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.thenStatement, visitor, ts.isStatement, false, liftToBlock), visitNode(node.elseStatement, visitor, ts.isStatement, true, liftToBlock));
- case 209:
- return ts.updateDo(node, visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock), visitNode(node.expression, visitor, ts.isExpression));
- case 210:
- return ts.updateWhile(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 211:
- return ts.updateFor(node, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.condition, visitor, ts.isExpression), visitNode(node.incrementor, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 212:
- return ts.updateForIn(node, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 213:
- return ts.updateForOf(node, visitNode(node.initializer, visitor, ts.isForInitializer), visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 214:
- return ts.updateContinue(node, visitNode(node.label, visitor, ts.isIdentifier, true));
- case 215:
- return ts.updateBreak(node, visitNode(node.label, visitor, ts.isIdentifier, true));
- case 216:
- return ts.updateReturn(node, visitNode(node.expression, visitor, ts.isExpression, true));
- case 217:
- return ts.updateWith(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 218:
- return ts.updateSwitch(node, visitNode(node.expression, visitor, ts.isExpression), visitNode(node.caseBlock, visitor, ts.isCaseBlock));
- case 219:
- return ts.updateLabel(node, visitNode(node.label, visitor, ts.isIdentifier), visitNode(node.statement, visitor, ts.isStatement, false, liftToBlock));
- case 220:
- return ts.updateThrow(node, visitNode(node.expression, visitor, ts.isExpression));
- case 221:
- return ts.updateTry(node, visitNode(node.tryBlock, visitor, ts.isBlock), visitNode(node.catchClause, visitor, ts.isCatchClause, true), visitNode(node.finallyBlock, visitor, ts.isBlock, true));
- case 223:
- return ts.updateVariableDeclaration(node, visitNode(node.name, visitor, ts.isBindingName), visitNode(node.type, visitor, ts.isTypeNode, true), visitNode(node.initializer, visitor, ts.isExpression, true));
- case 224:
- return ts.updateVariableDeclarationList(node, visitNodes(node.declarations, visitor, ts.isVariableDeclaration));
- case 225:
- return ts.updateFunctionDeclaration(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isPropertyName), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitParameterList(node.parameters, visitor, context), visitNode(node.type, visitor, ts.isTypeNode, true), visitFunctionBody(node.body, visitor, context));
- case 226:
- return ts.updateClassDeclaration(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.name, visitor, ts.isIdentifier, true), visitNodes(node.typeParameters, visitor, ts.isTypeParameter), visitNodes(node.heritageClauses, visitor, ts.isHeritageClause), visitNodes(node.members, visitor, ts.isClassElement));
- case 232:
- return ts.updateCaseBlock(node, visitNodes(node.clauses, visitor, ts.isCaseOrDefaultClause));
- case 235:
- return ts.updateImportDeclaration(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.importClause, visitor, ts.isImportClause, true), visitNode(node.moduleSpecifier, visitor, ts.isExpression));
- case 236:
- return ts.updateImportClause(node, visitNode(node.name, visitor, ts.isIdentifier, true), visitNode(node.namedBindings, visitor, ts.isNamedImportBindings, true));
- case 237:
- return ts.updateNamespaceImport(node, visitNode(node.name, visitor, ts.isIdentifier));
- case 238:
- return ts.updateNamedImports(node, visitNodes(node.elements, visitor, ts.isImportSpecifier));
- case 239:
- return ts.updateImportSpecifier(node, visitNode(node.propertyName, visitor, ts.isIdentifier, true), visitNode(node.name, visitor, ts.isIdentifier));
- case 240:
- return ts.updateExportAssignment(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.expression, visitor, ts.isExpression));
- case 241:
- return ts.updateExportDeclaration(node, visitNodes(node.decorators, visitor, ts.isDecorator), visitNodes(node.modifiers, visitor, ts.isModifier), visitNode(node.exportClause, visitor, ts.isNamedExports, true), visitNode(node.moduleSpecifier, visitor, ts.isExpression, true));
- case 242:
- return ts.updateNamedExports(node, visitNodes(node.elements, visitor, ts.isExportSpecifier));
- case 243:
- return ts.updateExportSpecifier(node, visitNode(node.propertyName, visitor, ts.isIdentifier, true), visitNode(node.name, visitor, ts.isIdentifier));
- case 246:
- return ts.updateJsxElement(node, visitNode(node.openingElement, visitor, ts.isJsxOpeningElement), visitNodes(node.children, visitor, ts.isJsxChild), visitNode(node.closingElement, visitor, ts.isJsxClosingElement));
- case 247:
- return ts.updateJsxSelfClosingElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression), visitNodes(node.attributes, visitor, ts.isJsxAttributeLike));
- case 248:
- return ts.updateJsxOpeningElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression), visitNodes(node.attributes, visitor, ts.isJsxAttributeLike));
- case 249:
- return ts.updateJsxClosingElement(node, visitNode(node.tagName, visitor, ts.isJsxTagNameExpression));
- case 250:
- return ts.updateJsxAttribute(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.initializer, visitor, ts.isStringLiteralOrJsxExpression));
- case 251:
- return ts.updateJsxSpreadAttribute(node, visitNode(node.expression, visitor, ts.isExpression));
- case 252:
- return ts.updateJsxExpression(node, visitNode(node.expression, visitor, ts.isExpression));
- case 253:
- return ts.updateCaseClause(node, visitNode(node.expression, visitor, ts.isExpression), visitNodes(node.statements, visitor, ts.isStatement));
- case 254:
- return ts.updateDefaultClause(node, visitNodes(node.statements, visitor, ts.isStatement));
- case 255:
- return ts.updateHeritageClause(node, visitNodes(node.types, visitor, ts.isExpressionWithTypeArguments));
- case 256:
- return ts.updateCatchClause(node, visitNode(node.variableDeclaration, visitor, ts.isVariableDeclaration), visitNode(node.block, visitor, ts.isBlock));
- case 257:
- return ts.updatePropertyAssignment(node, visitNode(node.name, visitor, ts.isPropertyName), visitNode(node.initializer, visitor, ts.isExpression));
- case 258:
- return ts.updateShorthandPropertyAssignment(node, visitNode(node.name, visitor, ts.isIdentifier), visitNode(node.objectAssignmentInitializer, visitor, ts.isExpression));
- case 259:
- return ts.updateSpreadAssignment(node, visitNode(node.expression, visitor, ts.isExpression));
- case 261:
- return ts.updateSourceFileNode(node, visitLexicalEnvironment(node.statements, visitor, context));
- case 294:
- return ts.updatePartiallyEmittedExpression(node, visitNode(node.expression, visitor, ts.isExpression));
- default:
- var updated = void 0;
- var edgeTraversalPath = nodeEdgeTraversalMap[kind];
- if (edgeTraversalPath) {
- for (var _i = 0, edgeTraversalPath_2 = edgeTraversalPath; _i < edgeTraversalPath_2.length; _i++) {
- var edge = edgeTraversalPath_2[_i];
- var value = node[edge.name];
- if (value !== undefined) {
- var visited = ts.isArray(value)
- ? visitNodes(value, visitor, edge.test, 0, value.length, edge.parenthesize, node)
- : visitNode(value, visitor, edge.test, edge.optional, edge.lift, edge.parenthesize, node);
- if (updated !== undefined || visited !== value) {
- if (updated === undefined) {
- updated = ts.getMutableClone(node);
- }
- if (visited !== value) {
- updated[edge.name] = visited;
- }
- }
- }
- }
- }
- return updated ? ts.updateNode(updated, node) : node;
- }
- }
- ts.visitEachChild = visitEachChild;
function mergeLexicalEnvironment(statements, declarations) {
if (!ts.some(declarations)) {
return statements;
}
return ts.isNodeArray(statements)
- ? ts.createNodeArray(ts.concatenate(statements, declarations), statements)
+ ? ts.setTextRange(ts.createNodeArray(ts.concatenate(statements, declarations)), statements)
: ts.addRange(statements, declarations);
}
ts.mergeLexicalEnvironment = mergeLexicalEnvironment;
- function mergeFunctionBodyLexicalEnvironment(body, declarations) {
- if (body && declarations !== undefined && declarations.length > 0) {
- if (ts.isBlock(body)) {
- return ts.updateBlock(body, ts.createNodeArray(ts.concatenate(body.statements, declarations), body.statements));
- }
- else {
- return ts.createBlock(ts.createNodeArray([ts.createReturn(body, body)].concat(declarations), body), body, true);
- }
- }
- return body;
- }
- ts.mergeFunctionBodyLexicalEnvironment = mergeFunctionBodyLexicalEnvironment;
function liftToBlock(nodes) {
Debug.assert(ts.every(nodes, ts.isStatement), "Cannot lift nodes to a Block.");
return ts.singleOrUndefined(nodes) || ts.createBlock(nodes);
}
ts.liftToBlock = liftToBlock;
- function extractSingleNode(nodes) {
- Debug.assert(nodes.length <= 1, "Too many nodes written to output.");
- return ts.singleOrUndefined(nodes);
- }
function aggregateTransformFlags(node) {
aggregateTransformFlagsForNode(node);
return node;
@@ -36994,7 +40098,7 @@ var ts;
return subtreeFlags;
}
function aggregateTransformFlagsForSubtree(node) {
- if (ts.hasModifier(node, 2) || ts.isTypeNode(node)) {
+ if (ts.hasModifier(node, 2) || (ts.isTypeNode(node) && node.kind !== 200)) {
return 0;
}
return reduceEachChild(node, 0, aggregateTransformFlagsForChildNode, aggregateTransformFlagsForChildNodes);
@@ -37007,9 +40111,6 @@ var ts;
}
var Debug;
(function (Debug) {
- Debug.failNotOptional = Debug.shouldAssert(1)
- ? function (message) { return Debug.assert(false, message || "Node not optional."); }
- : ts.noop;
Debug.failBadSyntaxKind = Debug.shouldAssert(1)
? function (node, message) { return Debug.assert(false, message || "Unexpected node.", function () { return "Node " + ts.formatSyntaxKind(node.kind) + " was unexpected."; }); }
: ts.noop;
@@ -37042,7 +40143,6 @@ var ts;
}
}
})(Debug = ts.Debug || (ts.Debug = {}));
- var _a;
})(ts || (ts = {}));
var ts;
(function (ts) {
@@ -37051,7 +40151,7 @@ var ts;
var value;
if (ts.isDestructuringAssignment(node)) {
value = node.right;
- while (ts.isEmptyObjectLiteralOrArrayLiteral(node.left)) {
+ while (ts.isEmptyArrayLiteral(node.left) || ts.isEmptyObjectLiteral(node.left)) {
if (ts.isDestructuringAssignment(value)) {
location = node = value;
value = node.right;
@@ -37065,6 +40165,7 @@ var ts;
var flattenContext = {
context: context,
level: level,
+ downlevelIteration: context.getCompilerOptions().downlevelIteration,
hoistTempVariables: true,
emitExpression: emitExpression,
emitBindingOrAssignment: emitBindingOrAssignment,
@@ -37099,7 +40200,7 @@ var ts;
ts.Debug.assertNode(target, createAssignmentCallback ? ts.isIdentifier : ts.isExpression);
var expression = createAssignmentCallback
? createAssignmentCallback(target, value, location)
- : ts.createAssignment(ts.visitNode(target, visitor, ts.isExpression), value, location);
+ : ts.setTextRange(ts.createAssignment(ts.visitNode(target, visitor, ts.isExpression), value), location);
expression.original = original;
emitExpression(expression);
}
@@ -37112,6 +40213,7 @@ var ts;
var flattenContext = {
context: context,
level: level,
+ downlevelIteration: context.getCompilerOptions().downlevelIteration,
hoistTempVariables: hoistTempVariables,
emitExpression: emitExpression,
emitBindingOrAssignment: emitBindingOrAssignment,
@@ -37137,10 +40239,11 @@ var ts;
}
}
for (var _i = 0, pendingDeclarations_1 = pendingDeclarations; _i < pendingDeclarations_1.length; _i++) {
- var _a = pendingDeclarations_1[_i], pendingExpressions_1 = _a.pendingExpressions, name_29 = _a.name, value = _a.value, location_2 = _a.location, original = _a.original;
- var variable = ts.createVariableDeclaration(name_29, undefined, pendingExpressions_1 ? ts.inlineExpressions(ts.append(pendingExpressions_1, value)) : value, location_2);
+ var _a = pendingDeclarations_1[_i], pendingExpressions_1 = _a.pendingExpressions, name = _a.name, value = _a.value, location = _a.location, original = _a.original;
+ var variable = ts.createVariableDeclaration(name, undefined, pendingExpressions_1 ? ts.inlineExpressions(ts.append(pendingExpressions_1, value)) : value);
variable.original = original;
- if (ts.isIdentifier(name_29)) {
+ ts.setTextRange(variable, location);
+ if (ts.isIdentifier(name)) {
ts.setEmitFlags(variable, 64);
}
ts.aggregateTransformFlags(variable);
@@ -37228,7 +40331,12 @@ var ts;
function flattenArrayBindingOrAssignmentPattern(flattenContext, parent, pattern, value, location) {
var elements = ts.getElementsOfBindingOrAssignmentPattern(pattern);
var numElements = elements.length;
- if (numElements !== 1 && (flattenContext.level < 1 || numElements === 0)) {
+ if (flattenContext.level < 1 && flattenContext.downlevelIteration) {
+ value = ensureIdentifier(flattenContext, ts.createReadHelper(flattenContext.context, value, numElements > 0 && ts.getRestIndicatorOfBindingOrAssignmentElement(elements[numElements - 1])
+ ? undefined
+ : numElements, location), false, location);
+ }
+ else if (numElements !== 1 && (flattenContext.level < 1 || numElements === 0)) {
var reuseIdentifierExpressions = !ts.isDeclarationBindingElement(parent) || numElements !== 0;
value = ensureIdentifier(flattenContext, value, reuseIdentifierExpressions, location);
}
@@ -37286,8 +40394,8 @@ var ts;
return ts.createElementAccess(value, argumentExpression);
}
else {
- var name_30 = ts.createIdentifier(ts.unescapeIdentifier(propertyName.text));
- return ts.createPropertyAccess(value, name_30);
+ var name = ts.createIdentifier(ts.unescapeIdentifier(propertyName.text));
+ return ts.createPropertyAccess(value, name);
}
}
function ensureIdentifier(flattenContext, value, reuseIdentifierExpressions, location) {
@@ -37298,7 +40406,7 @@ var ts;
var temp = ts.createTempVariable(undefined);
if (flattenContext.hoistTempVariables) {
flattenContext.context.hoistVariableDeclaration(temp);
- flattenContext.emitExpression(ts.createAssignment(temp, value, location));
+ flattenContext.emitExpression(ts.setTextRange(ts.createAssignment(temp, value), location));
}
else {
flattenContext.emitBindingOrAssignment(temp, value, location, undefined);
@@ -37329,7 +40437,7 @@ var ts;
var restHelper = {
name: "typescript:rest",
scoped: false,
- text: "\n var __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)\n t[p[i]] = s[p[i]];\n return t;\n };"
+ text: "\n var __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)\n t[p[i]] = s[p[i]];\n return t;\n };"
};
function createRestCall(context, value, elements, computedTempVariables, location) {
context.requestEmitHelper(restHelper);
@@ -37348,7 +40456,10 @@ var ts;
}
}
}
- return ts.createCall(ts.getHelperName("__rest"), undefined, [value, ts.createArrayLiteral(propertyNames, location)]);
+ return ts.createCall(ts.getHelperName("__rest"), undefined, [
+ value,
+ ts.setTextRange(ts.createArrayLiteral(propertyNames), location)
+ ]);
}
})(ts || (ts = {}));
var ts;
@@ -37364,8 +40475,8 @@ var ts;
var previousOnSubstituteNode = context.onSubstituteNode;
context.onEmitNode = onEmitNode;
context.onSubstituteNode = onSubstituteNode;
- context.enableSubstitution(177);
context.enableSubstitution(178);
+ context.enableSubstitution(179);
var currentSourceFile;
var currentNamespace;
var currentNamespaceContainerName;
@@ -37398,15 +40509,15 @@ var ts;
}
function onBeforeVisitNode(node) {
switch (node.kind) {
- case 261:
- case 232:
- case 231:
- case 204:
+ case 264:
+ case 234:
+ case 233:
+ case 206:
currentScope = node;
currentScopeFirstDeclarationsOfName = undefined;
break;
- case 226:
- case 225:
+ case 228:
+ case 227:
if (ts.hasModifier(node, 2)) {
break;
}
@@ -37431,13 +40542,13 @@ var ts;
}
function sourceElementVisitorWorker(node) {
switch (node.kind) {
- case 235:
+ case 237:
return visitImportDeclaration(node);
- case 234:
+ case 236:
return visitImportEqualsDeclaration(node);
- case 240:
+ case 242:
return visitExportAssignment(node);
- case 241:
+ case 243:
return visitExportDeclaration(node);
default:
return visitorWorker(node);
@@ -37447,11 +40558,11 @@ var ts;
return saveStateAndInvoke(node, namespaceElementVisitorWorker);
}
function namespaceElementVisitorWorker(node) {
- if (node.kind === 241 ||
- node.kind === 235 ||
- node.kind === 236 ||
- (node.kind === 234 &&
- node.moduleReference.kind === 245)) {
+ if (node.kind === 243 ||
+ node.kind === 237 ||
+ node.kind === 238 ||
+ (node.kind === 236 &&
+ node.moduleReference.kind === 247)) {
return undefined;
}
else if (node.transformFlags & 1 || ts.hasModifier(node, 1)) {
@@ -37467,15 +40578,15 @@ var ts;
}
function classElementVisitorWorker(node) {
switch (node.kind) {
- case 150:
- return undefined;
- case 147:
- case 155:
case 151:
+ return undefined;
+ case 148:
+ case 156:
case 152:
- case 149:
+ case 153:
+ case 150:
return visitorWorker(node);
- case 203:
+ case 205:
return node;
default:
ts.Debug.failBadSyntaxKind(node);
@@ -37506,23 +40617,22 @@ var ts;
case 75:
case 123:
case 130:
- case 162:
case 163:
- case 161:
- case 156:
- case 143:
+ case 164:
+ case 162:
+ case 157:
+ case 144:
case 118:
case 121:
- case 134:
+ case 135:
case 132:
case 129:
case 104:
- case 135:
+ case 136:
+ case 160:
case 159:
+ case 161:
case 158:
- case 160:
- case 157:
- case 164:
case 165:
case 166:
case 167:
@@ -37530,56 +40640,58 @@ var ts;
case 169:
case 170:
case 171:
- case 155:
- case 145:
- case 228:
- case 147:
- case 150:
+ case 172:
+ case 156:
+ case 146:
+ case 230:
+ case 148:
+ return undefined;
+ case 151:
return visitConstructor(node);
- case 227:
+ case 229:
return ts.createNotEmittedStatement(node);
- case 226:
+ case 228:
return visitClassDeclaration(node);
- case 197:
+ case 198:
return visitClassExpression(node);
- case 255:
+ case 258:
return visitHeritageClause(node);
- case 199:
+ case 200:
return visitExpressionWithTypeArguments(node);
- case 149:
+ case 150:
return visitMethodDeclaration(node);
- case 151:
- return visitGetAccessor(node);
case 152:
+ return visitGetAccessor(node);
+ case 153:
return visitSetAccessor(node);
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 184:
- return visitFunctionExpression(node);
case 185:
+ return visitFunctionExpression(node);
+ case 186:
return visitArrowFunction(node);
- case 144:
+ case 145:
return visitParameter(node);
- case 183:
+ case 184:
return visitParenthesizedExpression(node);
- case 182:
- case 200:
+ case 183:
+ case 201:
return visitAssertionExpression(node);
- case 179:
- return visitCallExpression(node);
case 180:
+ return visitCallExpression(node);
+ case 181:
return visitNewExpression(node);
- case 201:
+ case 202:
return visitNonNullExpression(node);
- case 229:
+ case 231:
return visitEnumDeclaration(node);
- case 205:
+ case 207:
return visitVariableStatement(node);
- case 223:
+ case 225:
return visitVariableDeclaration(node);
- case 230:
+ case 232:
return visitModuleDeclaration(node);
- case 234:
+ case 236:
return visitImportEqualsDeclaration(node);
default:
ts.Debug.failBadSyntaxKind(node);
@@ -37587,7 +40699,8 @@ var ts;
}
}
function visitSourceFile(node) {
- var alwaysStrict = compilerOptions.alwaysStrict && !(ts.isExternalModule(node) && moduleKind === ts.ModuleKind.ES2015);
+ var alwaysStrict = (compilerOptions.alwaysStrict === undefined ? compilerOptions.strict : compilerOptions.alwaysStrict) &&
+ !(ts.isExternalModule(node) && moduleKind === ts.ModuleKind.ES2015);
return ts.updateSourceFileNode(node, ts.visitLexicalEnvironment(node.statements, sourceElementVisitor, context, 0, alwaysStrict));
}
function shouldEmitDecorateCallForClass(node) {
@@ -37639,11 +40752,12 @@ var ts;
return ts.singleOrMany(statements);
}
function createClassDeclarationHeadWithoutDecorators(node, name, hasExtendsClause, hasStaticProperties) {
- var classDeclaration = ts.createClassDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), name, undefined, ts.visitNodes(node.heritageClauses, visitor, ts.isHeritageClause), transformClassMembers(node, hasExtendsClause), node);
+ var classDeclaration = ts.createClassDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), name, undefined, ts.visitNodes(node.heritageClauses, visitor, ts.isHeritageClause), transformClassMembers(node, hasExtendsClause));
var emitFlags = ts.getEmitFlags(node);
if (hasStaticProperties) {
emitFlags |= 32;
}
+ ts.setTextRange(classDeclaration, node);
ts.setOriginalNode(classDeclaration, node);
ts.setEmitFlags(classDeclaration, emitFlags);
return classDeclaration;
@@ -37654,10 +40768,14 @@ var ts;
var declName = ts.getLocalName(node, false, true);
var heritageClauses = ts.visitNodes(node.heritageClauses, visitor, ts.isHeritageClause);
var members = transformClassMembers(node, hasExtendsClause);
- var classExpression = ts.createClassExpression(undefined, name, undefined, heritageClauses, members, location);
+ var classExpression = ts.createClassExpression(undefined, name, undefined, heritageClauses, members);
ts.setOriginalNode(classExpression, node);
- var statement = ts.createLetStatement(declName, classAlias ? ts.createAssignment(classAlias, classExpression) : classExpression, location);
+ ts.setTextRange(classExpression, location);
+ var statement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ ts.createVariableDeclaration(declName, undefined, classAlias ? ts.createAssignment(classAlias, classExpression) : classExpression)
+ ], 1));
ts.setOriginalNode(statement, node);
+ ts.setTextRange(statement, location);
ts.setCommentRange(statement, node);
return statement;
}
@@ -37665,7 +40783,9 @@ var ts;
var staticProperties = getInitializedProperties(node, true);
var heritageClauses = ts.visitNodes(node.heritageClauses, visitor, ts.isHeritageClause);
var members = transformClassMembers(node, ts.some(heritageClauses, function (c) { return c.token === 84; }));
- var classExpression = ts.setOriginalNode(ts.createClassExpression(undefined, node.name, undefined, heritageClauses, members, node), node);
+ var classExpression = ts.createClassExpression(undefined, node.name, undefined, heritageClauses, members);
+ ts.setOriginalNode(classExpression, node);
+ ts.setTextRange(classExpression, node);
if (staticProperties.length > 0) {
var expressions = [];
var temp = ts.createTempVariable(hoistVariableDeclaration);
@@ -37688,7 +40808,7 @@ var ts;
members.push(constructor);
}
ts.addRange(members, ts.visitNodes(node.members, classElementVisitor, ts.isClassElement));
- return ts.createNodeArray(members, node.members);
+ return ts.setTextRange(ts.createNodeArray(members), node.members);
}
function transformConstructor(node, hasExtendsClause) {
var hasInstancePropertyWithInitializer = ts.forEach(node.members, isInstanceInitializedProperty);
@@ -37699,7 +40819,7 @@ var ts;
}
var parameters = transformConstructorParameters(constructor);
var body = transformConstructorBody(node, constructor, hasExtendsClause);
- return ts.startOnNewLine(ts.setOriginalNode(ts.createConstructor(undefined, undefined, parameters, body, constructor || node), constructor));
+ return ts.startOnNewLine(ts.setOriginalNode(ts.setTextRange(ts.createConstructor(undefined, undefined, parameters, body), constructor || node), constructor));
}
function transformConstructorParameters(constructor) {
return ts.visitParameterList(constructor && constructor.parameters, visitor, context)
@@ -37722,18 +40842,18 @@ var ts;
if (constructor) {
ts.addRange(statements, ts.visitNodes(constructor.body.statements, visitor, ts.isStatement, indexOfFirstStatement));
}
- ts.addRange(statements, endLexicalEnvironment());
- return ts.createBlock(ts.createNodeArray(statements, constructor ? constructor.body.statements : node.members), constructor ? constructor.body : undefined, true);
+ statements = ts.mergeLexicalEnvironment(statements, endLexicalEnvironment());
+ return ts.setTextRange(ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), constructor ? constructor.body.statements : node.members), true), constructor ? constructor.body : undefined);
}
function addPrologueDirectivesAndInitialSuperCall(ctor, result) {
if (ctor.body) {
var statements = ctor.body.statements;
- var index = ts.addPrologueDirectives(result, statements, false, visitor);
+ var index = ts.addPrologue(result, statements, false, visitor);
if (index === statements.length) {
return index;
}
var statement = statements[index];
- if (statement.kind === 207 && ts.isSuperCall(statement.expression)) {
+ if (statement.kind === 209 && ts.isSuperCall(statement.expression)) {
result.push(ts.visitNode(statement, visitor, ts.isStatement));
return index + 1;
}
@@ -37755,7 +40875,7 @@ var ts;
ts.setEmitFlags(propertyName, 1536 | 48);
var localName = ts.getMutableClone(name);
ts.setEmitFlags(localName, 1536);
- return ts.startOnNewLine(ts.createStatement(ts.createAssignment(ts.createPropertyAccess(ts.createThis(), propertyName, node.name), localName), ts.moveRangePos(node, -1)));
+ return ts.startOnNewLine(ts.setTextRange(ts.createStatement(ts.createAssignment(ts.setTextRange(ts.createPropertyAccess(ts.createThis(), propertyName), node.name), localName)), ts.moveRangePos(node, -1)));
}
function getInitializedProperties(node, isStatic) {
return ts.filter(node.members, isStatic ? isStaticInitializedProperty : isInstanceInitializedProperty);
@@ -37767,13 +40887,13 @@ var ts;
return isInitializedProperty(member, false);
}
function isInitializedProperty(member, isStatic) {
- return member.kind === 147
+ return member.kind === 148
&& isStatic === ts.hasModifier(member, 32)
&& member.initializer !== undefined;
}
function addInitializedPropertyStatements(statements, properties, receiver) {
- for (var _i = 0, properties_7 = properties; _i < properties_7.length; _i++) {
- var property = properties_7[_i];
+ for (var _i = 0, properties_9 = properties; _i < properties_9.length; _i++) {
+ var property = properties_9[_i];
var statement = ts.createStatement(transformInitializedProperty(property, receiver));
ts.setSourceMapRange(statement, ts.moveRangePastModifiers(property));
ts.setCommentRange(statement, property);
@@ -37782,8 +40902,8 @@ var ts;
}
function generateInitializedPropertyExpressions(properties, receiver) {
var expressions = [];
- for (var _i = 0, properties_8 = properties; _i < properties_8.length; _i++) {
- var property = properties_8[_i];
+ for (var _i = 0, properties_10 = properties; _i < properties_10.length; _i++) {
+ var property = properties_10[_i];
var expression = transformInitializedProperty(property, receiver);
expression.startsOnNewLine = true;
ts.setSourceMapRange(expression, ts.moveRangePastModifiers(property));
@@ -37840,12 +40960,12 @@ var ts;
}
function getAllDecoratorsOfClassElement(node, member) {
switch (member.kind) {
- case 151:
case 152:
+ case 153:
return getAllDecoratorsOfAccessors(node, member);
- case 149:
+ case 150:
return getAllDecoratorsOfMethod(member);
- case 147:
+ case 148:
return getAllDecoratorsOfProperty(member);
default:
return undefined;
@@ -37856,10 +40976,11 @@ var ts;
return undefined;
}
var _a = ts.getAllAccessorDeclarations(node.members, accessor), firstAccessor = _a.firstAccessor, secondAccessor = _a.secondAccessor, setAccessor = _a.setAccessor;
- if (accessor !== firstAccessor) {
+ var firstAccessorWithDecorators = firstAccessor.decorators ? firstAccessor : secondAccessor && secondAccessor.decorators ? secondAccessor : undefined;
+ if (!firstAccessorWithDecorators || accessor !== firstAccessorWithDecorators) {
return undefined;
}
- var decorators = firstAccessor.decorators || (secondAccessor && secondAccessor.decorators);
+ var decorators = firstAccessorWithDecorators.decorators;
var parameters = getDecoratorsOfParameters(setAccessor);
if (!decorators && !parameters) {
return undefined;
@@ -37884,14 +41005,14 @@ var ts;
}
return { decorators: decorators };
}
- function transformAllDecoratorsOfDeclaration(node, allDecorators) {
+ function transformAllDecoratorsOfDeclaration(node, container, allDecorators) {
if (!allDecorators) {
return undefined;
}
var decoratorExpressions = [];
ts.addRange(decoratorExpressions, ts.map(allDecorators.decorators, transformDecorator));
ts.addRange(decoratorExpressions, ts.flatMap(allDecorators.parameters, transformDecoratorsOfParameter));
- addTypeMetadata(node, decoratorExpressions);
+ addTypeMetadata(node, container, decoratorExpressions);
return decoratorExpressions;
}
function addClassElementDecorationStatements(statements, node, isStatic) {
@@ -37916,14 +41037,14 @@ var ts;
}
function generateClassElementDecorationExpression(node, member) {
var allDecorators = getAllDecoratorsOfClassElement(node, member);
- var decoratorExpressions = transformAllDecoratorsOfDeclaration(member, allDecorators);
+ var decoratorExpressions = transformAllDecoratorsOfDeclaration(member, node, allDecorators);
if (!decoratorExpressions) {
return undefined;
}
var prefix = getClassMemberPrefix(node, member);
var memberName = getExpressionForPropertyName(member, true);
var descriptor = languageVersion > 0
- ? member.kind === 147
+ ? member.kind === 148
? ts.createVoidZero()
: ts.createNull()
: undefined;
@@ -37939,7 +41060,7 @@ var ts;
}
function generateConstructorDecorationExpression(node) {
var allDecorators = getAllDecoratorsOfConstructor(node);
- var decoratorExpressions = transformAllDecoratorsOfDeclaration(node, allDecorators);
+ var decoratorExpressions = transformAllDecoratorsOfDeclaration(node, node, allDecorators);
if (!decoratorExpressions) {
return undefined;
}
@@ -37967,90 +41088,83 @@ var ts;
}
return expressions;
}
- function addTypeMetadata(node, decoratorExpressions) {
+ function addTypeMetadata(node, container, decoratorExpressions) {
if (USE_NEW_TYPE_METADATA_FORMAT) {
- addNewTypeMetadata(node, decoratorExpressions);
+ addNewTypeMetadata(node, container, decoratorExpressions);
}
else {
- addOldTypeMetadata(node, decoratorExpressions);
+ addOldTypeMetadata(node, container, decoratorExpressions);
}
}
- function addOldTypeMetadata(node, decoratorExpressions) {
+ function addOldTypeMetadata(node, container, decoratorExpressions) {
if (compilerOptions.emitDecoratorMetadata) {
if (shouldAddTypeMetadata(node)) {
decoratorExpressions.push(createMetadataHelper(context, "design:type", serializeTypeOfNode(node)));
}
if (shouldAddParamTypesMetadata(node)) {
- decoratorExpressions.push(createMetadataHelper(context, "design:paramtypes", serializeParameterTypesOfNode(node)));
+ decoratorExpressions.push(createMetadataHelper(context, "design:paramtypes", serializeParameterTypesOfNode(node, container)));
}
if (shouldAddReturnTypeMetadata(node)) {
decoratorExpressions.push(createMetadataHelper(context, "design:returntype", serializeReturnTypeOfNode(node)));
}
}
}
- function addNewTypeMetadata(node, decoratorExpressions) {
+ function addNewTypeMetadata(node, container, decoratorExpressions) {
if (compilerOptions.emitDecoratorMetadata) {
var properties = void 0;
if (shouldAddTypeMetadata(node)) {
(properties || (properties = [])).push(ts.createPropertyAssignment("type", ts.createArrowFunction(undefined, undefined, [], undefined, ts.createToken(35), serializeTypeOfNode(node))));
}
if (shouldAddParamTypesMetadata(node)) {
- (properties || (properties = [])).push(ts.createPropertyAssignment("paramTypes", ts.createArrowFunction(undefined, undefined, [], undefined, ts.createToken(35), serializeParameterTypesOfNode(node))));
+ (properties || (properties = [])).push(ts.createPropertyAssignment("paramTypes", ts.createArrowFunction(undefined, undefined, [], undefined, ts.createToken(35), serializeParameterTypesOfNode(node, container))));
}
if (shouldAddReturnTypeMetadata(node)) {
(properties || (properties = [])).push(ts.createPropertyAssignment("returnType", ts.createArrowFunction(undefined, undefined, [], undefined, ts.createToken(35), serializeReturnTypeOfNode(node))));
}
if (properties) {
- decoratorExpressions.push(createMetadataHelper(context, "design:typeinfo", ts.createObjectLiteral(properties, undefined, true)));
+ decoratorExpressions.push(createMetadataHelper(context, "design:typeinfo", ts.createObjectLiteral(properties, true)));
}
}
}
function shouldAddTypeMetadata(node) {
var kind = node.kind;
- return kind === 149
- || kind === 151
+ return kind === 150
|| kind === 152
- || kind === 147;
+ || kind === 153
+ || kind === 148;
}
function shouldAddReturnTypeMetadata(node) {
- return node.kind === 149;
+ return node.kind === 150;
}
function shouldAddParamTypesMetadata(node) {
- var kind = node.kind;
- return kind === 226
- || kind === 197
- || kind === 149
- || kind === 151
- || kind === 152;
+ switch (node.kind) {
+ case 228:
+ case 198:
+ return ts.getFirstConstructorWithBody(node) !== undefined;
+ case 150:
+ case 152:
+ case 153:
+ return true;
+ }
+ return false;
}
function serializeTypeOfNode(node) {
switch (node.kind) {
- case 147:
- case 144:
- case 151:
- return serializeTypeNode(node.type);
+ case 148:
+ case 145:
case 152:
+ return serializeTypeNode(node.type);
+ case 153:
return serializeTypeNode(ts.getSetAccessorTypeAnnotationNode(node));
- case 226:
- case 197:
- case 149:
+ case 228:
+ case 198:
+ case 150:
return ts.createIdentifier("Function");
default:
return ts.createVoidZero();
}
}
- function getRestParameterElementType(node) {
- if (node && node.kind === 162) {
- return node.elementType;
- }
- else if (node && node.kind === 157) {
- return ts.singleOrUndefined(node.typeArguments);
- }
- else {
- return undefined;
- }
- }
- function serializeParameterTypesOfNode(node) {
+ function serializeParameterTypesOfNode(node, container) {
var valueDeclaration = ts.isClassLike(node)
? ts.getFirstConstructorWithBody(node)
: ts.isFunctionLike(node) && ts.nodeIsPresent(node.body)
@@ -38058,7 +41172,7 @@ var ts;
: undefined;
var expressions = [];
if (valueDeclaration) {
- var parameters = valueDeclaration.parameters;
+ var parameters = getParametersOfDecoratedDeclaration(valueDeclaration, container);
var numParameters = parameters.length;
for (var i = 0; i < numParameters; i++) {
var parameter = parameters[i];
@@ -38066,7 +41180,7 @@ var ts;
continue;
}
if (parameter.dotDotDotToken) {
- expressions.push(serializeTypeNode(getRestParameterElementType(parameter.type)));
+ expressions.push(serializeTypeNode(ts.getRestParameterElementType(parameter.type)));
}
else {
expressions.push(serializeTypeOfNode(parameter));
@@ -38075,11 +41189,20 @@ var ts;
}
return ts.createArrayLiteral(expressions);
}
+ function getParametersOfDecoratedDeclaration(node, container) {
+ if (container && node.kind === 152) {
+ var setAccessor = ts.getAllAccessorDeclarations(container.members, node).setAccessor;
+ if (setAccessor) {
+ return setAccessor.parameters;
+ }
+ }
+ return node.parameters;
+ }
function serializeReturnTypeOfNode(node) {
if (ts.isFunctionLike(node) && node.type) {
return serializeTypeNode(node.type);
}
- else if (ts.isAsyncFunctionLike(node)) {
+ else if (ts.isAsyncFunction(node)) {
return ts.createIdentifier("Promise");
}
return ts.createVoidZero();
@@ -38090,21 +41213,26 @@ var ts;
}
switch (node.kind) {
case 104:
+ case 138:
+ case 94:
+ case 129:
return ts.createVoidZero();
- case 166:
+ case 167:
return serializeTypeNode(node.type);
- case 158:
case 159:
+ case 160:
return ts.createIdentifier("Function");
- case 162:
case 163:
+ case 164:
return ts.createIdentifier("Array");
- case 156:
+ case 157:
case 121:
return ts.createIdentifier("Boolean");
- case 134:
+ case 135:
return ts.createIdentifier("String");
- case 171:
+ case 133:
+ return ts.createIdentifier("Object");
+ case 172:
switch (node.literal.kind) {
case 9:
return ts.createIdentifier("String");
@@ -38120,44 +41248,22 @@ var ts;
break;
case 132:
return ts.createIdentifier("Number");
- case 135:
+ case 136:
return languageVersion < 2
? getGlobalSymbolNameWithFallback()
: ts.createIdentifier("Symbol");
- case 157:
+ case 158:
return serializeTypeReferenceNode(node);
+ case 166:
case 165:
- case 164:
- {
- var unionOrIntersection = node;
- var serializedUnion = void 0;
- for (var _i = 0, _a = unionOrIntersection.types; _i < _a.length; _i++) {
- var typeNode = _a[_i];
- var serializedIndividual = serializeTypeNode(typeNode);
- if (serializedIndividual.kind !== 70) {
- serializedUnion = undefined;
- break;
- }
- if (serializedIndividual.text === "Object") {
- return serializedIndividual;
- }
- if (serializedUnion && serializedUnion.text !== serializedIndividual.text) {
- serializedUnion = undefined;
- break;
- }
- serializedUnion = serializedIndividual;
- }
- if (serializedUnion) {
- return serializedUnion;
- }
- }
- case 160:
- case 168:
+ return serializeUnionOrIntersectionType(node);
+ case 161:
case 169:
case 170:
- case 161:
+ case 171:
+ case 162:
case 118:
- case 167:
+ case 168:
break;
default:
ts.Debug.failBadSyntaxKind(node);
@@ -38165,6 +41271,32 @@ var ts;
}
return ts.createIdentifier("Object");
}
+ function serializeUnionOrIntersectionType(node) {
+ var serializedUnion;
+ for (var _i = 0, _a = node.types; _i < _a.length; _i++) {
+ var typeNode = _a[_i];
+ var serializedIndividual = serializeTypeNode(typeNode);
+ if (ts.isVoidExpression(serializedIndividual)) {
+ if (!serializedUnion) {
+ serializedUnion = serializedIndividual;
+ }
+ }
+ else if (ts.isIdentifier(serializedIndividual) && serializedIndividual.text === "Object") {
+ return serializedIndividual;
+ }
+ else if (serializedUnion && !ts.isVoidExpression(serializedUnion)) {
+ if (!ts.isIdentifier(serializedUnion) ||
+ !ts.isIdentifier(serializedIndividual) ||
+ serializedUnion.text !== serializedIndividual.text) {
+ return ts.createIdentifier("Object");
+ }
+ }
+ else {
+ serializedUnion = serializedIndividual;
+ }
+ }
+ return serializedUnion;
+ }
function serializeTypeReferenceNode(node) {
switch (resolver.getTypeReferenceSerializationKind(node.typeName, currentScope)) {
case ts.TypeReferenceSerializationKind.Unknown:
@@ -38199,15 +41331,15 @@ var ts;
function serializeEntityNameAsExpression(node, useFallback) {
switch (node.kind) {
case 70:
- var name_31 = ts.getMutableClone(node);
- name_31.flags &= ~8;
- name_31.original = undefined;
- name_31.parent = currentScope;
+ var name = ts.getMutableClone(node);
+ name.flags &= ~8;
+ name.original = undefined;
+ name.parent = currentScope;
if (useFallback) {
- return ts.createLogicalAnd(ts.createStrictInequality(ts.createTypeOf(name_31), ts.createLiteral("undefined")), name_31);
+ return ts.createLogicalAnd(ts.createStrictInequality(ts.createTypeOf(name), ts.createLiteral("undefined")), name);
}
- return name_31;
- case 141:
+ return name;
+ case 142:
return serializeQualifiedNameAsExpression(node, useFallback);
}
}
@@ -38236,7 +41368,7 @@ var ts;
: name.expression;
}
else if (ts.isIdentifier(name)) {
- return ts.createLiteral(name.text);
+ return ts.createLiteral(ts.unescapeIdentifier(name.text));
}
else {
return ts.getSynthesizedClone(name);
@@ -38251,7 +41383,7 @@ var ts;
hoistVariableDeclaration(generatedName);
expression = ts.createAssignment(generatedName, expression);
}
- return ts.setOriginalNode(ts.createComputedPropertyName(expression, name), name);
+ return ts.updateComputedPropertyName(name, expression);
}
else {
return name;
@@ -38260,13 +41392,12 @@ var ts;
function visitHeritageClause(node) {
if (node.token === 84) {
var types = ts.visitNodes(node.types, visitor, ts.isExpressionWithTypeArguments, 0, 1);
- return ts.createHeritageClause(84, types, node);
+ return ts.setTextRange(ts.createHeritageClause(84, types), node);
}
return undefined;
}
function visitExpressionWithTypeArguments(node) {
- var expression = ts.visitNode(node.expression, visitor, ts.isLeftHandSideExpression);
- return ts.createExpressionWithTypeArguments(undefined, expression, node);
+ return ts.updateExpressionWithTypeArguments(node, undefined, ts.visitNode(node.expression, visitor, ts.isLeftHandSideExpression));
}
function shouldEmitFunctionLikeDeclaration(node) {
return !ts.nodeIsMissing(node.body);
@@ -38275,13 +41406,13 @@ var ts;
if (!shouldEmitFunctionLikeDeclaration(node)) {
return undefined;
}
- return ts.visitEachChild(node, visitor, context);
+ return ts.updateConstructor(node, ts.visitNodes(node.decorators, visitor, ts.isDecorator), ts.visitNodes(node.modifiers, visitor, ts.isModifier), ts.visitParameterList(node.parameters, visitor, context), ts.visitFunctionBody(node.body, visitor, context));
}
function visitMethodDeclaration(node) {
if (!shouldEmitFunctionLikeDeclaration(node)) {
return undefined;
}
- var updated = ts.updateMethod(node, undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), visitPropertyNameOfClassElement(node), undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context));
+ var updated = ts.updateMethod(node, undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, visitPropertyNameOfClassElement(node), undefined, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context));
if (updated !== node) {
ts.setCommentRange(updated, node);
ts.setSourceMapRange(updated, ts.moveRangePastDecorators(node));
@@ -38317,7 +41448,7 @@ var ts;
if (!shouldEmitFunctionLikeDeclaration(node)) {
return ts.createNotEmittedStatement(node);
}
- var updated = ts.updateFunctionDeclaration(node, undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context) || ts.createBlock([]));
+ var updated = ts.updateFunctionDeclaration(node, undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context) || ts.createBlock([]));
if (isNamespaceExport(node)) {
var statements = [updated];
addExportMemberAssignment(statements, node);
@@ -38326,10 +41457,10 @@ var ts;
return updated;
}
function visitFunctionExpression(node) {
- if (ts.nodeIsMissing(node.body)) {
+ if (!shouldEmitFunctionLikeDeclaration(node)) {
return ts.createOmittedExpression();
}
- var updated = ts.updateFunctionExpression(node, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context));
+ var updated = ts.updateFunctionExpression(node, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.visitFunctionBody(node.body, visitor, context) || ts.createBlock([]));
return updated;
}
function visitArrowFunction(node) {
@@ -38340,8 +41471,9 @@ var ts;
if (ts.parameterIsThisKeyword(node)) {
return undefined;
}
- var parameter = ts.createParameter(undefined, undefined, node.dotDotDotToken, ts.visitNode(node.name, visitor, ts.isBindingName), undefined, undefined, ts.visitNode(node.initializer, visitor, ts.isExpression), ts.moveRangePastModifiers(node));
+ var parameter = ts.createParameter(undefined, undefined, node.dotDotDotToken, ts.visitNode(node.name, visitor, ts.isBindingName), undefined, undefined, ts.visitNode(node.initializer, visitor, ts.isExpression));
ts.setOriginalNode(parameter, node);
+ ts.setTextRange(parameter, ts.moveRangePastModifiers(node));
ts.setCommentRange(parameter, node);
ts.setSourceMapRange(parameter, ts.moveRangePastModifiers(node));
ts.setEmitFlags(parameter.name, 32);
@@ -38353,7 +41485,7 @@ var ts;
if (variables.length === 0) {
return undefined;
}
- return ts.createStatement(ts.inlineExpressions(ts.map(variables, transformInitializedVariable)), node);
+ return ts.setTextRange(ts.createStatement(ts.inlineExpressions(ts.map(variables, transformInitializedVariable))), node);
}
else {
return ts.visitEachChild(node, visitor, context);
@@ -38365,7 +41497,7 @@ var ts;
return ts.flattenDestructuringAssignment(node, visitor, context, 0, false, createNamespaceExportExpression);
}
else {
- return ts.createAssignment(getNamespaceMemberNameWithSourceMapsAndWithoutComments(name), ts.visitNode(node.initializer, visitor, ts.isExpression), node);
+ return ts.setTextRange(ts.createAssignment(getNamespaceMemberNameWithSourceMapsAndWithoutComments(name), ts.visitNode(node.initializer, visitor, ts.isExpression)), node);
}
}
function visitVariableDeclaration(node) {
@@ -38419,8 +41551,9 @@ var ts;
var localName = ts.getLocalName(node, false, true);
moduleArg = ts.createAssignment(localName, moduleArg);
}
- var enumStatement = ts.createStatement(ts.createCall(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, transformEnumBody(node, containerName)), undefined, [moduleArg]), node);
+ var enumStatement = ts.createStatement(ts.createCall(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, transformEnumBody(node, containerName)), undefined, [moduleArg]));
ts.setOriginalNode(enumStatement, node);
+ ts.setTextRange(enumStatement, node);
ts.setEmitFlags(enumStatement, emitFlags);
statements.push(enumStatement);
statements.push(ts.createEndOfDeclarationMarker(node));
@@ -38434,11 +41567,11 @@ var ts;
ts.addRange(statements, ts.map(node.members, transformEnumMember));
ts.addRange(statements, endLexicalEnvironment());
currentNamespaceContainerName = savedCurrentNamespaceLocalName;
- return ts.createBlock(ts.createNodeArray(statements, node.members), undefined, true);
+ return ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), node.members), true);
}
function transformEnumMember(member) {
var name = getExpressionForPropertyName(member, false);
- return ts.createStatement(ts.createAssignment(ts.createElementAccess(currentNamespaceContainerName, ts.createAssignment(ts.createElementAccess(currentNamespaceContainerName, name), transformEnumMemberDeclarationValue(member))), name, member), member);
+ return ts.setTextRange(ts.createStatement(ts.setTextRange(ts.createAssignment(ts.createElementAccess(currentNamespaceContainerName, ts.createAssignment(ts.createElementAccess(currentNamespaceContainerName, name), transformEnumMemberDeclarationValue(member))), name), member)), member);
}
function transformEnumMemberDeclarationValue(member) {
var value = resolver.getConstantValue(member);
@@ -38470,16 +41603,16 @@ var ts;
if (!currentScopeFirstDeclarationsOfName) {
currentScopeFirstDeclarationsOfName = ts.createMap();
}
- if (!(name in currentScopeFirstDeclarationsOfName)) {
- currentScopeFirstDeclarationsOfName[name] = node;
+ if (!currentScopeFirstDeclarationsOfName.has(name)) {
+ currentScopeFirstDeclarationsOfName.set(name, node);
}
}
}
function isFirstEmittedDeclarationInScope(node) {
if (currentScopeFirstDeclarationsOfName) {
- var name_32 = node.symbol && node.symbol.name;
- if (name_32) {
- return currentScopeFirstDeclarationsOfName[name_32] === node;
+ var name = node.symbol && node.symbol.name;
+ if (name) {
+ return currentScopeFirstDeclarationsOfName.get(name) === node;
}
}
return false;
@@ -38491,7 +41624,7 @@ var ts;
ts.setOriginalNode(statement, node);
recordEmittedDeclarationInScope(node);
if (isFirstEmittedDeclarationInScope(node)) {
- if (node.kind === 229) {
+ if (node.kind === 231) {
ts.setSourceMapRange(statement.declarationList, node);
}
else {
@@ -38532,8 +41665,9 @@ var ts;
var localName = ts.getLocalName(node, false, true);
moduleArg = ts.createAssignment(localName, moduleArg);
}
- var moduleStatement = ts.createStatement(ts.createCall(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, transformModuleBody(node, containerName)), undefined, [moduleArg]), node);
+ var moduleStatement = ts.createStatement(ts.createCall(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, transformModuleBody(node, containerName)), undefined, [moduleArg]));
ts.setOriginalNode(moduleStatement, node);
+ ts.setTextRange(moduleStatement, node);
ts.setEmitFlags(moduleStatement, emitFlags);
statements.push(moduleStatement);
statements.push(ts.createEndOfDeclarationMarker(node));
@@ -38551,8 +41685,8 @@ var ts;
var statementsLocation;
var blockLocation;
var body = node.body;
- if (body.kind === 231) {
- ts.addRange(statements, ts.visitNodes(body.statements, namespaceElementVisitor, ts.isStatement));
+ if (body.kind === 233) {
+ saveStateAndInvoke(body, function (body) { return ts.addRange(statements, ts.visitNodes(body.statements, namespaceElementVisitor, ts.isStatement)); });
statementsLocation = body.statements;
blockLocation = body;
}
@@ -38573,14 +41707,15 @@ var ts;
currentNamespaceContainerName = savedCurrentNamespaceContainerName;
currentNamespace = savedCurrentNamespace;
currentScopeFirstDeclarationsOfName = savedCurrentScopeFirstDeclarationsOfName;
- var block = ts.createBlock(ts.createNodeArray(statements, statementsLocation), blockLocation, true);
- if (body.kind !== 231) {
+ var block = ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), statementsLocation), true);
+ ts.setTextRange(block, blockLocation);
+ if (body.kind !== 233) {
ts.setEmitFlags(block, ts.getEmitFlags(block) | 1536);
}
return block;
}
function getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration) {
- if (moduleDeclaration.body.kind === 230) {
+ if (moduleDeclaration.body.kind === 232) {
var recursiveInnerModule = getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration.body);
return recursiveInnerModule || moduleDeclaration.body;
}
@@ -38589,18 +41724,18 @@ var ts;
if (!node.importClause) {
return node;
}
- var importClause = ts.visitNode(node.importClause, visitImportClause, ts.isImportClause, true);
+ var importClause = ts.visitNode(node.importClause, visitImportClause, ts.isImportClause);
return importClause
? ts.updateImportDeclaration(node, undefined, undefined, importClause, node.moduleSpecifier)
: undefined;
}
function visitImportClause(node) {
var name = resolver.isReferencedAliasDeclaration(node) ? node.name : undefined;
- var namedBindings = ts.visitNode(node.namedBindings, visitNamedImportBindings, ts.isNamedImportBindings, true);
+ var namedBindings = ts.visitNode(node.namedBindings, visitNamedImportBindings, ts.isNamedImportBindings);
return (name || namedBindings) ? ts.updateImportClause(node, name, namedBindings) : undefined;
}
function visitNamedImportBindings(node) {
- if (node.kind === 237) {
+ if (node.kind === 239) {
return resolver.isReferencedAliasDeclaration(node) ? node : undefined;
}
else {
@@ -38623,7 +41758,7 @@ var ts;
if (!resolver.isValueAliasDeclaration(node)) {
return undefined;
}
- var exportClause = ts.visitNode(node.exportClause, visitNamedExports, ts.isNamedExports, true);
+ var exportClause = ts.visitNode(node.exportClause, visitNamedExports, ts.isNamedExports);
return exportClause
? ts.updateExportDeclaration(node, undefined, undefined, exportClause, node.moduleSpecifier)
: undefined;
@@ -38652,9 +41787,9 @@ var ts;
var moduleReference = ts.createExpressionFromEntityName(node.moduleReference);
ts.setEmitFlags(moduleReference, 1536 | 2048);
if (isNamedExternalModuleExport(node) || !isNamespaceExport(node)) {
- return ts.setOriginalNode(ts.createVariableStatement(ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), ts.createVariableDeclarationList([
+ return ts.setOriginalNode(ts.setTextRange(ts.createVariableStatement(ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), ts.createVariableDeclarationList([
ts.setOriginalNode(ts.createVariableDeclaration(node.name, undefined, moduleReference), node)
- ]), node), node);
+ ])), node), node);
}
else {
return ts.setOriginalNode(createNamespaceExport(node.name, moduleReference, node), node);
@@ -38675,7 +41810,7 @@ var ts;
&& ts.hasModifier(node, 512);
}
function expressionToStatement(expression) {
- return ts.createStatement(expression, undefined);
+ return ts.createStatement(expression);
}
function addExportMemberAssignment(statements, node) {
var expression = ts.createAssignment(ts.getExternalModuleOrNamespaceExportName(currentNamespaceContainerName, node, false, true), ts.getLocalName(node));
@@ -38685,10 +41820,10 @@ var ts;
statements.push(statement);
}
function createNamespaceExport(exportName, exportValue, location) {
- return ts.createStatement(ts.createAssignment(ts.getNamespaceMemberName(currentNamespaceContainerName, exportName, false, true), exportValue), location);
+ return ts.setTextRange(ts.createStatement(ts.createAssignment(ts.getNamespaceMemberName(currentNamespaceContainerName, exportName, false, true), exportValue)), location);
}
function createNamespaceExportExpression(exportName, exportValue, location) {
- return ts.createAssignment(getNamespaceMemberNameWithSourceMapsAndWithoutComments(exportName), exportValue, location);
+ return ts.setTextRange(ts.createAssignment(getNamespaceMemberNameWithSourceMapsAndWithoutComments(exportName), exportValue), location);
}
function getNamespaceMemberNameWithSourceMapsAndWithoutComments(name) {
return ts.getNamespaceMemberName(currentNamespaceContainerName, name, false, true);
@@ -38704,7 +41839,7 @@ var ts;
function getClassAliasIfNeeded(node) {
if (resolver.getNodeCheckFlags(node) & 8388608) {
enableSubstitutionForClassAliases();
- var classAlias = ts.createUniqueName(node.name && !ts.isGeneratedIdentifier(node.name) ? node.name.text : "default");
+ var classAlias = ts.createUniqueName(node.name && !ts.isGeneratedIdentifier(node.name) ? ts.unescapeIdentifier(node.name.text) : "default");
classAliases[ts.getOriginalNodeId(node)] = classAlias;
hoistVariableDeclaration(classAlias);
return classAlias;
@@ -38728,37 +41863,42 @@ var ts;
if ((enabledSubstitutions & 1) === 0) {
enabledSubstitutions |= 1;
context.enableSubstitution(70);
- classAliases = ts.createMap();
+ classAliases = [];
}
}
function enableSubstitutionForNamespaceExports() {
if ((enabledSubstitutions & 2) === 0) {
enabledSubstitutions |= 2;
context.enableSubstitution(70);
- context.enableSubstitution(258);
- context.enableEmitNotification(230);
+ context.enableSubstitution(261);
+ context.enableEmitNotification(232);
}
}
function isTransformedModuleDeclaration(node) {
- return ts.getOriginalNode(node).kind === 230;
+ return ts.getOriginalNode(node).kind === 232;
}
function isTransformedEnumDeclaration(node) {
- return ts.getOriginalNode(node).kind === 229;
+ return ts.getOriginalNode(node).kind === 231;
}
- function onEmitNode(emitContext, node, emitCallback) {
+ function onEmitNode(hint, node, emitCallback) {
var savedApplicableSubstitutions = applicableSubstitutions;
+ var savedCurrentSourceFile = currentSourceFile;
+ if (ts.isSourceFile(node)) {
+ currentSourceFile = node;
+ }
if (enabledSubstitutions & 2 && isTransformedModuleDeclaration(node)) {
applicableSubstitutions |= 2;
}
if (enabledSubstitutions & 8 && isTransformedEnumDeclaration(node)) {
applicableSubstitutions |= 8;
}
- previousOnEmitNode(emitContext, node, emitCallback);
+ previousOnEmitNode(hint, node, emitCallback);
applicableSubstitutions = savedApplicableSubstitutions;
+ currentSourceFile = savedCurrentSourceFile;
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (emitContext === 1) {
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (hint === 1) {
return substituteExpression(node);
}
else if (ts.isShorthandPropertyAssignment(node)) {
@@ -38768,14 +41908,14 @@ var ts;
}
function substituteShorthandPropertyAssignment(node) {
if (enabledSubstitutions & 2) {
- var name_33 = node.name;
- var exportedName = trySubstituteNamespaceExportedName(name_33);
+ var name = node.name;
+ var exportedName = trySubstituteNamespaceExportedName(name);
if (exportedName) {
if (node.objectAssignmentInitializer) {
var initializer = ts.createAssignment(exportedName, node.objectAssignmentInitializer);
- return ts.createPropertyAssignment(name_33, initializer, node);
+ return ts.setTextRange(ts.createPropertyAssignment(name, initializer), node);
}
- return ts.createPropertyAssignment(name_33, exportedName, node);
+ return ts.setTextRange(ts.createPropertyAssignment(name, exportedName), node);
}
}
return node;
@@ -38784,9 +41924,9 @@ var ts;
switch (node.kind) {
case 70:
return substituteExpressionIdentifier(node);
- case 177:
- return substitutePropertyAccessExpression(node);
case 178:
+ return substitutePropertyAccessExpression(node);
+ case 179:
return substituteElementAccessExpression(node);
}
return node;
@@ -38816,11 +41956,11 @@ var ts;
function trySubstituteNamespaceExportedName(node) {
if (enabledSubstitutions & applicableSubstitutions && !ts.isGeneratedIdentifier(node) && !ts.isLocalName(node)) {
var container = resolver.getReferencedExportContainer(node, false);
- if (container && container.kind !== 261) {
- var substitute = (applicableSubstitutions & 2 && container.kind === 230) ||
- (applicableSubstitutions & 8 && container.kind === 229);
+ if (container && container.kind !== 264) {
+ var substitute = (applicableSubstitutions & 2 && container.kind === 232) ||
+ (applicableSubstitutions & 8 && container.kind === 231);
if (substitute) {
- return ts.createPropertyAccess(ts.getGeneratedNameForNode(container), node, node);
+ return ts.setTextRange(ts.createPropertyAccess(ts.getGeneratedNameForNode(container), node), node);
}
}
}
@@ -38835,16 +41975,14 @@ var ts;
function substituteConstantValue(node) {
var constantValue = tryGetConstEnumValue(node);
if (constantValue !== undefined) {
+ ts.setConstantValue(node, constantValue);
var substitute = ts.createLiteral(constantValue);
- ts.setSourceMapRange(substitute, node);
- ts.setCommentRange(substitute, node);
if (!compilerOptions.removeComments) {
var propertyName = ts.isPropertyAccessExpression(node)
? ts.declarationNameToString(node.name)
: ts.getTextOfNode(node.argumentExpression);
- substitute.trailingComment = " " + propertyName + " ";
+ ts.addSyntheticTrailingComment(substitute, 3, " " + propertyName + " ");
}
- ts.setConstantValue(node, constantValue);
return substitute;
}
return node;
@@ -38859,24 +41997,24 @@ var ts;
}
}
ts.transformTypeScript = transformTypeScript;
- var paramHelper = {
- name: "typescript:param",
- scoped: false,
- priority: 4,
- text: "\n var __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n };"
- };
- function createParamHelper(context, expression, parameterOffset, location) {
- context.requestEmitHelper(paramHelper);
- return ts.createCall(ts.getHelperName("__param"), undefined, [
- ts.createLiteral(parameterOffset),
- expression
- ], location);
+ function createDecorateHelper(context, decoratorExpressions, target, memberName, descriptor, location) {
+ var argumentsArray = [];
+ argumentsArray.push(ts.createArrayLiteral(decoratorExpressions, true));
+ argumentsArray.push(target);
+ if (memberName) {
+ argumentsArray.push(memberName);
+ if (descriptor) {
+ argumentsArray.push(descriptor);
+ }
+ }
+ context.requestEmitHelper(decorateHelper);
+ return ts.setTextRange(ts.createCall(ts.getHelperName("__decorate"), undefined, argumentsArray), location);
}
- var metadataHelper = {
- name: "typescript:metadata",
+ var decorateHelper = {
+ name: "typescript:decorate",
scoped: false,
- priority: 3,
- text: "\n var __metadata = (this && this.__metadata) || function (k, v) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(k, v);\n };"
+ priority: 2,
+ text: "\n var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n };"
};
function createMetadataHelper(context, metadataKey, metadataValue) {
context.requestEmitHelper(metadataHelper);
@@ -38885,30 +42023,281 @@ var ts;
metadataValue
]);
}
- var decorateHelper = {
- name: "typescript:decorate",
+ var metadataHelper = {
+ name: "typescript:metadata",
scoped: false,
- priority: 2,
- text: "\n var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n };"
+ priority: 3,
+ text: "\n var __metadata = (this && this.__metadata) || function (k, v) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(k, v);\n };"
};
- function createDecorateHelper(context, decoratorExpressions, target, memberName, descriptor, location) {
- context.requestEmitHelper(decorateHelper);
- var argumentsArray = [];
- argumentsArray.push(ts.createArrayLiteral(decoratorExpressions, undefined, true));
- argumentsArray.push(target);
- if (memberName) {
- argumentsArray.push(memberName);
- if (descriptor) {
- argumentsArray.push(descriptor);
+ function createParamHelper(context, expression, parameterOffset, location) {
+ context.requestEmitHelper(paramHelper);
+ return ts.setTextRange(ts.createCall(ts.getHelperName("__param"), undefined, [
+ ts.createLiteral(parameterOffset),
+ expression
+ ]), location);
+ }
+ var paramHelper = {
+ name: "typescript:param",
+ scoped: false,
+ priority: 4,
+ text: "\n var __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n };"
+ };
+})(ts || (ts = {}));
+var ts;
+(function (ts) {
+ function transformES2017(context) {
+ var startLexicalEnvironment = context.startLexicalEnvironment, resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment;
+ var resolver = context.getEmitResolver();
+ var compilerOptions = context.getCompilerOptions();
+ var languageVersion = ts.getEmitScriptTarget(compilerOptions);
+ var currentSourceFile;
+ var enabledSubstitutions;
+ var enclosingSuperContainerFlags = 0;
+ var previousOnEmitNode = context.onEmitNode;
+ var previousOnSubstituteNode = context.onSubstituteNode;
+ context.onEmitNode = onEmitNode;
+ context.onSubstituteNode = onSubstituteNode;
+ return transformSourceFile;
+ function transformSourceFile(node) {
+ if (ts.isDeclarationFile(node)) {
+ return node;
+ }
+ currentSourceFile = node;
+ var visited = ts.visitEachChild(node, visitor, context);
+ ts.addEmitHelpers(visited, context.readEmitHelpers());
+ currentSourceFile = undefined;
+ return visited;
+ }
+ function visitor(node) {
+ if ((node.transformFlags & 16) === 0) {
+ return node;
+ }
+ switch (node.kind) {
+ case 119:
+ return undefined;
+ case 190:
+ return visitAwaitExpression(node);
+ case 150:
+ return visitMethodDeclaration(node);
+ case 227:
+ return visitFunctionDeclaration(node);
+ case 185:
+ return visitFunctionExpression(node);
+ case 186:
+ return visitArrowFunction(node);
+ default:
+ return ts.visitEachChild(node, visitor, context);
+ }
+ }
+ function visitAwaitExpression(node) {
+ return ts.setOriginalNode(ts.setTextRange(ts.createYield(undefined, ts.visitNode(node.expression, visitor, ts.isExpression)), node), node);
+ }
+ function visitMethodDeclaration(node) {
+ return ts.updateMethod(node, undefined, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.asteriskToken, node.name, undefined, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.getFunctionFlags(node) & 2
+ ? transformAsyncFunctionBody(node)
+ : ts.visitFunctionBody(node.body, visitor, context));
+ }
+ function visitFunctionDeclaration(node) {
+ return ts.updateFunctionDeclaration(node, undefined, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.getFunctionFlags(node) & 2
+ ? transformAsyncFunctionBody(node)
+ : ts.visitFunctionBody(node.body, visitor, context));
+ }
+ function visitFunctionExpression(node) {
+ return ts.updateFunctionExpression(node, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.getFunctionFlags(node) & 2
+ ? transformAsyncFunctionBody(node)
+ : ts.visitFunctionBody(node.body, visitor, context));
+ }
+ function visitArrowFunction(node) {
+ return ts.updateArrowFunction(node, ts.visitNodes(node.modifiers, visitor, ts.isModifier), undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.getFunctionFlags(node) & 2
+ ? transformAsyncFunctionBody(node)
+ : ts.visitFunctionBody(node.body, visitor, context));
+ }
+ function transformAsyncFunctionBody(node) {
+ resumeLexicalEnvironment();
+ var original = ts.getOriginalNode(node, ts.isFunctionLike);
+ var nodeType = original.type;
+ var promiseConstructor = languageVersion < 2 ? getPromiseConstructor(nodeType) : undefined;
+ var isArrowFunction = node.kind === 186;
+ var hasLexicalArguments = (resolver.getNodeCheckFlags(node) & 8192) !== 0;
+ if (!isArrowFunction) {
+ var statements = [];
+ var statementOffset = ts.addPrologue(statements, node.body.statements, false, visitor);
+ statements.push(ts.createReturn(createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, transformFunctionBodyWorker(node.body, statementOffset))));
+ ts.addRange(statements, endLexicalEnvironment());
+ var block = ts.createBlock(statements, true);
+ ts.setTextRange(block, node.body);
+ if (languageVersion >= 2) {
+ if (resolver.getNodeCheckFlags(node) & 4096) {
+ enableSubstitutionForAsyncMethodsWithSuper();
+ ts.addEmitHelper(block, ts.advancedAsyncSuperHelper);
+ }
+ else if (resolver.getNodeCheckFlags(node) & 2048) {
+ enableSubstitutionForAsyncMethodsWithSuper();
+ ts.addEmitHelper(block, ts.asyncSuperHelper);
+ }
+ }
+ return block;
+ }
+ else {
+ var expression = createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, transformFunctionBodyWorker(node.body));
+ var declarations = endLexicalEnvironment();
+ if (ts.some(declarations)) {
+ var block = ts.convertToFunctionBody(expression);
+ return ts.updateBlock(block, ts.setTextRange(ts.createNodeArray(ts.concatenate(block.statements, declarations)), block.statements));
+ }
+ return expression;
+ }
+ }
+ function transformFunctionBodyWorker(body, start) {
+ if (ts.isBlock(body)) {
+ return ts.updateBlock(body, ts.visitLexicalEnvironment(body.statements, visitor, context, start));
+ }
+ else {
+ startLexicalEnvironment();
+ var visited = ts.convertToFunctionBody(ts.visitNode(body, visitor, ts.isConciseBody));
+ var declarations = endLexicalEnvironment();
+ return ts.updateBlock(visited, ts.setTextRange(ts.createNodeArray(ts.concatenate(visited.statements, declarations)), visited.statements));
+ }
+ }
+ function getPromiseConstructor(type) {
+ var typeName = type && ts.getEntityNameFromTypeNode(type);
+ if (typeName && ts.isEntityName(typeName)) {
+ var serializationKind = resolver.getTypeReferenceSerializationKind(typeName);
+ if (serializationKind === ts.TypeReferenceSerializationKind.TypeWithConstructSignatureAndValue
+ || serializationKind === ts.TypeReferenceSerializationKind.Unknown) {
+ return typeName;
+ }
+ }
+ return undefined;
+ }
+ function enableSubstitutionForAsyncMethodsWithSuper() {
+ if ((enabledSubstitutions & 1) === 0) {
+ enabledSubstitutions |= 1;
+ context.enableSubstitution(180);
+ context.enableSubstitution(178);
+ context.enableSubstitution(179);
+ context.enableEmitNotification(228);
+ context.enableEmitNotification(150);
+ context.enableEmitNotification(152);
+ context.enableEmitNotification(153);
+ context.enableEmitNotification(151);
+ }
+ }
+ function onEmitNode(hint, node, emitCallback) {
+ if (enabledSubstitutions & 1 && isSuperContainer(node)) {
+ var superContainerFlags = resolver.getNodeCheckFlags(node) & (2048 | 4096);
+ if (superContainerFlags !== enclosingSuperContainerFlags) {
+ var savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
+ enclosingSuperContainerFlags = superContainerFlags;
+ previousOnEmitNode(hint, node, emitCallback);
+ enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
+ return;
+ }
+ }
+ previousOnEmitNode(hint, node, emitCallback);
+ }
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (hint === 1 && enclosingSuperContainerFlags) {
+ return substituteExpression(node);
+ }
+ return node;
+ }
+ function substituteExpression(node) {
+ switch (node.kind) {
+ case 178:
+ return substitutePropertyAccessExpression(node);
+ case 179:
+ return substituteElementAccessExpression(node);
+ case 180:
+ return substituteCallExpression(node);
+ }
+ return node;
+ }
+ function substitutePropertyAccessExpression(node) {
+ if (node.expression.kind === 96) {
+ return createSuperAccessInAsyncMethod(ts.createLiteral(node.name.text), node);
+ }
+ return node;
+ }
+ function substituteElementAccessExpression(node) {
+ if (node.expression.kind === 96) {
+ return createSuperAccessInAsyncMethod(node.argumentExpression, node);
+ }
+ return node;
+ }
+ function substituteCallExpression(node) {
+ var expression = node.expression;
+ if (ts.isSuperProperty(expression)) {
+ var argumentExpression = ts.isPropertyAccessExpression(expression)
+ ? substitutePropertyAccessExpression(expression)
+ : substituteElementAccessExpression(expression);
+ return ts.createCall(ts.createPropertyAccess(argumentExpression, "call"), undefined, [
+ ts.createThis()
+ ].concat(node.arguments));
+ }
+ return node;
+ }
+ function isSuperContainer(node) {
+ var kind = node.kind;
+ return kind === 228
+ || kind === 151
+ || kind === 150
+ || kind === 152
+ || kind === 153;
+ }
+ function createSuperAccessInAsyncMethod(argumentExpression, location) {
+ if (enclosingSuperContainerFlags & 4096) {
+ return ts.setTextRange(ts.createPropertyAccess(ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression]), "value"), location);
+ }
+ else {
+ return ts.setTextRange(ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression]), location);
}
}
- return ts.createCall(ts.getHelperName("__decorate"), undefined, argumentsArray, location);
}
+ ts.transformES2017 = transformES2017;
+ var awaiterHelper = {
+ name: "typescript:awaiter",
+ scoped: false,
+ priority: 5,
+ text: "\n var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n };"
+ };
+ function createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, body) {
+ context.requestEmitHelper(awaiterHelper);
+ var generatorFunc = ts.createFunctionExpression(undefined, ts.createToken(38), undefined, undefined, [], undefined, body);
+ (generatorFunc.emitNode || (generatorFunc.emitNode = {})).flags |= 131072;
+ return ts.createCall(ts.getHelperName("__awaiter"), undefined, [
+ ts.createThis(),
+ hasLexicalArguments ? ts.createIdentifier("arguments") : ts.createVoidZero(),
+ promiseConstructor ? ts.createExpressionFromEntityName(promiseConstructor) : ts.createVoidZero(),
+ generatorFunc
+ ]);
+ }
+ ts.asyncSuperHelper = {
+ name: "typescript:async-super",
+ scoped: true,
+ text: "\n const _super = name => super[name];\n "
+ };
+ ts.advancedAsyncSuperHelper = {
+ name: "typescript:advanced-async-super",
+ scoped: true,
+ text: "\n const _super = (function (geti, seti) {\n const cache = Object.create(null);\n return name => cache[name] || (cache[name] = { get value() { return geti(name); }, set value(v) { seti(name, v); } });\n })(name => super[name], (name, value) => super[name] = value);\n "
+ };
})(ts || (ts = {}));
var ts;
(function (ts) {
function transformESNext(context) {
- var resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment;
+ var resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment, hoistVariableDeclaration = context.hoistVariableDeclaration;
+ var resolver = context.getEmitResolver();
+ var compilerOptions = context.getCompilerOptions();
+ var languageVersion = ts.getEmitScriptTarget(compilerOptions);
+ var previousOnEmitNode = context.onEmitNode;
+ context.onEmitNode = onEmitNode;
+ var previousOnSubstituteNode = context.onSubstituteNode;
+ context.onSubstituteNode = onSubstituteNode;
+ var enabledSubstitutions;
+ var enclosingFunctionFlags;
+ var enclosingSuperContainerFlags = 0;
return transformSourceFile;
function transformSourceFile(node) {
if (ts.isDeclarationFile(node)) {
@@ -38924,53 +42313,93 @@ var ts;
function visitorNoDestructuringValue(node) {
return visitorWorker(node, true);
}
+ function visitorNoAsyncModifier(node) {
+ if (node.kind === 119) {
+ return undefined;
+ }
+ return node;
+ }
function visitorWorker(node, noDestructuringValue) {
if ((node.transformFlags & 8) === 0) {
return node;
}
switch (node.kind) {
- case 176:
+ case 190:
+ return visitAwaitExpression(node);
+ case 196:
+ return visitYieldExpression(node);
+ case 221:
+ return visitLabeledStatement(node);
+ case 177:
return visitObjectLiteralExpression(node);
- case 192:
+ case 193:
return visitBinaryExpression(node, noDestructuringValue);
- case 223:
+ case 225:
return visitVariableDeclaration(node);
+ case 215:
+ return visitForOfStatement(node, undefined);
case 213:
- return visitForOfStatement(node);
- case 211:
return visitForStatement(node);
- case 188:
+ case 189:
return visitVoidExpression(node);
- case 150:
+ case 151:
return visitConstructorDeclaration(node);
- case 149:
+ case 150:
return visitMethodDeclaration(node);
- case 151:
- return visitGetAccessorDeclaration(node);
case 152:
+ return visitGetAccessorDeclaration(node);
+ case 153:
return visitSetAccessorDeclaration(node);
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 184:
- return visitFunctionExpression(node);
case 185:
+ return visitFunctionExpression(node);
+ case 186:
return visitArrowFunction(node);
- case 144:
+ case 145:
return visitParameter(node);
- case 207:
+ case 209:
return visitExpressionStatement(node);
- case 183:
+ case 184:
return visitParenthesizedExpression(node, noDestructuringValue);
default:
return ts.visitEachChild(node, visitor, context);
}
}
+ function visitAwaitExpression(node) {
+ if (enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1) {
+ var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
+ return ts.setOriginalNode(ts.setTextRange(ts.createYield(undefined, ts.createArrayLiteral([ts.createLiteral("await"), expression])), node), node);
+ }
+ return ts.visitEachChild(node, visitor, context);
+ }
+ function visitYieldExpression(node) {
+ if (enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1) {
+ var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
+ return ts.updateYield(node, node.asteriskToken, node.asteriskToken
+ ? createAsyncDelegatorHelper(context, expression, expression)
+ : ts.createArrayLiteral(expression
+ ? [ts.createLiteral("yield"), expression]
+ : [ts.createLiteral("yield")]));
+ }
+ return ts.visitEachChild(node, visitor, context);
+ }
+ function visitLabeledStatement(node) {
+ if (enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1) {
+ var statement = ts.unwrapInnermostStatementOfLabel(node);
+ if (statement.kind === 215 && statement.awaitModifier) {
+ return visitForOfStatement(statement, node);
+ }
+ return ts.restoreEnclosingLabel(ts.visitEachChild(node, visitor, context), node);
+ }
+ return ts.visitEachChild(node, visitor, context);
+ }
function chunkObjectLiteralElements(elements) {
var chunkObject;
var objects = [];
- for (var _i = 0, elements_3 = elements; _i < elements_3.length; _i++) {
- var e = elements_3[_i];
- if (e.kind === 259) {
+ for (var _i = 0, elements_4 = elements; _i < elements_4.length; _i++) {
+ var e = elements_4[_i];
+ if (e.kind === 262) {
if (chunkObject) {
objects.push(ts.createObjectLiteral(chunkObject));
chunkObject = undefined;
@@ -38982,7 +42411,7 @@ var ts;
if (!chunkObject) {
chunkObject = [];
}
- if (e.kind === 257) {
+ if (e.kind === 260) {
var p = e;
chunkObject.push(ts.createPropertyAssignment(p.name, ts.visitNode(p.initializer, visitor, ts.isExpression)));
}
@@ -38999,7 +42428,7 @@ var ts;
function visitObjectLiteralExpression(node) {
if (node.transformFlags & 1048576) {
var objects = chunkObjectLiteralElements(node.properties);
- if (objects.length && objects[0].kind !== 176) {
+ if (objects.length && objects[0].kind !== 177) {
objects.unshift(ts.createObjectLiteral());
}
return createAssignHelper(context, objects);
@@ -39033,68 +42462,202 @@ var ts;
function visitVoidExpression(node) {
return ts.visitEachChild(node, visitorNoDestructuringValue, context);
}
- function visitForOfStatement(node) {
- var leadingStatements;
- var temp;
- var initializer = ts.skipParentheses(node.initializer);
- if (initializer.transformFlags & 1048576) {
- if (ts.isVariableDeclarationList(initializer)) {
- temp = ts.createTempVariable(undefined);
- var firstDeclaration = ts.firstOrUndefined(initializer.declarations);
- var declarations = ts.flattenDestructuringBinding(firstDeclaration, visitor, context, 1, temp, false, true);
- if (ts.some(declarations)) {
- var statement = ts.createVariableStatement(undefined, ts.updateVariableDeclarationList(initializer, declarations), initializer);
- leadingStatements = ts.append(leadingStatements, statement);
- }
- }
- else if (ts.isAssignmentPattern(initializer)) {
- temp = ts.createTempVariable(undefined);
- var expression = ts.flattenDestructuringAssignment(ts.aggregateTransformFlags(ts.createAssignment(initializer, temp, node.initializer)), visitor, context, 1);
- leadingStatements = ts.append(leadingStatements, ts.createStatement(expression, node.initializer));
+ function visitForOfStatement(node, outermostLabeledStatement) {
+ if (node.initializer.transformFlags & 1048576) {
+ node = transformForOfStatementWithObjectRest(node);
+ }
+ if (node.awaitModifier) {
+ return transformForAwaitOfStatement(node, outermostLabeledStatement);
+ }
+ else {
+ return ts.restoreEnclosingLabel(ts.visitEachChild(node, visitor, context), outermostLabeledStatement);
+ }
+ }
+ function transformForOfStatementWithObjectRest(node) {
+ var initializerWithoutParens = ts.skipParentheses(node.initializer);
+ if (ts.isVariableDeclarationList(initializerWithoutParens) || ts.isAssignmentPattern(initializerWithoutParens)) {
+ var bodyLocation = void 0;
+ var statementsLocation = void 0;
+ var temp = ts.createTempVariable(undefined);
+ var statements = [ts.createForOfBindingStatement(initializerWithoutParens, temp)];
+ if (ts.isBlock(node.statement)) {
+ ts.addRange(statements, node.statement.statements);
+ bodyLocation = node.statement;
+ statementsLocation = node.statement.statements;
}
+ return ts.updateForOf(node, node.awaitModifier, ts.setTextRange(ts.createVariableDeclarationList([
+ ts.setTextRange(ts.createVariableDeclaration(temp), node.initializer)
+ ], 1), node.initializer), node.expression, ts.setTextRange(ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), statementsLocation), true), bodyLocation));
}
- if (temp) {
- var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
- var statement = ts.visitNode(node.statement, visitor, ts.isStatement);
- var block = ts.isBlock(statement)
- ? ts.updateBlock(statement, ts.createNodeArray(ts.concatenate(leadingStatements, statement.statements), statement.statements))
- : ts.createBlock(ts.append(leadingStatements, statement), statement, true);
- return ts.updateForOf(node, ts.createVariableDeclarationList([
- ts.createVariableDeclaration(temp, undefined, undefined, node.initializer)
- ], node.initializer, 1), expression, block);
+ return node;
+ }
+ function convertForOfStatementHead(node, boundValue) {
+ var binding = ts.createForOfBindingStatement(node.initializer, boundValue);
+ var bodyLocation;
+ var statementsLocation;
+ var statements = [ts.visitNode(binding, visitor, ts.isStatement)];
+ var statement = ts.visitNode(node.statement, visitor, ts.isStatement);
+ if (ts.isBlock(statement)) {
+ ts.addRange(statements, statement.statements);
+ bodyLocation = statement;
+ statementsLocation = statement.statements;
}
- return ts.visitEachChild(node, visitor, context);
+ else {
+ statements.push(statement);
+ }
+ return ts.setEmitFlags(ts.setTextRange(ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), statementsLocation), true), bodyLocation), 48 | 384);
+ }
+ function transformForAwaitOfStatement(node, outermostLabeledStatement) {
+ var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
+ var iterator = ts.isIdentifier(expression) ? ts.getGeneratedNameForNode(expression) : ts.createTempVariable(undefined);
+ var result = ts.isIdentifier(expression) ? ts.getGeneratedNameForNode(iterator) : ts.createTempVariable(undefined);
+ var errorRecord = ts.createUniqueName("e");
+ var catchVariable = ts.getGeneratedNameForNode(errorRecord);
+ var returnMethod = ts.createTempVariable(undefined);
+ var values = createAsyncValuesHelper(context, expression, node.expression);
+ var next = ts.createYield(undefined, enclosingFunctionFlags & 1
+ ? ts.createArrayLiteral([
+ ts.createLiteral("await"),
+ ts.createCall(ts.createPropertyAccess(iterator, "next"), undefined, [])
+ ])
+ : ts.createCall(ts.createPropertyAccess(iterator, "next"), undefined, []));
+ hoistVariableDeclaration(errorRecord);
+ hoistVariableDeclaration(returnMethod);
+ var forStatement = ts.setEmitFlags(ts.setTextRange(ts.createFor(ts.setEmitFlags(ts.setTextRange(ts.createVariableDeclarationList([
+ ts.setTextRange(ts.createVariableDeclaration(iterator, undefined, values), node.expression),
+ ts.createVariableDeclaration(result, undefined, next)
+ ]), node.expression), 1048576), ts.createLogicalNot(ts.createPropertyAccess(result, "done")), ts.createAssignment(result, next), convertForOfStatementHead(node, ts.createPropertyAccess(result, "value"))), node), 256);
+ return ts.createTry(ts.createBlock([
+ ts.restoreEnclosingLabel(forStatement, outermostLabeledStatement)
+ ]), ts.createCatchClause(ts.createVariableDeclaration(catchVariable), ts.setEmitFlags(ts.createBlock([
+ ts.createStatement(ts.createAssignment(errorRecord, ts.createObjectLiteral([
+ ts.createPropertyAssignment("error", catchVariable)
+ ])))
+ ]), 1)), ts.createBlock([
+ ts.createTry(ts.createBlock([
+ ts.setEmitFlags(ts.createIf(ts.createLogicalAnd(ts.createLogicalAnd(result, ts.createLogicalNot(ts.createPropertyAccess(result, "done"))), ts.createAssignment(returnMethod, ts.createPropertyAccess(iterator, "return"))), ts.createStatement(ts.createYield(undefined, enclosingFunctionFlags & 1
+ ? ts.createArrayLiteral([
+ ts.createLiteral("await"),
+ ts.createFunctionCall(returnMethod, iterator, [])
+ ])
+ : ts.createFunctionCall(returnMethod, iterator, [])))), 1)
+ ]), undefined, ts.setEmitFlags(ts.createBlock([
+ ts.setEmitFlags(ts.createIf(errorRecord, ts.createThrow(ts.createPropertyAccess(errorRecord, "error"))), 1)
+ ]), 1))
+ ]));
}
function visitParameter(node) {
if (node.transformFlags & 1048576) {
- return ts.updateParameter(node, undefined, undefined, node.dotDotDotToken, ts.getGeneratedNameForNode(node), undefined, ts.visitNode(node.initializer, visitor, ts.isExpression));
+ return ts.updateParameter(node, undefined, undefined, node.dotDotDotToken, ts.getGeneratedNameForNode(node), undefined, undefined, ts.visitNode(node.initializer, visitor, ts.isExpression));
}
return ts.visitEachChild(node, visitor, context);
}
function visitConstructorDeclaration(node) {
- return ts.updateConstructor(node, undefined, node.modifiers, ts.visitParameterList(node.parameters, visitor, context), transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = 0;
+ var updated = ts.updateConstructor(node, undefined, node.modifiers, ts.visitParameterList(node.parameters, visitor, context), transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitGetAccessorDeclaration(node) {
- return ts.updateGetAccessor(node, undefined, node.modifiers, ts.visitNode(node.name, visitor, ts.isPropertyName), ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = 0;
+ var updated = ts.updateGetAccessor(node, undefined, node.modifiers, ts.visitNode(node.name, visitor, ts.isPropertyName), ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitSetAccessorDeclaration(node) {
- return ts.updateSetAccessor(node, undefined, node.modifiers, ts.visitNode(node.name, visitor, ts.isPropertyName), ts.visitParameterList(node.parameters, visitor, context), transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = 0;
+ var updated = ts.updateSetAccessor(node, undefined, node.modifiers, ts.visitNode(node.name, visitor, ts.isPropertyName), ts.visitParameterList(node.parameters, visitor, context), transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitMethodDeclaration(node) {
- return ts.updateMethod(node, undefined, node.modifiers, ts.visitNode(node.name, visitor, ts.isPropertyName), undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = ts.getFunctionFlags(node);
+ var updated = ts.updateMethod(node, undefined, enclosingFunctionFlags & 1
+ ? ts.visitNodes(node.modifiers, visitorNoAsyncModifier, ts.isModifier)
+ : node.modifiers, enclosingFunctionFlags & 2
+ ? undefined
+ : node.asteriskToken, ts.visitNode(node.name, visitor, ts.isPropertyName), ts.visitNode(undefined, visitor, ts.isToken), undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1
+ ? transformAsyncGeneratorFunctionBody(node)
+ : transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitFunctionDeclaration(node) {
- return ts.updateFunctionDeclaration(node, undefined, node.modifiers, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = ts.getFunctionFlags(node);
+ var updated = ts.updateFunctionDeclaration(node, undefined, enclosingFunctionFlags & 1
+ ? ts.visitNodes(node.modifiers, visitorNoAsyncModifier, ts.isModifier)
+ : node.modifiers, enclosingFunctionFlags & 2
+ ? undefined
+ : node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1
+ ? transformAsyncGeneratorFunctionBody(node)
+ : transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitArrowFunction(node) {
- return ts.updateArrowFunction(node, node.modifiers, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = ts.getFunctionFlags(node);
+ var updated = ts.updateArrowFunction(node, node.modifiers, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
}
function visitFunctionExpression(node) {
- return ts.updateFunctionExpression(node, node.modifiers, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ var savedEnclosingFunctionFlags = enclosingFunctionFlags;
+ enclosingFunctionFlags = ts.getFunctionFlags(node);
+ var updated = ts.updateFunctionExpression(node, enclosingFunctionFlags & 1
+ ? ts.visitNodes(node.modifiers, visitorNoAsyncModifier, ts.isModifier)
+ : node.modifiers, enclosingFunctionFlags & 2
+ ? undefined
+ : node.asteriskToken, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, enclosingFunctionFlags & 2 && enclosingFunctionFlags & 1
+ ? transformAsyncGeneratorFunctionBody(node)
+ : transformFunctionBody(node));
+ enclosingFunctionFlags = savedEnclosingFunctionFlags;
+ return updated;
+ }
+ function transformAsyncGeneratorFunctionBody(node) {
+ resumeLexicalEnvironment();
+ var statements = [];
+ var statementOffset = ts.addPrologue(statements, node.body.statements, false, visitor);
+ appendObjectRestAssignmentsIfNeeded(statements, node);
+ statements.push(ts.createReturn(createAsyncGeneratorHelper(context, ts.createFunctionExpression(undefined, ts.createToken(38), node.name && ts.getGeneratedNameForNode(node.name), undefined, [], undefined, ts.updateBlock(node.body, ts.visitLexicalEnvironment(node.body.statements, visitor, context, statementOffset))))));
+ ts.addRange(statements, endLexicalEnvironment());
+ var block = ts.updateBlock(node.body, statements);
+ if (languageVersion >= 2) {
+ if (resolver.getNodeCheckFlags(node) & 4096) {
+ enableSubstitutionForAsyncMethodsWithSuper();
+ ts.addEmitHelper(block, ts.advancedAsyncSuperHelper);
+ }
+ else if (resolver.getNodeCheckFlags(node) & 2048) {
+ enableSubstitutionForAsyncMethodsWithSuper();
+ ts.addEmitHelper(block, ts.asyncSuperHelper);
+ }
+ }
+ return block;
}
function transformFunctionBody(node) {
resumeLexicalEnvironment();
- var leadingStatements;
+ var statementOffset = 0;
+ var statements = [];
+ var body = ts.visitNode(node.body, visitor, ts.isConciseBody);
+ if (ts.isBlock(body)) {
+ statementOffset = ts.addPrologue(statements, body.statements, false, visitor);
+ }
+ ts.addRange(statements, appendObjectRestAssignmentsIfNeeded(undefined, node));
+ var trailingStatements = endLexicalEnvironment();
+ if (statementOffset > 0 || ts.some(statements) || ts.some(trailingStatements)) {
+ var block = ts.convertToFunctionBody(body, true);
+ ts.addRange(statements, block.statements.slice(statementOffset));
+ ts.addRange(statements, trailingStatements);
+ return ts.updateBlock(block, ts.setTextRange(ts.createNodeArray(statements), block.statements));
+ }
+ return body;
+ }
+ function appendObjectRestAssignmentsIfNeeded(statements, node) {
for (var _i = 0, _a = node.parameters; _i < _a.length; _i++) {
var parameter = _a[_i];
if (parameter.transformFlags & 1048576) {
@@ -39103,17 +42666,95 @@ var ts;
if (ts.some(declarations)) {
var statement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList(declarations));
ts.setEmitFlags(statement, 524288);
- leadingStatements = ts.append(leadingStatements, statement);
+ statements = ts.append(statements, statement);
}
}
}
- var body = ts.visitNode(node.body, visitor, ts.isConciseBody);
- var trailingStatements = endLexicalEnvironment();
- if (ts.some(leadingStatements) || ts.some(trailingStatements)) {
- var block = ts.convertToFunctionBody(body, true);
- return ts.updateBlock(block, ts.createNodeArray(ts.concatenate(ts.concatenate(leadingStatements, block.statements), trailingStatements), block.statements));
+ return statements;
+ }
+ function enableSubstitutionForAsyncMethodsWithSuper() {
+ if ((enabledSubstitutions & 1) === 0) {
+ enabledSubstitutions |= 1;
+ context.enableSubstitution(180);
+ context.enableSubstitution(178);
+ context.enableSubstitution(179);
+ context.enableEmitNotification(228);
+ context.enableEmitNotification(150);
+ context.enableEmitNotification(152);
+ context.enableEmitNotification(153);
+ context.enableEmitNotification(151);
+ }
+ }
+ function onEmitNode(hint, node, emitCallback) {
+ if (enabledSubstitutions & 1 && isSuperContainer(node)) {
+ var superContainerFlags = resolver.getNodeCheckFlags(node) & (2048 | 4096);
+ if (superContainerFlags !== enclosingSuperContainerFlags) {
+ var savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
+ enclosingSuperContainerFlags = superContainerFlags;
+ previousOnEmitNode(hint, node, emitCallback);
+ enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
+ return;
+ }
+ }
+ previousOnEmitNode(hint, node, emitCallback);
+ }
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (hint === 1 && enclosingSuperContainerFlags) {
+ return substituteExpression(node);
+ }
+ return node;
+ }
+ function substituteExpression(node) {
+ switch (node.kind) {
+ case 178:
+ return substitutePropertyAccessExpression(node);
+ case 179:
+ return substituteElementAccessExpression(node);
+ case 180:
+ return substituteCallExpression(node);
+ }
+ return node;
+ }
+ function substitutePropertyAccessExpression(node) {
+ if (node.expression.kind === 96) {
+ return createSuperAccessInAsyncMethod(ts.createLiteral(node.name.text), node);
+ }
+ return node;
+ }
+ function substituteElementAccessExpression(node) {
+ if (node.expression.kind === 96) {
+ return createSuperAccessInAsyncMethod(node.argumentExpression, node);
+ }
+ return node;
+ }
+ function substituteCallExpression(node) {
+ var expression = node.expression;
+ if (ts.isSuperProperty(expression)) {
+ var argumentExpression = ts.isPropertyAccessExpression(expression)
+ ? substitutePropertyAccessExpression(expression)
+ : substituteElementAccessExpression(expression);
+ return ts.createCall(ts.createPropertyAccess(argumentExpression, "call"), undefined, [
+ ts.createThis()
+ ].concat(node.arguments));
+ }
+ return node;
+ }
+ function isSuperContainer(node) {
+ var kind = node.kind;
+ return kind === 228
+ || kind === 151
+ || kind === 150
+ || kind === 152
+ || kind === 153;
+ }
+ function createSuperAccessInAsyncMethod(argumentExpression, location) {
+ if (enclosingSuperContainerFlags & 4096) {
+ return ts.setTextRange(ts.createPropertyAccess(ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression]), "value"), location);
+ }
+ else {
+ return ts.setTextRange(ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression]), location);
}
- return body;
}
}
ts.transformESNext = transformESNext;
@@ -39124,25 +42765,57 @@ var ts;
text: "\n var __assign = (this && this.__assign) || Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };"
};
function createAssignHelper(context, attributesSegments) {
+ if (context.getCompilerOptions().target >= 2) {
+ return ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Object"), "assign"), undefined, attributesSegments);
+ }
context.requestEmitHelper(assignHelper);
return ts.createCall(ts.getHelperName("__assign"), undefined, attributesSegments);
}
ts.createAssignHelper = createAssignHelper;
+ var asyncGeneratorHelper = {
+ name: "typescript:asyncGenerator",
+ scoped: false,
+ text: "\n var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), q = [], c, i;\n return i = { next: verb(\"next\"), \"throw\": verb(\"throw\"), \"return\": verb(\"return\") }, i[Symbol.asyncIterator] = function () { return this; }, i;\n function verb(n) { return function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]), next(); }); }; }\n function next() { if (!c && q.length) resume((c = q.shift())[0], c[1]); }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(c[3], e); } }\n function step(r) { r.done ? settle(c[2], r) : Promise.resolve(r.value[1]).then(r.value[0] === \"yield\" ? _yield : r.value[0] === \"delegate\" ? delegate : fulfill, reject); }\n function _yield(value) { settle(c[2], { value: value, done: false }); }\n function delegate(r) { step(r.done ? r : { value: [\"yield\", r.value], done: false }); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { c = void 0, f(v), next(); }\n };\n "
+ };
+ function createAsyncGeneratorHelper(context, generatorFunc) {
+ context.requestEmitHelper(asyncGeneratorHelper);
+ (generatorFunc.emitNode || (generatorFunc.emitNode = {})).flags |= 131072;
+ return ts.createCall(ts.getHelperName("__asyncGenerator"), undefined, [
+ ts.createThis(),
+ ts.createIdentifier("arguments"),
+ generatorFunc
+ ]);
+ }
+ var asyncDelegator = {
+ name: "typescript:asyncDelegator",
+ scoped: false,
+ text: "\n var __asyncDelegator = (this && this.__asyncDelegator) || function (o) {\n var i = { next: verb(\"next\"), \"throw\": verb(\"throw\", function (e) { throw e; }), \"return\": verb(\"return\", function (v) { return { value: v, done: true }; }) };\n return o = __asyncValues(o), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { return function (v) { return { value: [\"delegate\", (o[n] || f).call(o, v)], done: false }; }; }\n };\n "
+ };
+ function createAsyncDelegatorHelper(context, expression, location) {
+ context.requestEmitHelper(asyncDelegator);
+ return ts.setTextRange(ts.createCall(ts.getHelperName("__asyncDelegator"), undefined, [expression]), location);
+ }
+ var asyncValues = {
+ name: "typescript:asyncValues",
+ scoped: false,
+ text: "\n var __asyncValues = (this && this.__asyncIterator) || function (o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator];\n return m ? m.call(o) : typeof __values === \"function\" ? __values(o) : o[Symbol.iterator]();\n };\n "
+ };
+ function createAsyncValuesHelper(context, expression, location) {
+ context.requestEmitHelper(asyncValues);
+ return ts.setTextRange(ts.createCall(ts.getHelperName("__asyncValues"), undefined, [expression]), location);
+ }
})(ts || (ts = {}));
var ts;
(function (ts) {
function transformJsx(context) {
var compilerOptions = context.getCompilerOptions();
- var currentSourceFile;
return transformSourceFile;
function transformSourceFile(node) {
if (ts.isDeclarationFile(node)) {
return node;
}
- currentSourceFile = node;
var visited = ts.visitEachChild(node, visitor, context);
ts.addEmitHelpers(visited, context.readEmitHelpers());
- currentSourceFile = undefined;
return visited;
}
function visitor(node) {
@@ -39155,11 +42828,11 @@ var ts;
}
function visitorWorker(node) {
switch (node.kind) {
- case 246:
+ case 248:
return visitJsxElement(node, false);
- case 247:
+ case 249:
return visitJsxSelfClosingElement(node, false);
- case 252:
+ case 255:
return visitJsxExpression(node);
default:
return ts.visitEachChild(node, visitor, context);
@@ -39169,11 +42842,11 @@ var ts;
switch (node.kind) {
case 10:
return visitJsxText(node);
- case 252:
+ case 255:
return visitJsxExpression(node);
- case 246:
+ case 248:
return visitJsxElement(node, true);
- case 247:
+ case 249:
return visitJsxSelfClosingElement(node, true);
default:
ts.Debug.failBadSyntaxKind(node);
@@ -39189,7 +42862,7 @@ var ts;
function visitJsxOpeningLikeElement(node, children, isChild, location) {
var tagName = getTagName(node);
var objectProperties;
- var attrs = node.attributes;
+ var attrs = node.attributes.properties;
if (attrs.length === 0) {
objectProperties = ts.createNull();
}
@@ -39221,13 +42894,16 @@ var ts;
}
function transformJsxAttributeInitializer(node) {
if (node === undefined) {
- return ts.createLiteral(true);
+ return ts.createTrue();
}
else if (node.kind === 9) {
var decoded = tryDecodeEntities(node.text);
- return decoded ? ts.createLiteral(decoded, node) : node;
+ return decoded ? ts.setTextRange(ts.createLiteral(decoded), node) : node;
}
- else if (node.kind === 252) {
+ else if (node.kind === 255) {
+ if (node.expression === undefined) {
+ return ts.createTrue();
+ }
return visitJsxExpression(node);
}
else {
@@ -39235,43 +42911,35 @@ var ts;
}
}
function visitJsxText(node) {
- var text = ts.getTextOfNode(node, true);
- var parts;
+ var fixed = fixupWhitespaceAndDecodeEntities(ts.getTextOfNode(node, true));
+ return fixed === undefined ? undefined : ts.createLiteral(fixed);
+ }
+ function fixupWhitespaceAndDecodeEntities(text) {
+ var acc;
var firstNonWhitespace = 0;
var lastNonWhitespace = -1;
for (var i = 0; i < text.length; i++) {
var c = text.charCodeAt(i);
if (ts.isLineBreak(c)) {
- if (firstNonWhitespace !== -1 && (lastNonWhitespace - firstNonWhitespace + 1 > 0)) {
- var part = text.substr(firstNonWhitespace, lastNonWhitespace - firstNonWhitespace + 1);
- if (!parts) {
- parts = [];
- }
- parts.push(ts.createLiteral(decodeEntities(part)));
+ if (firstNonWhitespace !== -1 && lastNonWhitespace !== -1) {
+ acc = addLineOfJsxText(acc, text.substr(firstNonWhitespace, lastNonWhitespace - firstNonWhitespace + 1));
}
firstNonWhitespace = -1;
}
- else if (!ts.isWhiteSpace(c)) {
+ else if (!ts.isWhiteSpaceSingleLine(c)) {
lastNonWhitespace = i;
if (firstNonWhitespace === -1) {
firstNonWhitespace = i;
}
}
}
- if (firstNonWhitespace !== -1) {
- var part = text.substr(firstNonWhitespace);
- if (!parts) {
- parts = [];
- }
- parts.push(ts.createLiteral(decodeEntities(part)));
- }
- if (parts) {
- return ts.reduceLeft(parts, aggregateJsxTextParts);
- }
- return undefined;
+ return firstNonWhitespace !== -1
+ ? addLineOfJsxText(acc, text.substr(firstNonWhitespace))
+ : acc;
}
- function aggregateJsxTextParts(left, right) {
- return ts.createAdd(ts.createAdd(left, ts.createLiteral(" ")), right);
+ function addLineOfJsxText(acc, trimmedLine) {
+ var decoded = decodeEntities(trimmedLine);
+ return acc === undefined ? decoded : acc + " " + decoded;
}
function decodeEntities(text) {
return text.replace(/&((#((\d+)|x([\da-fA-F]+)))|(\w+));/g, function (match, _all, _number, _digits, decimal, hex, word) {
@@ -39282,7 +42950,7 @@ var ts;
return String.fromCharCode(parseInt(hex, 16));
}
else {
- var ch = entities[word];
+ var ch = entities.get(word);
return ch ? String.fromCharCode(ch) : match;
}
});
@@ -39292,16 +42960,16 @@ var ts;
return decoded === text ? undefined : decoded;
}
function getTagName(node) {
- if (node.kind === 246) {
+ if (node.kind === 248) {
return getTagName(node.openingElement);
}
else {
- var name_34 = node.tagName;
- if (ts.isIdentifier(name_34) && ts.isIntrinsicJsxName(name_34.text)) {
- return ts.createLiteral(name_34.text);
+ var name = node.tagName;
+ if (ts.isIdentifier(name) && ts.isIntrinsicJsxName(name.text)) {
+ return ts.createLiteral(name.text);
}
else {
- return ts.createExpressionFromEntityName(name_34);
+ return ts.createExpressionFromEntityName(name);
}
}
}
@@ -39319,7 +42987,7 @@ var ts;
}
}
ts.transformJsx = transformJsx;
- var entities = ts.createMap({
+ var entities = ts.createMapFromTemplate({
"quot": 0x0022,
"amp": 0x0026,
"apos": 0x0027,
@@ -39577,263 +43245,6 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- function transformES2017(context) {
- var startLexicalEnvironment = context.startLexicalEnvironment, resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment;
- var resolver = context.getEmitResolver();
- var compilerOptions = context.getCompilerOptions();
- var languageVersion = ts.getEmitScriptTarget(compilerOptions);
- var currentSourceFile;
- var enabledSubstitutions;
- var currentSuperContainer;
- var previousOnEmitNode = context.onEmitNode;
- var previousOnSubstituteNode = context.onSubstituteNode;
- context.onEmitNode = onEmitNode;
- context.onSubstituteNode = onSubstituteNode;
- return transformSourceFile;
- function transformSourceFile(node) {
- if (ts.isDeclarationFile(node)) {
- return node;
- }
- currentSourceFile = node;
- var visited = ts.visitEachChild(node, visitor, context);
- ts.addEmitHelpers(visited, context.readEmitHelpers());
- currentSourceFile = undefined;
- return visited;
- }
- function visitor(node) {
- if ((node.transformFlags & 16) === 0) {
- return node;
- }
- switch (node.kind) {
- case 119:
- return undefined;
- case 189:
- return visitAwaitExpression(node);
- case 149:
- return visitMethodDeclaration(node);
- case 225:
- return visitFunctionDeclaration(node);
- case 184:
- return visitFunctionExpression(node);
- case 185:
- return visitArrowFunction(node);
- default:
- return ts.visitEachChild(node, visitor, context);
- }
- }
- function visitAwaitExpression(node) {
- return ts.setOriginalNode(ts.createYield(undefined, ts.visitNode(node.expression, visitor, ts.isExpression), node), node);
- }
- function visitMethodDeclaration(node) {
- return ts.updateMethod(node, undefined, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.isAsyncFunctionLike(node)
- ? transformAsyncFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
- }
- function visitFunctionDeclaration(node) {
- return ts.updateFunctionDeclaration(node, undefined, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.isAsyncFunctionLike(node)
- ? transformAsyncFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
- }
- function visitFunctionExpression(node) {
- if (ts.nodeIsMissing(node.body)) {
- return ts.createOmittedExpression();
- }
- return ts.updateFunctionExpression(node, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.isAsyncFunctionLike(node)
- ? transformAsyncFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
- }
- function visitArrowFunction(node) {
- return ts.updateArrowFunction(node, ts.visitNodes(node.modifiers, visitor, ts.isModifier), undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, ts.isAsyncFunctionLike(node)
- ? transformAsyncFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
- }
- function transformAsyncFunctionBody(node) {
- resumeLexicalEnvironment();
- var original = ts.getOriginalNode(node, ts.isFunctionLike);
- var nodeType = original.type;
- var promiseConstructor = languageVersion < 2 ? getPromiseConstructor(nodeType) : undefined;
- var isArrowFunction = node.kind === 185;
- var hasLexicalArguments = (resolver.getNodeCheckFlags(node) & 8192) !== 0;
- if (!isArrowFunction) {
- var statements = [];
- var statementOffset = ts.addPrologueDirectives(statements, node.body.statements, false, visitor);
- statements.push(ts.createReturn(createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, transformFunctionBodyWorker(node.body, statementOffset))));
- ts.addRange(statements, endLexicalEnvironment());
- var block = ts.createBlock(statements, node.body, true);
- if (languageVersion >= 2) {
- if (resolver.getNodeCheckFlags(node) & 4096) {
- enableSubstitutionForAsyncMethodsWithSuper();
- ts.addEmitHelper(block, advancedAsyncSuperHelper);
- }
- else if (resolver.getNodeCheckFlags(node) & 2048) {
- enableSubstitutionForAsyncMethodsWithSuper();
- ts.addEmitHelper(block, asyncSuperHelper);
- }
- }
- return block;
- }
- else {
- var expression = createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, transformFunctionBodyWorker(node.body));
- var declarations = endLexicalEnvironment();
- if (ts.some(declarations)) {
- var block = ts.convertToFunctionBody(expression);
- return ts.updateBlock(block, ts.createNodeArray(ts.concatenate(block.statements, declarations), block.statements));
- }
- return expression;
- }
- }
- function transformFunctionBodyWorker(body, start) {
- if (ts.isBlock(body)) {
- return ts.updateBlock(body, ts.visitLexicalEnvironment(body.statements, visitor, context, start));
- }
- else {
- startLexicalEnvironment();
- var visited = ts.convertToFunctionBody(ts.visitNode(body, visitor, ts.isConciseBody));
- var declarations = endLexicalEnvironment();
- return ts.updateBlock(visited, ts.createNodeArray(ts.concatenate(visited.statements, declarations), visited.statements));
- }
- }
- function getPromiseConstructor(type) {
- var typeName = type && ts.getEntityNameFromTypeNode(type);
- if (typeName && ts.isEntityName(typeName)) {
- var serializationKind = resolver.getTypeReferenceSerializationKind(typeName);
- if (serializationKind === ts.TypeReferenceSerializationKind.TypeWithConstructSignatureAndValue
- || serializationKind === ts.TypeReferenceSerializationKind.Unknown) {
- return typeName;
- }
- }
- return undefined;
- }
- function enableSubstitutionForAsyncMethodsWithSuper() {
- if ((enabledSubstitutions & 1) === 0) {
- enabledSubstitutions |= 1;
- context.enableSubstitution(179);
- context.enableSubstitution(177);
- context.enableSubstitution(178);
- context.enableEmitNotification(226);
- context.enableEmitNotification(149);
- context.enableEmitNotification(151);
- context.enableEmitNotification(152);
- context.enableEmitNotification(150);
- }
- }
- function substituteExpression(node) {
- switch (node.kind) {
- case 177:
- return substitutePropertyAccessExpression(node);
- case 178:
- return substituteElementAccessExpression(node);
- case 179:
- if (enabledSubstitutions & 1) {
- return substituteCallExpression(node);
- }
- break;
- }
- return node;
- }
- function substitutePropertyAccessExpression(node) {
- if (enabledSubstitutions & 1 && node.expression.kind === 96) {
- var flags = getSuperContainerAsyncMethodFlags();
- if (flags) {
- return createSuperAccessInAsyncMethod(ts.createLiteral(node.name.text), flags, node);
- }
- }
- return node;
- }
- function substituteElementAccessExpression(node) {
- if (enabledSubstitutions & 1 && node.expression.kind === 96) {
- var flags = getSuperContainerAsyncMethodFlags();
- if (flags) {
- return createSuperAccessInAsyncMethod(node.argumentExpression, flags, node);
- }
- }
- return node;
- }
- function substituteCallExpression(node) {
- var expression = node.expression;
- if (ts.isSuperProperty(expression)) {
- var flags = getSuperContainerAsyncMethodFlags();
- if (flags) {
- var argumentExpression = ts.isPropertyAccessExpression(expression)
- ? substitutePropertyAccessExpression(expression)
- : substituteElementAccessExpression(expression);
- return ts.createCall(ts.createPropertyAccess(argumentExpression, "call"), undefined, [
- ts.createThis()
- ].concat(node.arguments));
- }
- }
- return node;
- }
- function isSuperContainer(node) {
- var kind = node.kind;
- return kind === 226
- || kind === 150
- || kind === 149
- || kind === 151
- || kind === 152;
- }
- function onEmitNode(emitContext, node, emitCallback) {
- if (enabledSubstitutions & 1 && isSuperContainer(node)) {
- var savedCurrentSuperContainer = currentSuperContainer;
- currentSuperContainer = node;
- previousOnEmitNode(emitContext, node, emitCallback);
- currentSuperContainer = savedCurrentSuperContainer;
- }
- else {
- previousOnEmitNode(emitContext, node, emitCallback);
- }
- }
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (emitContext === 1) {
- return substituteExpression(node);
- }
- return node;
- }
- function createSuperAccessInAsyncMethod(argumentExpression, flags, location) {
- if (flags & 4096) {
- return ts.createPropertyAccess(ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression]), "value", location);
- }
- else {
- return ts.createCall(ts.createIdentifier("_super"), undefined, [argumentExpression], location);
- }
- }
- function getSuperContainerAsyncMethodFlags() {
- return currentSuperContainer !== undefined
- && resolver.getNodeCheckFlags(currentSuperContainer) & (2048 | 4096);
- }
- }
- ts.transformES2017 = transformES2017;
- function createAwaiterHelper(context, hasLexicalArguments, promiseConstructor, body) {
- context.requestEmitHelper(awaiterHelper);
- var generatorFunc = ts.createFunctionExpression(undefined, ts.createToken(38), undefined, undefined, [], undefined, body);
- (generatorFunc.emitNode || (generatorFunc.emitNode = {})).flags |= 131072;
- return ts.createCall(ts.getHelperName("__awaiter"), undefined, [
- ts.createThis(),
- hasLexicalArguments ? ts.createIdentifier("arguments") : ts.createVoidZero(),
- promiseConstructor ? ts.createExpressionFromEntityName(promiseConstructor) : ts.createVoidZero(),
- generatorFunc
- ]);
- }
- var awaiterHelper = {
- name: "typescript:awaiter",
- scoped: false,
- priority: 5,
- text: "\n var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments)).next());\n });\n };"
- };
- var asyncSuperHelper = {
- name: "typescript:async-super",
- scoped: true,
- text: "\n const _super = name => super[name];"
- };
- var advancedAsyncSuperHelper = {
- name: "typescript:advanced-async-super",
- scoped: true,
- text: "\n const _super = (function (geti, seti) {\n const cache = Object.create(null);\n return name => cache[name] || (cache[name] = { get value() { return geti(name); }, set value(v) { seti(name, v); } });\n })(name => super[name], (name, value) => super[name] = value);"
- };
-})(ts || (ts = {}));
-var ts;
-(function (ts) {
function transformES2016(context) {
var hoistVariableDeclaration = context.hoistVariableDeclaration;
return transformSourceFile;
@@ -39848,7 +43259,7 @@ var ts;
return node;
}
switch (node.kind) {
- case 192:
+ case 193:
return visitBinaryExpression(node);
default:
return ts.visitEachChild(node, visitor, context);
@@ -39872,19 +43283,19 @@ var ts;
if (ts.isElementAccessExpression(left)) {
var expressionTemp = ts.createTempVariable(hoistVariableDeclaration);
var argumentExpressionTemp = ts.createTempVariable(hoistVariableDeclaration);
- target = ts.createElementAccess(ts.createAssignment(expressionTemp, left.expression, left.expression), ts.createAssignment(argumentExpressionTemp, left.argumentExpression, left.argumentExpression), left);
- value = ts.createElementAccess(expressionTemp, argumentExpressionTemp, left);
+ target = ts.setTextRange(ts.createElementAccess(ts.setTextRange(ts.createAssignment(expressionTemp, left.expression), left.expression), ts.setTextRange(ts.createAssignment(argumentExpressionTemp, left.argumentExpression), left.argumentExpression)), left);
+ value = ts.setTextRange(ts.createElementAccess(expressionTemp, argumentExpressionTemp), left);
}
else if (ts.isPropertyAccessExpression(left)) {
var expressionTemp = ts.createTempVariable(hoistVariableDeclaration);
- target = ts.createPropertyAccess(ts.createAssignment(expressionTemp, left.expression, left.expression), left.name, left);
- value = ts.createPropertyAccess(expressionTemp, left.name, left);
+ target = ts.setTextRange(ts.createPropertyAccess(ts.setTextRange(ts.createAssignment(expressionTemp, left.expression), left.expression), left.name), left);
+ value = ts.setTextRange(ts.createPropertyAccess(expressionTemp, left.name), left);
}
else {
target = left;
value = left;
}
- return ts.createAssignment(target, ts.createMathPow(value, right, node), node);
+ return ts.setTextRange(ts.createAssignment(target, ts.createMathPow(value, right, node)), node);
}
function visitExponentiationExpression(node) {
var left = ts.visitNode(node.left, visitor, ts.isExpression);
@@ -39898,6 +43309,7 @@ var ts;
(function (ts) {
function transformES2015(context) {
var startLexicalEnvironment = context.startLexicalEnvironment, resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment, hoistVariableDeclaration = context.hoistVariableDeclaration;
+ var compilerOptions = context.getCompilerOptions();
var resolver = context.getEmitResolver();
var previousOnSubstituteNode = context.onSubstituteNode;
var previousOnEmitNode = context.onEmitNode;
@@ -39905,15 +43317,7 @@ var ts;
context.onSubstituteNode = onSubstituteNode;
var currentSourceFile;
var currentText;
- var currentParent;
- var currentNode;
- var enclosingVariableStatement;
- var enclosingBlockScopeContainer;
- var enclosingBlockScopeContainerParent;
- var enclosingFunction;
- var enclosingNonArrowFunction;
- var enclosingNonAsyncFunctionBody;
- var isInConstructorWithCapturedSuper;
+ var hierarchyFacts;
var convertedLoopState;
var enabledSubstitutions;
return transformSourceFile;
@@ -39923,247 +43327,207 @@ var ts;
}
currentSourceFile = node;
currentText = node.text;
- var visited = saveStateAndInvoke(node, visitSourceFile);
+ var visited = visitSourceFile(node);
ts.addEmitHelpers(visited, context.readEmitHelpers());
currentSourceFile = undefined;
currentText = undefined;
+ hierarchyFacts = 0;
return visited;
}
- function visitor(node) {
- return saveStateAndInvoke(node, dispatcher);
- }
- function dispatcher(node) {
- return convertedLoopState
- ? visitorForConvertedLoopWorker(node)
- : visitorWorker(node);
+ function enterSubtree(excludeFacts, includeFacts) {
+ var ancestorFacts = hierarchyFacts;
+ hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & 16383;
+ return ancestorFacts;
}
- function saveStateAndInvoke(node, f) {
- var savedEnclosingFunction = enclosingFunction;
- var savedEnclosingNonArrowFunction = enclosingNonArrowFunction;
- var savedEnclosingNonAsyncFunctionBody = enclosingNonAsyncFunctionBody;
- var savedEnclosingBlockScopeContainer = enclosingBlockScopeContainer;
- var savedEnclosingBlockScopeContainerParent = enclosingBlockScopeContainerParent;
- var savedEnclosingVariableStatement = enclosingVariableStatement;
- var savedCurrentParent = currentParent;
- var savedCurrentNode = currentNode;
- var savedConvertedLoopState = convertedLoopState;
- var savedIsInConstructorWithCapturedSuper = isInConstructorWithCapturedSuper;
- if (ts.nodeStartsNewLexicalEnvironment(node)) {
- isInConstructorWithCapturedSuper = false;
- convertedLoopState = undefined;
- }
- onBeforeVisitNode(node);
- var visited = f(node);
- isInConstructorWithCapturedSuper = savedIsInConstructorWithCapturedSuper;
- convertedLoopState = savedConvertedLoopState;
- enclosingFunction = savedEnclosingFunction;
- enclosingNonArrowFunction = savedEnclosingNonArrowFunction;
- enclosingNonAsyncFunctionBody = savedEnclosingNonAsyncFunctionBody;
- enclosingBlockScopeContainer = savedEnclosingBlockScopeContainer;
- enclosingBlockScopeContainerParent = savedEnclosingBlockScopeContainerParent;
- enclosingVariableStatement = savedEnclosingVariableStatement;
- currentParent = savedCurrentParent;
- currentNode = savedCurrentNode;
- return visited;
- }
- function onBeforeVisitNode(node) {
- if (currentNode) {
- if (ts.isBlockScope(currentNode, currentParent)) {
- enclosingBlockScopeContainer = currentNode;
- enclosingBlockScopeContainerParent = currentParent;
- }
- if (ts.isFunctionLike(currentNode)) {
- enclosingFunction = currentNode;
- if (currentNode.kind !== 185) {
- enclosingNonArrowFunction = currentNode;
- if (!(ts.getEmitFlags(currentNode) & 131072)) {
- enclosingNonAsyncFunctionBody = currentNode;
- }
- }
- }
- switch (currentNode.kind) {
- case 205:
- enclosingVariableStatement = currentNode;
- break;
- case 224:
- case 223:
- case 174:
- case 172:
- case 173:
- break;
- default:
- enclosingVariableStatement = undefined;
- }
- }
- currentParent = currentNode;
- currentNode = node;
- }
- function returnCapturedThis(node) {
- return ts.setOriginalNode(ts.createReturn(ts.createIdentifier("_this")), node);
+ function exitSubtree(ancestorFacts, excludeFacts, includeFacts) {
+ hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & -16384 | ancestorFacts;
}
function isReturnVoidStatementInConstructorWithCapturedSuper(node) {
- return isInConstructorWithCapturedSuper && node.kind === 216 && !node.expression;
+ return hierarchyFacts & 4096
+ && node.kind === 218
+ && !node.expression;
}
- function shouldCheckNode(node) {
- return (node.transformFlags & 64) !== 0 ||
- node.kind === 219 ||
- (ts.isIterationStatement(node, false) && shouldConvertIterationStatementBody(node));
+ function shouldVisitNode(node) {
+ return (node.transformFlags & 128) !== 0
+ || convertedLoopState !== undefined
+ || (hierarchyFacts & 4096 && ts.isStatement(node))
+ || (ts.isIterationStatement(node, false) && shouldConvertIterationStatementBody(node));
}
- function visitorWorker(node) {
- if (isReturnVoidStatementInConstructorWithCapturedSuper(node)) {
- return returnCapturedThis(node);
- }
- else if (shouldCheckNode(node)) {
+ function visitor(node) {
+ if (shouldVisitNode(node)) {
return visitJavaScript(node);
}
- else if (node.transformFlags & 128 || (isInConstructorWithCapturedSuper && !ts.isExpression(node))) {
- return ts.visitEachChild(node, visitor, context);
- }
else {
return node;
}
}
- function visitorForConvertedLoopWorker(node) {
- var result;
- if (shouldCheckNode(node)) {
- result = visitJavaScript(node);
+ function functionBodyVisitor(node) {
+ if (shouldVisitNode(node)) {
+ return visitBlock(node, true);
}
- else {
- result = visitNodesInConvertedLoop(node);
- }
- return result;
+ return node;
}
- function visitNodesInConvertedLoop(node) {
- switch (node.kind) {
- case 216:
- node = isReturnVoidStatementInConstructorWithCapturedSuper(node) ? returnCapturedThis(node) : node;
- return visitReturnStatement(node);
- case 205:
- return visitVariableStatement(node);
- case 218:
- return visitSwitchStatement(node);
- case 215:
- case 214:
- return visitBreakOrContinueStatement(node);
- case 98:
- return visitThisKeyword(node);
- case 70:
- return visitIdentifier(node);
- default:
- return ts.visitEachChild(node, visitor, context);
+ function callExpressionVisitor(node) {
+ if (node.kind === 96) {
+ return visitSuperKeyword(true);
}
+ return visitor(node);
}
function visitJavaScript(node) {
switch (node.kind) {
case 114:
return undefined;
- case 226:
+ case 228:
return visitClassDeclaration(node);
- case 197:
+ case 198:
return visitClassExpression(node);
- case 144:
+ case 145:
return visitParameter(node);
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 185:
+ case 186:
return visitArrowFunction(node);
- case 184:
+ case 185:
return visitFunctionExpression(node);
- case 223:
+ case 225:
return visitVariableDeclaration(node);
case 70:
return visitIdentifier(node);
- case 224:
+ case 226:
return visitVariableDeclarationList(node);
- case 219:
+ case 220:
+ return visitSwitchStatement(node);
+ case 234:
+ return visitCaseBlock(node);
+ case 206:
+ return visitBlock(node, false);
+ case 217:
+ case 216:
+ return visitBreakOrContinueStatement(node);
+ case 221:
return visitLabeledStatement(node);
- case 209:
- return visitDoStatement(node);
- case 210:
- return visitWhileStatement(node);
case 211:
- return visitForStatement(node);
case 212:
- return visitForInStatement(node);
+ return visitDoOrWhileStatement(node, undefined);
case 213:
- return visitForOfStatement(node);
- case 207:
+ return visitForStatement(node, undefined);
+ case 214:
+ return visitForInStatement(node, undefined);
+ case 215:
+ return visitForOfStatement(node, undefined);
+ case 209:
return visitExpressionStatement(node);
- case 176:
+ case 177:
return visitObjectLiteralExpression(node);
- case 256:
+ case 259:
return visitCatchClause(node);
- case 258:
+ case 261:
return visitShorthandPropertyAssignment(node);
- case 175:
+ case 143:
+ return visitComputedPropertyName(node);
+ case 176:
return visitArrayLiteralExpression(node);
- case 179:
- return visitCallExpression(node);
case 180:
+ return visitCallExpression(node);
+ case 181:
return visitNewExpression(node);
- case 183:
+ case 184:
return visitParenthesizedExpression(node, true);
- case 192:
+ case 193:
return visitBinaryExpression(node, true);
case 12:
case 13:
case 14:
case 15:
return visitTemplateLiteral(node);
- case 181:
+ case 9:
+ return visitStringLiteral(node);
+ case 8:
+ return visitNumericLiteral(node);
+ case 182:
return visitTaggedTemplateExpression(node);
- case 194:
- return visitTemplateExpression(node);
case 195:
- return visitYieldExpression(node);
+ return visitTemplateExpression(node);
case 196:
+ return visitYieldExpression(node);
+ case 197:
return visitSpreadElement(node);
case 96:
- return visitSuperKeyword();
- case 195:
- return ts.visitEachChild(node, visitor, context);
- case 149:
+ return visitSuperKeyword(false);
+ case 98:
+ return visitThisKeyword(node);
+ case 203:
+ return visitMetaProperty(node);
+ case 150:
return visitMethodDeclaration(node);
- case 205:
+ case 152:
+ case 153:
+ return visitAccessorDeclaration(node);
+ case 207:
return visitVariableStatement(node);
+ case 218:
+ return visitReturnStatement(node);
default:
- ts.Debug.failBadSyntaxKind(node);
return ts.visitEachChild(node, visitor, context);
}
}
function visitSourceFile(node) {
+ var ancestorFacts = enterSubtree(3968, 64);
var statements = [];
startLexicalEnvironment();
- var statementOffset = ts.addPrologueDirectives(statements, node.statements, false, visitor);
+ var statementOffset = ts.addStandardPrologue(statements, node.statements, false);
addCaptureThisForNodeIfNeeded(statements, node);
+ statementOffset = ts.addCustomPrologue(statements, node.statements, statementOffset, visitor);
ts.addRange(statements, ts.visitNodes(node.statements, visitor, ts.isStatement, statementOffset));
ts.addRange(statements, endLexicalEnvironment());
- return ts.updateSourceFileNode(node, ts.createNodeArray(statements, node.statements));
+ exitSubtree(ancestorFacts, 0, 0);
+ return ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray(statements), node.statements));
}
function visitSwitchStatement(node) {
- ts.Debug.assert(convertedLoopState !== undefined);
- var savedAllowedNonLabeledJumps = convertedLoopState.allowedNonLabeledJumps;
- convertedLoopState.allowedNonLabeledJumps |= 2;
- var result = ts.visitEachChild(node, visitor, context);
- convertedLoopState.allowedNonLabeledJumps = savedAllowedNonLabeledJumps;
- return result;
+ if (convertedLoopState !== undefined) {
+ var savedAllowedNonLabeledJumps = convertedLoopState.allowedNonLabeledJumps;
+ convertedLoopState.allowedNonLabeledJumps |= 2;
+ var result = ts.visitEachChild(node, visitor, context);
+ convertedLoopState.allowedNonLabeledJumps = savedAllowedNonLabeledJumps;
+ return result;
+ }
+ return ts.visitEachChild(node, visitor, context);
+ }
+ function visitCaseBlock(node) {
+ var ancestorFacts = enterSubtree(4032, 0);
+ var updated = ts.visitEachChild(node, visitor, context);
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
+ }
+ function returnCapturedThis(node) {
+ return ts.setOriginalNode(ts.createReturn(ts.createIdentifier("_this")), node);
}
function visitReturnStatement(node) {
- ts.Debug.assert(convertedLoopState !== undefined);
- convertedLoopState.nonLocalJumps |= 8;
- return ts.createReturn(ts.createObjectLiteral([
- ts.createPropertyAssignment(ts.createIdentifier("value"), node.expression
- ? ts.visitNode(node.expression, visitor, ts.isExpression)
- : ts.createVoidZero())
- ]));
+ if (convertedLoopState) {
+ convertedLoopState.nonLocalJumps |= 8;
+ if (isReturnVoidStatementInConstructorWithCapturedSuper(node)) {
+ node = returnCapturedThis(node);
+ }
+ return ts.createReturn(ts.createObjectLiteral([
+ ts.createPropertyAssignment(ts.createIdentifier("value"), node.expression
+ ? ts.visitNode(node.expression, visitor, ts.isExpression)
+ : ts.createVoidZero())
+ ]));
+ }
+ else if (isReturnVoidStatementInConstructorWithCapturedSuper(node)) {
+ return returnCapturedThis(node);
+ }
+ return ts.visitEachChild(node, visitor, context);
}
function visitThisKeyword(node) {
- ts.Debug.assert(convertedLoopState !== undefined);
- if (enclosingFunction && enclosingFunction.kind === 185) {
- convertedLoopState.containsLexicalThis = true;
- return node;
+ if (convertedLoopState) {
+ if (hierarchyFacts & 2) {
+ convertedLoopState.containsLexicalThis = true;
+ return node;
+ }
+ return convertedLoopState.thisName || (convertedLoopState.thisName = ts.createUniqueName("this"));
}
- return convertedLoopState.thisName || (convertedLoopState.thisName = ts.createUniqueName("this"));
+ return node;
}
function visitIdentifier(node) {
if (!convertedLoopState) {
@@ -40172,20 +43536,20 @@ var ts;
if (ts.isGeneratedIdentifier(node)) {
return node;
}
- if (node.text !== "arguments" && !resolver.isArgumentsLocalBinding(node)) {
+ if (node.text !== "arguments" || !resolver.isArgumentsLocalBinding(node)) {
return node;
}
return convertedLoopState.argumentsName || (convertedLoopState.argumentsName = ts.createUniqueName("arguments"));
}
function visitBreakOrContinueStatement(node) {
if (convertedLoopState) {
- var jump = node.kind === 215 ? 2 : 4;
- var canUseBreakOrContinue = (node.label && convertedLoopState.labels && convertedLoopState.labels[node.label.text]) ||
+ var jump = node.kind === 217 ? 2 : 4;
+ var canUseBreakOrContinue = (node.label && convertedLoopState.labels && convertedLoopState.labels.get(node.label.text)) ||
(!node.label && (convertedLoopState.allowedNonLabeledJumps & jump));
if (!canUseBreakOrContinue) {
var labelMarker = void 0;
if (!node.label) {
- if (node.kind === 215) {
+ if (node.kind === 217) {
convertedLoopState.nonLocalJumps |= 2;
labelMarker = "break";
}
@@ -40195,7 +43559,7 @@ var ts;
}
}
else {
- if (node.kind === 215) {
+ if (node.kind === 217) {
labelMarker = "break-" + node.label.text;
setLabeledJump(convertedLoopState, true, node.label.text, labelMarker);
}
@@ -40228,8 +43592,9 @@ var ts;
var variable = ts.createVariableDeclaration(ts.getLocalName(node, true), undefined, transformClassLikeDeclarationToExpression(node));
ts.setOriginalNode(variable, node);
var statements = [];
- var statement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList([variable]), node);
+ var statement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList([variable]));
ts.setOriginalNode(statement, node);
+ ts.setTextRange(statement, node);
ts.startOnNewLine(statement);
statements.push(statement);
if (ts.hasModifier(node, 1)) {
@@ -40284,23 +43649,29 @@ var ts;
ts.setEmitFlags(statement, 1536 | 384);
statements.push(statement);
ts.addRange(statements, endLexicalEnvironment());
- var block = ts.createBlock(ts.createNodeArray(statements, node.members), undefined, true);
+ var block = ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), node.members), true);
ts.setEmitFlags(block, 1536);
return block;
}
function addExtendsHelperIfNeeded(statements, node, extendsClauseElement) {
if (extendsClauseElement) {
- statements.push(ts.createStatement(createExtendsHelper(context, ts.getLocalName(node)), extendsClauseElement));
+ statements.push(ts.setTextRange(ts.createStatement(createExtendsHelper(context, ts.getLocalName(node))), extendsClauseElement));
}
}
function addConstructor(statements, node, extendsClauseElement) {
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var ancestorFacts = enterSubtree(16278, 73);
var constructor = ts.getFirstConstructorWithBody(node);
var hasSynthesizedSuper = hasSynthesizedDefaultSuperCall(constructor, extendsClauseElement !== undefined);
- var constructorFunction = ts.createFunctionDeclaration(undefined, undefined, undefined, ts.getDeclarationName(node), undefined, transformConstructorParameters(constructor, hasSynthesizedSuper), undefined, transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper), constructor || node);
+ var constructorFunction = ts.createFunctionDeclaration(undefined, undefined, undefined, ts.getDeclarationName(node), undefined, transformConstructorParameters(constructor, hasSynthesizedSuper), undefined, transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper));
+ ts.setTextRange(constructorFunction, constructor || node);
if (extendsClauseElement) {
ts.setEmitFlags(constructorFunction, 8);
}
statements.push(constructorFunction);
+ exitSubtree(ancestorFacts, 49152, 0);
+ convertedLoopState = savedConvertedLoopState;
}
function transformConstructorParameters(constructor, hasSynthesizedSuper) {
return ts.visitParameterList(constructor && !hasSynthesizedSuper && constructor.parameters, visitor, context)
@@ -40314,48 +43685,55 @@ var ts;
statementOffset = 0;
}
else if (constructor) {
- statementOffset = ts.addPrologueDirectives(statements, constructor.body.statements, false, visitor);
+ statementOffset = ts.addStandardPrologue(statements, constructor.body.statements, false);
}
if (constructor) {
addDefaultValueAssignmentsIfNeeded(statements, constructor);
addRestParameterIfNeeded(statements, constructor, hasSynthesizedSuper);
+ if (!hasSynthesizedSuper) {
+ statementOffset = ts.addCustomPrologue(statements, constructor.body.statements, statementOffset, visitor);
+ }
ts.Debug.assert(statementOffset >= 0, "statementOffset not initialized correctly!");
}
- var superCaptureStatus = declareOrCaptureOrReturnThisForConstructorIfNeeded(statements, constructor, !!extendsClauseElement, hasSynthesizedSuper, statementOffset);
+ var isDerivedClass = extendsClauseElement && ts.skipOuterExpressions(extendsClauseElement.expression).kind !== 94;
+ var superCaptureStatus = declareOrCaptureOrReturnThisForConstructorIfNeeded(statements, constructor, isDerivedClass, hasSynthesizedSuper, statementOffset);
if (superCaptureStatus === 1 || superCaptureStatus === 2) {
statementOffset++;
}
if (constructor) {
- var body = saveStateAndInvoke(constructor, function (constructor) {
- isInConstructorWithCapturedSuper = superCaptureStatus === 1;
- return ts.visitNodes(constructor.body.statements, visitor, ts.isStatement, statementOffset);
- });
- ts.addRange(statements, body);
+ if (superCaptureStatus === 1) {
+ hierarchyFacts |= 4096;
+ }
+ ts.addRange(statements, ts.visitNodes(constructor.body.statements, visitor, ts.isStatement, statementOffset));
}
- if (extendsClauseElement
+ if (isDerivedClass
&& superCaptureStatus !== 2
&& !(constructor && isSufficientlyCoveredByReturnStatements(constructor.body))) {
statements.push(ts.createReturn(ts.createIdentifier("_this")));
}
ts.addRange(statements, endLexicalEnvironment());
- var block = ts.createBlock(ts.createNodeArray(statements, constructor ? constructor.body.statements : node.members), constructor ? constructor.body : node, true);
+ if (constructor) {
+ prependCaptureNewTargetIfNeeded(statements, constructor, false);
+ }
+ var block = ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), constructor ? constructor.body.statements : node.members), true);
+ ts.setTextRange(block, constructor ? constructor.body : node);
if (!constructor) {
ts.setEmitFlags(block, 1536);
}
return block;
}
function isSufficientlyCoveredByReturnStatements(statement) {
- if (statement.kind === 216) {
+ if (statement.kind === 218) {
return true;
}
- else if (statement.kind === 208) {
+ else if (statement.kind === 210) {
var ifStatement = statement;
if (ifStatement.elseStatement) {
return isSufficientlyCoveredByReturnStatements(ifStatement.thenStatement) &&
isSufficientlyCoveredByReturnStatements(ifStatement.elseStatement);
}
}
- else if (statement.kind === 204) {
+ else if (statement.kind === 206) {
var lastStatement = ts.lastOrUndefined(statement.statements);
if (lastStatement && isSufficientlyCoveredByReturnStatements(lastStatement)) {
return true;
@@ -40363,8 +43741,8 @@ var ts;
}
return false;
}
- function declareOrCaptureOrReturnThisForConstructorIfNeeded(statements, ctor, hasExtendsClause, hasSynthesizedSuper, statementOffset) {
- if (!hasExtendsClause) {
+ function declareOrCaptureOrReturnThisForConstructorIfNeeded(statements, ctor, isDerivedClass, hasSynthesizedSuper, statementOffset) {
+ if (!isDerivedClass) {
if (ctor) {
addCaptureThisForNodeIfNeeded(statements, ctor);
}
@@ -40384,42 +43762,43 @@ var ts;
var ctorStatements = ctor.body.statements;
if (statementOffset < ctorStatements.length) {
firstStatement = ctorStatements[statementOffset];
- if (firstStatement.kind === 207 && ts.isSuperCall(firstStatement.expression)) {
- var superCall = firstStatement.expression;
- superCallExpression = ts.setOriginalNode(saveStateAndInvoke(superCall, visitImmediateSuperCallInBody), superCall);
+ if (firstStatement.kind === 209 && ts.isSuperCall(firstStatement.expression)) {
+ superCallExpression = visitImmediateSuperCallInBody(firstStatement.expression);
}
}
- if (superCallExpression && statementOffset === ctorStatements.length - 1) {
+ if (superCallExpression
+ && statementOffset === ctorStatements.length - 1
+ && !(ctor.transformFlags & (16384 | 32768))) {
var returnStatement = ts.createReturn(superCallExpression);
- if (superCallExpression.kind !== 192
- || superCallExpression.left.kind !== 179) {
+ if (superCallExpression.kind !== 193
+ || superCallExpression.left.kind !== 180) {
ts.Debug.fail("Assumed generated super call would have form 'super.call(...) || this'.");
}
ts.setCommentRange(returnStatement, ts.getCommentRange(ts.setEmitFlags(superCallExpression.left, 1536)));
statements.push(returnStatement);
return 2;
}
- captureThisForNode(statements, ctor, superCallExpression, firstStatement);
+ captureThisForNode(statements, ctor, superCallExpression || createActualThis(), firstStatement);
if (superCallExpression) {
return 1;
}
return 0;
}
+ function createActualThis() {
+ return ts.setEmitFlags(ts.createThis(), 4);
+ }
function createDefaultSuperCallOrThis() {
- var actualThis = ts.createThis();
- ts.setEmitFlags(actualThis, 4);
- var superCall = ts.createFunctionApply(ts.createIdentifier("_super"), actualThis, ts.createIdentifier("arguments"));
- return ts.createLogicalOr(superCall, actualThis);
+ return ts.createLogicalOr(ts.createLogicalAnd(ts.createStrictInequality(ts.createIdentifier("_super"), ts.createNull()), ts.createFunctionApply(ts.createIdentifier("_super"), createActualThis(), ts.createIdentifier("arguments"))), createActualThis());
}
function visitParameter(node) {
if (node.dotDotDotToken) {
return undefined;
}
else if (ts.isBindingPattern(node.name)) {
- return ts.setOriginalNode(ts.createParameter(undefined, undefined, undefined, ts.getGeneratedNameForNode(node), undefined, undefined, undefined, node), node);
+ return ts.setOriginalNode(ts.setTextRange(ts.createParameter(undefined, undefined, undefined, ts.getGeneratedNameForNode(node), undefined, undefined, undefined), node), node);
}
else if (node.initializer) {
- return ts.setOriginalNode(ts.createParameter(undefined, undefined, undefined, node.name, undefined, undefined, undefined, node), node);
+ return ts.setOriginalNode(ts.setTextRange(ts.createParameter(undefined, undefined, undefined, node.name, undefined, undefined, undefined), node), node);
}
else {
return node;
@@ -40434,15 +43813,15 @@ var ts;
}
for (var _i = 0, _a = node.parameters; _i < _a.length; _i++) {
var parameter = _a[_i];
- var name_35 = parameter.name, initializer = parameter.initializer, dotDotDotToken = parameter.dotDotDotToken;
+ var name = parameter.name, initializer = parameter.initializer, dotDotDotToken = parameter.dotDotDotToken;
if (dotDotDotToken) {
continue;
}
- if (ts.isBindingPattern(name_35)) {
- addDefaultValueAssignmentForBindingPattern(statements, parameter, name_35, initializer);
+ if (ts.isBindingPattern(name)) {
+ addDefaultValueAssignmentForBindingPattern(statements, parameter, name, initializer);
}
else if (initializer) {
- addDefaultValueAssignmentForInitializer(statements, parameter, name_35, initializer);
+ addDefaultValueAssignmentForInitializer(statements, parameter, name, initializer);
}
}
}
@@ -40457,10 +43836,11 @@ var ts;
}
function addDefaultValueAssignmentForInitializer(statements, parameter, name, initializer) {
initializer = ts.visitNode(initializer, visitor, ts.isExpression);
- var statement = ts.createIf(ts.createTypeCheck(ts.getSynthesizedClone(name), "undefined"), ts.setEmitFlags(ts.createBlock([
- ts.createStatement(ts.createAssignment(ts.setEmitFlags(ts.getMutableClone(name), 48), ts.setEmitFlags(initializer, 48 | ts.getEmitFlags(initializer)), parameter))
- ], parameter), 1 | 32 | 384), undefined, parameter);
+ var statement = ts.createIf(ts.createTypeCheck(ts.getSynthesizedClone(name), "undefined"), ts.setEmitFlags(ts.setTextRange(ts.createBlock([
+ ts.createStatement(ts.setTextRange(ts.createAssignment(ts.setEmitFlags(ts.getMutableClone(name), 48), ts.setEmitFlags(initializer, 48 | ts.getEmitFlags(initializer))), parameter))
+ ]), parameter), 1 | 32 | 384));
statement.startsOnNewLine = true;
+ ts.setTextRange(statement, parameter);
ts.setEmitFlags(statement, 384 | 32 | 524288);
statements.push(statement);
}
@@ -40477,22 +43857,22 @@ var ts;
var expressionName = ts.getSynthesizedClone(parameter.name);
var restIndex = node.parameters.length - 1;
var temp = ts.createLoopVariable();
- statements.push(ts.setEmitFlags(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ statements.push(ts.setEmitFlags(ts.setTextRange(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
ts.createVariableDeclaration(declarationName, undefined, ts.createArrayLiteral([]))
- ]), parameter), 524288));
- var forStatement = ts.createFor(ts.createVariableDeclarationList([
+ ])), parameter), 524288));
+ var forStatement = ts.createFor(ts.setTextRange(ts.createVariableDeclarationList([
ts.createVariableDeclaration(temp, undefined, ts.createLiteral(restIndex))
- ], parameter), ts.createLessThan(temp, ts.createPropertyAccess(ts.createIdentifier("arguments"), "length"), parameter), ts.createPostfixIncrement(temp, parameter), ts.createBlock([
- ts.startOnNewLine(ts.createStatement(ts.createAssignment(ts.createElementAccess(expressionName, restIndex === 0
+ ]), parameter), ts.setTextRange(ts.createLessThan(temp, ts.createPropertyAccess(ts.createIdentifier("arguments"), "length")), parameter), ts.setTextRange(ts.createPostfixIncrement(temp), parameter), ts.createBlock([
+ ts.startOnNewLine(ts.setTextRange(ts.createStatement(ts.createAssignment(ts.createElementAccess(expressionName, restIndex === 0
? temp
- : ts.createSubtract(temp, ts.createLiteral(restIndex))), ts.createElementAccess(ts.createIdentifier("arguments"), temp)), parameter))
+ : ts.createSubtract(temp, ts.createLiteral(restIndex))), ts.createElementAccess(ts.createIdentifier("arguments"), temp))), parameter))
]));
ts.setEmitFlags(forStatement, 524288);
ts.startOnNewLine(forStatement);
statements.push(forStatement);
}
function addCaptureThisForNodeIfNeeded(statements, node) {
- if (node.transformFlags & 32768 && node.kind !== 185) {
+ if (node.transformFlags & 32768 && node.kind !== 186) {
captureThisForNode(statements, node, ts.createThis());
}
}
@@ -40500,29 +43880,62 @@ var ts;
enableSubstitutionsForCapturedThis();
var captureThisStatement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
ts.createVariableDeclaration("_this", undefined, initializer)
- ]), originalStatement);
+ ]));
ts.setEmitFlags(captureThisStatement, 1536 | 524288);
+ ts.setTextRange(captureThisStatement, originalStatement);
ts.setSourceMapRange(captureThisStatement, node);
statements.push(captureThisStatement);
}
+ function prependCaptureNewTargetIfNeeded(statements, node, copyOnWrite) {
+ if (hierarchyFacts & 16384) {
+ var newTarget = void 0;
+ switch (node.kind) {
+ case 186:
+ return statements;
+ case 150:
+ case 152:
+ case 153:
+ newTarget = ts.createVoidZero();
+ break;
+ case 151:
+ newTarget = ts.createPropertyAccess(ts.setEmitFlags(ts.createThis(), 4), "constructor");
+ break;
+ case 227:
+ case 185:
+ newTarget = ts.createConditional(ts.createLogicalAnd(ts.setEmitFlags(ts.createThis(), 4), ts.createBinary(ts.setEmitFlags(ts.createThis(), 4), 92, ts.getLocalName(node))), ts.createPropertyAccess(ts.setEmitFlags(ts.createThis(), 4), "constructor"), ts.createVoidZero());
+ break;
+ default:
+ ts.Debug.failBadSyntaxKind(node);
+ break;
+ }
+ var captureNewTargetStatement = ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ ts.createVariableDeclaration("_newTarget", undefined, newTarget)
+ ]));
+ if (copyOnWrite) {
+ return [captureNewTargetStatement].concat(statements);
+ }
+ statements.unshift(captureNewTargetStatement);
+ }
+ return statements;
+ }
function addClassMembers(statements, node) {
for (var _i = 0, _a = node.members; _i < _a.length; _i++) {
var member = _a[_i];
switch (member.kind) {
- case 203:
+ case 205:
statements.push(transformSemicolonClassElementToStatement(member));
break;
- case 149:
- statements.push(transformClassMethodDeclarationToStatement(getClassMemberPrefix(node, member), member));
+ case 150:
+ statements.push(transformClassMethodDeclarationToStatement(getClassMemberPrefix(node, member), member, node));
break;
- case 151:
case 152:
+ case 153:
var accessors = ts.getAllAccessorDeclarations(node.members, member);
if (member === accessors.firstAccessor) {
- statements.push(transformAccessorsToStatement(getClassMemberPrefix(node, member), accessors));
+ statements.push(transformAccessorsToStatement(getClassMemberPrefix(node, member), accessors, node));
}
break;
- case 150:
+ case 151:
break;
default:
ts.Debug.failBadSyntaxKind(node);
@@ -40531,28 +43944,32 @@ var ts;
}
}
function transformSemicolonClassElementToStatement(member) {
- return ts.createEmptyStatement(member);
+ return ts.setTextRange(ts.createEmptyStatement(), member);
}
- function transformClassMethodDeclarationToStatement(receiver, member) {
+ function transformClassMethodDeclarationToStatement(receiver, member, container) {
+ var ancestorFacts = enterSubtree(0, 0);
var commentRange = ts.getCommentRange(member);
var sourceMapRange = ts.getSourceMapRange(member);
var memberName = ts.createMemberAccessForPropertyName(receiver, ts.visitNode(member.name, visitor, ts.isPropertyName), member.name);
- var memberFunction = transformFunctionLikeToExpression(member, member, undefined);
+ var memberFunction = transformFunctionLikeToExpression(member, member, undefined, container);
ts.setEmitFlags(memberFunction, 1536);
ts.setSourceMapRange(memberFunction, sourceMapRange);
- var statement = ts.createStatement(ts.createAssignment(memberName, memberFunction), member);
+ var statement = ts.setTextRange(ts.createStatement(ts.createAssignment(memberName, memberFunction)), member);
ts.setOriginalNode(statement, member);
ts.setCommentRange(statement, commentRange);
ts.setEmitFlags(statement, 48);
+ exitSubtree(ancestorFacts, 49152, hierarchyFacts & 49152 ? 16384 : 0);
return statement;
}
- function transformAccessorsToStatement(receiver, accessors) {
- var statement = ts.createStatement(transformAccessorsToExpression(receiver, accessors, false), ts.getSourceMapRange(accessors.firstAccessor));
+ function transformAccessorsToStatement(receiver, accessors, container) {
+ var statement = ts.createStatement(transformAccessorsToExpression(receiver, accessors, container, false));
ts.setEmitFlags(statement, 1536);
+ ts.setSourceMapRange(statement, ts.getSourceMapRange(accessors.firstAccessor));
return statement;
}
- function transformAccessorsToExpression(receiver, _a, startsOnNewLine) {
+ function transformAccessorsToExpression(receiver, _a, container, startsOnNewLine) {
var firstAccessor = _a.firstAccessor, getAccessor = _a.getAccessor, setAccessor = _a.setAccessor;
+ var ancestorFacts = enterSubtree(0, 0);
var target = ts.getMutableClone(receiver);
ts.setEmitFlags(target, 1536 | 32);
ts.setSourceMapRange(target, firstAccessor.name);
@@ -40561,7 +43978,7 @@ var ts;
ts.setSourceMapRange(propertyName, firstAccessor.name);
var properties = [];
if (getAccessor) {
- var getterFunction = transformFunctionLikeToExpression(getAccessor, undefined, undefined);
+ var getterFunction = transformFunctionLikeToExpression(getAccessor, undefined, undefined, container);
ts.setSourceMapRange(getterFunction, ts.getSourceMapRange(getAccessor));
ts.setEmitFlags(getterFunction, 512);
var getter = ts.createPropertyAssignment("get", getterFunction);
@@ -40569,51 +43986,86 @@ var ts;
properties.push(getter);
}
if (setAccessor) {
- var setterFunction = transformFunctionLikeToExpression(setAccessor, undefined, undefined);
+ var setterFunction = transformFunctionLikeToExpression(setAccessor, undefined, undefined, container);
ts.setSourceMapRange(setterFunction, ts.getSourceMapRange(setAccessor));
ts.setEmitFlags(setterFunction, 512);
var setter = ts.createPropertyAssignment("set", setterFunction);
ts.setCommentRange(setter, ts.getCommentRange(setAccessor));
properties.push(setter);
}
- properties.push(ts.createPropertyAssignment("enumerable", ts.createLiteral(true)), ts.createPropertyAssignment("configurable", ts.createLiteral(true)));
+ properties.push(ts.createPropertyAssignment("enumerable", ts.createTrue()), ts.createPropertyAssignment("configurable", ts.createTrue()));
var call = ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Object"), "defineProperty"), undefined, [
target,
propertyName,
- ts.createObjectLiteral(properties, undefined, true)
+ ts.createObjectLiteral(properties, true)
]);
if (startsOnNewLine) {
call.startsOnNewLine = true;
}
+ exitSubtree(ancestorFacts, 49152, hierarchyFacts & 49152 ? 16384 : 0);
return call;
}
function visitArrowFunction(node) {
if (node.transformFlags & 16384) {
enableSubstitutionsForCapturedThis();
}
- var func = ts.createFunctionExpression(undefined, undefined, undefined, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node), node);
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var ancestorFacts = enterSubtree(16256, 66);
+ var func = ts.createFunctionExpression(undefined, undefined, undefined, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformFunctionBody(node));
+ ts.setTextRange(func, node);
ts.setOriginalNode(func, node);
ts.setEmitFlags(func, 8);
+ exitSubtree(ancestorFacts, 0, 0);
+ convertedLoopState = savedConvertedLoopState;
return func;
}
function visitFunctionExpression(node) {
- return ts.updateFunctionExpression(node, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, node.transformFlags & 64
+ var ancestorFacts = ts.getEmitFlags(node) & 131072
+ ? enterSubtree(16278, 69)
+ : enterSubtree(16286, 65);
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var parameters = ts.visitParameterList(node.parameters, visitor, context);
+ var body = node.transformFlags & 64
? transformFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
+ : visitFunctionBodyDownLevel(node);
+ var name = hierarchyFacts & 16384
+ ? ts.getLocalName(node)
+ : node.name;
+ exitSubtree(ancestorFacts, 49152, 0);
+ convertedLoopState = savedConvertedLoopState;
+ return ts.updateFunctionExpression(node, undefined, node.asteriskToken, name, undefined, parameters, undefined, body);
}
function visitFunctionDeclaration(node) {
- return ts.updateFunctionDeclaration(node, undefined, node.modifiers, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, node.transformFlags & 64
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var ancestorFacts = enterSubtree(16286, 65);
+ var parameters = ts.visitParameterList(node.parameters, visitor, context);
+ var body = node.transformFlags & 64
? transformFunctionBody(node)
- : ts.visitFunctionBody(node.body, visitor, context));
+ : visitFunctionBodyDownLevel(node);
+ var name = hierarchyFacts & 16384
+ ? ts.getLocalName(node)
+ : node.name;
+ exitSubtree(ancestorFacts, 49152, 0);
+ convertedLoopState = savedConvertedLoopState;
+ return ts.updateFunctionDeclaration(node, undefined, ts.visitNodes(node.modifiers, visitor, ts.isModifier), node.asteriskToken, name, undefined, parameters, undefined, body);
}
- function transformFunctionLikeToExpression(node, location, name) {
- var savedContainingNonArrowFunction = enclosingNonArrowFunction;
- if (node.kind !== 185) {
- enclosingNonArrowFunction = node;
+ function transformFunctionLikeToExpression(node, location, name, container) {
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var ancestorFacts = container && ts.isClassLike(container) && !ts.hasModifier(node, 32)
+ ? enterSubtree(16286, 65 | 8)
+ : enterSubtree(16286, 65);
+ var parameters = ts.visitParameterList(node.parameters, visitor, context);
+ var body = transformFunctionBody(node);
+ if (hierarchyFacts & 16384 && !name && (node.kind === 227 || node.kind === 185)) {
+ name = ts.getGeneratedNameForNode(node);
}
- var expression = ts.setOriginalNode(ts.createFunctionExpression(undefined, node.asteriskToken, name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, saveStateAndInvoke(node, transformFunctionBody), location), node);
- enclosingNonArrowFunction = savedContainingNonArrowFunction;
- return expression;
+ exitSubtree(ancestorFacts, 49152, 0);
+ convertedLoopState = savedConvertedLoopState;
+ return ts.setOriginalNode(ts.setTextRange(ts.createFunctionExpression(undefined, node.asteriskToken, name, undefined, parameters, undefined, body), location), node);
}
function transformFunctionBody(node) {
var multiLine = false;
@@ -40625,7 +44077,7 @@ var ts;
var statementOffset;
resumeLexicalEnvironment();
if (ts.isBlock(body)) {
- statementOffset = ts.addPrologueDirectives(statements, body.statements, false, visitor);
+ statementOffset = ts.addStandardPrologue(statements, body.statements, false);
}
addCaptureThisForNodeIfNeeded(statements, node);
addDefaultValueAssignmentsIfNeeded(statements, node);
@@ -40634,6 +44086,7 @@ var ts;
multiLine = true;
}
if (ts.isBlock(body)) {
+ statementOffset = ts.addCustomPrologue(statements, body.statements, statementOffset, visitor);
statementsLocation = body.statements;
ts.addRange(statements, ts.visitNodes(body.statements, visitor, ts.isStatement, statementOffset));
if (!multiLine && body.multiLine) {
@@ -40641,7 +44094,7 @@ var ts;
}
}
else {
- ts.Debug.assert(node.kind === 185);
+ ts.Debug.assert(node.kind === 186);
statementsLocation = ts.moveRangeEnd(body, -1);
var equalsGreaterThanToken = node.equalsGreaterThanToken;
if (!ts.nodeIsSynthesized(equalsGreaterThanToken) && !ts.nodeIsSynthesized(body)) {
@@ -40653,17 +44106,20 @@ var ts;
}
}
var expression = ts.visitNode(body, visitor, ts.isExpression);
- var returnStatement = ts.createReturn(expression, body);
+ var returnStatement = ts.createReturn(expression);
+ ts.setTextRange(returnStatement, body);
ts.setEmitFlags(returnStatement, 384 | 32 | 1024);
statements.push(returnStatement);
closeBraceLocation = body;
}
var lexicalEnvironment = context.endLexicalEnvironment();
ts.addRange(statements, lexicalEnvironment);
+ prependCaptureNewTargetIfNeeded(statements, node, false);
if (!multiLine && lexicalEnvironment && lexicalEnvironment.length) {
multiLine = true;
}
- var block = ts.createBlock(ts.createNodeArray(statements, statementsLocation), node.body, multiLine);
+ var block = ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), statementsLocation), multiLine);
+ ts.setTextRange(block, node.body);
if (!multiLine && singleLine) {
ts.setEmitFlags(block, 1);
}
@@ -40673,11 +44129,26 @@ var ts;
ts.setOriginalNode(block, node.body);
return block;
}
+ function visitFunctionBodyDownLevel(node) {
+ var updated = ts.visitFunctionBody(node.body, functionBodyVisitor, context);
+ return ts.updateBlock(updated, ts.setTextRange(ts.createNodeArray(prependCaptureNewTargetIfNeeded(updated.statements, node, true)), updated.statements));
+ }
+ function visitBlock(node, isFunctionBody) {
+ if (isFunctionBody) {
+ return ts.visitEachChild(node, visitor, context);
+ }
+ var ancestorFacts = hierarchyFacts & 256
+ ? enterSubtree(4032, 512)
+ : enterSubtree(3904, 128);
+ var updated = ts.visitEachChild(node, visitor, context);
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
+ }
function visitExpressionStatement(node) {
switch (node.expression.kind) {
- case 183:
+ case 184:
return ts.updateStatement(node, visitParenthesizedExpression(node.expression, false));
- case 192:
+ case 193:
return ts.updateStatement(node, visitBinaryExpression(node.expression, false));
}
return ts.visitEachChild(node, visitor, context);
@@ -40685,9 +44156,9 @@ var ts;
function visitParenthesizedExpression(node, needsDestructuringValue) {
if (!needsDestructuringValue) {
switch (node.expression.kind) {
- case 183:
+ case 184:
return ts.updateParen(node, visitParenthesizedExpression(node.expression, false));
- case 192:
+ case 193:
return ts.updateParen(node, visitBinaryExpression(node.expression, false));
}
}
@@ -40697,9 +44168,12 @@ var ts;
if (ts.isDestructuringAssignment(node)) {
return ts.flattenDestructuringAssignment(node, visitor, context, 0, needsDestructuringValue);
}
+ return ts.visitEachChild(node, visitor, context);
}
function visitVariableStatement(node) {
- if (convertedLoopState && (ts.getCombinedNodeFlags(node.declarationList) & 3) == 0) {
+ var ancestorFacts = enterSubtree(0, ts.hasModifier(node, 1) ? 32 : 0);
+ var updated;
+ if (convertedLoopState && (node.declarationList.flags & 3) === 0) {
var assignments = void 0;
for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
var decl = _a[_i];
@@ -40712,53 +44186,59 @@ var ts;
else {
assignment = ts.createBinary(decl.name, 57, ts.visitNode(decl.initializer, visitor, ts.isExpression));
}
- (assignments || (assignments = [])).push(assignment);
+ assignments = ts.append(assignments, assignment);
}
}
if (assignments) {
- return ts.createStatement(ts.reduceLeft(assignments, function (acc, v) { return ts.createBinary(v, 25, acc); }), node);
+ updated = ts.setTextRange(ts.createStatement(ts.reduceLeft(assignments, function (acc, v) { return ts.createBinary(v, 25, acc); })), node);
}
else {
- return undefined;
+ updated = undefined;
}
}
- return ts.visitEachChild(node, visitor, context);
+ else {
+ updated = ts.visitEachChild(node, visitor, context);
+ }
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
}
function visitVariableDeclarationList(node) {
- if (node.flags & 3) {
- enableSubstitutionsForBlockScopedBindings();
+ if (node.transformFlags & 64) {
+ if (node.flags & 3) {
+ enableSubstitutionsForBlockScopedBindings();
+ }
+ var declarations = ts.flatten(ts.map(node.declarations, node.flags & 1
+ ? visitVariableDeclarationInLetDeclarationList
+ : visitVariableDeclaration));
+ var declarationList = ts.createVariableDeclarationList(declarations);
+ ts.setOriginalNode(declarationList, node);
+ ts.setTextRange(declarationList, node);
+ ts.setCommentRange(declarationList, node);
+ if (node.transformFlags & 8388608
+ && (ts.isBindingPattern(node.declarations[0].name)
+ || ts.isBindingPattern(ts.lastOrUndefined(node.declarations).name))) {
+ var firstDeclaration = ts.firstOrUndefined(declarations);
+ var lastDeclaration = ts.lastOrUndefined(declarations);
+ ts.setSourceMapRange(declarationList, ts.createRange(firstDeclaration.pos, lastDeclaration.end));
+ }
+ return declarationList;
}
- var declarations = ts.flatten(ts.map(node.declarations, node.flags & 1
- ? visitVariableDeclarationInLetDeclarationList
- : visitVariableDeclaration));
- var declarationList = ts.createVariableDeclarationList(declarations, node);
- ts.setOriginalNode(declarationList, node);
- ts.setCommentRange(declarationList, node);
- if (node.transformFlags & 8388608
- && (ts.isBindingPattern(node.declarations[0].name)
- || ts.isBindingPattern(ts.lastOrUndefined(node.declarations).name))) {
- var firstDeclaration = ts.firstOrUndefined(declarations);
- var lastDeclaration = ts.lastOrUndefined(declarations);
- ts.setSourceMapRange(declarationList, ts.createRange(firstDeclaration.pos, lastDeclaration.end));
- }
- return declarationList;
+ return ts.visitEachChild(node, visitor, context);
}
function shouldEmitExplicitInitializerForLetDeclaration(node) {
var flags = resolver.getNodeCheckFlags(node);
var isCapturedInFunction = flags & 131072;
var isDeclaredInLoop = flags & 262144;
- var emittedAsTopLevel = ts.isBlockScopedContainerTopLevel(enclosingBlockScopeContainer)
+ var emittedAsTopLevel = (hierarchyFacts & 64) !== 0
|| (isCapturedInFunction
&& isDeclaredInLoop
- && ts.isBlock(enclosingBlockScopeContainer)
- && ts.isIterationStatement(enclosingBlockScopeContainerParent, false));
+ && (hierarchyFacts & 512) !== 0);
var emitExplicitInitializer = !emittedAsTopLevel
- && enclosingBlockScopeContainer.kind !== 212
- && enclosingBlockScopeContainer.kind !== 213
+ && (hierarchyFacts & 2048) === 0
&& (!resolver.isDeclarationWithCollidingName(node)
|| (isDeclaredInLoop
&& !isCapturedInFunction
- && !ts.isIterationStatement(enclosingBlockScopeContainer, false)));
+ && (hierarchyFacts & (1024 | 2048)) === 0));
return emitExplicitInitializer;
}
function visitVariableDeclarationInLetDeclarationList(node) {
@@ -40774,84 +44254,94 @@ var ts;
return ts.visitEachChild(node, visitor, context);
}
function visitVariableDeclaration(node) {
+ var ancestorFacts = enterSubtree(32, 0);
+ var updated;
if (ts.isBindingPattern(node.name)) {
- var hoistTempVariables = enclosingVariableStatement
- && ts.hasModifier(enclosingVariableStatement, 1);
- return ts.flattenDestructuringBinding(node, visitor, context, 0, undefined, hoistTempVariables);
+ updated = ts.flattenDestructuringBinding(node, visitor, context, 0, undefined, (ancestorFacts & 32) !== 0);
}
- return ts.visitEachChild(node, visitor, context);
+ else {
+ updated = ts.visitEachChild(node, visitor, context);
+ }
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
+ }
+ function recordLabel(node) {
+ convertedLoopState.labels.set(node.label.text, node.label.text);
+ }
+ function resetLabel(node) {
+ convertedLoopState.labels.set(node.label.text, undefined);
}
function visitLabeledStatement(node) {
- if (convertedLoopState) {
- if (!convertedLoopState.labels) {
- convertedLoopState.labels = ts.createMap();
- }
- convertedLoopState.labels[node.label.text] = node.label.text;
+ if (convertedLoopState && !convertedLoopState.labels) {
+ convertedLoopState.labels = ts.createMap();
}
- var result;
- if (ts.isIterationStatement(node.statement, false) && shouldConvertIterationStatementBody(node.statement)) {
- result = ts.visitNodes(ts.createNodeArray([node.statement]), visitor, ts.isStatement);
- }
- else {
- result = ts.visitEachChild(node, visitor, context);
- }
- if (convertedLoopState) {
- convertedLoopState.labels[node.label.text] = undefined;
+ var statement = ts.unwrapInnermostStatementOfLabel(node, convertedLoopState && recordLabel);
+ return ts.isIterationStatement(statement, false)
+ ? visitIterationStatement(statement, node)
+ : ts.restoreEnclosingLabel(ts.visitNode(statement, visitor, ts.isStatement), node, convertedLoopState && resetLabel);
+ }
+ function visitIterationStatement(node, outermostLabeledStatement) {
+ switch (node.kind) {
+ case 211:
+ case 212:
+ return visitDoOrWhileStatement(node, outermostLabeledStatement);
+ case 213:
+ return visitForStatement(node, outermostLabeledStatement);
+ case 214:
+ return visitForInStatement(node, outermostLabeledStatement);
+ case 215:
+ return visitForOfStatement(node, outermostLabeledStatement);
}
- return result;
}
- function visitDoStatement(node) {
- return convertIterationStatementBodyIfNecessary(node);
+ function visitIterationStatementWithFacts(excludeFacts, includeFacts, node, outermostLabeledStatement, convert) {
+ var ancestorFacts = enterSubtree(excludeFacts, includeFacts);
+ var updated = convertIterationStatementBodyIfNecessary(node, outermostLabeledStatement, convert);
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
}
- function visitWhileStatement(node) {
- return convertIterationStatementBodyIfNecessary(node);
+ function visitDoOrWhileStatement(node, outermostLabeledStatement) {
+ return visitIterationStatementWithFacts(0, 256, node, outermostLabeledStatement);
}
- function visitForStatement(node) {
- return convertIterationStatementBodyIfNecessary(node);
+ function visitForStatement(node, outermostLabeledStatement) {
+ return visitIterationStatementWithFacts(3008, 1280, node, outermostLabeledStatement);
}
- function visitForInStatement(node) {
- return convertIterationStatementBodyIfNecessary(node);
+ function visitForInStatement(node, outermostLabeledStatement) {
+ return visitIterationStatementWithFacts(1984, 2304, node, outermostLabeledStatement);
}
- function visitForOfStatement(node) {
- return convertIterationStatementBodyIfNecessary(node, convertForOfToFor);
+ function visitForOfStatement(node, outermostLabeledStatement) {
+ return visitIterationStatementWithFacts(1984, 2304, node, outermostLabeledStatement, compilerOptions.downlevelIteration ? convertForOfStatementForIterable : convertForOfStatementForArray);
}
- function convertForOfToFor(node, convertedLoopBodyStatements) {
- var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
- var initializer = node.initializer;
+ function convertForOfStatementHead(node, boundValue, convertedLoopBodyStatements) {
var statements = [];
- var counter = ts.createLoopVariable();
- var rhsReference = expression.kind === 70
- ? ts.createUniqueName(expression.text)
- : ts.createTempVariable(undefined);
- var elementAccess = ts.createElementAccess(rhsReference, counter);
- if (ts.isVariableDeclarationList(initializer)) {
- if (initializer.flags & 3) {
+ if (ts.isVariableDeclarationList(node.initializer)) {
+ if (node.initializer.flags & 3) {
enableSubstitutionsForBlockScopedBindings();
}
- var firstOriginalDeclaration = ts.firstOrUndefined(initializer.declarations);
+ var firstOriginalDeclaration = ts.firstOrUndefined(node.initializer.declarations);
if (firstOriginalDeclaration && ts.isBindingPattern(firstOriginalDeclaration.name)) {
- var declarations = ts.flattenDestructuringBinding(firstOriginalDeclaration, visitor, context, 0, elementAccess);
- var declarationList = ts.createVariableDeclarationList(declarations, initializer);
- ts.setOriginalNode(declarationList, initializer);
+ var declarations = ts.flattenDestructuringBinding(firstOriginalDeclaration, visitor, context, 0, boundValue);
+ var declarationList = ts.setTextRange(ts.createVariableDeclarationList(declarations), node.initializer);
+ ts.setOriginalNode(declarationList, node.initializer);
var firstDeclaration = declarations[0];
var lastDeclaration = ts.lastOrUndefined(declarations);
ts.setSourceMapRange(declarationList, ts.createRange(firstDeclaration.pos, lastDeclaration.end));
statements.push(ts.createVariableStatement(undefined, declarationList));
}
else {
- statements.push(ts.createVariableStatement(undefined, ts.setOriginalNode(ts.createVariableDeclarationList([
- ts.createVariableDeclaration(firstOriginalDeclaration ? firstOriginalDeclaration.name : ts.createTempVariable(undefined), undefined, ts.createElementAccess(rhsReference, counter))
- ], ts.moveRangePos(initializer, -1)), initializer), ts.moveRangeEnd(initializer, -1)));
+ statements.push(ts.setTextRange(ts.createVariableStatement(undefined, ts.setOriginalNode(ts.setTextRange(ts.createVariableDeclarationList([
+ ts.createVariableDeclaration(firstOriginalDeclaration ? firstOriginalDeclaration.name : ts.createTempVariable(undefined), undefined, boundValue)
+ ]), ts.moveRangePos(node.initializer, -1)), node.initializer)), ts.moveRangeEnd(node.initializer, -1)));
}
}
else {
- var assignment = ts.createAssignment(initializer, elementAccess);
+ var assignment = ts.createAssignment(node.initializer, boundValue);
if (ts.isDestructuringAssignment(assignment)) {
- statements.push(ts.createStatement(ts.flattenDestructuringAssignment(assignment, visitor, context, 0)));
+ ts.aggregateTransformFlags(assignment);
+ statements.push(ts.createStatement(visitBinaryExpression(assignment, false)));
}
else {
- assignment.end = initializer.end;
- statements.push(ts.createStatement(assignment, ts.moveRangeEnd(initializer, -1)));
+ assignment.end = node.initializer.end;
+ statements.push(ts.setTextRange(ts.createStatement(ts.visitNode(assignment, visitor, ts.isExpression)), ts.moveRangeEnd(node.initializer, -1)));
}
}
var bodyLocation;
@@ -40860,7 +44350,7 @@ var ts;
ts.addRange(statements, convertedLoopBodyStatements);
}
else {
- var statement = ts.visitNode(node.statement, visitor, ts.isStatement);
+ var statement = ts.visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock);
if (ts.isBlock(statement)) {
ts.addRange(statements, statement.statements);
bodyLocation = statement;
@@ -40870,39 +44360,82 @@ var ts;
statements.push(statement);
}
}
+ return ts.setEmitFlags(ts.setTextRange(ts.createBlock(ts.setTextRange(ts.createNodeArray(statements), statementsLocation), true), bodyLocation), 48 | 384);
+ }
+ function convertForOfStatementForArray(node, outermostLabeledStatement, convertedLoopBodyStatements) {
+ var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
+ var counter = ts.createLoopVariable();
+ var rhsReference = ts.isIdentifier(expression) ? ts.getGeneratedNameForNode(expression) : ts.createTempVariable(undefined);
ts.setEmitFlags(expression, 48 | ts.getEmitFlags(expression));
- var body = ts.createBlock(ts.createNodeArray(statements, statementsLocation), bodyLocation);
- ts.setEmitFlags(body, 48 | 384);
- var forStatement = ts.createFor(ts.setEmitFlags(ts.createVariableDeclarationList([
- ts.createVariableDeclaration(counter, undefined, ts.createLiteral(0), ts.moveRangePos(node.expression, -1)),
- ts.createVariableDeclaration(rhsReference, undefined, expression, node.expression)
- ], node.expression), 1048576), ts.createLessThan(counter, ts.createPropertyAccess(rhsReference, "length"), node.expression), ts.createPostfixIncrement(counter, node.expression), body, node);
+ var forStatement = ts.setTextRange(ts.createFor(ts.setEmitFlags(ts.setTextRange(ts.createVariableDeclarationList([
+ ts.setTextRange(ts.createVariableDeclaration(counter, undefined, ts.createLiteral(0)), ts.moveRangePos(node.expression, -1)),
+ ts.setTextRange(ts.createVariableDeclaration(rhsReference, undefined, expression), node.expression)
+ ]), node.expression), 1048576), ts.setTextRange(ts.createLessThan(counter, ts.createPropertyAccess(rhsReference, "length")), node.expression), ts.setTextRange(ts.createPostfixIncrement(counter), node.expression), convertForOfStatementHead(node, ts.createElementAccess(rhsReference, counter), convertedLoopBodyStatements)), node);
ts.setEmitFlags(forStatement, 256);
- return forStatement;
+ ts.setTextRange(forStatement, node);
+ return ts.restoreEnclosingLabel(forStatement, outermostLabeledStatement, convertedLoopState && resetLabel);
+ }
+ function convertForOfStatementForIterable(node, outermostLabeledStatement, convertedLoopBodyStatements) {
+ var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
+ var iterator = ts.isIdentifier(expression) ? ts.getGeneratedNameForNode(expression) : ts.createTempVariable(undefined);
+ var result = ts.isIdentifier(expression) ? ts.getGeneratedNameForNode(iterator) : ts.createTempVariable(undefined);
+ var errorRecord = ts.createUniqueName("e");
+ var catchVariable = ts.getGeneratedNameForNode(errorRecord);
+ var returnMethod = ts.createTempVariable(undefined);
+ var values = ts.createValuesHelper(context, expression, node.expression);
+ var next = ts.createCall(ts.createPropertyAccess(iterator, "next"), undefined, []);
+ hoistVariableDeclaration(errorRecord);
+ hoistVariableDeclaration(returnMethod);
+ var forStatement = ts.setEmitFlags(ts.setTextRange(ts.createFor(ts.setEmitFlags(ts.setTextRange(ts.createVariableDeclarationList([
+ ts.setTextRange(ts.createVariableDeclaration(iterator, undefined, values), node.expression),
+ ts.createVariableDeclaration(result, undefined, next)
+ ]), node.expression), 1048576), ts.createLogicalNot(ts.createPropertyAccess(result, "done")), ts.createAssignment(result, next), convertForOfStatementHead(node, ts.createPropertyAccess(result, "value"), convertedLoopBodyStatements)), node), 256);
+ return ts.createTry(ts.createBlock([
+ ts.restoreEnclosingLabel(forStatement, outermostLabeledStatement, convertedLoopState && resetLabel)
+ ]), ts.createCatchClause(ts.createVariableDeclaration(catchVariable), ts.setEmitFlags(ts.createBlock([
+ ts.createStatement(ts.createAssignment(errorRecord, ts.createObjectLiteral([
+ ts.createPropertyAssignment("error", catchVariable)
+ ])))
+ ]), 1)), ts.createBlock([
+ ts.createTry(ts.createBlock([
+ ts.setEmitFlags(ts.createIf(ts.createLogicalAnd(ts.createLogicalAnd(result, ts.createLogicalNot(ts.createPropertyAccess(result, "done"))), ts.createAssignment(returnMethod, ts.createPropertyAccess(iterator, "return"))), ts.createStatement(ts.createFunctionCall(returnMethod, iterator, []))), 1),
+ ]), undefined, ts.setEmitFlags(ts.createBlock([
+ ts.setEmitFlags(ts.createIf(errorRecord, ts.createThrow(ts.createPropertyAccess(errorRecord, "error"))), 1)
+ ]), 1))
+ ]));
}
function visitObjectLiteralExpression(node) {
var properties = node.properties;
var numProperties = properties.length;
var numInitialProperties = numProperties;
+ var numInitialPropertiesWithoutYield = numProperties;
for (var i = 0; i < numProperties; i++) {
var property = properties[i];
- if (property.transformFlags & 16777216
- || property.name.kind === 142) {
+ if ((property.transformFlags & 16777216 && hierarchyFacts & 4)
+ && i < numInitialPropertiesWithoutYield) {
+ numInitialPropertiesWithoutYield = i;
+ }
+ if (property.name.kind === 143) {
numInitialProperties = i;
break;
}
}
- ts.Debug.assert(numInitialProperties !== numProperties);
- var temp = ts.createTempVariable(hoistVariableDeclaration);
- var expressions = [];
- var assignment = ts.createAssignment(temp, ts.setEmitFlags(ts.createObjectLiteral(ts.visitNodes(properties, visitor, ts.isObjectLiteralElementLike, 0, numInitialProperties), undefined, node.multiLine), 32768));
- if (node.multiLine) {
- assignment.startsOnNewLine = true;
+ if (numInitialProperties !== numProperties) {
+ if (numInitialPropertiesWithoutYield < numInitialProperties) {
+ numInitialProperties = numInitialPropertiesWithoutYield;
+ }
+ var temp = ts.createTempVariable(hoistVariableDeclaration);
+ var expressions = [];
+ var assignment = ts.createAssignment(temp, ts.setEmitFlags(ts.createObjectLiteral(ts.visitNodes(properties, visitor, ts.isObjectLiteralElementLike, 0, numInitialProperties), node.multiLine), 32768));
+ if (node.multiLine) {
+ assignment.startsOnNewLine = true;
+ }
+ expressions.push(assignment);
+ addObjectLiteralMembers(expressions, node, temp, numInitialProperties);
+ expressions.push(node.multiLine ? ts.startOnNewLine(ts.getMutableClone(temp)) : temp);
+ return ts.inlineExpressions(expressions);
}
- expressions.push(assignment);
- addObjectLiteralMembers(expressions, node, temp, numInitialProperties);
- expressions.push(node.multiLine ? ts.startOnNewLine(ts.getMutableClone(temp)) : temp);
- return ts.inlineExpressions(expressions);
+ return ts.visitEachChild(node, visitor, context);
}
function shouldConvertIterationStatementBody(node) {
return (resolver.getNodeCheckFlags(node) & 65536) !== 0;
@@ -40926,14 +44459,16 @@ var ts;
}
}
}
- function convertIterationStatementBodyIfNecessary(node, convert) {
+ function convertIterationStatementBodyIfNecessary(node, outermostLabeledStatement, convert) {
if (!shouldConvertIterationStatementBody(node)) {
var saveAllowedNonLabeledJumps = void 0;
if (convertedLoopState) {
saveAllowedNonLabeledJumps = convertedLoopState.allowedNonLabeledJumps;
convertedLoopState.allowedNonLabeledJumps = 2 | 4;
}
- var result = convert ? convert(node, undefined) : ts.visitEachChild(node, visitor, context);
+ var result = convert
+ ? convert(node, outermostLabeledStatement, undefined)
+ : ts.restoreEnclosingLabel(ts.visitEachChild(node, visitor, context), outermostLabeledStatement, convertedLoopState && resetLabel);
if (convertedLoopState) {
convertedLoopState.allowedNonLabeledJumps = saveAllowedNonLabeledJumps;
}
@@ -40942,11 +44477,11 @@ var ts;
var functionName = ts.createUniqueName("_loop");
var loopInitializer;
switch (node.kind) {
- case 211:
- case 212:
case 213:
+ case 214:
+ case 215:
var initializer = node.initializer;
- if (initializer && initializer.kind === 224) {
+ if (initializer && initializer.kind === 226) {
loopInitializer = initializer;
}
break;
@@ -40972,19 +44507,26 @@ var ts;
convertedLoopState.hoistedLocalVariables = outerConvertedLoopState.hoistedLocalVariables;
}
}
- var loopBody = ts.visitNode(node.statement, visitor, ts.isStatement);
+ startLexicalEnvironment();
+ var loopBody = ts.visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock);
+ var lexicalEnvironment = endLexicalEnvironment();
var currentState = convertedLoopState;
convertedLoopState = outerConvertedLoopState;
- if (loopOutParameters.length) {
+ if (loopOutParameters.length || lexicalEnvironment) {
var statements_4 = ts.isBlock(loopBody) ? loopBody.statements.slice() : [loopBody];
- copyOutParameters(loopOutParameters, 1, statements_4);
- loopBody = ts.createBlock(statements_4, undefined, true);
+ if (loopOutParameters.length) {
+ copyOutParameters(loopOutParameters, 1, statements_4);
+ }
+ ts.addRange(statements_4, lexicalEnvironment);
+ loopBody = ts.createBlock(statements_4, true);
}
- if (!ts.isBlock(loopBody)) {
- loopBody = ts.createBlock([loopBody], undefined, true);
+ if (ts.isBlock(loopBody)) {
+ loopBody.multiLine = true;
+ }
+ else {
+ loopBody = ts.createBlock([loopBody], true);
}
- var isAsyncBlockContainingAwait = enclosingNonArrowFunction
- && (ts.getEmitFlags(enclosingNonArrowFunction) & 131072) !== 0
+ var isAsyncBlockContainingAwait = hierarchyFacts & 4
&& (node.statement.transformFlags & 16777216) !== 0;
var loopBodyFlags = 0;
if (currentState.containsLexicalThis) {
@@ -41043,19 +44585,18 @@ var ts;
var convertedLoopBodyStatements = generateCallToConvertedLoop(functionName, loopParameters, currentState, isAsyncBlockContainingAwait);
var loop;
if (convert) {
- loop = convert(node, convertedLoopBodyStatements);
+ loop = convert(node, outermostLabeledStatement, convertedLoopBodyStatements);
}
else {
- loop = ts.getMutableClone(node);
- loop.statement = undefined;
- loop = ts.visitEachChild(loop, visitor, context);
- loop.statement = ts.createBlock(convertedLoopBodyStatements, undefined, true);
- loop.transformFlags = 0;
- ts.aggregateTransformFlags(loop);
- }
- statements.push(currentParent.kind === 219
- ? ts.createLabel(currentParent.label, loop)
- : loop);
+ var clone_4 = ts.getMutableClone(node);
+ clone_4.statement = undefined;
+ clone_4 = ts.visitEachChild(clone_4, visitor, context);
+ clone_4.statement = ts.createBlock(convertedLoopBodyStatements, true);
+ clone_4.transformFlags = 0;
+ ts.aggregateTransformFlags(clone_4);
+ loop = ts.restoreEnclosingLabel(clone_4, outermostLabeledStatement, convertedLoopState && resetLabel);
+ }
+ statements.push(loop);
return statements;
}
function copyOutParameter(outParam, copyDirection) {
@@ -41076,7 +44617,9 @@ var ts;
!state.labeledNonLocalBreaks &&
!state.labeledNonLocalContinues;
var call = ts.createCall(loopFunctionExpressionName, undefined, ts.map(parameters, function (p) { return p.name; }));
- var callResult = isAsyncBlockContainingAwait ? ts.createYield(ts.createToken(38), call) : call;
+ var callResult = isAsyncBlockContainingAwait
+ ? ts.createYield(ts.createToken(38), ts.setEmitFlags(call, 4194304))
+ : call;
if (isSimpleLoop) {
statements.push(ts.createStatement(callResult));
copyOutParameters(state.loopOutParameters, 0, statements);
@@ -41114,23 +44657,22 @@ var ts;
if (!state.labeledNonLocalBreaks) {
state.labeledNonLocalBreaks = ts.createMap();
}
- state.labeledNonLocalBreaks[labelText] = labelMarker;
+ state.labeledNonLocalBreaks.set(labelText, labelMarker);
}
else {
if (!state.labeledNonLocalContinues) {
state.labeledNonLocalContinues = ts.createMap();
}
- state.labeledNonLocalContinues[labelText] = labelMarker;
+ state.labeledNonLocalContinues.set(labelText, labelMarker);
}
}
function processLabeledJumps(table, isBreak, loopResultName, outerLoop, caseClauses) {
if (!table) {
return;
}
- for (var labelText in table) {
- var labelMarker = table[labelText];
+ table.forEach(function (labelMarker, labelText) {
var statements = [];
- if (!outerLoop || (outerLoop.labels && outerLoop.labels[labelText])) {
+ if (!outerLoop || (outerLoop.labels && outerLoop.labels.get(labelText))) {
var label = ts.createIdentifier(labelText);
statements.push(isBreak ? ts.createBreak(label) : ts.createContinue(label));
}
@@ -41139,7 +44681,7 @@ var ts;
statements.push(ts.createReturn(loopResultName));
}
caseClauses.push(ts.createCaseClause(ts.createLiteral(labelMarker), statements));
- }
+ });
}
function processLoopVariableDeclaration(decl, loopParameters, loopOutParameters) {
var name = decl.name;
@@ -41154,7 +44696,7 @@ var ts;
else {
loopParameters.push(ts.createParameter(undefined, undefined, undefined, name));
if (resolver.getNodeCheckFlags(decl) & 2097152) {
- var outParamName = ts.createUniqueName("out_" + name.text);
+ var outParamName = ts.createUniqueName("out_" + ts.unescapeIdentifier(name.text));
loopOutParameters.push({ originalName: name, outParamName: outParamName });
}
}
@@ -41165,22 +44707,22 @@ var ts;
for (var i = start; i < numProperties; i++) {
var property = properties[i];
switch (property.kind) {
- case 151:
case 152:
+ case 153:
var accessors = ts.getAllAccessorDeclarations(node.properties, property);
if (property === accessors.firstAccessor) {
- expressions.push(transformAccessorsToExpression(receiver, accessors, node.multiLine));
+ expressions.push(transformAccessorsToExpression(receiver, accessors, node, node.multiLine));
}
break;
- case 257:
+ case 150:
+ expressions.push(transformObjectLiteralMethodDeclarationToExpression(property, receiver, node, node.multiLine));
+ break;
+ case 260:
expressions.push(transformPropertyAssignmentToExpression(property, receiver, node.multiLine));
break;
- case 258:
+ case 261:
expressions.push(transformShorthandPropertyAssignmentToExpression(property, receiver, node.multiLine));
break;
- case 149:
- expressions.push(transformObjectLiteralMethodDeclarationToExpression(property, receiver, node.multiLine));
- break;
default:
ts.Debug.failBadSyntaxKind(node);
break;
@@ -41188,34 +44730,49 @@ var ts;
}
}
function transformPropertyAssignmentToExpression(property, receiver, startsOnNewLine) {
- var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(property.name, visitor, ts.isPropertyName)), ts.visitNode(property.initializer, visitor, ts.isExpression), property);
+ var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(property.name, visitor, ts.isPropertyName)), ts.visitNode(property.initializer, visitor, ts.isExpression));
+ ts.setTextRange(expression, property);
if (startsOnNewLine) {
expression.startsOnNewLine = true;
}
return expression;
}
function transformShorthandPropertyAssignmentToExpression(property, receiver, startsOnNewLine) {
- var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(property.name, visitor, ts.isPropertyName)), ts.getSynthesizedClone(property.name), property);
+ var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(property.name, visitor, ts.isPropertyName)), ts.getSynthesizedClone(property.name));
+ ts.setTextRange(expression, property);
if (startsOnNewLine) {
expression.startsOnNewLine = true;
}
return expression;
}
- function transformObjectLiteralMethodDeclarationToExpression(method, receiver, startsOnNewLine) {
- var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(method.name, visitor, ts.isPropertyName)), transformFunctionLikeToExpression(method, method, undefined), method);
+ function transformObjectLiteralMethodDeclarationToExpression(method, receiver, container, startsOnNewLine) {
+ var ancestorFacts = enterSubtree(0, 0);
+ var expression = ts.createAssignment(ts.createMemberAccessForPropertyName(receiver, ts.visitNode(method.name, visitor, ts.isPropertyName)), transformFunctionLikeToExpression(method, method, undefined, container));
+ ts.setTextRange(expression, method);
if (startsOnNewLine) {
expression.startsOnNewLine = true;
}
+ exitSubtree(ancestorFacts, 49152, hierarchyFacts & 49152 ? 16384 : 0);
return expression;
}
function visitCatchClause(node) {
- ts.Debug.assert(ts.isBindingPattern(node.variableDeclaration.name));
- var temp = ts.createTempVariable(undefined);
- var newVariableDeclaration = ts.createVariableDeclaration(temp, undefined, undefined, node.variableDeclaration);
- var vars = ts.flattenDestructuringBinding(node.variableDeclaration, visitor, context, 0, temp);
- var list = ts.createVariableDeclarationList(vars, node.variableDeclaration, node.variableDeclaration.flags);
- var destructure = ts.createVariableStatement(undefined, list);
- return ts.updateCatchClause(node, newVariableDeclaration, addStatementToStartOfBlock(node.block, destructure));
+ var ancestorFacts = enterSubtree(4032, 0);
+ var updated;
+ if (ts.isBindingPattern(node.variableDeclaration.name)) {
+ var temp = ts.createTempVariable(undefined);
+ var newVariableDeclaration = ts.createVariableDeclaration(temp);
+ ts.setTextRange(newVariableDeclaration, node.variableDeclaration);
+ var vars = ts.flattenDestructuringBinding(node.variableDeclaration, visitor, context, 0, temp);
+ var list = ts.createVariableDeclarationList(vars);
+ ts.setTextRange(list, node.variableDeclaration);
+ var destructure = ts.createVariableStatement(undefined, list);
+ updated = ts.updateCatchClause(node, newVariableDeclaration, addStatementToStartOfBlock(node.block, destructure));
+ }
+ else {
+ updated = ts.visitEachChild(node, visitor, context);
+ }
+ exitSubtree(ancestorFacts, 0, 0);
+ return updated;
}
function addStatementToStartOfBlock(block, statement) {
var transformedStatements = ts.visitNodes(block.statements, visitor, ts.isStatement);
@@ -41223,21 +44780,43 @@ var ts;
}
function visitMethodDeclaration(node) {
ts.Debug.assert(!ts.isComputedPropertyName(node.name));
- var functionExpression = transformFunctionLikeToExpression(node, ts.moveRangePos(node, -1), undefined);
+ var functionExpression = transformFunctionLikeToExpression(node, ts.moveRangePos(node, -1), undefined, undefined);
ts.setEmitFlags(functionExpression, 512 | ts.getEmitFlags(functionExpression));
- return ts.createPropertyAssignment(node.name, functionExpression, node);
+ return ts.setTextRange(ts.createPropertyAssignment(node.name, functionExpression), node);
+ }
+ function visitAccessorDeclaration(node) {
+ ts.Debug.assert(!ts.isComputedPropertyName(node.name));
+ var savedConvertedLoopState = convertedLoopState;
+ convertedLoopState = undefined;
+ var ancestorFacts = enterSubtree(16286, 65);
+ var updated = ts.visitEachChild(node, visitor, context);
+ exitSubtree(ancestorFacts, 49152, 0);
+ convertedLoopState = savedConvertedLoopState;
+ return updated;
}
function visitShorthandPropertyAssignment(node) {
- return ts.createPropertyAssignment(node.name, ts.getSynthesizedClone(node.name), node);
+ return ts.setTextRange(ts.createPropertyAssignment(node.name, ts.getSynthesizedClone(node.name)), node);
+ }
+ function visitComputedPropertyName(node) {
+ var ancestorFacts = enterSubtree(0, 8192);
+ var updated = ts.visitEachChild(node, visitor, context);
+ exitSubtree(ancestorFacts, 49152, hierarchyFacts & 49152 ? 32768 : 0);
+ return updated;
}
function visitYieldExpression(node) {
return ts.visitEachChild(node, visitor, context);
}
function visitArrayLiteralExpression(node) {
- return transformAndSpreadElements(node.elements, true, node.multiLine, node.elements.hasTrailingComma);
+ if (node.transformFlags & 64) {
+ return transformAndSpreadElements(node.elements, true, node.multiLine, node.elements.hasTrailingComma);
+ }
+ return ts.visitEachChild(node, visitor, context);
}
function visitCallExpression(node) {
- return visitCallExpressionWithPotentialCapturedThisAssignment(node, true);
+ if (node.transformFlags & 64) {
+ return visitCallExpressionWithPotentialCapturedThisAssignment(node, true);
+ }
+ return ts.updateCall(node, ts.visitNode(node.expression, callExpressionVisitor, ts.isExpression), undefined, ts.visitNodes(node.arguments, visitor, ts.isExpression));
}
function visitImmediateSuperCallInBody(node) {
return visitCallExpressionWithPotentialCapturedThisAssignment(node, false);
@@ -41249,38 +44828,54 @@ var ts;
}
var resultingCall;
if (node.transformFlags & 524288) {
- resultingCall = ts.createFunctionApply(ts.visitNode(target, visitor, ts.isExpression), ts.visitNode(thisArg, visitor, ts.isExpression), transformAndSpreadElements(node.arguments, false, false, false));
+ resultingCall = ts.createFunctionApply(ts.visitNode(target, callExpressionVisitor, ts.isExpression), ts.visitNode(thisArg, visitor, ts.isExpression), transformAndSpreadElements(node.arguments, false, false, false));
}
else {
- resultingCall = ts.createFunctionCall(ts.visitNode(target, visitor, ts.isExpression), ts.visitNode(thisArg, visitor, ts.isExpression), ts.visitNodes(node.arguments, visitor, ts.isExpression), node);
+ resultingCall = ts.createFunctionCall(ts.visitNode(target, callExpressionVisitor, ts.isExpression), ts.visitNode(thisArg, visitor, ts.isExpression), ts.visitNodes(node.arguments, visitor, ts.isExpression), node);
}
if (node.expression.kind === 96) {
var actualThis = ts.createThis();
ts.setEmitFlags(actualThis, 4);
var initializer = ts.createLogicalOr(resultingCall, actualThis);
- return assignToCapturedThis
+ resultingCall = assignToCapturedThis
? ts.createAssignment(ts.createIdentifier("_this"), initializer)
: initializer;
}
- return resultingCall;
+ return ts.setOriginalNode(resultingCall, node);
}
function visitNewExpression(node) {
- ts.Debug.assert((node.transformFlags & 524288) !== 0);
- var _a = ts.createCallBinding(ts.createPropertyAccess(node.expression, "bind"), hoistVariableDeclaration), target = _a.target, thisArg = _a.thisArg;
- return ts.createNew(ts.createFunctionApply(ts.visitNode(target, visitor, ts.isExpression), thisArg, transformAndSpreadElements(ts.createNodeArray([ts.createVoidZero()].concat(node.arguments)), false, false, false)), undefined, []);
+ if (node.transformFlags & 524288) {
+ var _a = ts.createCallBinding(ts.createPropertyAccess(node.expression, "bind"), hoistVariableDeclaration), target = _a.target, thisArg = _a.thisArg;
+ return ts.createNew(ts.createFunctionApply(ts.visitNode(target, visitor, ts.isExpression), thisArg, transformAndSpreadElements(ts.createNodeArray([ts.createVoidZero()].concat(node.arguments)), false, false, false)), undefined, []);
+ }
+ return ts.visitEachChild(node, visitor, context);
}
function transformAndSpreadElements(elements, needsUniqueCopy, multiLine, hasTrailingComma) {
var numElements = elements.length;
var segments = ts.flatten(ts.spanMap(elements, partitionSpread, function (partition, visitPartition, _start, end) {
return visitPartition(partition, multiLine, hasTrailingComma && end === numElements);
}));
- if (segments.length === 1) {
- var firstElement = elements[0];
- return needsUniqueCopy && ts.isSpreadExpression(firstElement) && firstElement.expression.kind !== 175
- ? ts.createArraySlice(segments[0])
- : segments[0];
+ if (compilerOptions.downlevelIteration) {
+ if (segments.length === 1) {
+ var firstSegment = segments[0];
+ if (ts.isCallExpression(firstSegment)
+ && ts.isIdentifier(firstSegment.expression)
+ && (ts.getEmitFlags(firstSegment.expression) & 4096)
+ && firstSegment.expression.text === "___spread") {
+ return segments[0];
+ }
+ }
+ return ts.createSpreadHelper(context, segments);
+ }
+ else {
+ if (segments.length === 1) {
+ var firstElement = elements[0];
+ return needsUniqueCopy && ts.isSpreadExpression(firstElement) && firstElement.expression.kind !== 176
+ ? ts.createArraySlice(segments[0])
+ : segments[0];
+ }
+ return ts.createArrayConcat(segments.shift(), segments);
}
- return ts.createArrayConcat(segments.shift(), segments);
}
function partitionSpread(node) {
return ts.isSpreadExpression(node)
@@ -41291,7 +44886,7 @@ var ts;
return ts.map(chunk, visitExpressionOfSpread);
}
function visitSpanOfNonSpreads(chunk, multiLine, hasTrailingComma) {
- return ts.createArrayLiteral(ts.visitNodes(ts.createNodeArray(chunk, undefined, hasTrailingComma), visitor, ts.isExpression), undefined, multiLine);
+ return ts.createArrayLiteral(ts.visitNodes(ts.createNodeArray(chunk, hasTrailingComma), visitor, ts.isExpression), multiLine);
}
function visitSpreadElement(node) {
return ts.visitNode(node.expression, visitor, ts.isExpression);
@@ -41300,7 +44895,19 @@ var ts;
return ts.visitNode(node.expression, visitor, ts.isExpression);
}
function visitTemplateLiteral(node) {
- return ts.createLiteral(node.text, node);
+ return ts.setTextRange(ts.createLiteral(node.text), node);
+ }
+ function visitStringLiteral(node) {
+ if (node.hasExtendedUnicodeEscape) {
+ return ts.setTextRange(ts.createLiteral(node.text), node);
+ }
+ return node;
+ }
+ function visitNumericLiteral(node) {
+ if (node.numericLiteralFlags & 48) {
+ return ts.setTextRange(ts.createNumericLiteral(node.text), node);
+ }
+ return node;
}
function visitTaggedTemplateExpression(node) {
var tag = ts.visitNode(node.tag, visitor, ts.isExpression);
@@ -41334,7 +44941,7 @@ var ts;
var isLast = node.kind === 12 || node.kind === 15;
text = text.substring(1, text.length - (isLast ? 1 : 2));
text = text.replace(/\r\n?/g, "\n");
- return ts.createLiteral(text, node);
+ return ts.setTextRange(ts.createLiteral(text), node);
}
function visitTemplateExpression(node) {
var expressions = [];
@@ -41342,7 +44949,8 @@ var ts;
addTemplateSpans(expressions, node);
var expression = ts.reduceLeft(expressions, ts.createAdd);
if (ts.nodeIsSynthesized(expression)) {
- ts.setTextRange(expression, node);
+ expression.pos = node.pos;
+ expression.end = node.end;
}
return expression;
}
@@ -41365,21 +44973,34 @@ var ts;
}
}
}
- function visitSuperKeyword() {
- return enclosingNonAsyncFunctionBody
- && ts.isClassElement(enclosingNonAsyncFunctionBody)
- && !ts.hasModifier(enclosingNonAsyncFunctionBody, 32)
- && currentParent.kind !== 179
+ function visitSuperKeyword(isExpressionOfCall) {
+ return hierarchyFacts & 8
+ && !isExpressionOfCall
? ts.createPropertyAccess(ts.createIdentifier("_super"), "prototype")
: ts.createIdentifier("_super");
}
- function onEmitNode(emitContext, node, emitCallback) {
- var savedEnclosingFunction = enclosingFunction;
+ function visitMetaProperty(node) {
+ if (node.keywordToken === 93 && node.name.text === "target") {
+ if (hierarchyFacts & 8192) {
+ hierarchyFacts |= 32768;
+ }
+ else {
+ hierarchyFacts |= 16384;
+ }
+ return ts.createIdentifier("_newTarget");
+ }
+ return node;
+ }
+ function onEmitNode(hint, node, emitCallback) {
if (enabledSubstitutions & 1 && ts.isFunctionLike(node)) {
- enclosingFunction = node;
+ var ancestorFacts = enterSubtree(16286, ts.getEmitFlags(node) & 8
+ ? 65 | 16
+ : 65);
+ previousOnEmitNode(hint, node, emitCallback);
+ exitSubtree(ancestorFacts, 0, 0);
+ return;
}
- previousOnEmitNode(emitContext, node, emitCallback);
- enclosingFunction = savedEnclosingFunction;
+ previousOnEmitNode(hint, node, emitCallback);
}
function enableSubstitutionsForBlockScopedBindings() {
if ((enabledSubstitutions & 2) === 0) {
@@ -41391,18 +45012,18 @@ var ts;
if ((enabledSubstitutions & 1) === 0) {
enabledSubstitutions |= 1;
context.enableSubstitution(98);
- context.enableEmitNotification(150);
- context.enableEmitNotification(149);
context.enableEmitNotification(151);
+ context.enableEmitNotification(150);
context.enableEmitNotification(152);
+ context.enableEmitNotification(153);
+ context.enableEmitNotification(186);
context.enableEmitNotification(185);
- context.enableEmitNotification(184);
- context.enableEmitNotification(225);
+ context.enableEmitNotification(227);
}
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (emitContext === 1) {
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (hint === 1) {
return substituteExpression(node);
}
if (ts.isIdentifier(node)) {
@@ -41414,7 +45035,7 @@ var ts;
if (enabledSubstitutions & 2) {
var original = ts.getParseTreeNode(node, ts.isIdentifier);
if (original && isNameOfDeclarationWithCollidingName(original)) {
- return ts.getGeneratedNameForNode(original);
+ return ts.setTextRange(ts.getGeneratedNameForNode(original), node);
}
}
return node;
@@ -41422,10 +45043,10 @@ var ts;
function isNameOfDeclarationWithCollidingName(node) {
var parent = node.parent;
switch (parent.kind) {
- case 174:
- case 226:
- case 229:
- case 223:
+ case 175:
+ case 228:
+ case 231:
+ case 225:
return parent.name === node
&& resolver.isDeclarationWithCollidingName(parent);
}
@@ -41444,16 +45065,15 @@ var ts;
if (enabledSubstitutions & 2) {
var declaration = resolver.getReferencedDeclarationWithCollidingName(node);
if (declaration) {
- return ts.getGeneratedNameForNode(declaration.name);
+ return ts.setTextRange(ts.getGeneratedNameForNode(declaration.name), node);
}
}
return node;
}
function substituteThisKeyword(node) {
if (enabledSubstitutions & 1
- && enclosingFunction
- && ts.getEmitFlags(enclosingFunction) & 8) {
- return ts.createIdentifier("_this", node);
+ && hierarchyFacts & 16) {
+ return ts.setTextRange(ts.createIdentifier("_this"), node);
}
return node;
}
@@ -41469,11 +45089,11 @@ var ts;
return false;
}
var statement = ts.firstOrUndefined(constructor.body.statements);
- if (!statement || !ts.nodeIsSynthesized(statement) || statement.kind !== 207) {
+ if (!statement || !ts.nodeIsSynthesized(statement) || statement.kind !== 209) {
return false;
}
var statementExpression = statement.expression;
- if (!ts.nodeIsSynthesized(statementExpression) || statementExpression.kind !== 179) {
+ if (!ts.nodeIsSynthesized(statementExpression) || statementExpression.kind !== 180) {
return false;
}
var callTarget = statementExpression.expression;
@@ -41481,7 +45101,7 @@ var ts;
return false;
}
var callArgument = ts.singleOrUndefined(statementExpression.arguments);
- if (!callArgument || !ts.nodeIsSynthesized(callArgument) || callArgument.kind !== 196) {
+ if (!callArgument || !ts.nodeIsSynthesized(callArgument) || callArgument.kind !== 197) {
return false;
}
var expression = callArgument.expression;
@@ -41500,18 +45120,90 @@ var ts;
name: "typescript:extends",
scoped: false,
priority: 0,
- text: "\n var __extends = (this && this.__extends) || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };"
+ text: "\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n })();"
};
})(ts || (ts = {}));
var ts;
(function (ts) {
- var instructionNames = ts.createMap((_a = {},
- _a[2] = "return",
- _a[3] = "break",
- _a[4] = "yield",
- _a[5] = "yield*",
- _a[7] = "endfinally",
- _a));
+ function transformES5(context) {
+ var compilerOptions = context.getCompilerOptions();
+ var previousOnEmitNode;
+ var noSubstitution;
+ if (compilerOptions.jsx === 1 || compilerOptions.jsx === 3) {
+ previousOnEmitNode = context.onEmitNode;
+ context.onEmitNode = onEmitNode;
+ context.enableEmitNotification(250);
+ context.enableEmitNotification(251);
+ context.enableEmitNotification(249);
+ noSubstitution = [];
+ }
+ var previousOnSubstituteNode = context.onSubstituteNode;
+ context.onSubstituteNode = onSubstituteNode;
+ context.enableSubstitution(178);
+ context.enableSubstitution(260);
+ return transformSourceFile;
+ function transformSourceFile(node) {
+ return node;
+ }
+ function onEmitNode(hint, node, emitCallback) {
+ switch (node.kind) {
+ case 250:
+ case 251:
+ case 249:
+ var tagName = node.tagName;
+ noSubstitution[ts.getOriginalNodeId(tagName)] = true;
+ break;
+ }
+ previousOnEmitNode(hint, node, emitCallback);
+ }
+ function onSubstituteNode(hint, node) {
+ if (node.id && noSubstitution && noSubstitution[node.id]) {
+ return previousOnSubstituteNode(hint, node);
+ }
+ node = previousOnSubstituteNode(hint, node);
+ if (ts.isPropertyAccessExpression(node)) {
+ return substitutePropertyAccessExpression(node);
+ }
+ else if (ts.isPropertyAssignment(node)) {
+ return substitutePropertyAssignment(node);
+ }
+ return node;
+ }
+ function substitutePropertyAccessExpression(node) {
+ var literalName = trySubstituteReservedName(node.name);
+ if (literalName) {
+ return ts.setTextRange(ts.createElementAccess(node.expression, literalName), node);
+ }
+ return node;
+ }
+ function substitutePropertyAssignment(node) {
+ var literalName = ts.isIdentifier(node.name) && trySubstituteReservedName(node.name);
+ if (literalName) {
+ return ts.updatePropertyAssignment(node, literalName, node.initializer);
+ }
+ return node;
+ }
+ function trySubstituteReservedName(name) {
+ var token = name.originalKeywordKind || (ts.nodeIsSynthesized(name) ? ts.stringToToken(name.text) : undefined);
+ if (token >= 71 && token <= 106) {
+ return ts.setTextRange(ts.createLiteral(name), name);
+ }
+ return undefined;
+ }
+ }
+ ts.transformES5 = transformES5;
+})(ts || (ts = {}));
+var ts;
+(function (ts) {
+ function getInstructionName(instruction) {
+ switch (instruction) {
+ case 2: return "return";
+ case 3: return "break";
+ case 4: return "yield";
+ case 5: return "yield*";
+ case 7: return "endfinally";
+ }
+ }
function transformGenerators(context) {
var resumeLexicalEnvironment = context.resumeLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment, hoistFunctionDeclaration = context.hoistFunctionDeclaration, hoistVariableDeclaration = context.hoistVariableDeclaration;
var compilerOptions = context.getCompilerOptions();
@@ -41577,13 +45269,13 @@ var ts;
}
function visitJavaScriptInStatementContainingYield(node) {
switch (node.kind) {
- case 209:
+ case 211:
return visitDoStatement(node);
- case 210:
+ case 212:
return visitWhileStatement(node);
- case 218:
+ case 220:
return visitSwitchStatement(node);
- case 219:
+ case 221:
return visitLabeledStatement(node);
default:
return visitJavaScriptInGeneratorFunctionBody(node);
@@ -41591,24 +45283,24 @@ var ts;
}
function visitJavaScriptInGeneratorFunctionBody(node) {
switch (node.kind) {
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 184:
+ case 185:
return visitFunctionExpression(node);
- case 151:
case 152:
+ case 153:
return visitAccessorDeclaration(node);
- case 205:
+ case 207:
return visitVariableStatement(node);
- case 211:
+ case 213:
return visitForStatement(node);
- case 212:
+ case 214:
return visitForInStatement(node);
- case 215:
+ case 217:
return visitBreakStatement(node);
- case 214:
- return visitContinueStatement(node);
case 216:
+ return visitContinueStatement(node);
+ case 218:
return visitReturnStatement(node);
default:
if (node.transformFlags & 16777216) {
@@ -41624,21 +45316,21 @@ var ts;
}
function visitJavaScriptContainingYield(node) {
switch (node.kind) {
- case 192:
- return visitBinaryExpression(node);
case 193:
+ return visitBinaryExpression(node);
+ case 194:
return visitConditionalExpression(node);
- case 195:
+ case 196:
return visitYieldExpression(node);
- case 175:
- return visitArrayLiteralExpression(node);
case 176:
+ return visitArrayLiteralExpression(node);
+ case 177:
return visitObjectLiteralExpression(node);
- case 178:
- return visitElementAccessExpression(node);
case 179:
- return visitCallExpression(node);
+ return visitElementAccessExpression(node);
case 180:
+ return visitCallExpression(node);
+ case 181:
return visitNewExpression(node);
default:
return ts.visitEachChild(node, visitor, context);
@@ -41646,9 +45338,9 @@ var ts;
}
function visitGenerator(node) {
switch (node.kind) {
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 184:
+ case 185:
return visitFunctionExpression(node);
default:
ts.Debug.failBadSyntaxKind(node);
@@ -41656,8 +45348,8 @@ var ts;
}
}
function visitFunctionDeclaration(node) {
- if (node.asteriskToken && ts.getEmitFlags(node) & 131072) {
- node = ts.setOriginalNode(ts.createFunctionDeclaration(undefined, node.modifiers, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformGeneratorFunctionBody(node.body), node), node);
+ if (node.asteriskToken) {
+ node = ts.setOriginalNode(ts.setTextRange(ts.createFunctionDeclaration(undefined, node.modifiers, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformGeneratorFunctionBody(node.body)), node), node);
}
else {
var savedInGeneratorFunctionBody = inGeneratorFunctionBody;
@@ -41677,8 +45369,8 @@ var ts;
}
}
function visitFunctionExpression(node) {
- if (node.asteriskToken && ts.getEmitFlags(node) & 131072) {
- node = ts.setOriginalNode(ts.createFunctionExpression(undefined, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformGeneratorFunctionBody(node.body), node), node);
+ if (node.asteriskToken) {
+ node = ts.setOriginalNode(ts.setTextRange(ts.createFunctionExpression(undefined, undefined, node.name, undefined, ts.visitParameterList(node.parameters, visitor, context), undefined, transformGeneratorFunctionBody(node.body)), node), node);
}
else {
var savedInGeneratorFunctionBody = inGeneratorFunctionBody;
@@ -41730,7 +45422,7 @@ var ts;
operationLocations = undefined;
state = ts.createTempVariable(undefined);
resumeLexicalEnvironment();
- var statementOffset = ts.addPrologueDirectives(statements, body.statements, false, visitor);
+ var statementOffset = ts.addPrologue(statements, body.statements, false, visitor);
transformAndEmitStatements(body.statements, statementOffset);
var buildResult = build();
ts.addRange(statements, endLexicalEnvironment());
@@ -41748,7 +45440,7 @@ var ts;
operationArguments = savedOperationArguments;
operationLocations = savedOperationLocations;
state = savedState;
- return ts.createBlock(statements, body, body.multiLine);
+ return ts.setTextRange(ts.createBlock(statements, body.multiLine), body);
}
function visitVariableStatement(node) {
if (node.transformFlags & 16777216) {
@@ -41805,10 +45497,10 @@ var ts;
if (containsYield(right)) {
var target = void 0;
switch (left.kind) {
- case 177:
+ case 178:
target = ts.updatePropertyAccess(left, cacheExpression(ts.visitNode(left.expression, visitor, ts.isLeftHandSideExpression)), left.name);
break;
- case 178:
+ case 179:
target = ts.updateElementAccess(left, cacheExpression(ts.visitNode(left.expression, visitor, ts.isLeftHandSideExpression)), cacheExpression(ts.visitNode(left.argumentExpression, visitor, ts.isExpression)));
break;
default:
@@ -41817,7 +45509,7 @@ var ts;
}
var operator = node.operatorToken.kind;
if (isCompoundAssignment(operator)) {
- return ts.createBinary(target, 57, ts.createBinary(cacheExpression(target), getOperatorForCompoundAssignment(operator), ts.visitNode(right, visitor, ts.isExpression), node), node);
+ return ts.setTextRange(ts.createAssignment(target, ts.setTextRange(ts.createBinary(cacheExpression(target), getOperatorForCompoundAssignment(operator), ts.visitNode(right, visitor, ts.isExpression)), node)), node);
}
else {
return ts.updateBinary(node, target, ts.visitNode(right, visitor, ts.isExpression));
@@ -41833,10 +45525,10 @@ var ts;
else if (node.operatorToken.kind === 25) {
return visitCommaExpression(node);
}
- var clone_4 = ts.getMutableClone(node);
- clone_4.left = cacheExpression(ts.visitNode(node.left, visitor, ts.isExpression));
- clone_4.right = ts.visitNode(node.right, visitor, ts.isExpression);
- return clone_4;
+ var clone_5 = ts.getMutableClone(node);
+ clone_5.left = cacheExpression(ts.visitNode(node.left, visitor, ts.isExpression));
+ clone_5.right = ts.visitNode(node.right, visitor, ts.isExpression);
+ return clone_5;
}
return ts.visitEachChild(node, visitor, context);
}
@@ -41892,38 +45584,43 @@ var ts;
var resumeLabel = defineLabel();
var expression = ts.visitNode(node.expression, visitor, ts.isExpression);
if (node.asteriskToken) {
- emitYieldStar(expression, node);
+ var iterator = (ts.getEmitFlags(node.expression) & 4194304) === 0
+ ? ts.createValuesHelper(context, expression, node)
+ : expression;
+ emitYieldStar(iterator, node);
}
else {
emitYield(expression, node);
}
markLabel(resumeLabel);
- return createGeneratorResume();
+ return createGeneratorResume(node);
}
function visitArrayLiteralExpression(node) {
return visitElements(node.elements, undefined, undefined, node.multiLine);
}
function visitElements(elements, leadingElement, location, multiLine) {
var numInitialElements = countInitialNodesWithoutYield(elements);
- var temp = declareLocal();
- var hasAssignedTemp = false;
+ var temp;
if (numInitialElements > 0) {
+ temp = declareLocal();
var initialElements = ts.visitNodes(elements, visitor, ts.isExpression, 0, numInitialElements);
emitAssignment(temp, ts.createArrayLiteral(leadingElement
? [leadingElement].concat(initialElements) : initialElements));
leadingElement = undefined;
- hasAssignedTemp = true;
}
var expressions = ts.reduceLeft(elements, reduceElement, [], numInitialElements);
- return hasAssignedTemp
- ? ts.createArrayConcat(temp, [ts.createArrayLiteral(expressions, undefined, multiLine)])
- : ts.createArrayLiteral(leadingElement ? [leadingElement].concat(expressions) : expressions, location, multiLine);
+ return temp
+ ? ts.createArrayConcat(temp, [ts.createArrayLiteral(expressions, multiLine)])
+ : ts.setTextRange(ts.createArrayLiteral(leadingElement ? [leadingElement].concat(expressions) : expressions, multiLine), location);
function reduceElement(expressions, element) {
if (containsYield(element) && expressions.length > 0) {
+ var hasAssignedTemp = temp !== undefined;
+ if (!temp) {
+ temp = declareLocal();
+ }
emitAssignment(temp, hasAssignedTemp
- ? ts.createArrayConcat(temp, [ts.createArrayLiteral(expressions, undefined, multiLine)])
- : ts.createArrayLiteral(leadingElement ? [leadingElement].concat(expressions) : expressions, undefined, multiLine));
- hasAssignedTemp = true;
+ ? ts.createArrayConcat(temp, [ts.createArrayLiteral(expressions, multiLine)])
+ : ts.createArrayLiteral(leadingElement ? [leadingElement].concat(expressions) : expressions, multiLine));
leadingElement = undefined;
expressions = [];
}
@@ -41936,7 +45633,7 @@ var ts;
var multiLine = node.multiLine;
var numInitialProperties = countInitialNodesWithoutYield(properties);
var temp = declareLocal();
- emitAssignment(temp, ts.createObjectLiteral(ts.visitNodes(properties, visitor, ts.isObjectLiteralElementLike, 0, numInitialProperties), undefined, multiLine));
+ emitAssignment(temp, ts.createObjectLiteral(ts.visitNodes(properties, visitor, ts.isObjectLiteralElementLike, 0, numInitialProperties), multiLine));
var expressions = ts.reduceLeft(properties, reduceProperty, [], numInitialProperties);
expressions.push(multiLine ? ts.startOnNewLine(ts.getMutableClone(temp)) : temp);
return ts.inlineExpressions(expressions);
@@ -41958,10 +45655,10 @@ var ts;
}
function visitElementAccessExpression(node) {
if (containsYield(node.argumentExpression)) {
- var clone_5 = ts.getMutableClone(node);
- clone_5.expression = cacheExpression(ts.visitNode(node.expression, visitor, ts.isLeftHandSideExpression));
- clone_5.argumentExpression = ts.visitNode(node.argumentExpression, visitor, ts.isExpression);
- return clone_5;
+ var clone_6 = ts.getMutableClone(node);
+ clone_6.expression = cacheExpression(ts.visitNode(node.expression, visitor, ts.isLeftHandSideExpression));
+ clone_6.argumentExpression = ts.visitNode(node.argumentExpression, visitor, ts.isExpression);
+ return clone_6;
}
return ts.visitEachChild(node, visitor, context);
}
@@ -41975,7 +45672,7 @@ var ts;
function visitNewExpression(node) {
if (ts.forEach(node.arguments, containsYield)) {
var _a = ts.createCallBinding(ts.createPropertyAccess(node.expression, "bind"), hoistVariableDeclaration), target = _a.target, thisArg = _a.thisArg;
- return ts.setOriginalNode(ts.createNew(ts.createFunctionApply(cacheExpression(ts.visitNode(target, visitor, ts.isExpression)), thisArg, visitElements(node.arguments, ts.createVoidZero())), undefined, [], node), node);
+ return ts.setOriginalNode(ts.setTextRange(ts.createNew(ts.createFunctionApply(cacheExpression(ts.visitNode(target, visitor, ts.isExpression)), thisArg, visitElements(node.arguments, ts.createVoidZero())), undefined, []), node), node);
}
return ts.visitEachChild(node, visitor, context);
}
@@ -42004,38 +45701,38 @@ var ts;
}
function transformAndEmitStatementWorker(node) {
switch (node.kind) {
- case 204:
+ case 206:
return transformAndEmitBlock(node);
- case 207:
+ case 209:
return transformAndEmitExpressionStatement(node);
- case 208:
+ case 210:
return transformAndEmitIfStatement(node);
- case 209:
+ case 211:
return transformAndEmitDoStatement(node);
- case 210:
+ case 212:
return transformAndEmitWhileStatement(node);
- case 211:
+ case 213:
return transformAndEmitForStatement(node);
- case 212:
- return transformAndEmitForInStatement(node);
case 214:
+ return transformAndEmitForInStatement(node);
+ case 216:
return transformAndEmitContinueStatement(node);
- case 215:
+ case 217:
return transformAndEmitBreakStatement(node);
- case 216:
+ case 218:
return transformAndEmitReturnStatement(node);
- case 217:
+ case 219:
return transformAndEmitWithStatement(node);
- case 218:
+ case 220:
return transformAndEmitSwitchStatement(node);
- case 219:
+ case 221:
return transformAndEmitLabeledStatement(node);
- case 220:
+ case 222:
return transformAndEmitThrowStatement(node);
- case 221:
+ case 223:
return transformAndEmitTryStatement(node);
default:
- return emitStatement(ts.visitNode(node, visitor, ts.isStatement, true));
+ return emitStatement(ts.visitNode(node, visitor, ts.isStatement));
}
}
function transformAndEmitBlock(node) {
@@ -42052,7 +45749,9 @@ var ts;
function transformAndEmitVariableDeclarationList(node) {
for (var _i = 0, _a = node.declarations; _i < _a.length; _i++) {
var variable = _a[_i];
- hoistVariableDeclaration(variable.name);
+ var name = ts.getSynthesizedClone(variable.name);
+ ts.setCommentRange(name, variable.name);
+ hoistVariableDeclaration(name);
}
var variables = ts.getInitializedVariables(node);
var numVariables = variables.length;
@@ -42082,7 +45781,7 @@ var ts;
if (containsYield(node.thenStatement) || containsYield(node.elseStatement)) {
var endLabel = defineLabel();
var elseLabel = node.elseStatement ? defineLabel() : undefined;
- emitBreakWhenFalse(node.elseStatement ? elseLabel : endLabel, ts.visitNode(node.expression, visitor, ts.isExpression));
+ emitBreakWhenFalse(node.elseStatement ? elseLabel : endLabel, ts.visitNode(node.expression, visitor, ts.isExpression), node.expression);
transformAndEmitEmbeddedStatement(node.thenStatement);
if (node.elseStatement) {
emitBreak(endLabel);
@@ -42161,7 +45860,7 @@ var ts;
transformAndEmitVariableDeclarationList(initializer);
}
else {
- emitStatement(ts.createStatement(ts.visitNode(initializer, visitor, ts.isExpression), initializer));
+ emitStatement(ts.setTextRange(ts.createStatement(ts.visitNode(initializer, visitor, ts.isExpression)), initializer));
}
}
markLabel(conditionLabel);
@@ -42171,7 +45870,7 @@ var ts;
transformAndEmitEmbeddedStatement(node.statement);
markLabel(incrementLabel);
if (node.incrementor) {
- emitStatement(ts.createStatement(ts.visitNode(node.incrementor, visitor, ts.isExpression), node.incrementor));
+ emitStatement(ts.setTextRange(ts.createStatement(ts.visitNode(node.incrementor, visitor, ts.isExpression)), node.incrementor));
}
emitBreak(conditionLabel);
endLoopBlock();
@@ -42185,7 +45884,7 @@ var ts;
beginScriptLoopBlock();
}
var initializer = node.initializer;
- if (ts.isVariableDeclarationList(initializer)) {
+ if (initializer && ts.isVariableDeclarationList(initializer)) {
for (var _i = 0, _a = initializer.declarations; _i < _a.length; _i++) {
var variable = _a[_i];
hoistVariableDeclaration(variable.name);
@@ -42193,7 +45892,7 @@ var ts;
var variables = ts.getInitializedVariables(initializer);
node = ts.updateFor(node, variables.length > 0
? ts.inlineExpressions(ts.map(variables, transformInitializedVariable))
- : undefined, ts.visitNode(node.condition, visitor, ts.isExpression, true), ts.visitNode(node.incrementor, visitor, ts.isExpression, true), ts.visitNode(node.statement, visitor, ts.isStatement, false, ts.liftToBlock));
+ : undefined, ts.visitNode(node.condition, visitor, ts.isExpression), ts.visitNode(node.incrementor, visitor, ts.isExpression), ts.visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
}
else {
node = ts.visitEachChild(node, visitor, context);
@@ -42251,7 +45950,7 @@ var ts;
var variable = _a[_i];
hoistVariableDeclaration(variable.name);
}
- node = ts.updateForIn(node, initializer.declarations[0].name, ts.visitNode(node.expression, visitor, ts.isExpression), ts.visitNode(node.statement, visitor, ts.isStatement, false, ts.liftToBlock));
+ node = ts.updateForIn(node, initializer.declarations[0].name, ts.visitNode(node.expression, visitor, ts.isExpression), ts.visitNode(node.statement, visitor, ts.isStatement, ts.liftToBlock));
}
else {
node = ts.visitEachChild(node, visitor, context);
@@ -42290,10 +45989,10 @@ var ts;
return ts.visitEachChild(node, visitor, context);
}
function transformAndEmitReturnStatement(node) {
- emitReturn(ts.visitNode(node.expression, visitor, ts.isExpression, true), node);
+ emitReturn(ts.visitNode(node.expression, visitor, ts.isExpression), node);
}
function visitReturnStatement(node) {
- return createInlineReturn(ts.visitNode(node.expression, visitor, ts.isExpression, true), node);
+ return createInlineReturn(ts.visitNode(node.expression, visitor, ts.isExpression), node);
}
function transformAndEmitWithStatement(node) {
if (containsYield(node)) {
@@ -42316,7 +46015,7 @@ var ts;
for (var i = 0; i < numClauses; i++) {
var clause = caseBlock.clauses[i];
clauseLabels.push(defineLabel());
- if (clause.kind === 254 && defaultClauseIndex === -1) {
+ if (clause.kind === 257 && defaultClauseIndex === -1) {
defaultClauseIndex = i;
}
}
@@ -42326,7 +46025,7 @@ var ts;
var defaultClausesSkipped = 0;
for (var i = clausesWritten; i < numClauses; i++) {
var clause = caseBlock.clauses[i];
- if (clause.kind === 253) {
+ if (clause.kind === 256) {
var caseClause = clause;
if (containsYield(caseClause.expression) && pendingClauses.length > 0) {
break;
@@ -42428,9 +46127,9 @@ var ts;
}
return -1;
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (emitContext === 1) {
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (hint === 1) {
return substituteExpression(node);
}
return node;
@@ -42442,17 +46141,17 @@ var ts;
return node;
}
function substituteExpressionIdentifier(node) {
- if (renamedCatchVariables && ts.hasProperty(renamedCatchVariables, node.text)) {
+ if (!ts.isGeneratedIdentifier(node) && renamedCatchVariables && renamedCatchVariables.has(node.text)) {
var original = ts.getOriginalNode(node);
if (ts.isIdentifier(original) && original.parent) {
var declaration = resolver.getReferencedValueDeclaration(original);
if (declaration) {
- var name_36 = ts.getProperty(renamedCatchVariableDeclarations, String(ts.getOriginalNodeId(declaration)));
- if (name_36) {
- var clone_6 = ts.getMutableClone(name_36);
- ts.setSourceMapRange(clone_6, node);
- ts.setCommentRange(clone_6, node);
- return clone_6;
+ var name = renamedCatchVariableDeclarations[ts.getOriginalNodeId(declaration)];
+ if (name) {
+ var clone_7 = ts.getMutableClone(name);
+ ts.setSourceMapRange(clone_7, node);
+ ts.setCommentRange(clone_7, node);
+ return clone_7;
}
}
}
@@ -42461,7 +46160,7 @@ var ts;
}
function cacheExpression(node) {
var temp;
- if (ts.isGeneratedIdentifier(node)) {
+ if (ts.isGeneratedIdentifier(node) || ts.getEmitFlags(node) & 4096) {
return node;
}
temp = ts.createTempVariable(hoistVariableDeclaration);
@@ -42553,15 +46252,22 @@ var ts;
}
function beginCatchBlock(variable) {
ts.Debug.assert(peekBlockKind() === 0);
- var text = variable.name.text;
- var name = declareLocal(text);
- if (!renamedCatchVariables) {
- renamedCatchVariables = ts.createMap();
- renamedCatchVariableDeclarations = ts.createMap();
- context.enableSubstitution(70);
+ var name;
+ if (ts.isGeneratedIdentifier(variable.name)) {
+ name = variable.name;
+ hoistVariableDeclaration(variable.name);
+ }
+ else {
+ var text = variable.name.text;
+ name = declareLocal(text);
+ if (!renamedCatchVariables) {
+ renamedCatchVariables = ts.createMap();
+ renamedCatchVariableDeclarations = [];
+ context.enableSubstitution(70);
+ }
+ renamedCatchVariables.set(text, true);
+ renamedCatchVariableDeclarations[ts.getOriginalNodeId(variable)] = name;
}
- renamedCatchVariables[text] = true;
- renamedCatchVariableDeclarations[ts.getOriginalNodeId(variable)] = name;
var exception = peekBlock();
ts.Debug.assert(exception.state < 1);
var endLabel = exception.endLabel;
@@ -42761,23 +46467,23 @@ var ts;
}
function createInstruction(instruction) {
var literal = ts.createLiteral(instruction);
- literal.trailingComment = instructionNames[instruction];
+ ts.addSyntheticTrailingComment(literal, 3, getInstructionName(instruction));
return literal;
}
function createInlineBreak(label, location) {
ts.Debug.assert(label > 0, "Invalid label: " + label);
- return ts.createReturn(ts.createArrayLiteral([
+ return ts.setTextRange(ts.createReturn(ts.createArrayLiteral([
createInstruction(3),
createLabel(label)
- ]), location);
+ ])), location);
}
function createInlineReturn(expression, location) {
- return ts.createReturn(ts.createArrayLiteral(expression
+ return ts.setTextRange(ts.createReturn(ts.createArrayLiteral(expression
? [createInstruction(2), expression]
- : [createInstruction(2)]), location);
+ : [createInstruction(2)])), location);
}
function createGeneratorResume(location) {
- return ts.createCall(ts.createPropertyAccess(state, "sent"), undefined, [], location);
+ return ts.setTextRange(ts.createCall(ts.createPropertyAccess(state, "sent"), undefined, []), location);
}
function emitNop() {
emitWorker(0);
@@ -42843,7 +46549,7 @@ var ts;
currentExceptionBlock = undefined;
withBlockStack = undefined;
var buildResult = buildStatements();
- return createGeneratorHelper(context, ts.setEmitFlags(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, state)], undefined, ts.createBlock(buildResult, undefined, buildResult.length > 0)), 262144));
+ return createGeneratorHelper(context, ts.setEmitFlags(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, state)], undefined, ts.createBlock(buildResult, buildResult.length > 0)), 262144));
}
function buildStatements() {
if (operations) {
@@ -43052,51 +46758,51 @@ var ts;
}
}
function writeAssign(left, right, operationLocation) {
- writeStatement(ts.createStatement(ts.createAssignment(left, right), operationLocation));
+ writeStatement(ts.setTextRange(ts.createStatement(ts.createAssignment(left, right)), operationLocation));
}
function writeThrow(expression, operationLocation) {
lastOperationWasAbrupt = true;
lastOperationWasCompletion = true;
- writeStatement(ts.createThrow(expression, operationLocation));
+ writeStatement(ts.setTextRange(ts.createThrow(expression), operationLocation));
}
function writeReturn(expression, operationLocation) {
lastOperationWasAbrupt = true;
lastOperationWasCompletion = true;
- writeStatement(ts.createReturn(ts.createArrayLiteral(expression
+ writeStatement(ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral(expression
? [createInstruction(2), expression]
- : [createInstruction(2)]), operationLocation));
+ : [createInstruction(2)])), operationLocation), 384));
}
function writeBreak(label, operationLocation) {
lastOperationWasAbrupt = true;
- writeStatement(ts.createReturn(ts.createArrayLiteral([
+ writeStatement(ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral([
createInstruction(3),
createLabel(label)
- ]), operationLocation));
+ ])), operationLocation), 384));
}
function writeBreakWhenTrue(label, condition, operationLocation) {
- writeStatement(ts.createIf(condition, ts.createReturn(ts.createArrayLiteral([
+ writeStatement(ts.setEmitFlags(ts.createIf(condition, ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral([
createInstruction(3),
createLabel(label)
- ]), operationLocation)));
+ ])), operationLocation), 384)), 1));
}
function writeBreakWhenFalse(label, condition, operationLocation) {
- writeStatement(ts.createIf(ts.createLogicalNot(condition), ts.createReturn(ts.createArrayLiteral([
+ writeStatement(ts.setEmitFlags(ts.createIf(ts.createLogicalNot(condition), ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral([
createInstruction(3),
createLabel(label)
- ]), operationLocation)));
+ ])), operationLocation), 384)), 1));
}
function writeYield(expression, operationLocation) {
lastOperationWasAbrupt = true;
- writeStatement(ts.createReturn(ts.createArrayLiteral(expression
+ writeStatement(ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral(expression
? [createInstruction(4), expression]
- : [createInstruction(4)]), operationLocation));
+ : [createInstruction(4)])), operationLocation), 384));
}
function writeYieldStar(expression, operationLocation) {
lastOperationWasAbrupt = true;
- writeStatement(ts.createReturn(ts.createArrayLiteral([
+ writeStatement(ts.setEmitFlags(ts.setTextRange(ts.createReturn(ts.createArrayLiteral([
createInstruction(5),
expression
- ]), operationLocation));
+ ])), operationLocation), 384));
}
function writeEndfinally() {
lastOperationWasAbrupt = true;
@@ -43114,112 +46820,595 @@ var ts;
name: "typescript:generator",
scoped: false,
priority: 6,
- text: "\n var __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t;\n return { next: verb(0), \"throw\": verb(1), \"return\": verb(2) };\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = y[op[0] & 2 ? \"return\" : op[0] ? \"throw\" : \"next\"]) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [0, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n };"
+ text: "\n var __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = y[op[0] & 2 ? \"return\" : op[0] ? \"throw\" : \"next\"]) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [0, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n };"
};
- var _a;
})(ts || (ts = {}));
var ts;
(function (ts) {
- function transformES5(context) {
+ function transformModule(context) {
+ function getTransformModuleDelegate(moduleKind) {
+ switch (moduleKind) {
+ case ts.ModuleKind.AMD: return transformAMDModule;
+ case ts.ModuleKind.UMD: return transformUMDModule;
+ default: return transformCommonJSModule;
+ }
+ }
+ var startLexicalEnvironment = context.startLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment;
+ var compilerOptions = context.getCompilerOptions();
+ var resolver = context.getEmitResolver();
+ var host = context.getEmitHost();
+ var languageVersion = ts.getEmitScriptTarget(compilerOptions);
+ var moduleKind = ts.getEmitModuleKind(compilerOptions);
var previousOnSubstituteNode = context.onSubstituteNode;
+ var previousOnEmitNode = context.onEmitNode;
context.onSubstituteNode = onSubstituteNode;
- context.enableSubstitution(177);
- context.enableSubstitution(257);
+ context.onEmitNode = onEmitNode;
+ context.enableSubstitution(70);
+ context.enableSubstitution(193);
+ context.enableSubstitution(191);
+ context.enableSubstitution(192);
+ context.enableSubstitution(261);
+ context.enableEmitNotification(264);
+ var moduleInfoMap = [];
+ var deferredExports = [];
+ var currentSourceFile;
+ var currentModuleInfo;
+ var noSubstitution;
return transformSourceFile;
function transformSourceFile(node) {
- return node;
+ if (ts.isDeclarationFile(node) || !(ts.isExternalModule(node) || compilerOptions.isolatedModules)) {
+ return node;
+ }
+ currentSourceFile = node;
+ currentModuleInfo = ts.collectExternalModuleInfo(node, resolver, compilerOptions);
+ moduleInfoMap[ts.getOriginalNodeId(node)] = currentModuleInfo;
+ var transformModule = getTransformModuleDelegate(moduleKind);
+ var updated = transformModule(node);
+ currentSourceFile = undefined;
+ currentModuleInfo = undefined;
+ return ts.aggregateTransformFlags(updated);
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (ts.isPropertyAccessExpression(node)) {
- return substitutePropertyAccessExpression(node);
+ function shouldEmitUnderscoreUnderscoreESModule() {
+ if (!currentModuleInfo.exportEquals && ts.isExternalModule(currentSourceFile)) {
+ return true;
}
- else if (ts.isPropertyAssignment(node)) {
- return substitutePropertyAssignment(node);
+ return false;
+ }
+ function transformCommonJSModule(node) {
+ startLexicalEnvironment();
+ var statements = [];
+ var ensureUseStrict = compilerOptions.alwaysStrict || (!compilerOptions.noImplicitUseStrict && ts.isExternalModule(currentSourceFile));
+ var statementOffset = ts.addPrologue(statements, node.statements, ensureUseStrict, sourceElementVisitor);
+ if (shouldEmitUnderscoreUnderscoreESModule()) {
+ ts.append(statements, createUnderscoreUnderscoreESModule());
}
- return node;
+ ts.append(statements, ts.visitNode(currentModuleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement));
+ ts.addRange(statements, ts.visitNodes(node.statements, sourceElementVisitor, ts.isStatement, statementOffset));
+ addExportEqualsIfNeeded(statements, false);
+ ts.addRange(statements, endLexicalEnvironment());
+ var updated = ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray(statements), node.statements));
+ if (currentModuleInfo.hasExportStarsToExportValues) {
+ ts.addEmitHelper(updated, exportStarHelper);
+ }
+ return updated;
}
- function substitutePropertyAccessExpression(node) {
- var literalName = trySubstituteReservedName(node.name);
- if (literalName) {
- return ts.createElementAccess(node.expression, literalName, node);
+ function transformAMDModule(node) {
+ var define = ts.createIdentifier("define");
+ var moduleName = ts.tryGetModuleNameFromFile(node, host, compilerOptions);
+ var _a = collectAsynchronousDependencies(node, true), aliasedModuleNames = _a.aliasedModuleNames, unaliasedModuleNames = _a.unaliasedModuleNames, importAliasNames = _a.importAliasNames;
+ return ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray([
+ ts.createStatement(ts.createCall(define, undefined, (moduleName ? [moduleName] : []).concat([
+ ts.createArrayLiteral([
+ ts.createLiteral("require"),
+ ts.createLiteral("exports")
+ ].concat(aliasedModuleNames, unaliasedModuleNames)),
+ ts.createFunctionExpression(undefined, undefined, undefined, undefined, [
+ ts.createParameter(undefined, undefined, undefined, "require"),
+ ts.createParameter(undefined, undefined, undefined, "exports")
+ ].concat(importAliasNames), undefined, transformAsynchronousModuleBody(node))
+ ])))
+ ]), node.statements));
+ }
+ function transformUMDModule(node) {
+ var _a = collectAsynchronousDependencies(node, false), aliasedModuleNames = _a.aliasedModuleNames, unaliasedModuleNames = _a.unaliasedModuleNames, importAliasNames = _a.importAliasNames;
+ var umdHeader = ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, "factory")], undefined, ts.setTextRange(ts.createBlock([
+ ts.createIf(ts.createLogicalAnd(ts.createTypeCheck(ts.createIdentifier("module"), "object"), ts.createTypeCheck(ts.createPropertyAccess(ts.createIdentifier("module"), "exports"), "object")), ts.createBlock([
+ ts.createVariableStatement(undefined, [
+ ts.createVariableDeclaration("v", undefined, ts.createCall(ts.createIdentifier("factory"), undefined, [
+ ts.createIdentifier("require"),
+ ts.createIdentifier("exports")
+ ]))
+ ]),
+ ts.setEmitFlags(ts.createIf(ts.createStrictInequality(ts.createIdentifier("v"), ts.createIdentifier("undefined")), ts.createStatement(ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("module"), "exports"), ts.createIdentifier("v")))), 1)
+ ]), ts.createIf(ts.createLogicalAnd(ts.createTypeCheck(ts.createIdentifier("define"), "function"), ts.createPropertyAccess(ts.createIdentifier("define"), "amd")), ts.createBlock([
+ ts.createStatement(ts.createCall(ts.createIdentifier("define"), undefined, [
+ ts.createArrayLiteral([
+ ts.createLiteral("require"),
+ ts.createLiteral("exports")
+ ].concat(aliasedModuleNames, unaliasedModuleNames)),
+ ts.createIdentifier("factory")
+ ]))
+ ])))
+ ], true), undefined));
+ return ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray([
+ ts.createStatement(ts.createCall(umdHeader, undefined, [
+ ts.createFunctionExpression(undefined, undefined, undefined, undefined, [
+ ts.createParameter(undefined, undefined, undefined, "require"),
+ ts.createParameter(undefined, undefined, undefined, "exports")
+ ].concat(importAliasNames), undefined, transformAsynchronousModuleBody(node))
+ ]))
+ ]), node.statements));
+ }
+ function collectAsynchronousDependencies(node, includeNonAmdDependencies) {
+ var aliasedModuleNames = [];
+ var unaliasedModuleNames = [];
+ var importAliasNames = [];
+ for (var _i = 0, _a = node.amdDependencies; _i < _a.length; _i++) {
+ var amdDependency = _a[_i];
+ if (amdDependency.name) {
+ aliasedModuleNames.push(ts.createLiteral(amdDependency.path));
+ importAliasNames.push(ts.createParameter(undefined, undefined, undefined, amdDependency.name));
+ }
+ else {
+ unaliasedModuleNames.push(ts.createLiteral(amdDependency.path));
+ }
}
- return node;
+ for (var _b = 0, _c = currentModuleInfo.externalImports; _b < _c.length; _b++) {
+ var importNode = _c[_b];
+ var externalModuleName = ts.getExternalModuleNameLiteral(importNode, currentSourceFile, host, resolver, compilerOptions);
+ var importAliasName = ts.getLocalNameForExternalImport(importNode, currentSourceFile);
+ if (externalModuleName) {
+ if (includeNonAmdDependencies && importAliasName) {
+ ts.setEmitFlags(importAliasName, 4);
+ aliasedModuleNames.push(externalModuleName);
+ importAliasNames.push(ts.createParameter(undefined, undefined, undefined, importAliasName));
+ }
+ else {
+ unaliasedModuleNames.push(externalModuleName);
+ }
+ }
+ }
+ return { aliasedModuleNames: aliasedModuleNames, unaliasedModuleNames: unaliasedModuleNames, importAliasNames: importAliasNames };
}
- function substitutePropertyAssignment(node) {
- var literalName = ts.isIdentifier(node.name) && trySubstituteReservedName(node.name);
- if (literalName) {
- return ts.updatePropertyAssignment(node, literalName, node.initializer);
+ function transformAsynchronousModuleBody(node) {
+ startLexicalEnvironment();
+ var statements = [];
+ var statementOffset = ts.addPrologue(statements, node.statements, !compilerOptions.noImplicitUseStrict, sourceElementVisitor);
+ if (shouldEmitUnderscoreUnderscoreESModule()) {
+ ts.append(statements, createUnderscoreUnderscoreESModule());
}
- return node;
+ ts.append(statements, ts.visitNode(currentModuleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement));
+ ts.addRange(statements, ts.visitNodes(node.statements, sourceElementVisitor, ts.isStatement, statementOffset));
+ addExportEqualsIfNeeded(statements, true);
+ ts.addRange(statements, endLexicalEnvironment());
+ var body = ts.createBlock(statements, true);
+ if (currentModuleInfo.hasExportStarsToExportValues) {
+ ts.addEmitHelper(body, exportStarHelper);
+ }
+ return body;
}
- function trySubstituteReservedName(name) {
- var token = name.originalKeywordKind || (ts.nodeIsSynthesized(name) ? ts.stringToToken(name.text) : undefined);
- if (token >= 71 && token <= 106) {
- return ts.createLiteral(name, name);
+ function addExportEqualsIfNeeded(statements, emitAsReturn) {
+ if (currentModuleInfo.exportEquals) {
+ if (emitAsReturn) {
+ var statement = ts.createReturn(currentModuleInfo.exportEquals.expression);
+ ts.setTextRange(statement, currentModuleInfo.exportEquals);
+ ts.setEmitFlags(statement, 384 | 1536);
+ statements.push(statement);
+ }
+ else {
+ var statement = ts.createStatement(ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("module"), "exports"), currentModuleInfo.exportEquals.expression));
+ ts.setTextRange(statement, currentModuleInfo.exportEquals);
+ ts.setEmitFlags(statement, 1536);
+ statements.push(statement);
+ }
}
- return undefined;
}
- }
- ts.transformES5 = transformES5;
-})(ts || (ts = {}));
-var ts;
-(function (ts) {
- function transformES2015Module(context) {
- var compilerOptions = context.getCompilerOptions();
- var previousOnEmitNode = context.onEmitNode;
- var previousOnSubstituteNode = context.onSubstituteNode;
- context.onEmitNode = onEmitNode;
- context.onSubstituteNode = onSubstituteNode;
- context.enableEmitNotification(261);
- context.enableSubstitution(70);
- var currentSourceFile;
- return transformSourceFile;
- function transformSourceFile(node) {
- if (ts.isDeclarationFile(node)) {
- return node;
+ function sourceElementVisitor(node) {
+ switch (node.kind) {
+ case 237:
+ return visitImportDeclaration(node);
+ case 236:
+ return visitImportEqualsDeclaration(node);
+ case 243:
+ return visitExportDeclaration(node);
+ case 242:
+ return visitExportAssignment(node);
+ case 207:
+ return visitVariableStatement(node);
+ case 227:
+ return visitFunctionDeclaration(node);
+ case 228:
+ return visitClassDeclaration(node);
+ case 296:
+ return visitMergeDeclarationMarker(node);
+ case 297:
+ return visitEndOfDeclarationMarker(node);
+ default:
+ return node;
}
- if (ts.isExternalModule(node) || compilerOptions.isolatedModules) {
- var externalHelpersModuleName = ts.getOrCreateExternalHelpersModuleNameIfNeeded(node, compilerOptions);
- if (externalHelpersModuleName) {
- var statements = [];
- var statementOffset = ts.addPrologueDirectives(statements, node.statements);
- ts.append(statements, ts.createImportDeclaration(undefined, undefined, ts.createImportClause(undefined, ts.createNamespaceImport(externalHelpersModuleName)), ts.createLiteral(ts.externalHelpersModuleNameText)));
- ts.addRange(statements, ts.visitNodes(node.statements, visitor, ts.isStatement, statementOffset));
- return ts.updateSourceFileNode(node, ts.createNodeArray(statements, node.statements));
+ }
+ function visitImportDeclaration(node) {
+ var statements;
+ var namespaceDeclaration = ts.getNamespaceDeclarationNode(node);
+ if (moduleKind !== ts.ModuleKind.AMD) {
+ if (!node.importClause) {
+ return ts.setTextRange(ts.createStatement(createRequireCall(node)), node);
}
else {
- return ts.visitEachChild(node, visitor, context);
+ var variables = [];
+ if (namespaceDeclaration && !ts.isDefaultImport(node)) {
+ variables.push(ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, createRequireCall(node)));
+ }
+ else {
+ variables.push(ts.createVariableDeclaration(ts.getGeneratedNameForNode(node), undefined, createRequireCall(node)));
+ if (namespaceDeclaration && ts.isDefaultImport(node)) {
+ variables.push(ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, ts.getGeneratedNameForNode(node)));
+ }
+ }
+ statements = ts.append(statements, ts.setTextRange(ts.createVariableStatement(undefined, ts.createVariableDeclarationList(variables, languageVersion >= 2 ? 2 : 0)), node));
}
}
+ else if (namespaceDeclaration && ts.isDefaultImport(node)) {
+ statements = ts.append(statements, ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ ts.setTextRange(ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, ts.getGeneratedNameForNode(node)), node)
+ ], languageVersion >= 2 ? 2 : 0)));
+ }
+ if (hasAssociatedEndOfDeclarationMarker(node)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfImportDeclaration(deferredExports[id], node);
+ }
+ else {
+ statements = appendExportsOfImportDeclaration(statements, node);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function createRequireCall(importNode) {
+ var moduleName = ts.getExternalModuleNameLiteral(importNode, currentSourceFile, host, resolver, compilerOptions);
+ var args = [];
+ if (moduleName) {
+ args.push(moduleName);
+ }
+ return ts.createCall(ts.createIdentifier("require"), undefined, args);
+ }
+ function visitImportEqualsDeclaration(node) {
+ ts.Debug.assert(ts.isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
+ var statements;
+ if (moduleKind !== ts.ModuleKind.AMD) {
+ if (ts.hasModifier(node, 1)) {
+ statements = ts.append(statements, ts.setTextRange(ts.createStatement(createExportExpression(node.name, createRequireCall(node))), node));
+ }
+ else {
+ statements = ts.append(statements, ts.setTextRange(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ ts.createVariableDeclaration(ts.getSynthesizedClone(node.name), undefined, createRequireCall(node))
+ ], languageVersion >= 2 ? 2 : 0)), node));
+ }
+ }
+ else {
+ if (ts.hasModifier(node, 1)) {
+ statements = ts.append(statements, ts.setTextRange(ts.createStatement(createExportExpression(ts.getExportName(node), ts.getLocalName(node))), node));
+ }
+ }
+ if (hasAssociatedEndOfDeclarationMarker(node)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfImportEqualsDeclaration(deferredExports[id], node);
+ }
+ else {
+ statements = appendExportsOfImportEqualsDeclaration(statements, node);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function visitExportDeclaration(node) {
+ if (!node.moduleSpecifier) {
+ return undefined;
+ }
+ var generatedName = ts.getGeneratedNameForNode(node);
+ if (node.exportClause) {
+ var statements = [];
+ if (moduleKind !== ts.ModuleKind.AMD) {
+ statements.push(ts.setTextRange(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
+ ts.createVariableDeclaration(generatedName, undefined, createRequireCall(node))
+ ])), node));
+ }
+ for (var _i = 0, _a = node.exportClause.elements; _i < _a.length; _i++) {
+ var specifier = _a[_i];
+ var exportedValue = ts.createPropertyAccess(generatedName, specifier.propertyName || specifier.name);
+ statements.push(ts.setTextRange(ts.createStatement(createExportExpression(ts.getExportName(specifier), exportedValue)), specifier));
+ }
+ return ts.singleOrMany(statements);
+ }
+ else {
+ return ts.setTextRange(ts.createStatement(ts.createCall(ts.createIdentifier("__export"), undefined, [
+ moduleKind !== ts.ModuleKind.AMD
+ ? createRequireCall(node)
+ : generatedName
+ ])), node);
+ }
+ }
+ function visitExportAssignment(node) {
+ if (node.isExportEquals) {
+ return undefined;
+ }
+ var statements;
+ var original = node.original;
+ if (original && hasAssociatedEndOfDeclarationMarker(original)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportStatement(deferredExports[id], ts.createIdentifier("default"), node.expression, node, true);
+ }
+ else {
+ statements = appendExportStatement(statements, ts.createIdentifier("default"), node.expression, node, true);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function visitFunctionDeclaration(node) {
+ var statements;
+ if (ts.hasModifier(node, 1)) {
+ statements = ts.append(statements, ts.setOriginalNode(ts.setTextRange(ts.createFunctionDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, ts.getDeclarationName(node, true, true), undefined, node.parameters, undefined, node.body), node), node));
+ }
+ else {
+ statements = ts.append(statements, node);
+ }
+ if (hasAssociatedEndOfDeclarationMarker(node)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfHoistedDeclaration(deferredExports[id], node);
+ }
+ else {
+ statements = appendExportsOfHoistedDeclaration(statements, node);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function visitClassDeclaration(node) {
+ var statements;
+ if (ts.hasModifier(node, 1)) {
+ statements = ts.append(statements, ts.setOriginalNode(ts.setTextRange(ts.createClassDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), ts.getDeclarationName(node, true, true), undefined, node.heritageClauses, node.members), node), node));
+ }
+ else {
+ statements = ts.append(statements, node);
+ }
+ if (hasAssociatedEndOfDeclarationMarker(node)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfHoistedDeclaration(deferredExports[id], node);
+ }
+ else {
+ statements = appendExportsOfHoistedDeclaration(statements, node);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function visitVariableStatement(node) {
+ var statements;
+ var variables;
+ var expressions;
+ if (ts.hasModifier(node, 1)) {
+ var modifiers = void 0;
+ for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
+ var variable = _a[_i];
+ if (ts.isIdentifier(variable.name) && ts.isLocalName(variable.name)) {
+ if (!modifiers) {
+ modifiers = ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier);
+ }
+ variables = ts.append(variables, variable);
+ }
+ else if (variable.initializer) {
+ expressions = ts.append(expressions, transformInitializedVariable(variable));
+ }
+ }
+ if (variables) {
+ statements = ts.append(statements, ts.updateVariableStatement(node, modifiers, ts.updateVariableDeclarationList(node.declarationList, variables)));
+ }
+ if (expressions) {
+ statements = ts.append(statements, ts.setTextRange(ts.createStatement(ts.inlineExpressions(expressions)), node));
+ }
+ }
+ else {
+ statements = ts.append(statements, node);
+ }
+ if (hasAssociatedEndOfDeclarationMarker(node)) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfVariableStatement(deferredExports[id], node);
+ }
+ else {
+ statements = appendExportsOfVariableStatement(statements, node);
+ }
+ return ts.singleOrMany(statements);
+ }
+ function transformInitializedVariable(node) {
+ if (ts.isBindingPattern(node.name)) {
+ return ts.flattenDestructuringAssignment(node, undefined, context, 0, false, createExportExpression);
+ }
+ else {
+ return ts.createAssignment(ts.setTextRange(ts.createPropertyAccess(ts.createIdentifier("exports"), node.name), node.name), node.initializer);
+ }
+ }
+ function visitMergeDeclarationMarker(node) {
+ if (hasAssociatedEndOfDeclarationMarker(node) && node.original.kind === 207) {
+ var id = ts.getOriginalNodeId(node);
+ deferredExports[id] = appendExportsOfVariableStatement(deferredExports[id], node.original);
+ }
return node;
}
- function visitor(node) {
+ function hasAssociatedEndOfDeclarationMarker(node) {
+ return (ts.getEmitFlags(node) & 2097152) !== 0;
+ }
+ function visitEndOfDeclarationMarker(node) {
+ var id = ts.getOriginalNodeId(node);
+ var statements = deferredExports[id];
+ if (statements) {
+ delete deferredExports[id];
+ return ts.append(statements, node);
+ }
+ return node;
+ }
+ function appendExportsOfImportDeclaration(statements, decl) {
+ if (currentModuleInfo.exportEquals) {
+ return statements;
+ }
+ var importClause = decl.importClause;
+ if (!importClause) {
+ return statements;
+ }
+ if (importClause.name) {
+ statements = appendExportsOfDeclaration(statements, importClause);
+ }
+ var namedBindings = importClause.namedBindings;
+ if (namedBindings) {
+ switch (namedBindings.kind) {
+ case 239:
+ statements = appendExportsOfDeclaration(statements, namedBindings);
+ break;
+ case 240:
+ for (var _i = 0, _a = namedBindings.elements; _i < _a.length; _i++) {
+ var importBinding = _a[_i];
+ statements = appendExportsOfDeclaration(statements, importBinding);
+ }
+ break;
+ }
+ }
+ return statements;
+ }
+ function appendExportsOfImportEqualsDeclaration(statements, decl) {
+ if (currentModuleInfo.exportEquals) {
+ return statements;
+ }
+ return appendExportsOfDeclaration(statements, decl);
+ }
+ function appendExportsOfVariableStatement(statements, node) {
+ if (currentModuleInfo.exportEquals) {
+ return statements;
+ }
+ for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
+ var decl = _a[_i];
+ statements = appendExportsOfBindingElement(statements, decl);
+ }
+ return statements;
+ }
+ function appendExportsOfBindingElement(statements, decl) {
+ if (currentModuleInfo.exportEquals) {
+ return statements;
+ }
+ if (ts.isBindingPattern(decl.name)) {
+ for (var _i = 0, _a = decl.name.elements; _i < _a.length; _i++) {
+ var element = _a[_i];
+ if (!ts.isOmittedExpression(element)) {
+ statements = appendExportsOfBindingElement(statements, element);
+ }
+ }
+ }
+ else if (!ts.isGeneratedIdentifier(decl.name)) {
+ statements = appendExportsOfDeclaration(statements, decl);
+ }
+ return statements;
+ }
+ function appendExportsOfHoistedDeclaration(statements, decl) {
+ if (currentModuleInfo.exportEquals) {
+ return statements;
+ }
+ if (ts.hasModifier(decl, 1)) {
+ var exportName = ts.hasModifier(decl, 512) ? ts.createIdentifier("default") : decl.name;
+ statements = appendExportStatement(statements, exportName, ts.getLocalName(decl), decl);
+ }
+ if (decl.name) {
+ statements = appendExportsOfDeclaration(statements, decl);
+ }
+ return statements;
+ }
+ function appendExportsOfDeclaration(statements, decl) {
+ var name = ts.getDeclarationName(decl);
+ var exportSpecifiers = currentModuleInfo.exportSpecifiers.get(name.text);
+ if (exportSpecifiers) {
+ for (var _i = 0, exportSpecifiers_1 = exportSpecifiers; _i < exportSpecifiers_1.length; _i++) {
+ var exportSpecifier = exportSpecifiers_1[_i];
+ statements = appendExportStatement(statements, exportSpecifier.name, name, exportSpecifier.name);
+ }
+ }
+ return statements;
+ }
+ function appendExportStatement(statements, exportName, expression, location, allowComments) {
+ statements = ts.append(statements, createExportStatement(exportName, expression, location, allowComments));
+ return statements;
+ }
+ function createUnderscoreUnderscoreESModule() {
+ var statement;
+ if (languageVersion === 0) {
+ statement = ts.createStatement(createExportExpression(ts.createIdentifier("__esModule"), ts.createLiteral(true)));
+ }
+ else {
+ statement = ts.createStatement(ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Object"), "defineProperty"), undefined, [
+ ts.createIdentifier("exports"),
+ ts.createLiteral("__esModule"),
+ ts.createObjectLiteral([
+ ts.createPropertyAssignment("value", ts.createLiteral(true))
+ ])
+ ]));
+ }
+ ts.setEmitFlags(statement, 524288);
+ return statement;
+ }
+ function createExportStatement(name, value, location, allowComments) {
+ var statement = ts.setTextRange(ts.createStatement(createExportExpression(name, value)), location);
+ ts.startOnNewLine(statement);
+ if (!allowComments) {
+ ts.setEmitFlags(statement, 1536);
+ }
+ return statement;
+ }
+ function createExportExpression(name, value, location) {
+ return ts.setTextRange(ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("exports"), ts.getSynthesizedClone(name)), value), location);
+ }
+ function modifierVisitor(node) {
switch (node.kind) {
- case 234:
+ case 83:
+ case 78:
return undefined;
- case 240:
- return visitExportAssignment(node);
}
return node;
}
- function visitExportAssignment(node) {
- return node.isExportEquals ? undefined : node;
- }
- function onEmitNode(emitContext, node, emitCallback) {
- if (ts.isSourceFile(node)) {
+ function onEmitNode(hint, node, emitCallback) {
+ if (node.kind === 264) {
currentSourceFile = node;
- previousOnEmitNode(emitContext, node, emitCallback);
+ currentModuleInfo = moduleInfoMap[ts.getOriginalNodeId(currentSourceFile)];
+ noSubstitution = [];
+ previousOnEmitNode(hint, node, emitCallback);
currentSourceFile = undefined;
+ currentModuleInfo = undefined;
+ noSubstitution = undefined;
}
else {
- previousOnEmitNode(emitContext, node, emitCallback);
+ previousOnEmitNode(hint, node, emitCallback);
}
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (ts.isIdentifier(node) && emitContext === 1) {
- return substituteExpressionIdentifier(node);
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (node.id && noSubstitution[node.id]) {
+ return node;
+ }
+ if (hint === 1) {
+ return substituteExpression(node);
+ }
+ else if (ts.isShorthandPropertyAssignment(node)) {
+ return substituteShorthandPropertyAssignment(node);
+ }
+ return node;
+ }
+ function substituteShorthandPropertyAssignment(node) {
+ var name = node.name;
+ var exportedOrImportedName = substituteExpressionIdentifier(name);
+ if (exportedOrImportedName !== name) {
+ if (node.objectAssignmentInitializer) {
+ var initializer = ts.createAssignment(exportedOrImportedName, node.objectAssignmentInitializer);
+ return ts.setTextRange(ts.createPropertyAssignment(name, initializer), node);
+ }
+ return ts.setTextRange(ts.createPropertyAssignment(name, exportedOrImportedName), node);
+ }
+ return node;
+ }
+ function substituteExpression(node) {
+ switch (node.kind) {
+ case 70:
+ return substituteExpressionIdentifier(node);
+ case 193:
+ return substituteBinaryExpression(node);
+ case 192:
+ case 191:
+ return substituteUnaryExpression(node);
}
return node;
}
@@ -43229,11 +47418,83 @@ var ts;
if (externalHelpersModuleName) {
return ts.createPropertyAccess(externalHelpersModuleName, node);
}
+ return node;
+ }
+ if (!ts.isGeneratedIdentifier(node) && !ts.isLocalName(node)) {
+ var exportContainer = resolver.getReferencedExportContainer(node, ts.isExportName(node));
+ if (exportContainer && exportContainer.kind === 264) {
+ return ts.setTextRange(ts.createPropertyAccess(ts.createIdentifier("exports"), ts.getSynthesizedClone(node)), node);
+ }
+ var importDeclaration = resolver.getReferencedImportDeclaration(node);
+ if (importDeclaration) {
+ if (ts.isImportClause(importDeclaration)) {
+ return ts.setTextRange(ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent), ts.createIdentifier("default")), node);
+ }
+ else if (ts.isImportSpecifier(importDeclaration)) {
+ var name = importDeclaration.propertyName || importDeclaration.name;
+ return ts.setTextRange(ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent.parent.parent), ts.getSynthesizedClone(name)), node);
+ }
+ }
}
return node;
}
+ function substituteBinaryExpression(node) {
+ if (ts.isAssignmentOperator(node.operatorToken.kind)
+ && ts.isIdentifier(node.left)
+ && !ts.isGeneratedIdentifier(node.left)
+ && !ts.isLocalName(node.left)
+ && !ts.isDeclarationNameOfEnumOrNamespace(node.left)) {
+ var exportedNames = getExports(node.left);
+ if (exportedNames) {
+ var expression = node;
+ for (var _i = 0, exportedNames_1 = exportedNames; _i < exportedNames_1.length; _i++) {
+ var exportName = exportedNames_1[_i];
+ noSubstitution[ts.getNodeId(expression)] = true;
+ expression = createExportExpression(exportName, expression, node);
+ }
+ return expression;
+ }
+ }
+ return node;
+ }
+ function substituteUnaryExpression(node) {
+ if ((node.operator === 42 || node.operator === 43)
+ && ts.isIdentifier(node.operand)
+ && !ts.isGeneratedIdentifier(node.operand)
+ && !ts.isLocalName(node.operand)
+ && !ts.isDeclarationNameOfEnumOrNamespace(node.operand)) {
+ var exportedNames = getExports(node.operand);
+ if (exportedNames) {
+ var expression = node.kind === 192
+ ? ts.setTextRange(ts.createBinary(node.operand, ts.createToken(node.operator === 42 ? 58 : 59), ts.createLiteral(1)), node)
+ : node;
+ for (var _i = 0, exportedNames_2 = exportedNames; _i < exportedNames_2.length; _i++) {
+ var exportName = exportedNames_2[_i];
+ noSubstitution[ts.getNodeId(expression)] = true;
+ expression = createExportExpression(exportName, expression);
+ }
+ return expression;
+ }
+ }
+ return node;
+ }
+ function getExports(name) {
+ if (!ts.isGeneratedIdentifier(name)) {
+ var valueDeclaration = resolver.getReferencedImportDeclaration(name)
+ || resolver.getReferencedValueDeclaration(name);
+ if (valueDeclaration) {
+ return currentModuleInfo
+ && currentModuleInfo.exportedBindings[ts.getOriginalNodeId(valueDeclaration)];
+ }
+ }
+ }
}
- ts.transformES2015Module = transformES2015Module;
+ ts.transformModule = transformModule;
+ var exportStarHelper = {
+ name: "typescript:export-star",
+ scoped: true,
+ text: "\n function __export(m) {\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n }"
+ };
})(ts || (ts = {}));
var ts;
(function (ts) {
@@ -43247,14 +47508,14 @@ var ts;
context.onSubstituteNode = onSubstituteNode;
context.onEmitNode = onEmitNode;
context.enableSubstitution(70);
- context.enableSubstitution(192);
- context.enableSubstitution(190);
+ context.enableSubstitution(193);
context.enableSubstitution(191);
- context.enableEmitNotification(261);
- var moduleInfoMap = ts.createMap();
- var deferredExports = ts.createMap();
- var exportFunctionsMap = ts.createMap();
- var noSubstitutionMap = ts.createMap();
+ context.enableSubstitution(192);
+ context.enableEmitNotification(264);
+ var moduleInfoMap = [];
+ var deferredExports = [];
+ var exportFunctionsMap = [];
+ var noSubstitutionMap = [];
var currentSourceFile;
var moduleInfo;
var exportFunction;
@@ -43273,7 +47534,8 @@ var ts;
currentSourceFile = node;
enclosingBlockScopedContainer = node;
moduleInfo = moduleInfoMap[id] = ts.collectExternalModuleInfo(node, resolver, compilerOptions);
- exportFunction = exportFunctionsMap[id] = ts.createUniqueName("exports");
+ exportFunction = ts.createUniqueName("exports");
+ exportFunctionsMap[id] = exportFunction;
contextObject = ts.createUniqueName("context");
var dependencyGroups = collectDependencyGroups(moduleInfo.externalImports);
var moduleBodyBlock = createSystemModuleBody(node, dependencyGroups);
@@ -43283,11 +47545,11 @@ var ts;
], undefined, moduleBodyBlock);
var moduleName = ts.tryGetModuleNameFromFile(node, host, compilerOptions);
var dependencies = ts.createArrayLiteral(ts.map(dependencyGroups, function (dependencyGroup) { return dependencyGroup.name; }));
- var updated = ts.updateSourceFileNode(node, ts.createNodeArray([
+ var updated = ts.setEmitFlags(ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray([
ts.createStatement(ts.createCall(ts.createPropertyAccess(ts.createIdentifier("System"), "register"), undefined, moduleName
? [moduleName, dependencies, moduleBodyFunction]
: [dependencies, moduleBodyFunction]))
- ], node.statements));
+ ]), node.statements)), 1024);
if (!(compilerOptions.outFile || compilerOptions.out)) {
ts.moveEmitHelpers(updated, moduleBodyBlock, function (helper) { return !helper.scoped; });
}
@@ -43309,17 +47571,19 @@ var ts;
for (var i = 0; i < externalImports.length; i++) {
var externalImport = externalImports[i];
var externalModuleName = ts.getExternalModuleNameLiteral(externalImport, currentSourceFile, host, resolver, compilerOptions);
- var text = externalModuleName.text;
- if (ts.hasProperty(groupIndices, text)) {
- var groupIndex = groupIndices[text];
- dependencyGroups[groupIndex].externalImports.push(externalImport);
- }
- else {
- groupIndices[text] = dependencyGroups.length;
- dependencyGroups.push({
- name: externalModuleName,
- externalImports: [externalImport]
- });
+ if (externalModuleName) {
+ var text = externalModuleName.text;
+ var groupIndex = groupIndices.get(text);
+ if (groupIndex !== undefined) {
+ dependencyGroups[groupIndex].externalImports.push(externalImport);
+ }
+ else {
+ groupIndices.set(text, dependencyGroups.length);
+ dependencyGroups.push({
+ name: externalModuleName,
+ externalImports: [externalImport]
+ });
+ }
}
}
return dependencyGroups;
@@ -43327,30 +47591,33 @@ var ts;
function createSystemModuleBody(node, dependencyGroups) {
var statements = [];
startLexicalEnvironment();
- var statementOffset = ts.addPrologueDirectives(statements, node.statements, !compilerOptions.noImplicitUseStrict, sourceElementVisitor);
+ var ensureUseStrict = compilerOptions.alwaysStrict || (!compilerOptions.noImplicitUseStrict && ts.isExternalModule(currentSourceFile));
+ var statementOffset = ts.addPrologue(statements, node.statements, ensureUseStrict, sourceElementVisitor);
statements.push(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
ts.createVariableDeclaration("__moduleName", undefined, ts.createLogicalAnd(contextObject, ts.createPropertyAccess(contextObject, "id")))
])));
- ts.visitNode(moduleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement, true);
+ ts.visitNode(moduleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement);
var executeStatements = ts.visitNodes(node.statements, sourceElementVisitor, ts.isStatement, statementOffset);
ts.addRange(statements, hoistedStatements);
ts.addRange(statements, endLexicalEnvironment());
var exportStarFunction = addExportStarIfNeeded(statements);
- statements.push(ts.createReturn(ts.setMultiLine(ts.createObjectLiteral([
+ var moduleObject = ts.createObjectLiteral([
ts.createPropertyAssignment("setters", createSettersArray(exportStarFunction, dependencyGroups)),
- ts.createPropertyAssignment("execute", ts.createFunctionExpression(undefined, undefined, undefined, undefined, [], undefined, ts.createBlock(executeStatements, undefined, true)))
- ]), true)));
- return ts.createBlock(statements, undefined, true);
+ ts.createPropertyAssignment("execute", ts.createFunctionExpression(undefined, undefined, undefined, undefined, [], undefined, ts.createBlock(executeStatements, true)))
+ ]);
+ moduleObject.multiLine = true;
+ statements.push(ts.createReturn(moduleObject));
+ return ts.createBlock(statements, true);
}
function addExportStarIfNeeded(statements) {
if (!moduleInfo.hasExportStarsToExportValues) {
return;
}
- if (!moduleInfo.exportedNames && ts.isEmpty(moduleInfo.exportSpecifiers)) {
+ if (!moduleInfo.exportedNames && moduleInfo.exportSpecifiers.size === 0) {
var hasExportDeclarationWithExportClause = false;
for (var _i = 0, _a = moduleInfo.externalImports; _i < _a.length; _i++) {
var externalImport = _a[_i];
- if (externalImport.kind === 241 && externalImport.exportClause) {
+ if (externalImport.kind === 243 && externalImport.exportClause) {
hasExportDeclarationWithExportClause = true;
break;
}
@@ -43368,12 +47635,12 @@ var ts;
if (exportedLocalName.text === "default") {
continue;
}
- exportedNames.push(ts.createPropertyAssignment(ts.createLiteral(exportedLocalName), ts.createLiteral(true)));
+ exportedNames.push(ts.createPropertyAssignment(ts.createLiteral(exportedLocalName), ts.createTrue()));
}
}
for (var _d = 0, _e = moduleInfo.externalImports; _d < _e.length; _d++) {
var externalImport = _e[_d];
- if (externalImport.kind !== 241) {
+ if (externalImport.kind !== 243) {
continue;
}
var exportDecl = externalImport;
@@ -43382,12 +47649,12 @@ var ts;
}
for (var _f = 0, _g = exportDecl.exportClause.elements; _f < _g.length; _f++) {
var element = _g[_f];
- exportedNames.push(ts.createPropertyAssignment(ts.createLiteral((element.name || element.propertyName).text), ts.createLiteral(true)));
+ exportedNames.push(ts.createPropertyAssignment(ts.createLiteral((element.name || element.propertyName).text), ts.createTrue()));
}
}
var exportedNamesStorageRef = ts.createUniqueName("exportedNames");
statements.push(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
- ts.createVariableDeclaration(exportedNamesStorageRef, undefined, ts.createObjectLiteral(exportedNames, undefined, true))
+ ts.createVariableDeclaration(exportedNamesStorageRef, undefined, ts.createObjectLiteral(exportedNames, true))
])));
var exportStarFunction = createExportStarFunction(exportedNamesStorageRef);
statements.push(exportStarFunction);
@@ -43412,7 +47679,7 @@ var ts;
ts.setEmitFlags(ts.createIf(condition, ts.createStatement(ts.createAssignment(ts.createElementAccess(exports, n), ts.createElementAccess(m, n)))), 1)
])),
ts.createStatement(ts.createCall(exportFunction, undefined, [exports]))
- ], undefined, true));
+ ], true));
}
function createSettersArray(exportStarFunction, dependencyGroups) {
var setters = [];
@@ -43425,15 +47692,15 @@ var ts;
var entry = _b[_a];
var importVariableName = ts.getLocalNameForExternalImport(entry, currentSourceFile);
switch (entry.kind) {
- case 235:
+ case 237:
if (!entry.importClause) {
break;
}
- case 234:
+ case 236:
ts.Debug.assert(importVariableName !== undefined);
statements.push(ts.createStatement(ts.createAssignment(importVariableName, parameterName)));
break;
- case 241:
+ case 243:
ts.Debug.assert(importVariableName !== undefined);
if (entry.exportClause) {
var properties = [];
@@ -43441,7 +47708,7 @@ var ts;
var e = _d[_c];
properties.push(ts.createPropertyAssignment(ts.createLiteral(e.name.text), ts.createElementAccess(parameterName, ts.createLiteral((e.propertyName || e.name).text))));
}
- statements.push(ts.createStatement(ts.createCall(exportFunction, undefined, [ts.createObjectLiteral(properties, undefined, true)])));
+ statements.push(ts.createStatement(ts.createCall(exportFunction, undefined, [ts.createObjectLiteral(properties, true)])));
}
else {
statements.push(ts.createStatement(ts.createCall(exportStarFunction, undefined, [parameterName])));
@@ -43449,19 +47716,19 @@ var ts;
break;
}
}
- setters.push(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, ts.createBlock(statements, undefined, true)));
+ setters.push(ts.createFunctionExpression(undefined, undefined, undefined, undefined, [ts.createParameter(undefined, undefined, undefined, parameterName)], undefined, ts.createBlock(statements, true)));
}
- return ts.createArrayLiteral(setters, undefined, true);
+ return ts.createArrayLiteral(setters, true);
}
function sourceElementVisitor(node) {
switch (node.kind) {
- case 235:
+ case 237:
return visitImportDeclaration(node);
- case 234:
+ case 236:
return visitImportEqualsDeclaration(node);
- case 241:
+ case 243:
return undefined;
- case 240:
+ case 242:
return visitExportAssignment(node);
default:
return nestedElementVisitor(node);
@@ -43510,7 +47777,7 @@ var ts;
}
function visitFunctionDeclaration(node) {
if (ts.hasModifier(node, 1)) {
- hoistedStatements = ts.append(hoistedStatements, ts.updateFunctionDeclaration(node, node.decorators, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), ts.getDeclarationName(node, true, true), undefined, ts.visitNodes(node.parameters, destructuringVisitor, ts.isParameterDeclaration), undefined, ts.visitNode(node.body, destructuringVisitor, ts.isBlock)));
+ hoistedStatements = ts.append(hoistedStatements, ts.updateFunctionDeclaration(node, node.decorators, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, ts.getDeclarationName(node, true, true), undefined, ts.visitNodes(node.parameters, destructuringVisitor, ts.isParameterDeclaration), undefined, ts.visitNode(node.body, destructuringVisitor, ts.isBlock)));
}
else {
hoistedStatements = ts.append(hoistedStatements, node);
@@ -43528,7 +47795,7 @@ var ts;
var statements;
var name = ts.getLocalName(node);
hoistVariableDeclaration(name);
- statements = ts.append(statements, ts.createStatement(ts.createAssignment(name, ts.createClassExpression(undefined, node.name, undefined, ts.visitNodes(node.heritageClauses, destructuringVisitor, ts.isHeritageClause), ts.visitNodes(node.members, destructuringVisitor, ts.isClassElement), node)), node));
+ statements = ts.append(statements, ts.setTextRange(ts.createStatement(ts.createAssignment(name, ts.setTextRange(ts.createClassExpression(undefined, node.name, undefined, ts.visitNodes(node.heritageClauses, destructuringVisitor, ts.isHeritageClause), ts.visitNodes(node.members, destructuringVisitor, ts.isClassElement)), node))), node));
if (hasAssociatedEndOfDeclarationMarker(node)) {
var id = ts.getOriginalNodeId(node);
deferredExports[id] = appendExportsOfHoistedDeclaration(deferredExports[id], node);
@@ -43556,7 +47823,7 @@ var ts;
}
var statements;
if (expressions) {
- statements = ts.append(statements, ts.createStatement(ts.inlineExpressions(expressions), node));
+ statements = ts.append(statements, ts.setTextRange(ts.createStatement(ts.inlineExpressions(expressions)), node));
}
if (isMarkedDeclaration) {
var id = ts.getOriginalNodeId(node);
@@ -43582,7 +47849,7 @@ var ts;
}
function shouldHoistVariableDeclarationList(node) {
return (ts.getEmitFlags(node) & 1048576) === 0
- && (enclosingBlockScopedContainer.kind === 261
+ && (enclosingBlockScopedContainer.kind === 264
|| (ts.getOriginalNode(node).flags & 3) === 0);
}
function transformInitializedVariable(node, isExportedDeclaration) {
@@ -43600,11 +47867,11 @@ var ts;
function createVariableAssignment(name, value, location, isExportedDeclaration) {
hoistVariableDeclaration(ts.getSynthesizedClone(name));
return isExportedDeclaration
- ? createExportExpression(name, preventSubstitution(ts.createAssignment(name, value, location)))
- : preventSubstitution(ts.createAssignment(name, value, location));
+ ? createExportExpression(name, preventSubstitution(ts.setTextRange(ts.createAssignment(name, value), location)))
+ : preventSubstitution(ts.setTextRange(ts.createAssignment(name, value), location));
}
function visitMergeDeclarationMarker(node) {
- if (hasAssociatedEndOfDeclarationMarker(node) && node.original.kind === 205) {
+ if (hasAssociatedEndOfDeclarationMarker(node) && node.original.kind === 207) {
var id = ts.getOriginalNodeId(node);
var isExportedDeclaration = ts.hasModifier(node.original, 1);
deferredExports[id] = appendExportsOfVariableStatement(deferredExports[id], node.original, isExportedDeclaration);
@@ -43637,10 +47904,10 @@ var ts;
var namedBindings = importClause.namedBindings;
if (namedBindings) {
switch (namedBindings.kind) {
- case 237:
+ case 239:
statements = appendExportsOfDeclaration(statements, namedBindings);
break;
- case 238:
+ case 240:
for (var _i = 0, _a = namedBindings.elements; _i < _a.length; _i++) {
var importBinding = _a[_i];
statements = appendExportsOfDeclaration(statements, importBinding);
@@ -43710,10 +47977,10 @@ var ts;
return statements;
}
var name = ts.getDeclarationName(decl);
- var exportSpecifiers = moduleInfo.exportSpecifiers[name.text];
+ var exportSpecifiers = moduleInfo.exportSpecifiers.get(name.text);
if (exportSpecifiers) {
- for (var _i = 0, exportSpecifiers_1 = exportSpecifiers; _i < exportSpecifiers_1.length; _i++) {
- var exportSpecifier = exportSpecifiers_1[_i];
+ for (var _i = 0, exportSpecifiers_2 = exportSpecifiers; _i < exportSpecifiers_2.length; _i++) {
+ var exportSpecifier = exportSpecifiers_2[_i];
if (exportSpecifier.name.text !== excludeName) {
statements = appendExportStatement(statements, exportSpecifier.name, name);
}
@@ -43739,43 +48006,43 @@ var ts;
}
function nestedElementVisitor(node) {
switch (node.kind) {
- case 205:
+ case 207:
return visitVariableStatement(node);
- case 225:
+ case 227:
return visitFunctionDeclaration(node);
- case 226:
+ case 228:
return visitClassDeclaration(node);
- case 211:
+ case 213:
return visitForStatement(node);
- case 212:
+ case 214:
return visitForInStatement(node);
- case 213:
+ case 215:
return visitForOfStatement(node);
- case 209:
+ case 211:
return visitDoStatement(node);
- case 210:
+ case 212:
return visitWhileStatement(node);
- case 219:
+ case 221:
return visitLabeledStatement(node);
- case 217:
+ case 219:
return visitWithStatement(node);
- case 218:
+ case 220:
return visitSwitchStatement(node);
- case 232:
+ case 234:
return visitCaseBlock(node);
- case 253:
+ case 256:
return visitCaseClause(node);
- case 254:
+ case 257:
return visitDefaultClause(node);
- case 221:
+ case 223:
return visitTryStatement(node);
- case 256:
+ case 259:
return visitCatchClause(node);
- case 204:
+ case 206:
return visitBlock(node);
- case 295:
- return visitMergeDeclarationMarker(node);
case 296:
+ return visitMergeDeclarationMarker(node);
+ case 297:
return visitEndOfDeclarationMarker(node);
default:
return destructuringVisitor(node);
@@ -43784,21 +48051,21 @@ var ts;
function visitForStatement(node) {
var savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
enclosingBlockScopedContainer = node;
- node = ts.updateFor(node, visitForInitializer(node.initializer), ts.visitNode(node.condition, destructuringVisitor, ts.isExpression, true), ts.visitNode(node.incrementor, destructuringVisitor, ts.isExpression, true), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement));
+ node = ts.updateFor(node, visitForInitializer(node.initializer), ts.visitNode(node.condition, destructuringVisitor, ts.isExpression), ts.visitNode(node.incrementor, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement));
enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
return node;
}
function visitForInStatement(node) {
var savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
enclosingBlockScopedContainer = node;
- node = ts.updateForIn(node, visitForInitializer(node.initializer), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock));
+ node = ts.updateForIn(node, visitForInitializer(node.initializer), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock));
enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
return node;
}
function visitForOfStatement(node) {
var savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
enclosingBlockScopedContainer = node;
- node = ts.updateForOf(node, visitForInitializer(node.initializer), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock));
+ node = ts.updateForOf(node, node.awaitModifier, visitForInitializer(node.initializer), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock));
enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
return node;
}
@@ -43807,6 +48074,9 @@ var ts;
&& shouldHoistVariableDeclarationList(node);
}
function visitForInitializer(node) {
+ if (!node) {
+ return node;
+ }
if (shouldHoistForInitializer(node)) {
var expressions = void 0;
for (var _i = 0, _a = node.declarations; _i < _a.length; _i++) {
@@ -43820,16 +48090,16 @@ var ts;
}
}
function visitDoStatement(node) {
- return ts.updateDo(node, ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression));
+ return ts.updateDo(node, ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock), ts.visitNode(node.expression, destructuringVisitor, ts.isExpression));
}
function visitWhileStatement(node) {
- return ts.updateWhile(node, ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock));
+ return ts.updateWhile(node, ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock));
}
function visitLabeledStatement(node) {
- return ts.updateLabel(node, node.label, ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock));
+ return ts.updateLabel(node, node.label, ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock));
}
function visitWithStatement(node) {
- return ts.updateWith(node, ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, false, ts.liftToBlock));
+ return ts.updateWith(node, ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.statement, nestedElementVisitor, ts.isStatement, ts.liftToBlock));
}
function visitSwitchStatement(node) {
return ts.updateSwitch(node, ts.visitNode(node.expression, destructuringVisitor, ts.isExpression), ts.visitNode(node.caseBlock, nestedElementVisitor, ts.isCaseBlock));
@@ -43866,7 +48136,7 @@ var ts;
}
function destructuringVisitor(node) {
if (node.transformFlags & 1024
- && node.kind === 192) {
+ && node.kind === 193) {
return visitDestructuringAssignment(node);
}
else if (node.transformFlags & 2048) {
@@ -43883,7 +48153,7 @@ var ts;
return ts.visitEachChild(node, destructuringVisitor, context);
}
function hasExportedReferenceInDestructuringTarget(node) {
- if (ts.isAssignmentExpression(node)) {
+ if (ts.isAssignmentExpression(node, true)) {
return hasExportedReferenceInDestructuringTarget(node.left);
}
else if (ts.isSpreadExpression(node)) {
@@ -43903,7 +48173,7 @@ var ts;
}
else if (ts.isIdentifier(node)) {
var container = resolver.getReferencedExportContainer(node);
- return container !== undefined && container.kind === 261;
+ return container !== undefined && container.kind === 264;
}
else {
return false;
@@ -43917,8 +48187,8 @@ var ts;
}
return node;
}
- function onEmitNode(emitContext, node, emitCallback) {
- if (node.kind === 261) {
+ function onEmitNode(hint, node, emitCallback) {
+ if (node.kind === 264) {
var id = ts.getOriginalNodeId(node);
currentSourceFile = node;
moduleInfo = moduleInfoMap[id];
@@ -43927,22 +48197,22 @@ var ts;
if (noSubstitution) {
delete noSubstitutionMap[id];
}
- previousOnEmitNode(emitContext, node, emitCallback);
+ previousOnEmitNode(hint, node, emitCallback);
currentSourceFile = undefined;
moduleInfo = undefined;
exportFunction = undefined;
noSubstitution = undefined;
}
else {
- previousOnEmitNode(emitContext, node, emitCallback);
+ previousOnEmitNode(hint, node, emitCallback);
}
}
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
if (isSubstitutionPrevented(node)) {
return node;
}
- if (emitContext === 1) {
+ if (hint === 1) {
return substituteExpression(node);
}
return node;
@@ -43951,10 +48221,10 @@ var ts;
switch (node.kind) {
case 70:
return substituteExpressionIdentifier(node);
- case 192:
+ case 193:
return substituteBinaryExpression(node);
- case 190:
case 191:
+ case 192:
return substituteUnaryExpression(node);
}
return node;
@@ -43971,10 +48241,10 @@ var ts;
var importDeclaration = resolver.getReferencedImportDeclaration(node);
if (importDeclaration) {
if (ts.isImportClause(importDeclaration)) {
- return ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent), ts.createIdentifier("default"), node);
+ return ts.setTextRange(ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent), ts.createIdentifier("default")), node);
}
else if (ts.isImportSpecifier(importDeclaration)) {
- return ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent.parent.parent), ts.getSynthesizedClone(importDeclaration.propertyName || importDeclaration.name), node);
+ return ts.setTextRange(ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent.parent.parent), ts.getSynthesizedClone(importDeclaration.propertyName || importDeclaration.name)), node);
}
}
}
@@ -43989,8 +48259,8 @@ var ts;
var exportedNames = getExports(node.left);
if (exportedNames) {
var expression = node;
- for (var _i = 0, exportedNames_1 = exportedNames; _i < exportedNames_1.length; _i++) {
- var exportName = exportedNames_1[_i];
+ for (var _i = 0, exportedNames_3 = exportedNames; _i < exportedNames_3.length; _i++) {
+ var exportName = exportedNames_3[_i];
expression = createExportExpression(exportName, preventSubstitution(expression));
}
return expression;
@@ -44006,14 +48276,14 @@ var ts;
&& !ts.isDeclarationNameOfEnumOrNamespace(node.operand)) {
var exportedNames = getExports(node.operand);
if (exportedNames) {
- var expression = node.kind === 191
- ? ts.createPrefix(node.operator, node.operand, node)
+ var expression = node.kind === 192
+ ? ts.setTextRange(ts.createPrefix(node.operator, node.operand), node)
: node;
- for (var _i = 0, exportedNames_2 = exportedNames; _i < exportedNames_2.length; _i++) {
- var exportName = exportedNames_2[_i];
+ for (var _i = 0, exportedNames_4 = exportedNames; _i < exportedNames_4.length; _i++) {
+ var exportName = exportedNames_4[_i];
expression = createExportExpression(exportName, preventSubstitution(expression));
}
- if (node.kind === 191) {
+ if (node.kind === 192) {
expression = node.operator === 42
? ts.createSubtract(preventSubstitution(expression), ts.createLiteral(1))
: ts.createAdd(preventSubstitution(expression), ts.createLiteral(1));
@@ -44030,7 +48300,7 @@ var ts;
|| resolver.getReferencedValueDeclaration(name);
if (valueDeclaration) {
var exportContainer = resolver.getReferencedExportContainer(name, false);
- if (exportContainer && exportContainer.kind === 261) {
+ if (exportContainer && exportContainer.kind === 264) {
exportedNames = ts.append(exportedNames, ts.getDeclarationName(valueDeclaration));
}
exportedNames = ts.addRange(exportedNames, moduleInfo && moduleInfo.exportedBindings[ts.getOriginalNodeId(valueDeclaration)]);
@@ -44040,7 +48310,7 @@ var ts;
}
function preventSubstitution(node) {
if (noSubstitution === undefined)
- noSubstitution = ts.createMap();
+ noSubstitution = [];
noSubstitution[ts.getNodeId(node)] = true;
return node;
}
@@ -44052,550 +48322,61 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- function transformModule(context) {
- var transformModuleDelegates = ts.createMap((_a = {},
- _a[ts.ModuleKind.None] = transformCommonJSModule,
- _a[ts.ModuleKind.CommonJS] = transformCommonJSModule,
- _a[ts.ModuleKind.AMD] = transformAMDModule,
- _a[ts.ModuleKind.UMD] = transformUMDModule,
- _a));
- var startLexicalEnvironment = context.startLexicalEnvironment, endLexicalEnvironment = context.endLexicalEnvironment;
+ function transformES2015Module(context) {
var compilerOptions = context.getCompilerOptions();
- var resolver = context.getEmitResolver();
- var host = context.getEmitHost();
- var languageVersion = ts.getEmitScriptTarget(compilerOptions);
- var moduleKind = ts.getEmitModuleKind(compilerOptions);
- var previousOnSubstituteNode = context.onSubstituteNode;
var previousOnEmitNode = context.onEmitNode;
- context.onSubstituteNode = onSubstituteNode;
+ var previousOnSubstituteNode = context.onSubstituteNode;
context.onEmitNode = onEmitNode;
+ context.onSubstituteNode = onSubstituteNode;
+ context.enableEmitNotification(264);
context.enableSubstitution(70);
- context.enableSubstitution(192);
- context.enableSubstitution(190);
- context.enableSubstitution(191);
- context.enableSubstitution(258);
- context.enableEmitNotification(261);
- var moduleInfoMap = ts.createMap();
- var deferredExports = ts.createMap();
var currentSourceFile;
- var currentModuleInfo;
- var noSubstitution;
return transformSourceFile;
function transformSourceFile(node) {
- if (ts.isDeclarationFile(node)
- || !(ts.isExternalModule(node)
- || compilerOptions.isolatedModules)) {
+ if (ts.isDeclarationFile(node)) {
return node;
}
- currentSourceFile = node;
- currentModuleInfo = moduleInfoMap[ts.getOriginalNodeId(node)] = ts.collectExternalModuleInfo(node, resolver, compilerOptions);
- var transformModule = transformModuleDelegates[moduleKind] || transformModuleDelegates[ts.ModuleKind.None];
- var updated = transformModule(node);
- currentSourceFile = undefined;
- currentModuleInfo = undefined;
- return ts.aggregateTransformFlags(updated);
- }
- function transformCommonJSModule(node) {
- startLexicalEnvironment();
- var statements = [];
- var statementOffset = ts.addPrologueDirectives(statements, node.statements, !compilerOptions.noImplicitUseStrict, sourceElementVisitor);
- ts.append(statements, ts.visitNode(currentModuleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement, true));
- ts.addRange(statements, ts.visitNodes(node.statements, sourceElementVisitor, ts.isStatement, statementOffset));
- ts.addRange(statements, endLexicalEnvironment());
- addExportEqualsIfNeeded(statements, false);
- var updated = ts.updateSourceFileNode(node, ts.createNodeArray(statements, node.statements));
- if (currentModuleInfo.hasExportStarsToExportValues) {
- ts.addEmitHelper(updated, exportStarHelper);
- }
- return updated;
- }
- function transformAMDModule(node) {
- var define = ts.createIdentifier("define");
- var moduleName = ts.tryGetModuleNameFromFile(node, host, compilerOptions);
- return transformAsynchronousModule(node, define, moduleName, true);
- }
- function transformUMDModule(node) {
- var define = ts.createRawExpression(umdHelper);
- return transformAsynchronousModule(node, define, undefined, false);
- }
- function transformAsynchronousModule(node, define, moduleName, includeNonAmdDependencies) {
- var _a = collectAsynchronousDependencies(node, includeNonAmdDependencies), aliasedModuleNames = _a.aliasedModuleNames, unaliasedModuleNames = _a.unaliasedModuleNames, importAliasNames = _a.importAliasNames;
- return ts.updateSourceFileNode(node, ts.createNodeArray([
- ts.createStatement(ts.createCall(define, undefined, (moduleName ? [moduleName] : []).concat([
- ts.createArrayLiteral([
- ts.createLiteral("require"),
- ts.createLiteral("exports")
- ].concat(aliasedModuleNames, unaliasedModuleNames)),
- ts.createFunctionExpression(undefined, undefined, undefined, undefined, [
- ts.createParameter(undefined, undefined, undefined, "require"),
- ts.createParameter(undefined, undefined, undefined, "exports")
- ].concat(importAliasNames), undefined, transformAsynchronousModuleBody(node))
- ])))
- ], node.statements));
- }
- function collectAsynchronousDependencies(node, includeNonAmdDependencies) {
- var aliasedModuleNames = [];
- var unaliasedModuleNames = [];
- var importAliasNames = [];
- for (var _i = 0, _a = node.amdDependencies; _i < _a.length; _i++) {
- var amdDependency = _a[_i];
- if (amdDependency.name) {
- aliasedModuleNames.push(ts.createLiteral(amdDependency.path));
- importAliasNames.push(ts.createParameter(undefined, undefined, undefined, amdDependency.name));
- }
- else {
- unaliasedModuleNames.push(ts.createLiteral(amdDependency.path));
- }
- }
- for (var _b = 0, _c = currentModuleInfo.externalImports; _b < _c.length; _b++) {
- var importNode = _c[_b];
- var externalModuleName = ts.getExternalModuleNameLiteral(importNode, currentSourceFile, host, resolver, compilerOptions);
- var importAliasName = ts.getLocalNameForExternalImport(importNode, currentSourceFile);
- if (includeNonAmdDependencies && importAliasName) {
- ts.setEmitFlags(importAliasName, 4);
- aliasedModuleNames.push(externalModuleName);
- importAliasNames.push(ts.createParameter(undefined, undefined, undefined, importAliasName));
- }
- else {
- unaliasedModuleNames.push(externalModuleName);
- }
- }
- return { aliasedModuleNames: aliasedModuleNames, unaliasedModuleNames: unaliasedModuleNames, importAliasNames: importAliasNames };
- }
- function transformAsynchronousModuleBody(node) {
- startLexicalEnvironment();
- var statements = [];
- var statementOffset = ts.addPrologueDirectives(statements, node.statements, !compilerOptions.noImplicitUseStrict, sourceElementVisitor);
- ts.append(statements, ts.visitNode(currentModuleInfo.externalHelpersImportDeclaration, sourceElementVisitor, ts.isStatement, true));
- ts.addRange(statements, ts.visitNodes(node.statements, sourceElementVisitor, ts.isStatement, statementOffset));
- ts.addRange(statements, endLexicalEnvironment());
- addExportEqualsIfNeeded(statements, true);
- var body = ts.createBlock(statements, undefined, true);
- if (currentModuleInfo.hasExportStarsToExportValues) {
- ts.addEmitHelper(body, exportStarHelper);
- }
- return body;
- }
- function addExportEqualsIfNeeded(statements, emitAsReturn) {
- if (currentModuleInfo.exportEquals) {
- if (emitAsReturn) {
- var statement = ts.createReturn(currentModuleInfo.exportEquals.expression, currentModuleInfo.exportEquals);
- ts.setEmitFlags(statement, 384 | 1536);
- statements.push(statement);
- }
- else {
- var statement = ts.createStatement(ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("module"), "exports"), currentModuleInfo.exportEquals.expression), currentModuleInfo.exportEquals);
- ts.setEmitFlags(statement, 1536);
- statements.push(statement);
- }
- }
- }
- function sourceElementVisitor(node) {
- switch (node.kind) {
- case 235:
- return visitImportDeclaration(node);
- case 234:
- return visitImportEqualsDeclaration(node);
- case 241:
- return visitExportDeclaration(node);
- case 240:
- return visitExportAssignment(node);
- case 205:
- return visitVariableStatement(node);
- case 225:
- return visitFunctionDeclaration(node);
- case 226:
- return visitClassDeclaration(node);
- case 295:
- return visitMergeDeclarationMarker(node);
- case 296:
- return visitEndOfDeclarationMarker(node);
- default:
- return node;
- }
- }
- function visitImportDeclaration(node) {
- var statements;
- var namespaceDeclaration = ts.getNamespaceDeclarationNode(node);
- if (moduleKind !== ts.ModuleKind.AMD) {
- if (!node.importClause) {
- return ts.createStatement(createRequireCall(node), node);
- }
- else {
- var variables = [];
- if (namespaceDeclaration && !ts.isDefaultImport(node)) {
- variables.push(ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, createRequireCall(node)));
- }
- else {
- variables.push(ts.createVariableDeclaration(ts.getGeneratedNameForNode(node), undefined, createRequireCall(node)));
- if (namespaceDeclaration && ts.isDefaultImport(node)) {
- variables.push(ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, ts.getGeneratedNameForNode(node)));
- }
- }
- statements = ts.append(statements, ts.createVariableStatement(undefined, ts.createVariableDeclarationList(variables, undefined, languageVersion >= 2 ? 2 : 0), node));
- }
- }
- else if (namespaceDeclaration && ts.isDefaultImport(node)) {
- statements = ts.append(statements, ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
- ts.createVariableDeclaration(ts.getSynthesizedClone(namespaceDeclaration.name), undefined, ts.getGeneratedNameForNode(node), node)
- ], undefined, languageVersion >= 2 ? 2 : 0)));
- }
- if (hasAssociatedEndOfDeclarationMarker(node)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfImportDeclaration(deferredExports[id], node);
- }
- else {
- statements = appendExportsOfImportDeclaration(statements, node);
- }
- return ts.singleOrMany(statements);
- }
- function createRequireCall(importNode) {
- var moduleName = ts.getExternalModuleNameLiteral(importNode, currentSourceFile, host, resolver, compilerOptions);
- var args = [];
- if (moduleName) {
- args.push(moduleName);
- }
- return ts.createCall(ts.createIdentifier("require"), undefined, args);
- }
- function visitImportEqualsDeclaration(node) {
- ts.Debug.assert(ts.isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
- var statements;
- if (moduleKind !== ts.ModuleKind.AMD) {
- if (ts.hasModifier(node, 1)) {
- statements = ts.append(statements, ts.createStatement(createExportExpression(node.name, createRequireCall(node)), node));
+ if (ts.isExternalModule(node) || compilerOptions.isolatedModules) {
+ var externalHelpersModuleName = ts.getOrCreateExternalHelpersModuleNameIfNeeded(node, compilerOptions);
+ if (externalHelpersModuleName) {
+ var statements = [];
+ var statementOffset = ts.addPrologue(statements, node.statements);
+ ts.append(statements, ts.createImportDeclaration(undefined, undefined, ts.createImportClause(undefined, ts.createNamespaceImport(externalHelpersModuleName)), ts.createLiteral(ts.externalHelpersModuleNameText)));
+ ts.addRange(statements, ts.visitNodes(node.statements, visitor, ts.isStatement, statementOffset));
+ return ts.updateSourceFileNode(node, ts.setTextRange(ts.createNodeArray(statements), node.statements));
}
else {
- statements = ts.append(statements, ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
- ts.createVariableDeclaration(ts.getSynthesizedClone(node.name), undefined, createRequireCall(node))
- ], undefined, languageVersion >= 2 ? 2 : 0), node));
- }
- }
- else {
- if (ts.hasModifier(node, 1)) {
- statements = ts.append(statements, ts.createStatement(createExportExpression(ts.getExportName(node), ts.getLocalName(node)), node));
- }
- }
- if (hasAssociatedEndOfDeclarationMarker(node)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfImportEqualsDeclaration(deferredExports[id], node);
- }
- else {
- statements = appendExportsOfImportEqualsDeclaration(statements, node);
- }
- return ts.singleOrMany(statements);
- }
- function visitExportDeclaration(node) {
- if (!node.moduleSpecifier) {
- return undefined;
- }
- var generatedName = ts.getGeneratedNameForNode(node);
- if (node.exportClause) {
- var statements = [];
- if (moduleKind !== ts.ModuleKind.AMD) {
- statements.push(ts.createVariableStatement(undefined, ts.createVariableDeclarationList([
- ts.createVariableDeclaration(generatedName, undefined, createRequireCall(node))
- ]), node));
- }
- for (var _i = 0, _a = node.exportClause.elements; _i < _a.length; _i++) {
- var specifier = _a[_i];
- var exportedValue = ts.createPropertyAccess(generatedName, specifier.propertyName || specifier.name);
- statements.push(ts.createStatement(createExportExpression(ts.getExportName(specifier), exportedValue), specifier));
- }
- return ts.singleOrMany(statements);
- }
- else {
- return ts.createStatement(ts.createCall(ts.createIdentifier("__export"), undefined, [
- moduleKind !== ts.ModuleKind.AMD
- ? createRequireCall(node)
- : generatedName
- ]), node);
- }
- }
- function visitExportAssignment(node) {
- if (node.isExportEquals) {
- return undefined;
- }
- var statements;
- var original = node.original;
- if (original && hasAssociatedEndOfDeclarationMarker(original)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportStatement(deferredExports[id], ts.createIdentifier("default"), node.expression, node, true);
- }
- else {
- statements = appendExportStatement(statements, ts.createIdentifier("default"), node.expression, node, true);
- }
- return ts.singleOrMany(statements);
- }
- function visitFunctionDeclaration(node) {
- var statements;
- if (ts.hasModifier(node, 1)) {
- statements = ts.append(statements, ts.setOriginalNode(ts.createFunctionDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), node.asteriskToken, ts.getDeclarationName(node, true, true), undefined, node.parameters, undefined, node.body, node), node));
- }
- else {
- statements = ts.append(statements, node);
- }
- if (hasAssociatedEndOfDeclarationMarker(node)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfHoistedDeclaration(deferredExports[id], node);
- }
- else {
- statements = appendExportsOfHoistedDeclaration(statements, node);
- }
- return ts.singleOrMany(statements);
- }
- function visitClassDeclaration(node) {
- var statements;
- if (ts.hasModifier(node, 1)) {
- statements = ts.append(statements, ts.setOriginalNode(ts.createClassDeclaration(undefined, ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier), ts.getDeclarationName(node, true, true), undefined, node.heritageClauses, node.members, node), node));
- }
- else {
- statements = ts.append(statements, node);
- }
- if (hasAssociatedEndOfDeclarationMarker(node)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfHoistedDeclaration(deferredExports[id], node);
- }
- else {
- statements = appendExportsOfHoistedDeclaration(statements, node);
- }
- return ts.singleOrMany(statements);
- }
- function visitVariableStatement(node) {
- var statements;
- var variables;
- var expressions;
- if (ts.hasModifier(node, 1)) {
- var modifiers = void 0;
- for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
- var variable = _a[_i];
- if (ts.isIdentifier(variable.name) && ts.isLocalName(variable.name)) {
- if (!modifiers) {
- modifiers = ts.visitNodes(node.modifiers, modifierVisitor, ts.isModifier);
- }
- variables = ts.append(variables, variable);
- }
- else if (variable.initializer) {
- expressions = ts.append(expressions, transformInitializedVariable(variable));
- }
- }
- if (variables) {
- statements = ts.append(statements, ts.updateVariableStatement(node, modifiers, ts.updateVariableDeclarationList(node.declarationList, variables)));
- }
- if (expressions) {
- statements = ts.append(statements, ts.createStatement(ts.inlineExpressions(expressions), node));
+ return ts.visitEachChild(node, visitor, context);
}
}
- else {
- statements = ts.append(statements, node);
- }
- if (hasAssociatedEndOfDeclarationMarker(node)) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfVariableStatement(deferredExports[id], node);
- }
- else {
- statements = appendExportsOfVariableStatement(statements, node);
- }
- return ts.singleOrMany(statements);
- }
- function transformInitializedVariable(node) {
- if (ts.isBindingPattern(node.name)) {
- return ts.flattenDestructuringAssignment(node, undefined, context, 0, false, createExportExpression);
- }
- else {
- return ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("exports"), node.name, node.name), node.initializer);
- }
- }
- function visitMergeDeclarationMarker(node) {
- if (hasAssociatedEndOfDeclarationMarker(node) && node.original.kind === 205) {
- var id = ts.getOriginalNodeId(node);
- deferredExports[id] = appendExportsOfVariableStatement(deferredExports[id], node.original);
- }
- return node;
- }
- function hasAssociatedEndOfDeclarationMarker(node) {
- return (ts.getEmitFlags(node) & 2097152) !== 0;
- }
- function visitEndOfDeclarationMarker(node) {
- var id = ts.getOriginalNodeId(node);
- var statements = deferredExports[id];
- if (statements) {
- delete deferredExports[id];
- return ts.append(statements, node);
- }
return node;
}
- function appendExportsOfImportDeclaration(statements, decl) {
- if (currentModuleInfo.exportEquals) {
- return statements;
- }
- var importClause = decl.importClause;
- if (!importClause) {
- return statements;
- }
- if (importClause.name) {
- statements = appendExportsOfDeclaration(statements, importClause);
- }
- var namedBindings = importClause.namedBindings;
- if (namedBindings) {
- switch (namedBindings.kind) {
- case 237:
- statements = appendExportsOfDeclaration(statements, namedBindings);
- break;
- case 238:
- for (var _i = 0, _a = namedBindings.elements; _i < _a.length; _i++) {
- var importBinding = _a[_i];
- statements = appendExportsOfDeclaration(statements, importBinding);
- }
- break;
- }
- }
- return statements;
- }
- function appendExportsOfImportEqualsDeclaration(statements, decl) {
- if (currentModuleInfo.exportEquals) {
- return statements;
- }
- return appendExportsOfDeclaration(statements, decl);
- }
- function appendExportsOfVariableStatement(statements, node) {
- if (currentModuleInfo.exportEquals) {
- return statements;
- }
- for (var _i = 0, _a = node.declarationList.declarations; _i < _a.length; _i++) {
- var decl = _a[_i];
- statements = appendExportsOfBindingElement(statements, decl);
- }
- return statements;
- }
- function appendExportsOfBindingElement(statements, decl) {
- if (currentModuleInfo.exportEquals) {
- return statements;
- }
- if (ts.isBindingPattern(decl.name)) {
- for (var _i = 0, _a = decl.name.elements; _i < _a.length; _i++) {
- var element = _a[_i];
- if (!ts.isOmittedExpression(element)) {
- statements = appendExportsOfBindingElement(statements, element);
- }
- }
- }
- else if (!ts.isGeneratedIdentifier(decl.name)) {
- statements = appendExportsOfDeclaration(statements, decl);
- }
- return statements;
- }
- function appendExportsOfHoistedDeclaration(statements, decl) {
- if (currentModuleInfo.exportEquals) {
- return statements;
- }
- if (ts.hasModifier(decl, 1)) {
- var exportName = ts.hasModifier(decl, 512) ? ts.createIdentifier("default") : decl.name;
- statements = appendExportStatement(statements, exportName, ts.getLocalName(decl), decl);
- }
- if (decl.name) {
- statements = appendExportsOfDeclaration(statements, decl);
- }
- return statements;
- }
- function appendExportsOfDeclaration(statements, decl) {
- var name = ts.getDeclarationName(decl);
- var exportSpecifiers = currentModuleInfo.exportSpecifiers[name.text];
- if (exportSpecifiers) {
- for (var _i = 0, exportSpecifiers_2 = exportSpecifiers; _i < exportSpecifiers_2.length; _i++) {
- var exportSpecifier = exportSpecifiers_2[_i];
- statements = appendExportStatement(statements, exportSpecifier.name, name, exportSpecifier.name);
- }
- }
- return statements;
- }
- function appendExportStatement(statements, exportName, expression, location, allowComments) {
- if (exportName.text === "default") {
- var sourceFile = ts.getOriginalNode(currentSourceFile, ts.isSourceFile);
- if (sourceFile && !sourceFile.symbol.exports["___esModule"]) {
- if (languageVersion === 0) {
- statements = ts.append(statements, ts.createStatement(createExportExpression(ts.createIdentifier("__esModule"), ts.createLiteral(true))));
- }
- else {
- statements = ts.append(statements, ts.createStatement(ts.createCall(ts.createPropertyAccess(ts.createIdentifier("Object"), "defineProperty"), undefined, [
- ts.createIdentifier("exports"),
- ts.createLiteral("__esModule"),
- ts.createObjectLiteral([
- ts.createPropertyAssignment("value", ts.createLiteral(true))
- ])
- ])));
- }
- }
- }
- statements = ts.append(statements, createExportStatement(exportName, expression, location, allowComments));
- return statements;
- }
- function createExportStatement(name, value, location, allowComments) {
- var statement = ts.createStatement(createExportExpression(name, value), location);
- ts.startOnNewLine(statement);
- if (!allowComments) {
- ts.setEmitFlags(statement, 1536);
- }
- return statement;
- }
- function createExportExpression(name, value, location) {
- return ts.createAssignment(ts.createPropertyAccess(ts.createIdentifier("exports"), ts.getSynthesizedClone(name)), value, location);
- }
- function modifierVisitor(node) {
+ function visitor(node) {
switch (node.kind) {
- case 83:
- case 78:
+ case 236:
return undefined;
+ case 242:
+ return visitExportAssignment(node);
}
return node;
}
- function onEmitNode(emitContext, node, emitCallback) {
- if (node.kind === 261) {
+ function visitExportAssignment(node) {
+ return node.isExportEquals ? undefined : node;
+ }
+ function onEmitNode(hint, node, emitCallback) {
+ if (ts.isSourceFile(node)) {
currentSourceFile = node;
- currentModuleInfo = moduleInfoMap[ts.getOriginalNodeId(currentSourceFile)];
- noSubstitution = ts.createMap();
- previousOnEmitNode(emitContext, node, emitCallback);
+ previousOnEmitNode(hint, node, emitCallback);
currentSourceFile = undefined;
- currentModuleInfo = undefined;
- noSubstitution = undefined;
}
else {
- previousOnEmitNode(emitContext, node, emitCallback);
- }
- }
- function onSubstituteNode(emitContext, node) {
- node = previousOnSubstituteNode(emitContext, node);
- if (node.id && noSubstitution[node.id]) {
- return node;
- }
- if (emitContext === 1) {
- return substituteExpression(node);
- }
- else if (ts.isShorthandPropertyAssignment(node)) {
- return substituteShorthandPropertyAssignment(node);
- }
- return node;
- }
- function substituteShorthandPropertyAssignment(node) {
- var name = node.name;
- var exportedOrImportedName = substituteExpressionIdentifier(name);
- if (exportedOrImportedName !== name) {
- if (node.objectAssignmentInitializer) {
- var initializer = ts.createAssignment(exportedOrImportedName, node.objectAssignmentInitializer);
- return ts.createPropertyAssignment(name, initializer, node);
- }
- return ts.createPropertyAssignment(name, exportedOrImportedName, node);
+ previousOnEmitNode(hint, node, emitCallback);
}
- return node;
}
- function substituteExpression(node) {
- switch (node.kind) {
- case 70:
- return substituteExpressionIdentifier(node);
- case 192:
- return substituteBinaryExpression(node);
- case 191:
- case 190:
- return substituteUnaryExpression(node);
+ function onSubstituteNode(hint, node) {
+ node = previousOnSubstituteNode(hint, node);
+ if (ts.isIdentifier(node) && hint === 1) {
+ return substituteExpressionIdentifier(node);
}
return node;
}
@@ -44605,101 +48386,30 @@ var ts;
if (externalHelpersModuleName) {
return ts.createPropertyAccess(externalHelpersModuleName, node);
}
- return node;
- }
- if (!ts.isGeneratedIdentifier(node) && !ts.isLocalName(node)) {
- var exportContainer = resolver.getReferencedExportContainer(node, ts.isExportName(node));
- if (exportContainer && exportContainer.kind === 261) {
- return ts.createPropertyAccess(ts.createIdentifier("exports"), ts.getSynthesizedClone(node), node);
- }
- var importDeclaration = resolver.getReferencedImportDeclaration(node);
- if (importDeclaration) {
- if (ts.isImportClause(importDeclaration)) {
- return ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent), ts.createIdentifier("default"), node);
- }
- else if (ts.isImportSpecifier(importDeclaration)) {
- var name_37 = importDeclaration.propertyName || importDeclaration.name;
- return ts.createPropertyAccess(ts.getGeneratedNameForNode(importDeclaration.parent.parent.parent), ts.getSynthesizedClone(name_37), node);
- }
- }
}
return node;
}
- function substituteBinaryExpression(node) {
- if (ts.isAssignmentOperator(node.operatorToken.kind)
- && ts.isIdentifier(node.left)
- && !ts.isGeneratedIdentifier(node.left)
- && !ts.isLocalName(node.left)
- && !ts.isDeclarationNameOfEnumOrNamespace(node.left)) {
- var exportedNames = getExports(node.left);
- if (exportedNames) {
- var expression = node;
- for (var _i = 0, exportedNames_3 = exportedNames; _i < exportedNames_3.length; _i++) {
- var exportName = exportedNames_3[_i];
- noSubstitution[ts.getNodeId(expression)] = true;
- expression = createExportExpression(exportName, expression, node);
- }
- return expression;
- }
- }
- return node;
- }
- function substituteUnaryExpression(node) {
- if ((node.operator === 42 || node.operator === 43)
- && ts.isIdentifier(node.operand)
- && !ts.isGeneratedIdentifier(node.operand)
- && !ts.isLocalName(node.operand)
- && !ts.isDeclarationNameOfEnumOrNamespace(node.operand)) {
- var exportedNames = getExports(node.operand);
- if (exportedNames) {
- var expression = node.kind === 191
- ? ts.createBinary(node.operand, ts.createToken(node.operator === 42 ? 58 : 59), ts.createLiteral(1), node)
- : node;
- for (var _i = 0, exportedNames_4 = exportedNames; _i < exportedNames_4.length; _i++) {
- var exportName = exportedNames_4[_i];
- noSubstitution[ts.getNodeId(expression)] = true;
- expression = createExportExpression(exportName, expression);
- }
- return expression;
- }
- }
- return node;
- }
- function getExports(name) {
- if (!ts.isGeneratedIdentifier(name)) {
- var valueDeclaration = resolver.getReferencedImportDeclaration(name)
- || resolver.getReferencedValueDeclaration(name);
- if (valueDeclaration) {
- return currentModuleInfo
- && currentModuleInfo.exportedBindings[ts.getOriginalNodeId(valueDeclaration)];
- }
- }
- }
- var _a;
}
- ts.transformModule = transformModule;
- var exportStarHelper = {
- name: "typescript:export-star",
- scoped: true,
- text: "\n function __export(m) {\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n }"
- };
- var umdHelper = "\n (function (dependencies, factory) {\n if (typeof module === 'object' && typeof module.exports === 'object') {\n var v = factory(require, exports); if (v !== undefined) module.exports = v;\n }\n else if (typeof define === 'function' && define.amd) {\n define(dependencies, factory);\n }\n })";
+ ts.transformES2015Module = transformES2015Module;
})(ts || (ts = {}));
var ts;
(function (ts) {
- var moduleTransformerMap = ts.createMap((_a = {},
- _a[ts.ModuleKind.ES2015] = ts.transformES2015Module,
- _a[ts.ModuleKind.System] = ts.transformSystemModule,
- _a[ts.ModuleKind.AMD] = ts.transformModule,
- _a[ts.ModuleKind.CommonJS] = ts.transformModule,
- _a[ts.ModuleKind.UMD] = ts.transformModule,
- _a[ts.ModuleKind.None] = ts.transformModule,
- _a));
- function getTransformers(compilerOptions) {
+ function getModuleTransformer(moduleKind) {
+ switch (moduleKind) {
+ case ts.ModuleKind.ES2015:
+ return ts.transformES2015Module;
+ case ts.ModuleKind.System:
+ return ts.transformSystemModule;
+ default:
+ return ts.transformModule;
+ }
+ }
+ function getTransformers(compilerOptions, customTransformers) {
var jsx = compilerOptions.jsx;
var languageVersion = ts.getEmitScriptTarget(compilerOptions);
var moduleKind = ts.getEmitModuleKind(compilerOptions);
var transformers = [];
+ ts.addRange(transformers, customTransformers && customTransformers.before);
transformers.push(ts.transformTypeScript);
if (jsx === 2) {
transformers.push(ts.transformJsx);
@@ -44717,16 +48427,16 @@ var ts;
transformers.push(ts.transformES2015);
transformers.push(ts.transformGenerators);
}
- transformers.push(moduleTransformerMap[moduleKind] || moduleTransformerMap[ts.ModuleKind.None]);
+ transformers.push(getModuleTransformer(moduleKind));
if (languageVersion < 1) {
transformers.push(ts.transformES5);
}
+ ts.addRange(transformers, customTransformers && customTransformers.after);
return transformers;
}
ts.getTransformers = getTransformers;
- function transformFiles(resolver, host, sourceFiles, transformers) {
+ function transformNodes(resolver, host, options, nodes, transformers, allowDtsFiles) {
var enabledSyntaxKindFeatures = new Array(298);
- var lexicalEnvironmentDisabled = false;
var lexicalEnvironmentVariableDeclarations;
var lexicalEnvironmentFunctionDeclarations;
var lexicalEnvironmentVariableDeclarationsStack = [];
@@ -44734,8 +48444,11 @@ var ts;
var lexicalEnvironmentStackOffset = 0;
var lexicalEnvironmentSuspended = false;
var emitHelpers;
+ var onSubstituteNode = function (_, node) { return node; };
+ var onEmitNode = function (hint, node, callback) { return callback(hint, node); };
+ var state = 0;
var context = {
- getCompilerOptions: function () { return host.getCompilerOptions(); },
+ getCompilerOptions: function () { return options; },
getEmitResolver: function () { return resolver; },
getEmitHost: function () { return host; },
startLexicalEnvironment: startLexicalEnvironment,
@@ -44746,65 +48459,77 @@ var ts;
hoistFunctionDeclaration: hoistFunctionDeclaration,
requestEmitHelper: requestEmitHelper,
readEmitHelpers: readEmitHelpers,
- onSubstituteNode: function (_emitContext, node) { return node; },
enableSubstitution: enableSubstitution,
- isSubstitutionEnabled: isSubstitutionEnabled,
- onEmitNode: function (node, emitContext, emitCallback) { return emitCallback(node, emitContext); },
enableEmitNotification: enableEmitNotification,
- isEmitNotificationEnabled: isEmitNotificationEnabled
+ isSubstitutionEnabled: isSubstitutionEnabled,
+ isEmitNotificationEnabled: isEmitNotificationEnabled,
+ get onSubstituteNode() { return onSubstituteNode; },
+ set onSubstituteNode(value) {
+ ts.Debug.assert(state < 1, "Cannot modify transformation hooks after initialization has completed.");
+ ts.Debug.assert(value !== undefined, "Value must not be 'undefined'");
+ onSubstituteNode = value;
+ },
+ get onEmitNode() { return onEmitNode; },
+ set onEmitNode(value) {
+ ts.Debug.assert(state < 1, "Cannot modify transformation hooks after initialization has completed.");
+ ts.Debug.assert(value !== undefined, "Value must not be 'undefined'");
+ onEmitNode = value;
+ }
};
+ for (var _i = 0, nodes_4 = nodes; _i < nodes_4.length; _i++) {
+ var node = nodes_4[_i];
+ ts.disposeEmitNodes(ts.getSourceFileOfNode(ts.getParseTreeNode(node)));
+ }
+ ts.performance.mark("beforeTransform");
var transformation = ts.chain.apply(void 0, transformers)(context);
- var transformed = ts.map(sourceFiles, transformSourceFile);
- lexicalEnvironmentDisabled = true;
+ state = 1;
+ var transformed = ts.map(nodes, allowDtsFiles ? transformation : transformRoot);
+ state = 2;
+ ts.performance.mark("afterTransform");
+ ts.performance.measure("transformTime", "beforeTransform", "afterTransform");
return {
transformed: transformed,
- emitNodeWithSubstitution: emitNodeWithSubstitution,
- emitNodeWithNotification: emitNodeWithNotification
+ substituteNode: substituteNode,
+ emitNodeWithNotification: emitNodeWithNotification,
+ dispose: dispose
};
- function transformSourceFile(sourceFile) {
- if (ts.isDeclarationFile(sourceFile)) {
- return sourceFile;
- }
- return transformation(sourceFile);
+ function transformRoot(node) {
+ return node && (!ts.isSourceFile(node) || !ts.isDeclarationFile(node)) ? transformation(node) : node;
}
function enableSubstitution(kind) {
+ ts.Debug.assert(state < 2, "Cannot modify the transformation context after transformation has completed.");
enabledSyntaxKindFeatures[kind] |= 1;
}
function isSubstitutionEnabled(node) {
return (enabledSyntaxKindFeatures[node.kind] & 1) !== 0
&& (ts.getEmitFlags(node) & 4) === 0;
}
- function emitNodeWithSubstitution(emitContext, node, emitCallback) {
- if (node) {
- if (isSubstitutionEnabled(node)) {
- var substitute = context.onSubstituteNode(emitContext, node);
- if (substitute && substitute !== node) {
- emitCallback(emitContext, substitute);
- return;
- }
- }
- emitCallback(emitContext, node);
- }
+ function substituteNode(hint, node) {
+ ts.Debug.assert(state < 3, "Cannot substitute a node after the result is disposed.");
+ return node && isSubstitutionEnabled(node) && onSubstituteNode(hint, node) || node;
}
function enableEmitNotification(kind) {
+ ts.Debug.assert(state < 2, "Cannot modify the transformation context after transformation has completed.");
enabledSyntaxKindFeatures[kind] |= 2;
}
function isEmitNotificationEnabled(node) {
return (enabledSyntaxKindFeatures[node.kind] & 2) !== 0
|| (ts.getEmitFlags(node) & 2) !== 0;
}
- function emitNodeWithNotification(emitContext, node, emitCallback) {
+ function emitNodeWithNotification(hint, node, emitCallback) {
+ ts.Debug.assert(state < 3, "Cannot invoke TransformationResult callbacks after the result is disposed.");
if (node) {
if (isEmitNotificationEnabled(node)) {
- context.onEmitNode(emitContext, node, emitCallback);
+ onEmitNode(hint, node, emitCallback);
}
else {
- emitCallback(emitContext, node);
+ emitCallback(hint, node);
}
}
}
function hoistVariableDeclaration(name) {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot modify the lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
var decl = ts.createVariableDeclaration(name);
if (!lexicalEnvironmentVariableDeclarations) {
lexicalEnvironmentVariableDeclarations = [decl];
@@ -44814,7 +48539,8 @@ var ts;
}
}
function hoistFunctionDeclaration(func) {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot modify the lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
if (!lexicalEnvironmentFunctionDeclarations) {
lexicalEnvironmentFunctionDeclarations = [func];
}
@@ -44823,7 +48549,8 @@ var ts;
}
}
function startLexicalEnvironment() {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot start a lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
ts.Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is suspended.");
lexicalEnvironmentVariableDeclarationsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentVariableDeclarations;
lexicalEnvironmentFunctionDeclarationsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentFunctionDeclarations;
@@ -44832,17 +48559,20 @@ var ts;
lexicalEnvironmentFunctionDeclarations = undefined;
}
function suspendLexicalEnvironment() {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot suspend a lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
ts.Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is already suspended.");
lexicalEnvironmentSuspended = true;
}
function resumeLexicalEnvironment() {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot resume a lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
ts.Debug.assert(lexicalEnvironmentSuspended, "Lexical environment is not suspended.");
lexicalEnvironmentSuspended = false;
}
function endLexicalEnvironment() {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot end a lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the lexical environment during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the lexical environment after transformation has completed.");
ts.Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is suspended.");
var statements;
if (lexicalEnvironmentVariableDeclarations || lexicalEnvironmentFunctionDeclarations) {
@@ -44869,19 +48599,36 @@ var ts;
return statements;
}
function requestEmitHelper(helper) {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot modify the lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the transformation context during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the transformation context after transformation has completed.");
ts.Debug.assert(!helper.scoped, "Cannot request a scoped emit helper.");
emitHelpers = ts.append(emitHelpers, helper);
}
function readEmitHelpers() {
- ts.Debug.assert(!lexicalEnvironmentDisabled, "Cannot modify the lexical environment during the print phase.");
+ ts.Debug.assert(state > 0, "Cannot modify the transformation context during initialization.");
+ ts.Debug.assert(state < 2, "Cannot modify the transformation context after transformation has completed.");
var helpers = emitHelpers;
emitHelpers = undefined;
return helpers;
}
+ function dispose() {
+ if (state < 3) {
+ for (var _i = 0, nodes_5 = nodes; _i < nodes_5.length; _i++) {
+ var node = nodes_5[_i];
+ ts.disposeEmitNodes(ts.getSourceFileOfNode(ts.getParseTreeNode(node)));
+ }
+ lexicalEnvironmentVariableDeclarations = undefined;
+ lexicalEnvironmentVariableDeclarationsStack = undefined;
+ lexicalEnvironmentFunctionDeclarations = undefined;
+ lexicalEnvironmentFunctionDeclarationsStack = undefined;
+ onSubstituteNode = undefined;
+ onEmitNode = undefined;
+ emitHelpers = undefined;
+ state = 3;
+ }
+ }
}
- ts.transformFiles = transformFiles;
- var _a;
+ ts.transformNodes = transformNodes;
})(ts || (ts = {}));
var ts;
(function (ts) {
@@ -44915,7 +48662,7 @@ var ts;
getText: getText,
getSourceMappingURL: getSourceMappingURL,
};
- function initialize(filePath, sourceMapFilePath, sourceFiles, isBundledEmit) {
+ function initialize(filePath, sourceMapFilePath, sourceFileOrBundle) {
if (disabled) {
return;
}
@@ -44946,9 +48693,8 @@ var ts;
}
if (compilerOptions.mapRoot) {
sourceMapDir = ts.normalizeSlashes(compilerOptions.mapRoot);
- if (!isBundledEmit) {
- ts.Debug.assert(sourceFiles.length === 1);
- sourceMapDir = ts.getDirectoryPath(ts.getSourceFilePathInNewDir(sourceFiles[0], host, sourceMapDir));
+ if (sourceFileOrBundle.kind === 264) {
+ sourceMapDir = ts.getDirectoryPath(ts.getSourceFilePathInNewDir(sourceFileOrBundle, host, sourceMapDir));
}
if (!ts.isRootedDiskPath(sourceMapDir) && !ts.isUrl(sourceMapDir)) {
sourceMapDir = ts.combinePaths(host.getCommonSourceDirectory(), sourceMapDir);
@@ -45039,28 +48785,28 @@ var ts;
ts.performance.measure("Source Map", "beforeSourcemap", "afterSourcemap");
}
}
- function emitNodeWithSourceMap(emitContext, node, emitCallback) {
+ function emitNodeWithSourceMap(hint, node, emitCallback) {
if (disabled) {
- return emitCallback(emitContext, node);
+ return emitCallback(hint, node);
}
if (node) {
var emitNode = node.emitNode;
var emitFlags = emitNode && emitNode.flags;
var _a = emitNode && emitNode.sourceMapRange || node, pos = _a.pos, end = _a.end;
- if (node.kind !== 293
+ if (node.kind !== 294
&& (emitFlags & 16) === 0
&& pos >= 0) {
emitPos(ts.skipTrivia(currentSourceText, pos));
}
if (emitFlags & 64) {
disabled = true;
- emitCallback(emitContext, node);
+ emitCallback(hint, node);
disabled = false;
}
else {
- emitCallback(emitContext, node);
+ emitCallback(hint, node);
}
- if (node.kind !== 293
+ if (node.kind !== 294
&& (emitFlags & 32) === 0
&& end >= 0) {
emitPos(end);
@@ -45109,7 +48855,7 @@ var ts;
return;
}
encodeLastRecordedSourceMapSpan();
- return ts.stringify({
+ return JSON.stringify({
version: 3,
file: sourceMapData.sourceMapFile,
sourceRoot: sourceMapData.sourceMapSourceRoot,
@@ -45161,11 +48907,10 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- function createCommentWriter(host, writer, sourceMap) {
- var compilerOptions = host.getCompilerOptions();
- var extendedDiagnostics = compilerOptions.extendedDiagnostics;
- var newLine = host.getNewLine();
- var emitPos = sourceMap.emitPos;
+ function createCommentWriter(printerOptions, emitPos) {
+ var extendedDiagnostics = printerOptions.extendedDiagnostics;
+ var newLine = ts.getNewLineCharacter(printerOptions);
+ var writer;
var containerPos = -1;
var containerEnd = -1;
var declarationListContainerEnd = -1;
@@ -45174,37 +48919,34 @@ var ts;
var currentLineMap;
var detachedCommentsInfo;
var hasWrittenComment = false;
- var disabled = compilerOptions.removeComments;
+ var disabled = printerOptions.removeComments;
return {
reset: reset,
+ setWriter: setWriter,
setSourceFile: setSourceFile,
emitNodeWithComments: emitNodeWithComments,
emitBodyWithDetachedComments: emitBodyWithDetachedComments,
emitTrailingCommentsOfPosition: emitTrailingCommentsOfPosition,
+ emitLeadingCommentsOfPosition: emitLeadingCommentsOfPosition,
};
- function emitNodeWithComments(emitContext, node, emitCallback) {
+ function emitNodeWithComments(hint, node, emitCallback) {
if (disabled) {
- emitCallback(emitContext, node);
+ emitCallback(hint, node);
return;
}
if (node) {
- var _a = ts.getCommentRange(node), pos = _a.pos, end = _a.end;
- var emitFlags = ts.getEmitFlags(node);
+ hasWrittenComment = false;
+ var emitNode = node.emitNode;
+ var emitFlags = emitNode && emitNode.flags;
+ var _a = emitNode && emitNode.commentRange || node, pos = _a.pos, end = _a.end;
if ((pos < 0 && end < 0) || (pos === end)) {
- if (emitFlags & 2048) {
- disabled = true;
- emitCallback(emitContext, node);
- disabled = false;
- }
- else {
- emitCallback(emitContext, node);
- }
+ emitNodeWithSynthesizedComments(hint, node, emitNode, emitFlags, emitCallback);
}
else {
if (extendedDiagnostics) {
ts.performance.mark("preEmitNodeWithComment");
}
- var isEmittedNode = node.kind !== 293;
+ var isEmittedNode = node.kind !== 294;
var skipLeadingComments = pos < 0 || (emitFlags & 512) !== 0;
var skipTrailingComments = end < 0 || (emitFlags & 1024) !== 0;
if (!skipLeadingComments) {
@@ -45218,23 +48960,16 @@ var ts;
}
if (!skipTrailingComments) {
containerEnd = end;
- if (node.kind === 224) {
+ if (node.kind === 226) {
declarationListContainerEnd = end;
}
}
if (extendedDiagnostics) {
ts.performance.measure("commentTime", "preEmitNodeWithComment");
}
- if (emitFlags & 2048) {
- disabled = true;
- emitCallback(emitContext, node);
- disabled = false;
- }
- else {
- emitCallback(emitContext, node);
- }
+ emitNodeWithSynthesizedComments(hint, node, emitNode, emitFlags, emitCallback);
if (extendedDiagnostics) {
- ts.performance.mark("beginEmitNodeWithComment");
+ ts.performance.mark("postEmitNodeWithComment");
}
containerPos = savedContainerPos;
containerEnd = savedContainerEnd;
@@ -45243,11 +48978,75 @@ var ts;
emitTrailingComments(end);
}
if (extendedDiagnostics) {
- ts.performance.measure("commentTime", "beginEmitNodeWithComment");
+ ts.performance.measure("commentTime", "postEmitNodeWithComment");
}
}
}
}
+ function emitNodeWithSynthesizedComments(hint, node, emitNode, emitFlags, emitCallback) {
+ var leadingComments = emitNode && emitNode.leadingComments;
+ if (ts.some(leadingComments)) {
+ if (extendedDiagnostics) {
+ ts.performance.mark("preEmitNodeWithSynthesizedComments");
+ }
+ ts.forEach(leadingComments, emitLeadingSynthesizedComment);
+ if (extendedDiagnostics) {
+ ts.performance.measure("commentTime", "preEmitNodeWithSynthesizedComments");
+ }
+ }
+ emitNodeWithNestedComments(hint, node, emitFlags, emitCallback);
+ var trailingComments = emitNode && emitNode.trailingComments;
+ if (ts.some(trailingComments)) {
+ if (extendedDiagnostics) {
+ ts.performance.mark("postEmitNodeWithSynthesizedComments");
+ }
+ ts.forEach(trailingComments, emitTrailingSynthesizedComment);
+ if (extendedDiagnostics) {
+ ts.performance.measure("commentTime", "postEmitNodeWithSynthesizedComments");
+ }
+ }
+ }
+ function emitLeadingSynthesizedComment(comment) {
+ if (comment.kind === 2) {
+ writer.writeLine();
+ }
+ writeSynthesizedComment(comment);
+ if (comment.hasTrailingNewLine || comment.kind === 2) {
+ writer.writeLine();
+ }
+ else {
+ writer.write(" ");
+ }
+ }
+ function emitTrailingSynthesizedComment(comment) {
+ if (!writer.isAtStartOfLine()) {
+ writer.write(" ");
+ }
+ writeSynthesizedComment(comment);
+ if (comment.hasTrailingNewLine) {
+ writer.writeLine();
+ }
+ }
+ function writeSynthesizedComment(comment) {
+ var text = formatSynthesizedComment(comment);
+ var lineMap = comment.kind === 3 ? ts.computeLineStarts(text) : undefined;
+ ts.writeCommentRange(text, lineMap, writer, 0, text.length, newLine);
+ }
+ function formatSynthesizedComment(comment) {
+ return comment.kind === 3
+ ? "/*" + comment.text + "*/"
+ : "//" + comment.text;
+ }
+ function emitNodeWithNestedComments(hint, node, emitFlags, emitCallback) {
+ if (emitFlags & 2048) {
+ disabled = true;
+ emitCallback(hint, node);
+ disabled = false;
+ }
+ else {
+ emitCallback(hint, node);
+ }
+ }
function emitBodyWithDetachedComments(node, detachedRange, emitCallback) {
if (extendedDiagnostics) {
ts.performance.mark("preEmitBodyWithDetachedComments");
@@ -45275,6 +49074,9 @@ var ts;
}
if (!skipTrailingComments) {
emitLeadingComments(detachedRange.end, true);
+ if (hasWrittenComment && !writer.isAtStartOfLine()) {
+ writer.writeLine();
+ }
}
if (extendedDiagnostics) {
ts.performance.measure("commentTime", "beginEmitBodyWithDetachedCommetns");
@@ -45299,9 +49101,11 @@ var ts;
ts.emitNewLineBeforeLeadingCommentOfPosition(currentLineMap, writer, rangePos, commentPos);
hasWrittenComment = true;
}
- emitPos(commentPos);
+ if (emitPos)
+ emitPos(commentPos);
ts.writeCommentRange(currentText, currentLineMap, writer, commentPos, commentEnd, newLine);
- emitPos(commentEnd);
+ if (emitPos)
+ emitPos(commentEnd);
if (hasTrailingNewLine) {
writer.writeLine();
}
@@ -45309,6 +49113,12 @@ var ts;
writer.write(" ");
}
}
+ function emitLeadingCommentsOfPosition(pos) {
+ if (disabled || pos === -1) {
+ return;
+ }
+ emitLeadingComments(pos, true);
+ }
function emitTrailingComments(pos) {
forEachTrailingCommentToEmit(pos, emitTrailingComment);
}
@@ -45316,9 +49126,11 @@ var ts;
if (!writer.isAtStartOfLine()) {
writer.write(" ");
}
- emitPos(commentPos);
+ if (emitPos)
+ emitPos(commentPos);
ts.writeCommentRange(currentText, currentLineMap, writer, commentPos, commentEnd, newLine);
- emitPos(commentEnd);
+ if (emitPos)
+ emitPos(commentEnd);
if (hasTrailingNewLine) {
writer.writeLine();
}
@@ -45336,9 +49148,11 @@ var ts;
}
}
function emitTrailingCommentOfPosition(commentPos, commentEnd, _kind, hasTrailingNewLine) {
- emitPos(commentPos);
+ if (emitPos)
+ emitPos(commentPos);
ts.writeCommentRange(currentText, currentLineMap, writer, commentPos, commentEnd, newLine);
- emitPos(commentEnd);
+ if (emitPos)
+ emitPos(commentEnd);
if (hasTrailingNewLine) {
writer.writeLine();
}
@@ -45367,6 +49181,9 @@ var ts;
currentLineMap = undefined;
detachedCommentsInfo = undefined;
}
+ function setWriter(output) {
+ writer = output;
+ }
function setSourceFile(sourceFile) {
currentSourceFile = sourceFile;
currentText = currentSourceFile.text;
@@ -45398,9 +49215,11 @@ var ts;
}
}
function writeComment(text, lineMap, writer, commentPos, commentEnd, newLine) {
- emitPos(commentPos);
+ if (emitPos)
+ emitPos(commentPos);
ts.writeCommentRange(text, lineMap, writer, commentPos, commentEnd, newLine);
- emitPos(commentEnd);
+ if (emitPos)
+ emitPos(commentEnd);
}
function isTripleSlashComment(commentPos, commentEnd) {
if (currentText.charCodeAt(commentPos + 1) === 47 &&
@@ -45420,15 +49239,17 @@ var ts;
(function (ts) {
function getDeclarationDiagnostics(host, resolver, targetSourceFile) {
var declarationDiagnostics = ts.createDiagnosticCollection();
- ts.forEachExpectedEmitFile(host, getDeclarationDiagnosticsFromFile, targetSourceFile);
+ ts.forEachEmittedFile(host, getDeclarationDiagnosticsFromFile, targetSourceFile);
return declarationDiagnostics.getDiagnostics(targetSourceFile ? targetSourceFile.fileName : undefined);
- function getDeclarationDiagnosticsFromFile(_a, sources, isBundledEmit) {
+ function getDeclarationDiagnosticsFromFile(_a, sourceFileOrBundle) {
var declarationFilePath = _a.declarationFilePath;
- emitDeclarations(host, resolver, declarationDiagnostics, declarationFilePath, sources, isBundledEmit, false);
+ emitDeclarations(host, resolver, declarationDiagnostics, declarationFilePath, sourceFileOrBundle, false);
}
}
ts.getDeclarationDiagnostics = getDeclarationDiagnostics;
- function emitDeclarations(host, resolver, emitterDiagnostics, declarationFilePath, sourceFiles, isBundledEmit, emitOnlyDtsFiles) {
+ function emitDeclarations(host, resolver, emitterDiagnostics, declarationFilePath, sourceFileOrBundle, emitOnlyDtsFiles) {
+ var sourceFiles = sourceFileOrBundle.kind === 265 ? sourceFileOrBundle.sourceFiles : [sourceFileOrBundle];
+ var isBundledEmit = sourceFileOrBundle.kind === 265;
var newLine = host.getNewLine();
var compilerOptions = host.getCompilerOptions();
var write;
@@ -45490,7 +49311,7 @@ var ts;
var oldWriter = writer;
ts.forEach(moduleElementDeclarationEmitInfo, function (aliasEmitInfo) {
if (aliasEmitInfo.isVisible && !aliasEmitInfo.asynchronousOutput) {
- ts.Debug.assert(aliasEmitInfo.node.kind === 235);
+ ts.Debug.assert(aliasEmitInfo.node.kind === 237);
createAndSetNewTextWriterWithSymbolWriter();
ts.Debug.assert(aliasEmitInfo.indent === 0 || (aliasEmitInfo.indent === 1 && isBundledEmit));
for (var i = 0; i < aliasEmitInfo.indent; i++) {
@@ -45513,9 +49334,9 @@ var ts;
}
});
if (usedTypeDirectiveReferences) {
- for (var directive in usedTypeDirectiveReferences) {
+ ts.forEachKey(usedTypeDirectiveReferences, function (directive) {
referencesOutput += "/// <reference types=\"" + directive + "\" />" + newLine;
- }
+ });
}
return {
reportedDeclarationError: reportedDeclarationError,
@@ -45540,12 +49361,14 @@ var ts;
var writer = ts.createTextWriter(newLine);
writer.trackSymbol = trackSymbol;
writer.reportInaccessibleThisError = reportInaccessibleThisError;
+ writer.reportIllegalExtends = reportIllegalExtends;
writer.writeKeyword = writer.write;
writer.writeOperator = writer.write;
writer.writePunctuation = writer.write;
writer.writeSpace = writer.write;
writer.writeStringLiteral = writer.writeLiteral;
writer.writeParameter = writer.write;
+ writer.writeProperty = writer.write;
writer.writeSymbol = writer.write;
setWriter(writer);
}
@@ -45561,10 +49384,10 @@ var ts;
var oldWriter = writer;
ts.forEach(nodes, function (declaration) {
var nodeToCheck;
- if (declaration.kind === 223) {
+ if (declaration.kind === 225) {
nodeToCheck = declaration.parent.parent;
}
- else if (declaration.kind === 238 || declaration.kind === 239 || declaration.kind === 236) {
+ else if (declaration.kind === 240 || declaration.kind === 241 || declaration.kind === 238) {
ts.Debug.fail("We should be getting ImportDeclaration instead to write");
}
else {
@@ -45575,7 +49398,7 @@ var ts;
moduleElementEmitInfo = ts.forEach(asynchronousSubModuleDeclarationEmitInfo, function (declEmitInfo) { return declEmitInfo.node === nodeToCheck ? declEmitInfo : undefined; });
}
if (moduleElementEmitInfo) {
- if (moduleElementEmitInfo.node.kind === 235) {
+ if (moduleElementEmitInfo.node.kind === 237) {
moduleElementEmitInfo.isVisible = true;
}
else {
@@ -45583,12 +49406,12 @@ var ts;
for (var declarationIndent = moduleElementEmitInfo.indent; declarationIndent; declarationIndent--) {
increaseIndent();
}
- if (nodeToCheck.kind === 230) {
+ if (nodeToCheck.kind === 232) {
ts.Debug.assert(asynchronousSubModuleDeclarationEmitInfo === undefined);
asynchronousSubModuleDeclarationEmitInfo = [];
}
writeModuleElement(nodeToCheck);
- if (nodeToCheck.kind === 230) {
+ if (nodeToCheck.kind === 232) {
moduleElementEmitInfo.subModuleElementDeclarationEmitInfo = asynchronousSubModuleDeclarationEmitInfo;
asynchronousSubModuleDeclarationEmitInfo = undefined;
}
@@ -45607,8 +49430,8 @@ var ts;
}
for (var _i = 0, typeReferenceDirectives_1 = typeReferenceDirectives; _i < typeReferenceDirectives_1.length; _i++) {
var directive = typeReferenceDirectives_1[_i];
- if (!(directive in usedTypeDirectiveReferences)) {
- usedTypeDirectiveReferences[directive] = directive;
+ if (!usedTypeDirectiveReferences.has(directive)) {
+ usedTypeDirectiveReferences.set(directive, directive);
}
}
}
@@ -45635,6 +49458,12 @@ var ts;
handleSymbolAccessibilityError(resolver.isSymbolAccessible(symbol, enclosingDeclaration, meaning, true));
recordTypeReferenceDirectivesIfNecessary(resolver.getTypeReferenceDirectivesForSymbol(symbol, meaning));
}
+ function reportIllegalExtends() {
+ if (errorNameNode) {
+ reportedDeclarationError = true;
+ emitterDiagnostics.add(ts.createDiagnosticForNode(errorNameNode, ts.Diagnostics.extends_clause_of_exported_class_0_refers_to_a_type_whose_name_cannot_be_referenced, ts.declarationNameToString(errorNameNode)));
+ }
+ }
function reportInaccessibleThisError() {
if (errorNameNode) {
reportedDeclarationError = true;
@@ -45644,12 +49473,16 @@ var ts;
function writeTypeOfDeclaration(declaration, type, getSymbolAccessibilityDiagnostic) {
writer.getSymbolAccessibilityDiagnostic = getSymbolAccessibilityDiagnostic;
write(": ");
- if (type) {
+ var shouldUseResolverType = declaration.kind === 145 &&
+ resolver.isRequiredInitializedParameter(declaration);
+ if (type && !shouldUseResolverType) {
emitType(type);
}
else {
errorNameNode = declaration.name;
- resolver.writeTypeOfDeclaration(declaration, enclosingDeclaration, 2 | 1024, writer);
+ var format = 2 | 1024 |
+ (shouldUseResolverType ? 4096 : 0);
+ resolver.writeTypeOfDeclaration(declaration, enclosingDeclaration, format, writer);
errorNameNode = undefined;
}
}
@@ -45666,15 +49499,15 @@ var ts;
}
}
function emitLines(nodes) {
- for (var _i = 0, nodes_4 = nodes; _i < nodes_4.length; _i++) {
- var node = nodes_4[_i];
+ for (var _i = 0, nodes_6 = nodes; _i < nodes_6.length; _i++) {
+ var node = nodes_6[_i];
emit(node);
}
}
function emitSeparatedList(nodes, separator, eachNodeEmitFn, canEmitFn) {
var currentWriterPos = writer.getTextPos();
- for (var _i = 0, nodes_5 = nodes; _i < nodes_5.length; _i++) {
- var node = nodes_5[_i];
+ for (var _i = 0, nodes_7 = nodes; _i < nodes_7.length; _i++) {
+ var node = nodes_7[_i];
if (!canEmitFn || canEmitFn(node)) {
if (currentWriterPos !== writer.getTextPos()) {
write(separator);
@@ -45701,49 +49534,50 @@ var ts;
function emitType(type) {
switch (type.kind) {
case 118:
- case 134:
+ case 135:
case 132:
case 121:
- case 135:
+ case 133:
+ case 136:
case 104:
- case 137:
+ case 138:
case 94:
case 129:
- case 167:
- case 171:
+ case 168:
+ case 172:
return writeTextOfNode(currentText, type);
- case 199:
+ case 200:
return emitExpressionWithTypeArguments(type);
- case 157:
+ case 158:
return emitTypeReference(type);
- case 160:
+ case 161:
return emitTypeQuery(type);
- case 162:
- return emitArrayType(type);
case 163:
- return emitTupleType(type);
+ return emitArrayType(type);
case 164:
- return emitUnionType(type);
+ return emitTupleType(type);
case 165:
- return emitIntersectionType(type);
+ return emitUnionType(type);
case 166:
+ return emitIntersectionType(type);
+ case 167:
return emitParenType(type);
- case 168:
- return emitTypeOperator(type);
case 169:
- return emitIndexedAccessType(type);
+ return emitTypeOperator(type);
case 170:
+ return emitIndexedAccessType(type);
+ case 171:
return emitMappedType(type);
- case 158:
case 159:
+ case 160:
return emitSignatureDeclarationWithJsDocComments(type);
- case 161:
+ case 162:
return emitTypeLiteral(type);
case 70:
return emitEntityName(type);
- case 141:
+ case 142:
return emitEntityName(type);
- case 156:
+ case 157:
return emitTypePredicate(type);
}
function writeEntityName(entityName) {
@@ -45751,22 +49585,22 @@ var ts;
writeTextOfNode(currentText, entityName);
}
else {
- var left = entityName.kind === 141 ? entityName.left : entityName.expression;
- var right = entityName.kind === 141 ? entityName.right : entityName.name;
+ var left = entityName.kind === 142 ? entityName.left : entityName.expression;
+ var right = entityName.kind === 142 ? entityName.right : entityName.name;
writeEntityName(left);
write(".");
writeTextOfNode(currentText, right);
}
}
function emitEntityName(entityName) {
- var visibilityResult = resolver.isEntityNameVisible(entityName, entityName.parent.kind === 234 ? entityName.parent : enclosingDeclaration);
+ var visibilityResult = resolver.isEntityNameVisible(entityName, entityName.parent.kind === 236 ? entityName.parent : enclosingDeclaration);
handleSymbolAccessibilityError(visibilityResult);
recordTypeReferenceDirectivesIfNecessary(resolver.getTypeReferenceDirectivesForEntityName(entityName));
writeEntityName(entityName);
}
function emitExpressionWithTypeArguments(node) {
if (ts.isEntityNameExpression(node.expression)) {
- ts.Debug.assert(node.expression.kind === 70 || node.expression.kind === 177);
+ ts.Debug.assert(node.expression.kind === 70 || node.expression.kind === 178);
emitEntityName(node.expression);
if (node.typeArguments) {
write("<");
@@ -45870,15 +49704,15 @@ var ts;
}
function getExportDefaultTempVariableName() {
var baseName = "_default";
- if (!(baseName in currentIdentifiers)) {
+ if (!currentIdentifiers.has(baseName)) {
return baseName;
}
var count = 0;
while (true) {
count++;
- var name_38 = baseName + "_" + count;
- if (!(name_38 in currentIdentifiers)) {
- return name_38;
+ var name = baseName + "_" + count;
+ if (!currentIdentifiers.has(name)) {
+ return name;
}
}
}
@@ -45922,10 +49756,10 @@ var ts;
if (isModuleElementVisible) {
writeModuleElement(node);
}
- else if (node.kind === 234 ||
- (node.parent.kind === 261 && isCurrentFileExternalModule)) {
+ else if (node.kind === 236 ||
+ (node.parent.kind === 264 && isCurrentFileExternalModule)) {
var isVisible = void 0;
- if (asynchronousSubModuleDeclarationEmitInfo && node.parent.kind !== 261) {
+ if (asynchronousSubModuleDeclarationEmitInfo && node.parent.kind !== 264) {
asynchronousSubModuleDeclarationEmitInfo.push({
node: node,
outputPos: writer.getTextPos(),
@@ -45934,7 +49768,7 @@ var ts;
});
}
else {
- if (node.kind === 235) {
+ if (node.kind === 237) {
var importDeclaration = node;
if (importDeclaration.importClause) {
isVisible = (importDeclaration.importClause.name && resolver.isDeclarationVisible(importDeclaration.importClause)) ||
@@ -45952,30 +49786,30 @@ var ts;
}
function writeModuleElement(node) {
switch (node.kind) {
- case 225:
+ case 227:
return writeFunctionDeclaration(node);
- case 205:
+ case 207:
return writeVariableStatement(node);
- case 227:
+ case 229:
return writeInterfaceDeclaration(node);
- case 226:
- return writeClassDeclaration(node);
case 228:
+ return writeClassDeclaration(node);
+ case 230:
return writeTypeAliasDeclaration(node);
- case 229:
+ case 231:
return writeEnumDeclaration(node);
- case 230:
+ case 232:
return writeModuleDeclaration(node);
- case 234:
+ case 236:
return writeImportEqualsDeclaration(node);
- case 235:
+ case 237:
return writeImportDeclaration(node);
default:
ts.Debug.fail("Unknown symbol kind");
}
}
function emitModuleElementDeclarationFlags(node) {
- if (node.parent.kind === 261) {
+ if (node.parent.kind === 264) {
var modifiers = ts.getModifierFlags(node);
if (modifiers & 1) {
write("export ");
@@ -45983,7 +49817,7 @@ var ts;
if (modifiers & 512) {
write("default ");
}
- else if (node.kind !== 227 && !noDeclare) {
+ else if (node.kind !== 229 && !noDeclare) {
write("declare ");
}
}
@@ -46033,7 +49867,7 @@ var ts;
}
function isVisibleNamedBinding(namedBindings) {
if (namedBindings) {
- if (namedBindings.kind === 237) {
+ if (namedBindings.kind === 239) {
return resolver.isDeclarationVisible(namedBindings);
}
else {
@@ -46056,7 +49890,7 @@ var ts;
if (currentWriterPos !== writer.getTextPos()) {
write(", ");
}
- if (node.importClause.namedBindings.kind === 237) {
+ if (node.importClause.namedBindings.kind === 239) {
write("* as ");
writeTextOfNode(currentText, node.importClause.namedBindings.name);
}
@@ -46073,13 +49907,13 @@ var ts;
writer.writeLine();
}
function emitExternalModuleSpecifier(parent) {
- resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent.kind !== 230;
+ resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent.kind !== 232;
var moduleSpecifier;
- if (parent.kind === 234) {
+ if (parent.kind === 236) {
var node = parent;
moduleSpecifier = ts.getExternalModuleImportEqualsDeclarationExpression(node);
}
- else if (parent.kind === 230) {
+ else if (parent.kind === 232) {
moduleSpecifier = parent.name;
}
else {
@@ -46147,7 +49981,7 @@ var ts;
writeTextOfNode(currentText, node.name);
}
}
- while (node.body && node.body.kind !== 231) {
+ while (node.body && node.body.kind !== 233) {
node = node.body;
write(".");
writeTextOfNode(currentText, node.name);
@@ -46217,7 +50051,7 @@ var ts;
writeLine();
}
function isPrivateMethodTypeParameter(node) {
- return node.parent.kind === 149 && ts.hasModifier(node.parent, 8);
+ return node.parent.kind === 150 && ts.hasModifier(node.parent, 8);
}
function emitTypeParameters(typeParameters) {
function emitTypeParameter(node) {
@@ -46227,52 +50061,69 @@ var ts;
writeTextOfNode(currentText, node.name);
if (node.constraint && !isPrivateMethodTypeParameter(node)) {
write(" extends ");
- if (node.parent.kind === 158 ||
- node.parent.kind === 159 ||
- (node.parent.parent && node.parent.parent.kind === 161)) {
- ts.Debug.assert(node.parent.kind === 149 ||
- node.parent.kind === 148 ||
- node.parent.kind === 158 ||
+ if (node.parent.kind === 159 ||
+ node.parent.kind === 160 ||
+ (node.parent.parent && node.parent.parent.kind === 162)) {
+ ts.Debug.assert(node.parent.kind === 150 ||
+ node.parent.kind === 149 ||
node.parent.kind === 159 ||
- node.parent.kind === 153 ||
- node.parent.kind === 154);
+ node.parent.kind === 160 ||
+ node.parent.kind === 154 ||
+ node.parent.kind === 155);
emitType(node.constraint);
}
else {
emitTypeWithNewGetSymbolAccessibilityDiagnostic(node.constraint, getTypeParameterConstraintVisibilityError);
}
}
+ if (node.default && !isPrivateMethodTypeParameter(node)) {
+ write(" = ");
+ if (node.parent.kind === 159 ||
+ node.parent.kind === 160 ||
+ (node.parent.parent && node.parent.parent.kind === 162)) {
+ ts.Debug.assert(node.parent.kind === 150 ||
+ node.parent.kind === 149 ||
+ node.parent.kind === 159 ||
+ node.parent.kind === 160 ||
+ node.parent.kind === 154 ||
+ node.parent.kind === 155);
+ emitType(node.default);
+ }
+ else {
+ emitTypeWithNewGetSymbolAccessibilityDiagnostic(node.default, getTypeParameterConstraintVisibilityError);
+ }
+ }
function getTypeParameterConstraintVisibilityError() {
var diagnosticMessage;
switch (node.parent.kind) {
- case 226:
+ case 228:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_exported_class_has_or_is_using_private_name_1;
break;
- case 227:
+ case 229:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1;
break;
- case 154:
+ case 155:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
break;
- case 153:
+ case 154:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
break;
+ case 150:
case 149:
- case 148:
if (ts.hasModifier(node.parent, 32)) {
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
}
- else if (node.parent.parent.kind === 226) {
+ else if (node.parent.parent.kind === 228) {
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1;
}
else {
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
}
break;
- case 225:
+ case 227:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_exported_function_has_or_is_using_private_name_1;
break;
- case 228:
+ case 230:
diagnosticMessage = ts.Diagnostics.Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1;
break;
default:
@@ -46291,7 +50142,7 @@ var ts;
write(">");
}
}
- function emitHeritageClause(typeReferences, isImplementsList) {
+ function emitHeritageClause(className, typeReferences, isImplementsList) {
if (typeReferences) {
write(isImplementsList ? " implements " : " extends ");
emitCommaList(typeReferences, emitTypeOfTypeReference);
@@ -46305,17 +50156,19 @@ var ts;
}
else {
writer.getSymbolAccessibilityDiagnostic = getHeritageClauseVisibilityError;
+ errorNameNode = className;
resolver.writeBaseConstructorTypeOfClass(enclosingDeclaration, enclosingDeclaration, 2 | 1024, writer);
+ errorNameNode = undefined;
}
function getHeritageClauseVisibilityError() {
var diagnosticMessage;
- if (node.parent.parent.kind === 226) {
+ if (node.parent.parent.kind === 228) {
diagnosticMessage = isImplementsList ?
ts.Diagnostics.Implements_clause_of_exported_class_0_has_or_is_using_private_name_1 :
- ts.Diagnostics.Extends_clause_of_exported_class_0_has_or_is_using_private_name_1;
+ ts.Diagnostics.extends_clause_of_exported_class_0_has_or_is_using_private_name_1;
}
else {
- diagnosticMessage = ts.Diagnostics.Extends_clause_of_exported_interface_0_has_or_is_using_private_name_1;
+ diagnosticMessage = ts.Diagnostics.extends_clause_of_exported_interface_0_has_or_is_using_private_name_1;
}
return {
diagnosticMessage: diagnosticMessage,
@@ -46347,9 +50200,10 @@ var ts;
emitTypeParameters(node.typeParameters);
var baseTypeNode = ts.getClassExtendsHeritageClauseElement(node);
if (baseTypeNode) {
- emitHeritageClause([baseTypeNode], false);
+ node.name;
+ emitHeritageClause(node.name, [baseTypeNode], false);
}
- emitHeritageClause(ts.getClassImplementsHeritageClauseElements(node), true);
+ emitHeritageClause(node.name, ts.getClassImplementsHeritageClauseElements(node), true);
write(" {");
writeLine();
increaseIndent();
@@ -46370,7 +50224,7 @@ var ts;
emitTypeParameters(node.typeParameters);
var interfaceExtendsTypes = ts.filter(ts.getInterfaceBaseTypeNodes(node), function (base) { return ts.isEntityNameExpression(base.expression); });
if (interfaceExtendsTypes && interfaceExtendsTypes.length) {
- emitHeritageClause(interfaceExtendsTypes, false);
+ emitHeritageClause(node.name, interfaceExtendsTypes, false);
}
write(" {");
writeLine();
@@ -46392,17 +50246,17 @@ var ts;
writeLine();
}
function emitVariableDeclaration(node) {
- if (node.kind !== 223 || resolver.isDeclarationVisible(node)) {
+ if (node.kind !== 225 || resolver.isDeclarationVisible(node)) {
if (ts.isBindingPattern(node.name)) {
emitBindingPattern(node.name);
}
else {
writeTextOfNode(currentText, node.name);
- if ((node.kind === 147 || node.kind === 146 ||
- (node.kind === 144 && !ts.isParameterPropertyDeclaration(node))) && ts.hasQuestionToken(node)) {
+ if ((node.kind === 148 || node.kind === 147 ||
+ (node.kind === 145 && !ts.isParameterPropertyDeclaration(node))) && ts.hasQuestionToken(node)) {
write("?");
}
- if ((node.kind === 147 || node.kind === 146) && node.parent.kind === 161) {
+ if ((node.kind === 148 || node.kind === 147) && node.parent.kind === 162) {
emitTypeOfVariableDeclarationFromTypeLiteral(node);
}
else if (resolver.isLiteralConstDeclaration(node)) {
@@ -46415,14 +50269,14 @@ var ts;
}
}
function getVariableDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
- if (node.kind === 223) {
+ if (node.kind === 225) {
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named :
ts.Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Exported_variable_0_has_or_is_using_private_name_1;
}
- else if (node.kind === 147 || node.kind === 146) {
+ else if (node.kind === 148 || node.kind === 147) {
if (ts.hasModifier(node, 32)) {
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
@@ -46430,7 +50284,7 @@ var ts;
ts.Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1;
}
- else if (node.parent.kind === 226) {
+ else if (node.parent.kind === 228) {
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named :
@@ -46456,7 +50310,7 @@ var ts;
var elements = [];
for (var _i = 0, _a = bindingPattern.elements; _i < _a.length; _i++) {
var element = _a[_i];
- if (element.kind !== 198) {
+ if (element.kind !== 199) {
elements.push(element);
}
}
@@ -46522,7 +50376,7 @@ var ts;
accessorWithTypeAnnotation = node;
var type = getTypeAnnotationFromAccessor(node);
if (!type) {
- var anotherAccessor = node.kind === 151 ? accessors.setAccessor : accessors.getAccessor;
+ var anotherAccessor = node.kind === 152 ? accessors.setAccessor : accessors.getAccessor;
type = getTypeAnnotationFromAccessor(anotherAccessor);
if (type) {
accessorWithTypeAnnotation = anotherAccessor;
@@ -46535,7 +50389,7 @@ var ts;
}
function getTypeAnnotationFromAccessor(accessor) {
if (accessor) {
- return accessor.kind === 151
+ return accessor.kind === 152
? accessor.type
: accessor.parameters.length > 0
? accessor.parameters[0].type
@@ -46544,7 +50398,7 @@ var ts;
}
function getAccessorDeclarationTypeVisibilityError(symbolAccessibilityResult) {
var diagnosticMessage;
- if (accessorWithTypeAnnotation.kind === 152) {
+ if (accessorWithTypeAnnotation.kind === 153) {
if (ts.hasModifier(accessorWithTypeAnnotation.parent, 32)) {
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Parameter_0_of_public_static_property_setter_from_exported_class_has_or_is_using_name_1_from_private_module_2 :
@@ -46590,17 +50444,17 @@ var ts;
}
if (!resolver.isImplementationOfOverload(node)) {
emitJsDocComments(node);
- if (node.kind === 225) {
+ if (node.kind === 227) {
emitModuleElementDeclarationFlags(node);
}
- else if (node.kind === 149 || node.kind === 150) {
+ else if (node.kind === 150 || node.kind === 151) {
emitClassMemberDeclarationFlags(ts.getModifierFlags(node));
}
- if (node.kind === 225) {
+ if (node.kind === 227) {
write("function ");
writeTextOfNode(currentText, node.name);
}
- else if (node.kind === 150) {
+ else if (node.kind === 151) {
write("constructor");
}
else {
@@ -46620,15 +50474,15 @@ var ts;
var prevEnclosingDeclaration = enclosingDeclaration;
enclosingDeclaration = node;
var closeParenthesizedFunctionType = false;
- if (node.kind === 155) {
+ if (node.kind === 156) {
emitClassMemberDeclarationFlags(ts.getModifierFlags(node));
write("[");
}
else {
- if (node.kind === 154 || node.kind === 159) {
+ if (node.kind === 155 || node.kind === 160) {
write("new ");
}
- else if (node.kind === 158) {
+ else if (node.kind === 159) {
var currentOutput = writer.getText();
if (node.typeParameters && currentOutput.charAt(currentOutput.length - 1) === "<") {
closeParenthesizedFunctionType = true;
@@ -46639,20 +50493,20 @@ var ts;
write("(");
}
emitCommaList(node.parameters, emitParameterDeclaration);
- if (node.kind === 155) {
+ if (node.kind === 156) {
write("]");
}
else {
write(")");
}
- var isFunctionTypeOrConstructorType = node.kind === 158 || node.kind === 159;
- if (isFunctionTypeOrConstructorType || node.parent.kind === 161) {
+ var isFunctionTypeOrConstructorType = node.kind === 159 || node.kind === 160;
+ if (isFunctionTypeOrConstructorType || node.parent.kind === 162) {
if (node.type) {
write(isFunctionTypeOrConstructorType ? " => " : ": ");
emitType(node.type);
}
}
- else if (node.kind !== 150 && !ts.hasModifier(node, 8)) {
+ else if (node.kind !== 151 && !ts.hasModifier(node, 8)) {
writeReturnTypeAtSignature(node, getReturnTypeVisibilityError);
}
enclosingDeclaration = prevEnclosingDeclaration;
@@ -46666,23 +50520,23 @@ var ts;
function getReturnTypeVisibilityError(symbolAccessibilityResult) {
var diagnosticMessage;
switch (node.kind) {
- case 154:
+ case 155:
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 :
ts.Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0;
break;
- case 153:
+ case 154:
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 :
ts.Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0;
break;
- case 155:
+ case 156:
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 :
ts.Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0;
break;
+ case 150:
case 149:
- case 148:
if (ts.hasModifier(node, 32)) {
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
@@ -46690,7 +50544,7 @@ var ts;
ts.Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 :
ts.Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0;
}
- else if (node.parent.kind === 226) {
+ else if (node.parent.kind === 228) {
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named :
@@ -46703,7 +50557,7 @@ var ts;
ts.Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0;
}
break;
- case 225:
+ case 227:
diagnosticMessage = symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named :
@@ -46735,9 +50589,9 @@ var ts;
write("?");
}
decreaseIndent();
- if (node.parent.kind === 158 ||
- node.parent.kind === 159 ||
- node.parent.parent.kind === 161) {
+ if (node.parent.kind === 159 ||
+ node.parent.kind === 160 ||
+ node.parent.parent.kind === 162) {
emitTypeOfVariableDeclarationFromTypeLiteral(node);
}
else if (!ts.hasModifier(node.parent, 8)) {
@@ -46753,22 +50607,26 @@ var ts;
}
function getParameterDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
switch (node.parent.kind) {
- case 150:
+ case 151:
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named :
ts.Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1;
- case 154:
+ case 155:
return symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
- case 153:
+ case 154:
return symbolAccessibilityResult.errorModuleName ?
ts.Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
+ case 156:
+ return symbolAccessibilityResult.errorModuleName ?
+ ts.Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 :
+ ts.Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1;
+ case 150:
case 149:
- case 148:
if (ts.hasModifier(node.parent, 32)) {
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
@@ -46776,7 +50634,7 @@ var ts;
ts.Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
}
- else if (node.parent.parent.kind === 226) {
+ else if (node.parent.parent.kind === 228) {
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named :
@@ -46788,7 +50646,7 @@ var ts;
ts.Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2 :
ts.Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
}
- case 225:
+ case 227:
return symbolAccessibilityResult.errorModuleName ?
symbolAccessibilityResult.accessibility === 2 ?
ts.Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named :
@@ -46799,12 +50657,12 @@ var ts;
}
}
function emitBindingPattern(bindingPattern) {
- if (bindingPattern.kind === 172) {
+ if (bindingPattern.kind === 173) {
write("{");
emitCommaList(bindingPattern.elements, emitBindingElement);
write("}");
}
- else if (bindingPattern.kind === 173) {
+ else if (bindingPattern.kind === 174) {
write("[");
var elements = bindingPattern.elements;
emitCommaList(elements, emitBindingElement);
@@ -46815,10 +50673,10 @@ var ts;
}
}
function emitBindingElement(bindingElement) {
- if (bindingElement.kind === 198) {
+ if (bindingElement.kind === 199) {
write(" ");
}
- else if (bindingElement.kind === 174) {
+ else if (bindingElement.kind === 175) {
if (bindingElement.propertyName) {
writeTextOfNode(currentText, bindingElement.propertyName);
write(": ");
@@ -46840,39 +50698,39 @@ var ts;
}
function emitNode(node) {
switch (node.kind) {
- case 225:
- case 230:
- case 234:
case 227:
- case 226:
- case 228:
+ case 232:
+ case 236:
case 229:
+ case 228:
+ case 230:
+ case 231:
return emitModuleElement(node, isModuleElementVisible(node));
- case 205:
+ case 207:
return emitModuleElement(node, isVariableStatementVisible(node));
- case 235:
+ case 237:
return emitModuleElement(node, !node.importClause);
- case 241:
+ case 243:
return emitExportDeclaration(node);
+ case 151:
case 150:
case 149:
- case 148:
return writeFunctionDeclaration(node);
- case 154:
- case 153:
case 155:
+ case 154:
+ case 156:
return emitSignatureDeclarationWithJsDocComments(node);
- case 151:
case 152:
+ case 153:
return emitAccessorDeclaration(node);
+ case 148:
case 147:
- case 146:
return emitPropertyDeclaration(node);
- case 260:
+ case 263:
return emitEnumMemberDeclaration(node);
- case 240:
+ case 242:
return emitExportAssignment(node);
- case 261:
+ case 264:
return emitSourceFile(node);
}
}
@@ -46883,14 +50741,15 @@ var ts;
declFileName = referencedFile.fileName;
}
else {
- ts.forEachExpectedEmitFile(host, getDeclFileName, referencedFile, emitOnlyDtsFiles);
+ ts.forEachEmittedFile(host, getDeclFileName, referencedFile, emitOnlyDtsFiles);
}
if (declFileName) {
declFileName = ts.getRelativePathToDirectoryOrUrl(ts.getDirectoryPath(ts.normalizeSlashes(declarationFilePath)), declFileName, host.getCurrentDirectory(), host.getCanonicalFileName, false);
referencesOutput += "/// <reference path=\"" + declFileName + "\" />" + newLine;
}
return addedBundledEmitReference;
- function getDeclFileName(emitFileNames, _sourceFiles, isBundledEmit) {
+ function getDeclFileName(emitFileNames, sourceFileOrBundle) {
+ var isBundledEmit = sourceFileOrBundle.kind === 265;
if (isBundledEmit && !addBundledFileReference) {
return;
}
@@ -46900,10 +50759,11 @@ var ts;
}
}
}
- function writeDeclarationFile(declarationFilePath, sourceFiles, isBundledEmit, host, resolver, emitterDiagnostics, emitOnlyDtsFiles) {
- var emitDeclarationResult = emitDeclarations(host, resolver, emitterDiagnostics, declarationFilePath, sourceFiles, isBundledEmit, emitOnlyDtsFiles);
+ function writeDeclarationFile(declarationFilePath, sourceFileOrBundle, host, resolver, emitterDiagnostics, emitOnlyDtsFiles) {
+ var emitDeclarationResult = emitDeclarations(host, resolver, emitterDiagnostics, declarationFilePath, sourceFileOrBundle, emitOnlyDtsFiles);
var emitSkipped = emitDeclarationResult.reportedDeclarationError || host.isEmitBlocked(declarationFilePath) || host.getCompilerOptions().noEmit;
if (!emitSkipped) {
+ var sourceFiles = sourceFileOrBundle.kind === 265 ? sourceFileOrBundle.sourceFiles : [sourceFileOrBundle];
var declarationOutput = emitDeclarationResult.referencesOutput
+ getDeclarationOutput(emitDeclarationResult.synchronousDeclarationOutput, emitDeclarationResult.moduleElementDeclarationEmitInfo);
ts.writeFile(host, emitterDiagnostics, declarationFilePath, declarationOutput, host.getCompilerOptions().emitBOM, sourceFiles);
@@ -46927,63 +50787,55 @@ var ts;
})(ts || (ts = {}));
var ts;
(function (ts) {
- var id = function (s) { return s; };
- var nullTransformers = [function (_) { return id; }];
- function emitFiles(resolver, host, targetSourceFile, emitOnlyDtsFiles) {
- var delimiters = createDelimiterMap();
- var brackets = createBracketsMap();
+ var delimiters = createDelimiterMap();
+ var brackets = createBracketsMap();
+ function emitFiles(resolver, host, targetSourceFile, emitOnlyDtsFiles, transformers) {
var compilerOptions = host.getCompilerOptions();
- var languageVersion = ts.getEmitScriptTarget(compilerOptions);
var moduleKind = ts.getEmitModuleKind(compilerOptions);
var sourceMapDataList = compilerOptions.sourceMap || compilerOptions.inlineSourceMap ? [] : undefined;
var emittedFilesList = compilerOptions.listEmittedFiles ? [] : undefined;
var emitterDiagnostics = ts.createDiagnosticCollection();
var newLine = host.getNewLine();
- var transformers = emitOnlyDtsFiles ? nullTransformers : ts.getTransformers(compilerOptions);
var writer = ts.createTextWriter(newLine);
- var write = writer.write, writeLine = writer.writeLine, increaseIndent = writer.increaseIndent, decreaseIndent = writer.decreaseIndent;
var sourceMap = ts.createSourceMapWriter(host, writer);
- var emitNodeWithSourceMap = sourceMap.emitNodeWithSourceMap, emitTokenWithSourceMap = sourceMap.emitTokenWithSourceMap;
- var comments = ts.createCommentWriter(host, writer, sourceMap);
- var emitNodeWithComments = comments.emitNodeWithComments, emitBodyWithDetachedComments = comments.emitBodyWithDetachedComments, emitTrailingCommentsOfPosition = comments.emitTrailingCommentsOfPosition;
- var nodeIdToGeneratedName;
- var autoGeneratedIdToGeneratedName;
- var generatedNameSet;
- var tempFlags;
var currentSourceFile;
- var currentText;
- var currentFileIdentifiers;
var bundledHelpers;
var isOwnFileEmit;
var emitSkipped = false;
var sourceFiles = ts.getSourceFilesToEmit(host, targetSourceFile);
- ts.performance.mark("beforeTransform");
- var _a = ts.transformFiles(resolver, host, sourceFiles, transformers), transformed = _a.transformed, emitNodeWithSubstitution = _a.emitNodeWithSubstitution, emitNodeWithNotification = _a.emitNodeWithNotification;
- ts.performance.measure("transformTime", "beforeTransform");
+ var transform = ts.transformNodes(resolver, host, compilerOptions, sourceFiles, transformers, false);
+ var printer = createPrinter(compilerOptions, {
+ hasGlobalName: resolver.hasGlobalName,
+ onEmitNode: transform.emitNodeWithNotification,
+ substituteNode: transform.substituteNode,
+ onEmitSourceMapOfNode: sourceMap.emitNodeWithSourceMap,
+ onEmitSourceMapOfToken: sourceMap.emitTokenWithSourceMap,
+ onEmitSourceMapOfPosition: sourceMap.emitPos,
+ onEmitHelpers: emitHelpers,
+ onSetSourceFile: setSourceFile,
+ });
ts.performance.mark("beforePrint");
- ts.forEachTransformedEmitFile(host, transformed, emitFile, emitOnlyDtsFiles);
+ ts.forEachEmittedFile(host, emitSourceFileOrBundle, transform.transformed, emitOnlyDtsFiles);
ts.performance.measure("printTime", "beforePrint");
- for (var _b = 0, sourceFiles_4 = sourceFiles; _b < sourceFiles_4.length; _b++) {
- var sourceFile = sourceFiles_4[_b];
- ts.disposeEmitNodes(sourceFile);
- }
+ transform.dispose();
return {
emitSkipped: emitSkipped,
diagnostics: emitterDiagnostics.getDiagnostics(),
emittedFiles: emittedFilesList,
sourceMaps: sourceMapDataList
};
- function emitFile(jsFilePath, sourceMapFilePath, declarationFilePath, sourceFiles, isBundledEmit) {
+ function emitSourceFileOrBundle(_a, sourceFileOrBundle) {
+ var jsFilePath = _a.jsFilePath, sourceMapFilePath = _a.sourceMapFilePath, declarationFilePath = _a.declarationFilePath;
if (!host.isEmitBlocked(jsFilePath) && !compilerOptions.noEmit) {
if (!emitOnlyDtsFiles) {
- printFile(jsFilePath, sourceMapFilePath, sourceFiles, isBundledEmit);
+ printSourceFileOrBundle(jsFilePath, sourceMapFilePath, sourceFileOrBundle);
}
}
else {
emitSkipped = true;
}
if (declarationFilePath) {
- emitSkipped = ts.writeDeclarationFile(declarationFilePath, ts.getOriginalSourceFiles(sourceFiles), isBundledEmit, host, resolver, emitterDiagnostics, emitOnlyDtsFiles) || emitSkipped;
+ emitSkipped = ts.writeDeclarationFile(declarationFilePath, ts.getOriginalSourceFileOrBundle(sourceFileOrBundle), host, resolver, emitterDiagnostics, emitOnlyDtsFiles) || emitSkipped;
}
if (!emitSkipped && emittedFilesList) {
if (!emitOnlyDtsFiles) {
@@ -46997,24 +50849,24 @@ var ts;
}
}
}
- function printFile(jsFilePath, sourceMapFilePath, sourceFiles, isBundledEmit) {
- sourceMap.initialize(jsFilePath, sourceMapFilePath, sourceFiles, isBundledEmit);
- nodeIdToGeneratedName = [];
- autoGeneratedIdToGeneratedName = [];
- generatedNameSet = ts.createMap();
- bundledHelpers = isBundledEmit ? ts.createMap() : undefined;
- isOwnFileEmit = !isBundledEmit;
- if (isBundledEmit && moduleKind) {
- for (var _a = 0, sourceFiles_5 = sourceFiles; _a < sourceFiles_5.length; _a++) {
- var sourceFile = sourceFiles_5[_a];
- emitHelpers(sourceFile, true);
- }
+ function printSourceFileOrBundle(jsFilePath, sourceMapFilePath, sourceFileOrBundle) {
+ var bundle = sourceFileOrBundle.kind === 265 ? sourceFileOrBundle : undefined;
+ var sourceFile = sourceFileOrBundle.kind === 264 ? sourceFileOrBundle : undefined;
+ var sourceFiles = bundle ? bundle.sourceFiles : [sourceFile];
+ sourceMap.initialize(jsFilePath, sourceMapFilePath, sourceFileOrBundle);
+ if (bundle) {
+ bundledHelpers = ts.createMap();
+ isOwnFileEmit = false;
+ printer.writeBundle(bundle, writer);
}
- ts.forEach(sourceFiles, printSourceFile);
- writeLine();
+ else {
+ isOwnFileEmit = true;
+ printer.writeFile(sourceFile, writer);
+ }
+ writer.writeLine();
var sourceMappingURL = sourceMap.getSourceMappingURL();
if (sourceMappingURL) {
- write("//# " + "sourceMappingURL" + "=" + sourceMappingURL);
+ writer.write("//# " + "sourceMappingURL" + "=" + sourceMappingURL);
}
if (compilerOptions.sourceMap && !compilerOptions.inlineSourceMap) {
ts.writeFile(host, emitterDiagnostics, sourceMapFilePath, sourceMap.getText(), false, sourceFiles);
@@ -47024,20 +50876,164 @@ var ts;
}
ts.writeFile(host, emitterDiagnostics, jsFilePath, writer.getText(), compilerOptions.emitBOM, sourceFiles);
sourceMap.reset();
- comments.reset();
writer.reset();
- tempFlags = 0;
currentSourceFile = undefined;
- currentText = undefined;
+ bundledHelpers = undefined;
isOwnFileEmit = false;
}
- function printSourceFile(node) {
+ function setSourceFile(node) {
currentSourceFile = node;
- currentText = node.text;
- currentFileIdentifiers = node.identifiers;
sourceMap.setSourceFile(node);
- comments.setSourceFile(node);
- pipelineEmitWithNotification(0, node);
+ }
+ function emitHelpers(node, writeLines) {
+ var helpersEmitted = false;
+ var bundle = node.kind === 265 ? node : undefined;
+ if (bundle && moduleKind === ts.ModuleKind.None) {
+ return;
+ }
+ var numNodes = bundle ? bundle.sourceFiles.length : 1;
+ for (var i = 0; i < numNodes; i++) {
+ var currentNode = bundle ? bundle.sourceFiles[i] : node;
+ var sourceFile = ts.isSourceFile(currentNode) ? currentNode : currentSourceFile;
+ var shouldSkip = compilerOptions.noEmitHelpers || (sourceFile && ts.getExternalHelpersModuleName(sourceFile) !== undefined);
+ var shouldBundle = ts.isSourceFile(currentNode) && !isOwnFileEmit;
+ var helpers = ts.getEmitHelpers(currentNode);
+ if (helpers) {
+ for (var _a = 0, _b = ts.stableSort(helpers, ts.compareEmitHelpers); _a < _b.length; _a++) {
+ var helper = _b[_a];
+ if (!helper.scoped) {
+ if (shouldSkip)
+ continue;
+ if (shouldBundle) {
+ if (bundledHelpers.get(helper.name)) {
+ continue;
+ }
+ bundledHelpers.set(helper.name, true);
+ }
+ }
+ else if (bundle) {
+ continue;
+ }
+ writeLines(helper.text);
+ helpersEmitted = true;
+ }
+ }
+ }
+ return helpersEmitted;
+ }
+ }
+ ts.emitFiles = emitFiles;
+ function createPrinter(printerOptions, handlers) {
+ if (printerOptions === void 0) { printerOptions = {}; }
+ if (handlers === void 0) { handlers = {}; }
+ var hasGlobalName = handlers.hasGlobalName, onEmitSourceMapOfNode = handlers.onEmitSourceMapOfNode, onEmitSourceMapOfToken = handlers.onEmitSourceMapOfToken, onEmitSourceMapOfPosition = handlers.onEmitSourceMapOfPosition, onEmitNode = handlers.onEmitNode, onEmitHelpers = handlers.onEmitHelpers, onSetSourceFile = handlers.onSetSourceFile, substituteNode = handlers.substituteNode, onBeforeEmitNodeArray = handlers.onBeforeEmitNodeArray, onAfterEmitNodeArray = handlers.onAfterEmitNodeArray;
+ var newLine = ts.getNewLineCharacter(printerOptions);
+ var comments = ts.createCommentWriter(printerOptions, onEmitSourceMapOfPosition);
+ var emitNodeWithComments = comments.emitNodeWithComments, emitBodyWithDetachedComments = comments.emitBodyWithDetachedComments, emitTrailingCommentsOfPosition = comments.emitTrailingCommentsOfPosition, emitLeadingCommentsOfPosition = comments.emitLeadingCommentsOfPosition;
+ var currentSourceFile;
+ var nodeIdToGeneratedName;
+ var autoGeneratedIdToGeneratedName;
+ var generatedNames;
+ var tempFlagsStack;
+ var tempFlags;
+ var writer;
+ var ownWriter;
+ reset();
+ return {
+ printNode: printNode,
+ printFile: printFile,
+ printBundle: printBundle,
+ writeNode: writeNode,
+ writeFile: writeFile,
+ writeBundle: writeBundle
+ };
+ function printNode(hint, node, sourceFile) {
+ switch (hint) {
+ case 0:
+ ts.Debug.assert(ts.isSourceFile(node), "Expected a SourceFile node.");
+ break;
+ case 2:
+ ts.Debug.assert(ts.isIdentifier(node), "Expected an Identifier node.");
+ break;
+ case 1:
+ ts.Debug.assert(ts.isExpression(node), "Expected an Expression node.");
+ break;
+ }
+ switch (node.kind) {
+ case 264: return printFile(node);
+ case 265: return printBundle(node);
+ }
+ writeNode(hint, node, sourceFile, beginPrint());
+ return endPrint();
+ }
+ function printBundle(bundle) {
+ writeBundle(bundle, beginPrint());
+ return endPrint();
+ }
+ function printFile(sourceFile) {
+ writeFile(sourceFile, beginPrint());
+ return endPrint();
+ }
+ function writeNode(hint, node, sourceFile, output) {
+ var previousWriter = writer;
+ setWriter(output);
+ print(hint, node, sourceFile);
+ reset();
+ writer = previousWriter;
+ }
+ function writeBundle(bundle, output) {
+ var previousWriter = writer;
+ setWriter(output);
+ emitShebangIfNeeded(bundle);
+ emitPrologueDirectivesIfNeeded(bundle);
+ emitHelpersIndirect(bundle);
+ for (var _a = 0, _b = bundle.sourceFiles; _a < _b.length; _a++) {
+ var sourceFile = _b[_a];
+ print(0, sourceFile, sourceFile);
+ }
+ reset();
+ writer = previousWriter;
+ }
+ function writeFile(sourceFile, output) {
+ var previousWriter = writer;
+ setWriter(output);
+ emitShebangIfNeeded(sourceFile);
+ emitPrologueDirectivesIfNeeded(sourceFile);
+ print(0, sourceFile, sourceFile);
+ reset();
+ writer = previousWriter;
+ }
+ function beginPrint() {
+ return ownWriter || (ownWriter = ts.createTextWriter(newLine));
+ }
+ function endPrint() {
+ var text = ownWriter.getText();
+ ownWriter.reset();
+ return text;
+ }
+ function print(hint, node, sourceFile) {
+ setSourceFile(sourceFile);
+ pipelineEmitWithNotification(hint, node);
+ }
+ function setSourceFile(sourceFile) {
+ currentSourceFile = sourceFile;
+ comments.setSourceFile(sourceFile);
+ if (onSetSourceFile) {
+ onSetSourceFile(sourceFile);
+ }
+ }
+ function setWriter(output) {
+ writer = output;
+ comments.setWriter(output);
+ }
+ function reset() {
+ nodeIdToGeneratedName = [];
+ autoGeneratedIdToGeneratedName = [];
+ generatedNames = ts.createMap();
+ tempFlagsStack = [];
+ tempFlags = 0;
+ comments.reset();
+ setWriter(undefined);
}
function emit(node) {
pipelineEmitWithNotification(3, node);
@@ -47048,51 +51044,53 @@ var ts;
function emitExpression(node) {
pipelineEmitWithNotification(1, node);
}
- function pipelineEmitWithNotification(emitContext, node) {
- emitNodeWithNotification(emitContext, node, pipelineEmitWithComments);
- }
- function pipelineEmitWithComments(emitContext, node) {
- if (emitContext === 0) {
- pipelineEmitWithSourceMap(emitContext, node);
- return;
+ function pipelineEmitWithNotification(hint, node) {
+ if (onEmitNode) {
+ onEmitNode(hint, node, pipelineEmitWithComments);
}
- emitNodeWithComments(emitContext, node, pipelineEmitWithSourceMap);
- }
- function pipelineEmitWithSourceMap(emitContext, node) {
- if (emitContext === 0
- || emitContext === 2) {
- pipelineEmitWithSubstitution(emitContext, node);
- return;
+ else {
+ pipelineEmitWithComments(hint, node);
}
- emitNodeWithSourceMap(emitContext, node, pipelineEmitWithSubstitution);
- }
- function pipelineEmitWithSubstitution(emitContext, node) {
- emitNodeWithSubstitution(emitContext, node, pipelineEmitForContext);
}
- function pipelineEmitForContext(emitContext, node) {
- switch (emitContext) {
- case 0: return pipelineEmitInSourceFileContext(node);
- case 2: return pipelineEmitInIdentifierNameContext(node);
- case 3: return pipelineEmitInUnspecifiedContext(node);
- case 1: return pipelineEmitInExpressionContext(node);
+ function pipelineEmitWithComments(hint, node) {
+ node = trySubstituteNode(hint, node);
+ if (emitNodeWithComments && hint !== 0) {
+ emitNodeWithComments(hint, node, pipelineEmitWithSourceMap);
+ }
+ else {
+ pipelineEmitWithSourceMap(hint, node);
}
}
- function pipelineEmitInSourceFileContext(node) {
- var kind = node.kind;
- switch (kind) {
- case 261:
- return emitSourceFile(node);
+ function pipelineEmitWithSourceMap(hint, node) {
+ if (onEmitSourceMapOfNode && hint !== 0 && hint !== 2) {
+ onEmitSourceMapOfNode(hint, node, pipelineEmitWithHint);
+ }
+ else {
+ pipelineEmitWithHint(hint, node);
}
}
- function pipelineEmitInIdentifierNameContext(node) {
- var kind = node.kind;
- switch (kind) {
- case 70:
- return emitIdentifier(node);
+ function pipelineEmitWithHint(hint, node) {
+ switch (hint) {
+ case 0: return pipelineEmitSourceFile(node);
+ case 2: return pipelineEmitIdentifierName(node);
+ case 1: return pipelineEmitExpression(node);
+ case 3: return pipelineEmitUnspecified(node);
}
}
- function pipelineEmitInUnspecifiedContext(node) {
+ function pipelineEmitSourceFile(node) {
+ ts.Debug.assertNode(node, ts.isSourceFile);
+ emitSourceFile(node);
+ }
+ function pipelineEmitIdentifierName(node) {
+ ts.Debug.assertNode(node, ts.isIdentifier);
+ emitIdentifier(node);
+ }
+ function pipelineEmitUnspecified(node) {
var kind = node.kind;
+ if (ts.isKeyword(kind)) {
+ writeTokenText(kind);
+ return;
+ }
switch (kind) {
case 13:
case 14:
@@ -47100,229 +51098,201 @@ var ts;
return emitLiteral(node);
case 70:
return emitIdentifier(node);
- case 75:
- case 78:
- case 83:
- case 104:
- case 111:
- case 112:
- case 113:
- case 114:
- case 116:
- case 117:
- case 118:
- case 119:
- case 120:
- case 121:
- case 122:
- case 123:
- case 124:
- case 125:
- case 127:
- case 128:
- case 129:
- case 130:
- case 131:
- case 132:
- case 133:
- case 134:
- case 135:
- case 136:
- case 137:
- case 138:
- case 139:
- case 140:
- writeTokenText(kind);
- return;
- case 141:
- return emitQualifiedName(node);
case 142:
- return emitComputedPropertyName(node);
+ return emitQualifiedName(node);
case 143:
- return emitTypeParameter(node);
+ return emitComputedPropertyName(node);
case 144:
- return emitParameter(node);
+ return emitTypeParameter(node);
case 145:
- return emitDecorator(node);
+ return emitParameter(node);
case 146:
- return emitPropertySignature(node);
+ return emitDecorator(node);
case 147:
- return emitPropertyDeclaration(node);
+ return emitPropertySignature(node);
case 148:
- return emitMethodSignature(node);
+ return emitPropertyDeclaration(node);
case 149:
- return emitMethodDeclaration(node);
+ return emitMethodSignature(node);
case 150:
- return emitConstructor(node);
+ return emitMethodDeclaration(node);
case 151:
+ return emitConstructor(node);
case 152:
- return emitAccessorDeclaration(node);
case 153:
- return emitCallSignature(node);
+ return emitAccessorDeclaration(node);
case 154:
- return emitConstructSignature(node);
+ return emitCallSignature(node);
case 155:
- return emitIndexSignature(node);
+ return emitConstructSignature(node);
case 156:
- return emitTypePredicate(node);
+ return emitIndexSignature(node);
case 157:
- return emitTypeReference(node);
+ return emitTypePredicate(node);
case 158:
- return emitFunctionType(node);
+ return emitTypeReference(node);
case 159:
- return emitConstructorType(node);
+ return emitFunctionType(node);
case 160:
- return emitTypeQuery(node);
+ return emitConstructorType(node);
case 161:
- return emitTypeLiteral(node);
+ return emitTypeQuery(node);
case 162:
- return emitArrayType(node);
+ return emitTypeLiteral(node);
case 163:
- return emitTupleType(node);
+ return emitArrayType(node);
case 164:
- return emitUnionType(node);
+ return emitTupleType(node);
case 165:
- return emitIntersectionType(node);
+ return emitUnionType(node);
case 166:
+ return emitIntersectionType(node);
+ case 167:
return emitParenthesizedType(node);
- case 199:
+ case 200:
return emitExpressionWithTypeArguments(node);
- case 167:
- return emitThisType();
case 168:
- return emitTypeOperator(node);
+ return emitThisType();
case 169:
- return emitIndexedAccessType(node);
+ return emitTypeOperator(node);
case 170:
- return emitMappedType(node);
+ return emitIndexedAccessType(node);
case 171:
- return emitLiteralType(node);
+ return emitMappedType(node);
case 172:
- return emitObjectBindingPattern(node);
+ return emitLiteralType(node);
case 173:
- return emitArrayBindingPattern(node);
+ return emitObjectBindingPattern(node);
case 174:
+ return emitArrayBindingPattern(node);
+ case 175:
return emitBindingElement(node);
- case 202:
+ case 204:
return emitTemplateSpan(node);
- case 203:
+ case 205:
return emitSemicolonClassElement();
- case 204:
+ case 206:
return emitBlock(node);
- case 205:
+ case 207:
return emitVariableStatement(node);
- case 206:
+ case 208:
return emitEmptyStatement();
- case 207:
+ case 209:
return emitExpressionStatement(node);
- case 208:
+ case 210:
return emitIfStatement(node);
- case 209:
+ case 211:
return emitDoStatement(node);
- case 210:
+ case 212:
return emitWhileStatement(node);
- case 211:
+ case 213:
return emitForStatement(node);
- case 212:
+ case 214:
return emitForInStatement(node);
- case 213:
+ case 215:
return emitForOfStatement(node);
- case 214:
+ case 216:
return emitContinueStatement(node);
- case 215:
+ case 217:
return emitBreakStatement(node);
- case 216:
+ case 218:
return emitReturnStatement(node);
- case 217:
+ case 219:
return emitWithStatement(node);
- case 218:
+ case 220:
return emitSwitchStatement(node);
- case 219:
+ case 221:
return emitLabeledStatement(node);
- case 220:
+ case 222:
return emitThrowStatement(node);
- case 221:
+ case 223:
return emitTryStatement(node);
- case 222:
+ case 224:
return emitDebuggerStatement(node);
- case 223:
+ case 225:
return emitVariableDeclaration(node);
- case 224:
+ case 226:
return emitVariableDeclarationList(node);
- case 225:
+ case 227:
return emitFunctionDeclaration(node);
- case 226:
+ case 228:
return emitClassDeclaration(node);
- case 227:
+ case 229:
return emitInterfaceDeclaration(node);
- case 228:
+ case 230:
return emitTypeAliasDeclaration(node);
- case 229:
+ case 231:
return emitEnumDeclaration(node);
- case 230:
+ case 232:
return emitModuleDeclaration(node);
- case 231:
+ case 233:
return emitModuleBlock(node);
- case 232:
- return emitCaseBlock(node);
case 234:
+ return emitCaseBlock(node);
+ case 236:
return emitImportEqualsDeclaration(node);
- case 235:
+ case 237:
return emitImportDeclaration(node);
- case 236:
+ case 238:
return emitImportClause(node);
- case 237:
+ case 239:
return emitNamespaceImport(node);
- case 238:
+ case 240:
return emitNamedImports(node);
- case 239:
+ case 241:
return emitImportSpecifier(node);
- case 240:
+ case 242:
return emitExportAssignment(node);
- case 241:
+ case 243:
return emitExportDeclaration(node);
- case 242:
+ case 244:
return emitNamedExports(node);
- case 243:
+ case 245:
return emitExportSpecifier(node);
- case 244:
+ case 246:
return;
- case 245:
+ case 247:
return emitExternalModuleReference(node);
case 10:
return emitJsxText(node);
- case 248:
+ case 250:
return emitJsxOpeningElement(node);
- case 249:
+ case 251:
return emitJsxClosingElement(node);
- case 250:
+ case 252:
return emitJsxAttribute(node);
- case 251:
+ case 253:
+ return emitJsxAttributes(node);
+ case 254:
return emitJsxSpreadAttribute(node);
- case 252:
+ case 255:
return emitJsxExpression(node);
- case 253:
+ case 256:
return emitCaseClause(node);
- case 254:
+ case 257:
return emitDefaultClause(node);
- case 255:
+ case 258:
return emitHeritageClause(node);
- case 256:
+ case 259:
return emitCatchClause(node);
- case 257:
+ case 260:
return emitPropertyAssignment(node);
- case 258:
+ case 261:
return emitShorthandPropertyAssignment(node);
- case 259:
+ case 262:
return emitSpreadAssignment(node);
- case 260:
+ case 263:
return emitEnumMember(node);
}
if (ts.isExpression(node)) {
- return pipelineEmitWithSubstitution(1, node);
+ return pipelineEmitExpression(trySubstituteNode(1, node));
+ }
+ if (ts.isToken(node)) {
+ writeTokenText(kind);
+ return;
}
}
- function pipelineEmitInExpressionContext(node) {
+ function pipelineEmitExpression(node) {
var kind = node.kind;
switch (kind) {
case 8:
@@ -47340,77 +51310,82 @@ var ts;
case 98:
writeTokenText(kind);
return;
- case 175:
- return emitArrayLiteralExpression(node);
case 176:
- return emitObjectLiteralExpression(node);
+ return emitArrayLiteralExpression(node);
case 177:
- return emitPropertyAccessExpression(node);
+ return emitObjectLiteralExpression(node);
case 178:
- return emitElementAccessExpression(node);
+ return emitPropertyAccessExpression(node);
case 179:
- return emitCallExpression(node);
+ return emitElementAccessExpression(node);
case 180:
- return emitNewExpression(node);
+ return emitCallExpression(node);
case 181:
- return emitTaggedTemplateExpression(node);
+ return emitNewExpression(node);
case 182:
- return emitTypeAssertionExpression(node);
+ return emitTaggedTemplateExpression(node);
case 183:
- return emitParenthesizedExpression(node);
+ return emitTypeAssertionExpression(node);
case 184:
- return emitFunctionExpression(node);
+ return emitParenthesizedExpression(node);
case 185:
- return emitArrowFunction(node);
+ return emitFunctionExpression(node);
case 186:
- return emitDeleteExpression(node);
+ return emitArrowFunction(node);
case 187:
- return emitTypeOfExpression(node);
+ return emitDeleteExpression(node);
case 188:
- return emitVoidExpression(node);
+ return emitTypeOfExpression(node);
case 189:
- return emitAwaitExpression(node);
+ return emitVoidExpression(node);
case 190:
- return emitPrefixUnaryExpression(node);
+ return emitAwaitExpression(node);
case 191:
- return emitPostfixUnaryExpression(node);
+ return emitPrefixUnaryExpression(node);
case 192:
- return emitBinaryExpression(node);
+ return emitPostfixUnaryExpression(node);
case 193:
- return emitConditionalExpression(node);
+ return emitBinaryExpression(node);
case 194:
- return emitTemplateExpression(node);
+ return emitConditionalExpression(node);
case 195:
- return emitYieldExpression(node);
+ return emitTemplateExpression(node);
case 196:
- return emitSpreadExpression(node);
+ return emitYieldExpression(node);
case 197:
- return emitClassExpression(node);
+ return emitSpreadExpression(node);
case 198:
+ return emitClassExpression(node);
+ case 199:
return;
- case 200:
- return emitAsExpression(node);
case 201:
+ return emitAsExpression(node);
+ case 202:
return emitNonNullExpression(node);
- case 246:
+ case 203:
+ return emitMetaProperty(node);
+ case 248:
return emitJsxElement(node);
- case 247:
+ case 249:
return emitJsxSelfClosingElement(node);
- case 294:
+ case 295:
return emitPartiallyEmittedExpression(node);
- case 297:
- return writeLines(node.text);
+ }
+ }
+ function trySubstituteNode(hint, node) {
+ return node && substituteNode && substituteNode(hint, node) || node;
+ }
+ function emitHelpersIndirect(node) {
+ if (onEmitHelpers) {
+ onEmitHelpers(node, writeLines);
}
}
function emitNumericLiteral(node) {
emitLiteral(node);
- if (node.trailingComment) {
- write(" /*" + node.trailingComment + "*/");
- }
}
function emitLiteral(node) {
var text = getLiteralTextOfNode(node);
- if ((compilerOptions.sourceMap || compilerOptions.inlineSourceMap)
+ if ((printerOptions.sourceMap || printerOptions.inlineSourceMap)
&& (node.kind === 9 || ts.isTemplateLiteralKind(node.kind))) {
writer.writeLiteral(text);
}
@@ -47449,8 +51424,8 @@ var ts;
writeIfPresent(node.dotDotDotToken, "...");
emit(node.name);
writeIfPresent(node.questionToken, "?");
- emitExpressionWithPrefix(" = ", node.initializer);
emitWithPrefix(": ", node.type);
+ emitExpressionWithPrefix(" = ", node.initializer);
}
function emitDecorator(decorator) {
write("@");
@@ -47497,7 +51472,7 @@ var ts;
function emitAccessorDeclaration(node) {
emitDecorators(node, node.decorators);
emitModifiers(node, node.modifiers);
- write(node.kind === 151 ? "get " : "set ");
+ write(node.kind === 152 ? "get " : "set ");
emit(node.name);
emitSignatureAndBody(node, emitSignatureHead);
}
@@ -47597,17 +51572,13 @@ var ts;
write("{");
writeLine();
increaseIndent();
- if (node.readonlyToken) {
- write("readonly ");
- }
+ writeIfPresent(node.readonlyToken, "readonly ");
write("[");
emit(node.typeParameter.name);
write(" in ");
emit(node.typeParameter.constraint);
write("]");
- if (node.questionToken) {
- write("?");
- }
+ writeIfPresent(node.questionToken, "?");
write(": ");
emit(node.type);
write(";");
@@ -47667,7 +51638,7 @@ var ts;
increaseIndent();
}
var preferNewLine = node.multiLine ? 32768 : 0;
- var allowTrailingComma = languageVersion >= 1 ? 32 : 0;
+ var allowTrailingComma = currentSourceFile.languageVersion >= 1 ? 32 : 0;
emitList(node, properties, 978 | allowTrailingComma | preferNewLine);
if (indentedFlag) {
decreaseIndent();
@@ -47679,7 +51650,7 @@ var ts;
var indentAfterDot = false;
if (!(ts.getEmitFlags(node) & 65536)) {
var dotRangeStart = node.expression.end;
- var dotRangeEnd = ts.skipTrivia(currentText, node.expression.end) + 1;
+ var dotRangeEnd = ts.skipTrivia(currentSourceFile.text, node.expression.end) + 1;
var dotToken = { kind: 22, pos: dotRangeStart, end: dotRangeEnd };
indentBeforeDot = needsIndentation(node, node.expression, dotToken);
indentAfterDot = needsIndentation(node, dotToken, node.name);
@@ -47693,15 +51664,17 @@ var ts;
decreaseIndentIf(indentBeforeDot, indentAfterDot);
}
function needsDotDotForPropertyAccess(expression) {
- if (expression.kind === 8) {
+ expression = ts.skipPartiallyEmittedExpressions(expression);
+ if (ts.isNumericLiteral(expression)) {
var text = getLiteralTextOfNode(expression);
- return text.indexOf(ts.tokenToString(22)) < 0;
+ return !expression.numericLiteralFlags
+ && text.indexOf(ts.tokenToString(22)) < 0;
}
else if (ts.isPropertyAccessExpression(expression) || ts.isElementAccessExpression(expression)) {
var constantValue = ts.getConstantValue(expression);
return isFinite(constantValue)
&& Math.floor(constantValue) === constantValue
- && compilerOptions.removeComments;
+ && printerOptions.removeComments;
}
}
function emitElementAccessExpression(node) {
@@ -47727,11 +51700,9 @@ var ts;
emitExpression(node.template);
}
function emitTypeAssertionExpression(node) {
- if (node.type) {
- write("<");
- emit(node.type);
- write(">");
- }
+ write("<");
+ emit(node.type);
+ write(">");
emitExpression(node.expression);
}
function emitParenthesizedExpression(node) {
@@ -47778,7 +51749,7 @@ var ts;
}
function shouldEmitWhitespaceBeforeOperand(node) {
var operand = node.operand;
- return operand.kind === 190
+ return operand.kind === 191
&& ((node.operator === 36 && (operand.operator === 36 || operand.operator === 42))
|| (node.operator === 37 && (operand.operator === 37 || operand.operator === 43)));
}
@@ -47844,6 +51815,11 @@ var ts;
emitExpression(node.expression);
write("!");
}
+ function emitMetaProperty(node) {
+ writeToken(node.keywordToken, node.pos);
+ write(".");
+ emit(node.name);
+ }
function emitTemplateSpan(node) {
emitExpression(node.expression);
emit(node.literal);
@@ -47857,6 +51833,9 @@ var ts;
else {
writeToken(16, node.pos, node);
emitBlockStatements(node);
+ increaseIndent();
+ emitLeadingCommentsOfPosition(node.statements.end);
+ decreaseIndent();
writeToken(17, node.statements.end, node);
}
}
@@ -47886,27 +51865,27 @@ var ts;
writeToken(18, openParenPos, node);
emitExpression(node.expression);
writeToken(19, node.expression.end, node);
- emitEmbeddedStatement(node.thenStatement);
+ emitEmbeddedStatement(node, node.thenStatement);
if (node.elseStatement) {
- writeLine();
+ writeLineOrSpace(node);
writeToken(81, node.thenStatement.end, node);
- if (node.elseStatement.kind === 208) {
+ if (node.elseStatement.kind === 210) {
write(" ");
emit(node.elseStatement);
}
else {
- emitEmbeddedStatement(node.elseStatement);
+ emitEmbeddedStatement(node, node.elseStatement);
}
}
}
function emitDoStatement(node) {
write("do");
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
if (ts.isBlock(node.statement)) {
write(" ");
}
else {
- writeLine();
+ writeLineOrSpace(node);
}
write("while (");
emitExpression(node.expression);
@@ -47916,7 +51895,7 @@ var ts;
write("while (");
emitExpression(node.expression);
write(")");
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
}
function emitForStatement(node) {
var openParenPos = writeToken(87, node.pos);
@@ -47928,7 +51907,7 @@ var ts;
write(";");
emitExpressionWithPrefix(" ", node.incrementor);
write(")");
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
}
function emitForInStatement(node) {
var openParenPos = writeToken(87, node.pos);
@@ -47938,21 +51917,22 @@ var ts;
write(" in ");
emitExpression(node.expression);
writeToken(19, node.expression.end);
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
}
function emitForOfStatement(node) {
var openParenPos = writeToken(87, node.pos);
write(" ");
+ emitWithSuffix(node.awaitModifier, " ");
writeToken(18, openParenPos);
emitForBinding(node.initializer);
write(" of ");
emitExpression(node.expression);
writeToken(19, node.expression.end);
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
}
function emitForBinding(node) {
if (node !== undefined) {
- if (node.kind === 224) {
+ if (node.kind === 226) {
emit(node);
}
else {
@@ -47979,7 +51959,7 @@ var ts;
write("with (");
emitExpression(node.expression);
write(")");
- emitEmbeddedStatement(node.statement);
+ emitEmbeddedStatement(node, node.statement);
}
function emitSwitchStatement(node) {
var openParenPos = writeToken(97, node.pos);
@@ -48003,9 +51983,12 @@ var ts;
function emitTryStatement(node) {
write("try ");
emit(node.tryBlock);
- emit(node.catchClause);
+ if (node.catchClause) {
+ writeLineOrSpace(node);
+ emit(node.catchClause);
+ }
if (node.finallyBlock) {
- writeLine();
+ writeLineOrSpace(node);
write("finally ");
emit(node.finallyBlock);
}
@@ -48033,6 +52016,9 @@ var ts;
emitIdentifierName(node.name);
emitSignatureAndBody(node, emitSignatureHead);
}
+ function emitBlockCallback(_hint, body) {
+ emitBlockFunctionBody(body);
+ }
function emitSignatureAndBody(node, emitSignatureHead) {
var body = node.body;
if (body) {
@@ -48043,14 +52029,23 @@ var ts;
}
if (ts.getEmitFlags(node) & 262144) {
emitSignatureHead(node);
- emitBlockFunctionBody(body);
+ if (onEmitNode) {
+ onEmitNode(3, body, emitBlockCallback);
+ }
+ else {
+ emitBlockFunctionBody(body);
+ }
}
else {
- var savedTempFlags = tempFlags;
- tempFlags = 0;
+ pushNameGenerationScope();
emitSignatureHead(node);
- emitBlockFunctionBody(body);
- tempFlags = savedTempFlags;
+ if (onEmitNode) {
+ onEmitNode(3, body, emitBlockCallback);
+ }
+ else {
+ emitBlockFunctionBody(body);
+ }
+ popNameGenerationScope();
}
if (indentedFlag) {
decreaseIndent();
@@ -48099,9 +52094,15 @@ var ts;
function emitBlockFunctionBody(body) {
write(" {");
increaseIndent();
- emitBodyWithDetachedComments(body, body.statements, shouldEmitBlockFunctionBodyOnSingleLine(body)
+ var emitBlockFunctionBody = shouldEmitBlockFunctionBodyOnSingleLine(body)
? emitBlockFunctionBodyOnSingleLine
- : emitBlockFunctionBodyWorker);
+ : emitBlockFunctionBodyWorker;
+ if (emitBodyWithDetachedComments) {
+ emitBodyWithDetachedComments(body, body.statements, emitBlockFunctionBody);
+ }
+ else {
+ emitBlockFunctionBody(body);
+ }
decreaseIndent();
writeToken(17, body.statements.end, body);
}
@@ -48110,8 +52111,9 @@ var ts;
}
function emitBlockFunctionBodyWorker(body, emitBlockFunctionBodyOnSingleLine) {
var statementOffset = emitPrologueDirectives(body.statements, true);
- var helpersEmitted = emitHelpers(body);
- if (statementOffset === 0 && !helpersEmitted && emitBlockFunctionBodyOnSingleLine) {
+ var pos = writer.getTextPos();
+ emitHelpersIndirect(body);
+ if (statementOffset === 0 && pos === writer.getTextPos() && emitBlockFunctionBodyOnSingleLine) {
decreaseIndent();
emitList(body, body.statements, 384);
increaseIndent();
@@ -48134,15 +52136,14 @@ var ts;
}
emitTypeParameters(node, node.typeParameters);
emitList(node, node.heritageClauses, 256);
- var savedTempFlags = tempFlags;
- tempFlags = 0;
+ pushNameGenerationScope();
write(" {");
emitList(node, node.members, 65);
write("}");
+ popNameGenerationScope();
if (indentedFlag) {
decreaseIndent();
}
- tempFlags = savedTempFlags;
}
function emitInterfaceDeclaration(node) {
emitDecorators(node, node.decorators);
@@ -48169,19 +52170,18 @@ var ts;
emitModifiers(node, node.modifiers);
write("enum ");
emit(node.name);
- var savedTempFlags = tempFlags;
- tempFlags = 0;
+ pushNameGenerationScope();
write(" {");
emitList(node, node.members, 81);
write("}");
- tempFlags = savedTempFlags;
+ popNameGenerationScope();
}
function emitModuleDeclaration(node) {
emitModifiers(node, node.modifiers);
write(node.flags & 16 ? "namespace " : "module ");
emit(node.name);
var body = node.body;
- while (body.kind === 230) {
+ while (body.kind === 232) {
write(".");
emit(body.name);
body = body.body;
@@ -48194,13 +52194,11 @@ var ts;
write("{ }");
}
else {
- var savedTempFlags = tempFlags;
- tempFlags = 0;
+ pushNameGenerationScope();
write("{");
- increaseIndent();
emitBlockStatements(node);
write("}");
- tempFlags = savedTempFlags;
+ popNameGenerationScope();
}
}
function emitCaseBlock(node) {
@@ -48302,14 +52300,18 @@ var ts;
write("<");
emitJsxTagName(node.tagName);
write(" ");
- emitList(node, node.attributes, 131328);
+ if (node.attributes.properties && node.attributes.properties.length > 0) {
+ emit(node.attributes);
+ }
write("/>");
}
function emitJsxOpeningElement(node) {
write("<");
emitJsxTagName(node.tagName);
- writeIfAny(node.attributes, " ");
- emitList(node, node.attributes, 131328);
+ writeIfAny(node.attributes.properties, " ");
+ if (node.attributes.properties && node.attributes.properties.length > 0) {
+ emit(node.attributes);
+ }
write(">");
}
function emitJsxText(node) {
@@ -48320,6 +52322,9 @@ var ts;
emitJsxTagName(node.tagName);
write(">");
}
+ function emitJsxAttributes(node) {
+ emitList(node, node.properties, 131328);
+ }
function emitJsxAttribute(node) {
emit(node.name);
emitWithPrefix("=", node.initializer);
@@ -48332,6 +52337,9 @@ var ts;
function emitJsxExpression(node) {
if (node.expression) {
write("{");
+ if (node.dotDotDotToken) {
+ write("...");
+ }
emitExpression(node.expression);
write("}");
}
@@ -48374,7 +52382,6 @@ var ts;
emitList(node, node.types, 272);
}
function emitCatchClause(node) {
- writeLine();
var openParenPos = writeToken(73, node.pos);
write(" ");
writeToken(18, openParenPos);
@@ -48387,7 +52394,7 @@ var ts;
emit(node.name);
write(": ");
var initializer = node.initializer;
- if ((ts.getEmitFlags(initializer) & 512) === 0) {
+ if (emitTrailingCommentsOfPosition && (ts.getEmitFlags(initializer) & 512) === 0) {
var commentRange = ts.getCommentRange(initializer);
emitTrailingCommentsOfPosition(commentRange.pos);
}
@@ -48412,28 +52419,43 @@ var ts;
}
function emitSourceFile(node) {
writeLine();
- emitShebang();
- emitBodyWithDetachedComments(node, node.statements, emitSourceFileWorker);
+ var statements = node.statements;
+ if (emitBodyWithDetachedComments) {
+ var shouldEmitDetachedComment = statements.length === 0 ||
+ !ts.isPrologueDirective(statements[0]) ||
+ ts.nodeIsSynthesized(statements[0]);
+ if (shouldEmitDetachedComment) {
+ emitBodyWithDetachedComments(node, statements, emitSourceFileWorker);
+ return;
+ }
+ }
+ emitSourceFileWorker(node);
}
function emitSourceFileWorker(node) {
var statements = node.statements;
- var statementOffset = emitPrologueDirectives(statements);
- var savedTempFlags = tempFlags;
- tempFlags = 0;
- emitHelpers(node);
- emitList(node, statements, 1, statementOffset);
- tempFlags = savedTempFlags;
+ pushNameGenerationScope();
+ emitHelpersIndirect(node);
+ var index = ts.findIndex(statements, function (statement) { return !ts.isPrologueDirective(statement); });
+ emitList(node, statements, 1, index === -1 ? statements.length : index);
+ popNameGenerationScope();
}
function emitPartiallyEmittedExpression(node) {
emitExpression(node.expression);
}
- function emitPrologueDirectives(statements, startWithNewLine) {
+ function emitPrologueDirectives(statements, startWithNewLine, seenPrologueDirectives) {
for (var i = 0; i < statements.length; i++) {
- if (ts.isPrologueDirective(statements[i])) {
- if (startWithNewLine || i > 0) {
- writeLine();
+ var statement = statements[i];
+ if (ts.isPrologueDirective(statement)) {
+ var shouldEmitPrologueDirective = seenPrologueDirectives ? !seenPrologueDirectives.has(statement.expression.text) : true;
+ if (shouldEmitPrologueDirective) {
+ if (startWithNewLine || i > 0) {
+ writeLine();
+ }
+ emit(statement);
+ if (seenPrologueDirectives) {
+ seenPrologueDirectives.set(statement.expression.text, statement.expression.text);
+ }
}
- emit(statements[i]);
}
else {
return i;
@@ -48441,71 +52463,37 @@ var ts;
}
return statements.length;
}
- function emitHelpers(node, isBundle) {
- var sourceFile = ts.isSourceFile(node) ? node : currentSourceFile;
- var shouldSkip = compilerOptions.noEmitHelpers || (sourceFile && ts.getExternalHelpersModuleName(sourceFile) !== undefined);
- var shouldBundle = ts.isSourceFile(node) && !isOwnFileEmit;
- var helpersEmitted = false;
- var helpers = ts.getEmitHelpers(node);
- if (helpers) {
- for (var _a = 0, _b = ts.stableSort(helpers, ts.compareEmitHelpers); _a < _b.length; _a++) {
- var helper = _b[_a];
- if (!helper.scoped) {
- if (shouldSkip)
- continue;
- if (shouldBundle) {
- if (bundledHelpers[helper.name]) {
- continue;
- }
- bundledHelpers[helper.name] = true;
- }
- }
- else if (isBundle) {
- continue;
- }
- writeLines(helper.text);
- helpersEmitted = true;
- }
+ function emitPrologueDirectivesIfNeeded(sourceFileOrBundle) {
+ if (ts.isSourceFile(sourceFileOrBundle)) {
+ setSourceFile(sourceFileOrBundle);
+ emitPrologueDirectives(sourceFileOrBundle.statements);
}
- if (helpersEmitted) {
- writeLine();
+ else {
+ var seenPrologueDirectives = ts.createMap();
+ for (var _a = 0, _b = sourceFileOrBundle.sourceFiles; _a < _b.length; _a++) {
+ var sourceFile = _b[_a];
+ setSourceFile(sourceFile);
+ emitPrologueDirectives(sourceFile.statements, true, seenPrologueDirectives);
+ }
}
- return helpersEmitted;
}
- function writeLines(text) {
- var lines = text.split(/\r\n?|\n/g);
- var indentation = guessIndentation(lines);
- for (var i = 0; i < lines.length; i++) {
- var line = indentation ? lines[i].slice(indentation) : lines[i];
- if (line.length) {
- if (i > 0) {
- writeLine();
- }
- write(line);
+ function emitShebangIfNeeded(sourceFileOrBundle) {
+ if (ts.isSourceFile(sourceFileOrBundle)) {
+ var shebang = ts.getShebang(sourceFileOrBundle.text);
+ if (shebang) {
+ write(shebang);
+ writeLine();
+ return true;
}
}
- }
- function guessIndentation(lines) {
- var indentation;
- for (var _a = 0, lines_1 = lines; _a < lines_1.length; _a++) {
- var line = lines_1[_a];
- for (var i = 0; i < line.length && (indentation === undefined || i < indentation); i++) {
- if (!ts.isWhiteSpace(line.charCodeAt(i))) {
- if (indentation === undefined || i < indentation) {
- indentation = i;
- break;
- }
+ else {
+ for (var _a = 0, _b = sourceFileOrBundle.sourceFiles; _a < _b.length; _a++) {
+ var sourceFile = _b[_a];
+ if (emitShebangIfNeeded(sourceFile)) {
+ break;
}
}
}
- return indentation;
- }
- function emitShebang() {
- var shebang = ts.getShebang(currentText);
- if (shebang) {
- write(shebang);
- writeLine();
- }
}
function emitModifiers(node, modifiers) {
if (modifiers && modifiers.length) {
@@ -48531,8 +52519,8 @@ var ts;
write(suffix);
}
}
- function emitEmbeddedStatement(node) {
- if (ts.isBlock(node)) {
+ function emitEmbeddedStatement(parent, node) {
+ if (ts.isBlock(node) || ts.getEmitFlags(parent) & 1) {
write(" ");
emit(node);
}
@@ -48589,6 +52577,9 @@ var ts;
if (format & 7680) {
write(getOpeningBracket(format));
}
+ if (onBeforeEmitNodeArray) {
+ onBeforeEmitNodeArray(children);
+ }
if (isEmpty) {
if (format & 1) {
writeLine();
@@ -48616,6 +52607,9 @@ var ts;
for (var i = 0; i < count; i++) {
var child = children[start + i];
if (previousSibling) {
+ if (delimiter && previousSibling.end !== parentNode.end) {
+ emitLeadingCommentsOfPosition(previousSibling.end);
+ }
write(delimiter);
if (shouldWriteSeparatingLineTerminator(previousSibling, child, format)) {
if ((format & (3 | 64)) === 0) {
@@ -48630,8 +52624,10 @@ var ts;
}
}
if (shouldEmitInterveningComments) {
- var commentRange = ts.getCommentRange(child);
- emitTrailingCommentsOfPosition(commentRange.pos);
+ if (emitTrailingCommentsOfPosition) {
+ var commentRange = ts.getCommentRange(child);
+ emitTrailingCommentsOfPosition(commentRange.pos);
+ }
}
else {
shouldEmitInterveningComments = mayEmitInterveningComments;
@@ -48647,6 +52643,9 @@ var ts;
if (format & 16 && hasTrailingComma) {
write(",");
}
+ if (previousSibling && delimiter && previousSibling.end !== parentNode.end) {
+ emitLeadingCommentsOfPosition(previousSibling.end);
+ }
if (format & 64) {
decreaseIndent();
}
@@ -48657,28 +52656,80 @@ var ts;
write(" ");
}
}
+ if (onAfterEmitNodeArray) {
+ onAfterEmitNodeArray(children);
+ }
if (format & 7680) {
write(getClosingBracket(format));
}
}
+ function write(s) {
+ writer.write(s);
+ }
+ function writeLine() {
+ writer.writeLine();
+ }
+ function increaseIndent() {
+ writer.increaseIndent();
+ }
+ function decreaseIndent() {
+ writer.decreaseIndent();
+ }
function writeIfAny(nodes, text) {
- if (nodes && nodes.length > 0) {
+ if (ts.some(nodes)) {
write(text);
}
}
function writeIfPresent(node, text) {
- if (node !== undefined) {
+ if (node) {
write(text);
}
}
function writeToken(token, pos, contextNode) {
- return emitTokenWithSourceMap(contextNode, token, pos, writeTokenText);
+ return onEmitSourceMapOfToken
+ ? onEmitSourceMapOfToken(contextNode, token, pos, writeTokenText)
+ : writeTokenText(token, pos);
}
function writeTokenText(token, pos) {
var tokenString = ts.tokenToString(token);
write(tokenString);
return pos < 0 ? pos : pos + tokenString.length;
}
+ function writeLineOrSpace(node) {
+ if (ts.getEmitFlags(node) & 1) {
+ write(" ");
+ }
+ else {
+ writeLine();
+ }
+ }
+ function writeLines(text) {
+ var lines = text.split(/\r\n?|\n/g);
+ var indentation = guessIndentation(lines);
+ for (var i = 0; i < lines.length; i++) {
+ var line = indentation ? lines[i].slice(indentation) : lines[i];
+ if (line.length) {
+ writeLine();
+ write(line);
+ writeLine();
+ }
+ }
+ }
+ function guessIndentation(lines) {
+ var indentation;
+ for (var _a = 0, lines_1 = lines; _a < lines_1.length; _a++) {
+ var line = lines_1[_a];
+ for (var i = 0; i < line.length && (indentation === undefined || i < indentation); i++) {
+ if (!ts.isWhiteSpace(line.charCodeAt(i))) {
+ if (indentation === undefined || i < indentation) {
+ indentation = i;
+ break;
+ }
+ }
+ }
+ }
+ return indentation;
+ }
function increaseIndentIf(value, valueToWriteWhenNotIndenting) {
if (value) {
increaseIndent();
@@ -48783,15 +52834,23 @@ var ts;
&& !ts.nodeIsSynthesized(node2)
&& !ts.rangeEndIsOnSameLineAsRangeStart(node1, node2, currentSourceFile);
}
+ function isSingleLineEmptyBlock(block) {
+ return !block.multiLine
+ && isEmptyBlock(block);
+ }
+ function isEmptyBlock(block) {
+ return block.statements.length === 0
+ && ts.rangeEndIsOnSameLineAsRangeStart(block, block, currentSourceFile);
+ }
function skipSynthesizedParentheses(node) {
- while (node.kind === 183 && ts.nodeIsSynthesized(node)) {
+ while (node.kind === 184 && ts.nodeIsSynthesized(node)) {
node = node.expression;
}
return node;
}
function getTextOfNode(node, includeTrivia) {
if (ts.isGeneratedIdentifier(node)) {
- return getGeneratedIdentifier(node);
+ return generateName(node);
}
else if (ts.isIdentifier(node) && (ts.nodeIsSynthesized(node) || !node.parent)) {
return ts.unescapeIdentifier(node.text);
@@ -48814,25 +52873,39 @@ var ts;
return getLiteralTextOfNode(textSourceNode);
}
}
- return ts.getLiteralText(node, currentSourceFile, languageVersion);
+ return ts.getLiteralText(node, currentSourceFile);
}
- function isSingleLineEmptyBlock(block) {
- return !block.multiLine
- && isEmptyBlock(block);
+ function pushNameGenerationScope() {
+ tempFlagsStack.push(tempFlags);
+ tempFlags = 0;
}
- function isEmptyBlock(block) {
- return block.statements.length === 0
- && ts.rangeEndIsOnSameLineAsRangeStart(block, block, currentSourceFile);
+ function popNameGenerationScope() {
+ tempFlags = tempFlagsStack.pop();
+ }
+ function generateName(name) {
+ if (name.autoGenerateKind === 4) {
+ var node = getNodeForGeneratedName(name);
+ return generateNameCached(node);
+ }
+ else {
+ var autoGenerateId = name.autoGenerateId;
+ return autoGeneratedIdToGeneratedName[autoGenerateId] || (autoGeneratedIdToGeneratedName[autoGenerateId] = ts.unescapeIdentifier(makeName(name)));
+ }
+ }
+ function generateNameCached(node) {
+ var nodeId = ts.getNodeId(node);
+ return nodeIdToGeneratedName[nodeId] || (nodeIdToGeneratedName[nodeId] = ts.unescapeIdentifier(generateNameForNode(node)));
}
function isUniqueName(name) {
- return !resolver.hasGlobalName(name) &&
- !ts.hasProperty(currentFileIdentifiers, name) &&
- !ts.hasProperty(generatedNameSet, name);
+ return !(hasGlobalName && hasGlobalName(name))
+ && !currentSourceFile.identifiers.has(name)
+ && !generatedNames.has(name);
}
function isUniqueLocalName(name, container) {
for (var node = container; ts.isNodeDescendantOf(node, container); node = node.nextContainer) {
- if (node.locals && ts.hasProperty(node.locals, name)) {
- if (node.locals[name].flags & (107455 | 1048576 | 8388608)) {
+ if (node.locals) {
+ var local = node.locals.get(name);
+ if (local && local.flags & (107455 | 1048576 | 8388608)) {
return false;
}
}
@@ -48841,21 +52914,21 @@ var ts;
}
function makeTempVariableName(flags) {
if (flags && !(tempFlags & flags)) {
- var name_39 = flags === 268435456 ? "_i" : "_n";
- if (isUniqueName(name_39)) {
+ var name = flags === 268435456 ? "_i" : "_n";
+ if (isUniqueName(name)) {
tempFlags |= flags;
- return name_39;
+ return name;
}
}
while (true) {
var count = tempFlags & 268435455;
tempFlags++;
if (count !== 8 && count !== 13) {
- var name_40 = count < 26
+ var name = count < 26
? "_" + String.fromCharCode(97 + count)
: "_" + (count - 26);
- if (isUniqueName(name_40)) {
- return name_40;
+ if (isUniqueName(name)) {
+ return name;
}
}
}
@@ -48868,7 +52941,8 @@ var ts;
while (true) {
var generatedName = baseName + i;
if (isUniqueName(generatedName)) {
- return generatedNameSet[generatedName] = generatedName;
+ generatedNames.set(generatedName, generatedName);
+ return generatedName;
}
i++;
}
@@ -48889,34 +52963,44 @@ var ts;
function generateNameForClassExpression() {
return makeUniqueName("class");
}
+ function generateNameForMethodOrAccessor(node) {
+ if (ts.isIdentifier(node.name)) {
+ return generateNameCached(node.name);
+ }
+ return makeTempVariableName(0);
+ }
function generateNameForNode(node) {
switch (node.kind) {
case 70:
return makeUniqueName(getTextOfNode(node));
- case 230:
- case 229:
+ case 232:
+ case 231:
return generateNameForModuleOrEnum(node);
- case 235:
- case 241:
+ case 237:
+ case 243:
return generateNameForImportOrExportDeclaration(node);
- case 225:
- case 226:
- case 240:
+ case 227:
+ case 228:
+ case 242:
return generateNameForExportDefault();
- case 197:
+ case 198:
return generateNameForClassExpression();
+ case 150:
+ case 152:
+ case 153:
+ return generateNameForMethodOrAccessor(node);
default:
return makeTempVariableName(0);
}
}
- function generateName(name) {
+ function makeName(name) {
switch (name.autoGenerateKind) {
case 1:
return makeTempVariableName(0);
case 2:
return makeTempVariableName(268435456);
case 3:
- return makeUniqueName(name.text);
+ return makeUniqueName(ts.unescapeIdentifier(name.text));
}
ts.Debug.fail("Unsupported GeneratedIdentifierKind.");
}
@@ -48935,48 +53019,38 @@ var ts;
}
return node;
}
- function getGeneratedIdentifier(name) {
- if (name.autoGenerateKind === 4) {
- var node = getNodeForGeneratedName(name);
- var nodeId = ts.getNodeId(node);
- return nodeIdToGeneratedName[nodeId] || (nodeIdToGeneratedName[nodeId] = ts.unescapeIdentifier(generateNameForNode(node)));
- }
- else {
- var autoGenerateId = name.autoGenerateId;
- return autoGeneratedIdToGeneratedName[autoGenerateId] || (autoGeneratedIdToGeneratedName[autoGenerateId] = ts.unescapeIdentifier(generateName(name)));
- }
- }
- function createDelimiterMap() {
- var delimiters = [];
- delimiters[0] = "";
- delimiters[16] = ",";
- delimiters[4] = " |";
- delimiters[8] = " &";
- return delimiters;
- }
- function getDelimiter(format) {
- return delimiters[format & 28];
- }
- function createBracketsMap() {
- var brackets = [];
- brackets[512] = ["{", "}"];
- brackets[1024] = ["(", ")"];
- brackets[2048] = ["<", ">"];
- brackets[4096] = ["[", "]"];
- return brackets;
- }
- function getOpeningBracket(format) {
- return brackets[format & 7680][0];
- }
- function getClosingBracket(format) {
- return brackets[format & 7680][1];
- }
}
- ts.emitFiles = emitFiles;
+ ts.createPrinter = createPrinter;
+ function createDelimiterMap() {
+ var delimiters = [];
+ delimiters[0] = "";
+ delimiters[16] = ",";
+ delimiters[4] = " |";
+ delimiters[8] = " &";
+ return delimiters;
+ }
+ function getDelimiter(format) {
+ return delimiters[format & 28];
+ }
+ function createBracketsMap() {
+ var brackets = [];
+ brackets[512] = ["{", "}"];
+ brackets[1024] = ["(", ")"];
+ brackets[2048] = ["<", ">"];
+ brackets[4096] = ["[", "]"];
+ return brackets;
+ }
+ function getOpeningBracket(format) {
+ return brackets[format & 7680][0];
+ }
+ function getClosingBracket(format) {
+ return brackets[format & 7680][1];
+ }
})(ts || (ts = {}));
var ts;
(function (ts) {
var emptyArray = [];
+ var ignoreDiagnosticCommentRegEx = /(^\s*$)|(^\s*\/\/\/?\s*(@ts-ignore)?)/;
function findConfigFile(searchPath, fileExists, configName) {
if (configName === void 0) { configName = "tsconfig.json"; }
while (true) {
@@ -49008,7 +53082,8 @@ var ts;
commonPathComponents = sourcePathComponents;
return;
}
- for (var i = 0, n = Math.min(commonPathComponents.length, sourcePathComponents.length); i < n; i++) {
+ var n = Math.min(commonPathComponents.length, sourcePathComponents.length);
+ for (var i = 0; i < n; i++) {
if (getCanonicalFileName(commonPathComponents[i]) !== getCanonicalFileName(sourcePathComponents[i])) {
if (i === 0) {
return true;
@@ -49035,7 +53110,6 @@ var ts;
function getCanonicalFileName(fileName) {
return ts.sys.useCaseSensitiveFileNames ? fileName : fileName.toLowerCase();
}
- var unsupportedFileEncodingErrorCode = -2147024809;
function getSourceFile(fileName, languageVersion, onError) {
var text;
try {
@@ -49046,20 +53120,18 @@ var ts;
}
catch (e) {
if (onError) {
- onError(e.number === unsupportedFileEncodingErrorCode
- ? ts.createCompilerDiagnostic(ts.Diagnostics.Unsupported_file_encoding).messageText
- : e.message);
+ onError(e.message);
}
text = "";
}
return text !== undefined ? ts.createSourceFile(fileName, text, languageVersion, setParentNodes) : undefined;
}
function directoryExists(directoryPath) {
- if (directoryPath in existingDirectories) {
+ if (existingDirectories.has(directoryPath)) {
return true;
}
if (ts.sys.directoryExists(directoryPath)) {
- existingDirectories[directoryPath] = true;
+ existingDirectories.set(directoryPath, true);
return true;
}
return false;
@@ -49078,9 +53150,10 @@ var ts;
}
var hash = ts.sys.createHash(data);
var mtimeBefore = ts.sys.getModifiedTime(fileName);
- if (mtimeBefore && fileName in outputFingerprints) {
- var fingerprint = outputFingerprints[fileName];
- if (fingerprint.byteOrderMark === writeByteOrderMark &&
+ if (mtimeBefore) {
+ var fingerprint = outputFingerprints.get(fileName);
+ if (fingerprint &&
+ fingerprint.byteOrderMark === writeByteOrderMark &&
fingerprint.hash === hash &&
fingerprint.mtime.getTime() === mtimeBefore.getTime()) {
return;
@@ -49088,11 +53161,11 @@ var ts;
}
ts.sys.writeFile(fileName, data, writeByteOrderMark);
var mtimeAfter = ts.sys.getModifiedTime(fileName);
- outputFingerprints[fileName] = {
+ outputFingerprints.set(fileName, {
hash: hash,
byteOrderMark: writeByteOrderMark,
mtime: mtimeAfter
- };
+ });
}
function writeFile(fileName, data, writeByteOrderMark, onError) {
try {
@@ -49191,10 +53264,14 @@ var ts;
var resolutions = [];
var cache = ts.createMap();
for (var _i = 0, names_1 = names; _i < names_1.length; _i++) {
- var name_41 = names_1[_i];
- var result = name_41 in cache
- ? cache[name_41]
- : cache[name_41] = loader(name_41, containingFile);
+ var name = names_1[_i];
+ var result = void 0;
+ if (cache.has(name)) {
+ result = cache.get(name);
+ }
+ else {
+ cache.set(name, result = loader(name, containingFile));
+ }
resolutions.push(result);
}
return resolutions;
@@ -49206,6 +53283,8 @@ var ts;
var diagnosticsProducingTypeChecker;
var noDiagnosticsTypeChecker;
var classifiableNames;
+ var cachedSemanticDiagnosticsForFile = {};
+ var cachedDeclarationDiagnosticsForFile = {};
var resolvedTypeReferenceDirectives = ts.createMap();
var fileProcessingDiagnostics = ts.createDiagnosticCollection();
var maxNodeModuleJsDepth = typeof options.maxNodeModuleJsDepth === "number" ? options.maxNodeModuleJsDepth : 0;
@@ -49219,6 +53298,7 @@ var ts;
var currentDirectory = host.getCurrentDirectory();
var supportedExtensions = ts.getSupportedExtensions(options);
var hasEmitBlockingDiagnostics = ts.createFileMap(getCanonicalFileName);
+ var moduleResolutionCache;
var resolveModuleNamesWorker;
if (host.resolveModuleNames) {
resolveModuleNamesWorker = function (moduleNames, containingFile) { return host.resolveModuleNames(moduleNames, containingFile).map(function (resolved) {
@@ -49231,7 +53311,8 @@ var ts;
}); };
}
else {
- var loader_1 = function (moduleName, containingFile) { return ts.resolveModuleName(moduleName, containingFile, options, host).resolvedModule; };
+ moduleResolutionCache = ts.createModuleResolutionCache(currentDirectory, function (x) { return host.getCanonicalFileName(x); });
+ var loader_1 = function (moduleName, containingFile) { return ts.resolveModuleName(moduleName, containingFile, options, host, moduleResolutionCache).resolvedModule; };
resolveModuleNamesWorker = function (moduleNames, containingFile) { return loadWithLocalCache(moduleNames, containingFile, loader_1); };
}
var resolveTypeReferenceDirectiveNamesWorker;
@@ -49267,6 +53348,7 @@ var ts;
}
}
}
+ moduleResolutionCache = undefined;
oldProgram = undefined;
program = {
getRootFileNames: function () { return rootNames; },
@@ -49300,7 +53382,7 @@ var ts;
return program;
function getCommonSourceDirectory() {
if (commonSourceDirectory === undefined) {
- var emittedFiles = ts.filterSourceFilesInDirectory(files, isSourceFileFromExternalLibrary);
+ var emittedFiles = ts.filter(files, function (file) { return ts.sourceFileMayBeEmitted(file, options, isSourceFileFromExternalLibrary); });
if (options.rootDir && checkSourceFilesBelongToPath(emittedFiles, options.rootDir)) {
commonSourceDirectory = ts.getNormalizedAbsolutePath(options.rootDir, currentDirectory);
}
@@ -49319,7 +53401,7 @@ var ts;
classifiableNames = ts.createMap();
for (var _i = 0, files_2 = files; _i < files_2.length; _i++) {
var sourceFile = files_2[_i];
- ts.copyProperties(sourceFile.classifiableNames, classifiableNames);
+ ts.copyEntries(sourceFile.classifiableNames, classifiableNames);
}
}
return classifiableNames;
@@ -49362,7 +53444,7 @@ var ts;
: emptyArray;
var j = 0;
for (var i = 0; i < result.length; i++) {
- if (result[i] == predictedToResolveToAmbientModuleMarker) {
+ if (result[i] === predictedToResolveToAmbientModuleMarker) {
result[i] = undefined;
}
else {
@@ -49473,7 +53555,7 @@ var ts;
newSourceFile.resolvedModules = oldSourceFile.resolvedModules;
newSourceFile.resolvedTypeReferenceDirectiveNames = oldSourceFile.resolvedTypeReferenceDirectiveNames;
}
- for (var i = 0, len = newSourceFiles.length; i < len; i++) {
+ for (var i = 0; i < newSourceFiles.length; i++) {
filesByName.set(filePaths[i], newSourceFiles[i]);
}
files = newSourceFiles;
@@ -49502,7 +53584,7 @@ var ts;
};
}
function isSourceFileFromExternalLibrary(file) {
- return sourceFilesFoundSearchingNodeModules[file.path];
+ return sourceFilesFoundSearchingNodeModules.get(file.path);
}
function getDiagnosticsProducingTypeChecker() {
return diagnosticsProducingTypeChecker || (diagnosticsProducingTypeChecker = ts.createTypeChecker(program, true));
@@ -49513,13 +53595,13 @@ var ts;
function getTypeChecker() {
return noDiagnosticsTypeChecker || (noDiagnosticsTypeChecker = ts.createTypeChecker(program, false));
}
- function emit(sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles) {
- return runWithCancellationToken(function () { return emitWorker(program, sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles); });
+ function emit(sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles, transformers) {
+ return runWithCancellationToken(function () { return emitWorker(program, sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles, transformers); });
}
function isEmitBlocked(emitFileName) {
return hasEmitBlockingDiagnostics.contains(ts.toPath(emitFileName, currentDirectory, getCanonicalFileName));
}
- function emitWorker(program, sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles) {
+ function emitWorker(program, sourceFile, writeFileCallback, cancellationToken, emitOnlyDtsFiles, customTransformers) {
var declarationDiagnostics = [];
if (options.noEmit) {
return { diagnostics: declarationDiagnostics, sourceMaps: undefined, emittedFiles: undefined, emitSkipped: true };
@@ -49540,7 +53622,8 @@ var ts;
}
var emitResolver = getDiagnosticsProducingTypeChecker().getEmitResolver((options.outFile || options.out) ? undefined : sourceFile);
ts.performance.mark("beforeEmit");
- var emitResult = ts.emitFiles(emitResolver, getEmitHost(writeFileCallback), sourceFile, emitOnlyDtsFiles);
+ var transformers = emitOnlyDtsFiles ? [] : ts.getTransformers(options, customTransformers);
+ var emitResult = ts.emitFiles(emitResolver, getEmitHost(writeFileCallback), sourceFile, emitOnlyDtsFiles, transformers);
ts.performance.mark("afterEmit");
ts.performance.measure("Emit", "beforeEmit", "afterEmit");
return emitResult;
@@ -49601,16 +53684,42 @@ var ts;
}
}
function getSemanticDiagnosticsForFile(sourceFile, cancellationToken) {
+ return getAndCacheDiagnostics(sourceFile, cancellationToken, cachedSemanticDiagnosticsForFile, getSemanticDiagnosticsForFileNoCache);
+ }
+ function getSemanticDiagnosticsForFileNoCache(sourceFile, cancellationToken) {
return runWithCancellationToken(function () {
var typeChecker = getDiagnosticsProducingTypeChecker();
ts.Debug.assert(!!sourceFile.bindDiagnostics);
var bindDiagnostics = sourceFile.bindDiagnostics;
- var checkDiagnostics = ts.isSourceFileJavaScript(sourceFile) ? [] : typeChecker.getDiagnostics(sourceFile, cancellationToken);
+ var includeCheckDiagnostics = !ts.isSourceFileJavaScript(sourceFile) || ts.isCheckJsEnabledForFile(sourceFile, options);
+ var checkDiagnostics = includeCheckDiagnostics ? typeChecker.getDiagnostics(sourceFile, cancellationToken) : [];
var fileProcessingDiagnosticsInFile = fileProcessingDiagnostics.getDiagnostics(sourceFile.fileName);
var programDiagnosticsInFile = programDiagnostics.getDiagnostics(sourceFile.fileName);
- return bindDiagnostics.concat(checkDiagnostics, fileProcessingDiagnosticsInFile, programDiagnosticsInFile);
+ var diagnostics = bindDiagnostics.concat(checkDiagnostics, fileProcessingDiagnosticsInFile, programDiagnosticsInFile);
+ return ts.isSourceFileJavaScript(sourceFile)
+ ? ts.filter(diagnostics, shouldReportDiagnostic)
+ : diagnostics;
});
}
+ function shouldReportDiagnostic(diagnostic) {
+ var file = diagnostic.file, start = diagnostic.start;
+ if (file) {
+ var lineStarts = ts.getLineStarts(file);
+ var line = ts.computeLineAndCharacterOfPosition(lineStarts, start).line;
+ while (line > 0) {
+ var previousLineText = file.text.slice(lineStarts[line - 1], lineStarts[line]);
+ var result = ignoreDiagnosticCommentRegEx.exec(previousLineText);
+ if (!result) {
+ return true;
+ }
+ if (result[3]) {
+ return false;
+ }
+ line--;
+ }
+ }
+ return true;
+ }
function getJavaScriptSyntacticDiagnosticsForFile(sourceFile) {
return runWithCancellationToken(function () {
var diagnostics = [];
@@ -49619,57 +53728,57 @@ var ts;
return diagnostics;
function walk(node) {
switch (parent.kind) {
- case 144:
- case 147:
+ case 145:
+ case 148:
if (parent.questionToken === node) {
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics._0_can_only_be_used_in_a_ts_file, "?"));
return;
}
- case 149:
- case 148:
case 150:
+ case 149:
case 151:
case 152:
- case 184:
- case 225:
+ case 153:
case 185:
+ case 227:
+ case 186:
+ case 227:
case 225:
- case 223:
if (parent.type === node) {
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.types_can_only_be_used_in_a_ts_file));
return;
}
}
switch (node.kind) {
- case 234:
+ case 236:
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.import_can_only_be_used_in_a_ts_file));
return;
- case 240:
+ case 242:
if (node.isExportEquals) {
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.export_can_only_be_used_in_a_ts_file));
return;
}
break;
- case 255:
+ case 258:
var heritageClause = node;
if (heritageClause.token === 107) {
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.implements_clauses_can_only_be_used_in_a_ts_file));
return;
}
break;
- case 227:
+ case 229:
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.interface_declarations_can_only_be_used_in_a_ts_file));
return;
- case 230:
+ case 232:
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.module_declarations_can_only_be_used_in_a_ts_file));
return;
- case 228:
+ case 230:
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.type_aliases_can_only_be_used_in_a_ts_file));
return;
- case 229:
+ case 231:
diagnostics.push(createDiagnosticForNode(node, ts.Diagnostics.enum_declarations_can_only_be_used_in_a_ts_file));
return;
- case 182:
+ case 183:
var typeAssertionExpression = node;
diagnostics.push(createDiagnosticForNode(typeAssertionExpression.type, ts.Diagnostics.type_assertion_expressions_can_only_be_used_in_a_ts_file));
return;
@@ -49684,26 +53793,26 @@ var ts;
diagnostics.push(createDiagnosticForNode(parent, ts.Diagnostics.Experimental_support_for_decorators_is_a_feature_that_is_subject_to_change_in_a_future_release_Set_the_experimentalDecorators_option_to_remove_this_warning));
}
switch (parent.kind) {
- case 226:
- case 149:
- case 148:
+ case 228:
case 150:
+ case 149:
case 151:
case 152:
- case 184:
- case 225:
+ case 153:
case 185:
- case 225:
+ case 227:
+ case 186:
+ case 227:
if (nodes === parent.typeParameters) {
diagnostics.push(createDiagnosticForNodeArray(nodes, ts.Diagnostics.type_parameter_declarations_can_only_be_used_in_a_ts_file));
return;
}
- case 205:
+ case 207:
if (nodes === parent.modifiers) {
- return checkModifiers(nodes, parent.kind === 205);
+ return checkModifiers(nodes, parent.kind === 207);
}
break;
- case 147:
+ case 148:
if (nodes === parent.modifiers) {
for (var _i = 0, _a = nodes; _i < _a.length; _i++) {
var modifier = _a[_i];
@@ -49714,23 +53823,23 @@ var ts;
return;
}
break;
- case 144:
+ case 145:
if (nodes === parent.modifiers) {
diagnostics.push(createDiagnosticForNodeArray(nodes, ts.Diagnostics.parameter_modifiers_can_only_be_used_in_a_ts_file));
return;
}
break;
- case 179:
case 180:
- case 199:
+ case 181:
+ case 200:
if (nodes === parent.typeArguments) {
diagnostics.push(createDiagnosticForNodeArray(nodes, ts.Diagnostics.type_arguments_can_only_be_used_in_a_ts_file));
return;
}
break;
}
- for (var _b = 0, nodes_6 = nodes; _b < nodes_6.length; _b++) {
- var node = nodes_6[_b];
+ for (var _b = 0, nodes_8 = nodes; _b < nodes_8.length; _b++) {
+ var node = nodes_8[_b];
walk(node);
}
}
@@ -49766,11 +53875,33 @@ var ts;
});
}
function getDeclarationDiagnosticsWorker(sourceFile, cancellationToken) {
+ return getAndCacheDiagnostics(sourceFile, cancellationToken, cachedDeclarationDiagnosticsForFile, getDeclarationDiagnosticsForFileNoCache);
+ }
+ function getDeclarationDiagnosticsForFileNoCache(sourceFile, cancellationToken) {
return runWithCancellationToken(function () {
var resolver = getDiagnosticsProducingTypeChecker().getEmitResolver(sourceFile, cancellationToken);
return ts.getDeclarationDiagnostics(getEmitHost(ts.noop), resolver, sourceFile);
});
}
+ function getAndCacheDiagnostics(sourceFile, cancellationToken, cache, getDiagnostics) {
+ var cachedResult = sourceFile
+ ? cache.perFile && cache.perFile.get(sourceFile.path)
+ : cache.allDiagnostics;
+ if (cachedResult) {
+ return cachedResult;
+ }
+ var result = getDiagnostics(sourceFile, cancellationToken) || emptyArray;
+ if (sourceFile) {
+ if (!cache.perFile) {
+ cache.perFile = ts.createFileMap();
+ }
+ cache.perFile.set(sourceFile.path, result);
+ }
+ else {
+ cache.allDiagnostics = result;
+ }
+ return result;
+ }
function getDeclarationDiagnosticsForFile(sourceFile, cancellationToken) {
return ts.isDeclarationFile(sourceFile) ? [] : getDeclarationDiagnosticsWorker(sourceFile, cancellationToken);
}
@@ -49810,11 +53941,10 @@ var ts;
if (options.importHelpers
&& (options.isolatedModules || isExternalModuleFile)
&& !file.isDeclarationFile) {
- var externalHelpersModuleReference = ts.createSynthesizedNode(9);
- externalHelpersModuleReference.text = ts.externalHelpersModuleNameText;
- var importDecl = ts.createSynthesizedNode(235);
- importDecl.parent = file;
+ var externalHelpersModuleReference = ts.createLiteral(ts.externalHelpersModuleNameText);
+ var importDecl = ts.createImportDeclaration(undefined, undefined, undefined);
externalHelpersModuleReference.parent = importDecl;
+ importDecl.parent = file;
imports = [externalHelpersModuleReference];
}
for (var _i = 0, _a = file.statements; _i < _a.length; _i++) {
@@ -49830,9 +53960,9 @@ var ts;
return;
function collectModuleReferences(node, inAmbientModule) {
switch (node.kind) {
- case 235:
- case 234:
- case 241:
+ case 237:
+ case 236:
+ case 243:
var moduleNameExpr = ts.getExternalModuleName(node);
if (!moduleNameExpr || moduleNameExpr.kind !== 9) {
break;
@@ -49844,7 +53974,7 @@ var ts;
(imports || (imports = [])).push(moduleNameExpr);
}
break;
- case 230:
+ case 232:
if (ts.isAmbientModule(node) && (inAmbientModule || ts.hasModifier(node, 2) || ts.isDeclarationFile(file))) {
var moduleName = node.name;
if (isExternalModuleFile || (inAmbientModule && !ts.isExternalModuleNameRelative(moduleName.text))) {
@@ -49928,18 +54058,18 @@ var ts;
if (file_1 && options.forceConsistentCasingInFileNames && ts.getNormalizedAbsolutePath(file_1.fileName, currentDirectory) !== ts.getNormalizedAbsolutePath(fileName, currentDirectory)) {
reportFileNamesDifferOnlyInCasingError(fileName, file_1.fileName, refFile, refPos, refEnd);
}
- if (file_1 && sourceFilesFoundSearchingNodeModules[file_1.path] && currentNodeModulesDepth == 0) {
- sourceFilesFoundSearchingNodeModules[file_1.path] = false;
+ if (file_1 && sourceFilesFoundSearchingNodeModules.get(file_1.path) && currentNodeModulesDepth === 0) {
+ sourceFilesFoundSearchingNodeModules.set(file_1.path, false);
if (!options.noResolve) {
processReferencedFiles(file_1, isDefaultLib);
processTypeReferenceDirectives(file_1);
}
- modulesWithElidedImports[file_1.path] = false;
+ modulesWithElidedImports.set(file_1.path, false);
processImportedModules(file_1);
}
- else if (file_1 && modulesWithElidedImports[file_1.path]) {
+ else if (file_1 && modulesWithElidedImports.get(file_1.path)) {
if (currentNodeModulesDepth < maxNodeModuleJsDepth) {
- modulesWithElidedImports[file_1.path] = false;
+ modulesWithElidedImports.set(file_1.path, false);
processImportedModules(file_1);
}
}
@@ -49955,7 +54085,7 @@ var ts;
});
filesByName.set(path, file);
if (file) {
- sourceFilesFoundSearchingNodeModules[path] = (currentNodeModulesDepth > 0);
+ sourceFilesFoundSearchingNodeModules.set(path, currentNodeModulesDepth > 0);
file.path = path;
if (host.useCaseSensitiveFileNames()) {
var existingFile = filesByNameIgnoreCase.get(path);
@@ -49999,7 +54129,7 @@ var ts;
}
}
function processTypeReferenceDirective(typeReferenceDirective, resolvedTypeReferenceDirective, refFile, refPos, refEnd) {
- var previousResolution = resolvedTypeReferenceDirectives[typeReferenceDirective];
+ var previousResolution = resolvedTypeReferenceDirectives.get(typeReferenceDirective);
if (previousResolution && previousResolution.primary) {
return;
}
@@ -50027,7 +54157,7 @@ var ts;
fileProcessingDiagnostics.add(createDiagnostic(refFile, refPos, refEnd, ts.Diagnostics.Cannot_find_type_definition_file_for_0, typeReferenceDirective));
}
if (saveResolution) {
- resolvedTypeReferenceDirectives[typeReferenceDirective] = resolvedTypeReferenceDirective;
+ resolvedTypeReferenceDirectives.set(typeReferenceDirective, resolvedTypeReferenceDirective);
}
}
function createDiagnostic(refFile, refPos, refEnd, message) {
@@ -50068,7 +54198,7 @@ var ts;
var elideImport = isJsFileFromNodeModules && currentNodeModulesDepth > maxNodeModuleJsDepth;
var shouldAddFile = resolvedFileName && !getResolutionDiagnostic(options, resolution) && !options.noResolve && i < file.imports.length && !elideImport;
if (elideImport) {
- modulesWithElidedImports[file.path] = true;
+ modulesWithElidedImports.set(file.path, true);
}
else if (shouldAddFile) {
var path = ts.toPath(resolvedFileName, currentDirectory, getCanonicalFileName);
@@ -50086,8 +54216,8 @@ var ts;
}
function computeCommonSourceDirectory(sourceFiles) {
var fileNames = [];
- for (var _i = 0, sourceFiles_6 = sourceFiles; _i < sourceFiles_6.length; _i++) {
- var file = sourceFiles_6[_i];
+ for (var _i = 0, sourceFiles_2 = sourceFiles; _i < sourceFiles_2.length; _i++) {
+ var file = sourceFiles_2[_i];
if (!file.isDeclarationFile) {
fileNames.push(file.fileName);
}
@@ -50098,8 +54228,8 @@ var ts;
var allFilesBelongToPath = true;
if (sourceFiles) {
var absoluteRootDirectoryPath = host.getCanonicalFileName(ts.getNormalizedAbsolutePath(rootDirectory, currentDirectory));
- for (var _i = 0, sourceFiles_7 = sourceFiles; _i < sourceFiles_7.length; _i++) {
- var sourceFile = sourceFiles_7[_i];
+ for (var _i = 0, sourceFiles_3 = sourceFiles; _i < sourceFiles_3.length; _i++) {
+ var sourceFile = sourceFiles_3[_i];
if (!ts.isDeclarationFile(sourceFile)) {
var absoluteSourceFilePath = host.getCanonicalFileName(ts.getNormalizedAbsolutePath(sourceFile.fileName, currentDirectory));
if (absoluteSourceFilePath.indexOf(absoluteRootDirectoryPath) !== 0) {
@@ -50192,7 +54322,7 @@ var ts;
if (options.lib && options.noLib) {
programDiagnostics.add(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_cannot_be_specified_with_option_1, "lib", "noLib"));
}
- if (options.noImplicitUseStrict && options.alwaysStrict) {
+ if (options.noImplicitUseStrict && (options.alwaysStrict === undefined ? options.strict : options.alwaysStrict)) {
programDiagnostics.add(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_cannot_be_specified_with_option_1, "noImplicitUseStrict", "alwaysStrict"));
}
var languageVersion = options.target || 0;
@@ -50232,6 +54362,9 @@ var ts;
if (!options.noEmit && options.allowJs && options.declaration) {
programDiagnostics.add(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_cannot_be_specified_with_option_1, "allowJs", "declaration"));
}
+ if (options.checkJs && !options.allowJs) {
+ programDiagnostics.add(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "checkJs", "allowJs"));
+ }
if (options.emitDecoratorMetadata &&
!options.experimentalDecorators) {
programDiagnostics.add(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "emitDecoratorMetadata", "experimentalDecorators"));
@@ -50250,7 +54383,7 @@ var ts;
if (!options.noEmit && !options.suppressOutputPathCheck) {
var emitHost = getEmitHost();
var emitFilesSeen_1 = ts.createFileMap(!host.useCaseSensitiveFileNames() ? function (key) { return key.toLocaleLowerCase(); } : undefined);
- ts.forEachExpectedEmitFile(emitHost, function (emitFileNames) {
+ ts.forEachEmittedFile(emitHost, function (emitFileNames) {
verifyEmitFilePath(emitFileNames.jsFilePath, emitFilesSeen_1);
verifyEmitFilePath(emitFileNames.declarationFilePath, emitFilesSeen_1);
});
@@ -50308,39 +54441,11 @@ var ts;
ts.compileOnSaveCommandLineOption = { name: "compileOnSave", type: "boolean" };
ts.optionDeclarations = [
{
- name: "charset",
- type: "string",
- },
- ts.compileOnSaveCommandLineOption,
- {
- name: "declaration",
- shortName: "d",
- type: "boolean",
- description: ts.Diagnostics.Generates_corresponding_d_ts_file,
- },
- {
- name: "declarationDir",
- type: "string",
- isFilePath: true,
- paramType: ts.Diagnostics.DIRECTORY,
- },
- {
- name: "diagnostics",
- type: "boolean",
- },
- {
- name: "extendedDiagnostics",
- type: "boolean",
- experimental: true
- },
- {
- name: "emitBOM",
- type: "boolean"
- },
- {
name: "help",
shortName: "h",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
description: ts.Diagnostics.Print_this_message,
},
{
@@ -50349,56 +54454,73 @@ var ts;
type: "boolean"
},
{
- name: "init",
+ name: "all",
type: "boolean",
- description: ts.Diagnostics.Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ description: ts.Diagnostics.Show_all_compiler_options,
},
{
- name: "inlineSourceMap",
+ name: "version",
+ shortName: "v",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ description: ts.Diagnostics.Print_the_compiler_s_version,
},
{
- name: "inlineSources",
+ name: "init",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ description: ts.Diagnostics.Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file,
},
{
- name: "jsx",
- type: ts.createMap({
- "preserve": 1,
- "react": 2
- }),
- paramType: ts.Diagnostics.KIND,
- description: ts.Diagnostics.Specify_JSX_code_generation_Colon_preserve_or_react,
- },
- {
- name: "reactNamespace",
- type: "string",
- description: ts.Diagnostics.Specify_the_object_invoked_for_createElement_and_spread_when_targeting_react_JSX_emit
- },
- {
- name: "jsxFactory",
+ name: "project",
+ shortName: "p",
type: "string",
- description: ts.Diagnostics.Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h
+ isFilePath: true,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ paramType: ts.Diagnostics.FILE_OR_DIRECTORY,
+ description: ts.Diagnostics.Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json,
},
{
- name: "listFiles",
+ name: "pretty",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ description: ts.Diagnostics.Stylize_errors_and_messages_using_color_and_context_experimental
},
{
- name: "locale",
- type: "string",
+ name: "watch",
+ shortName: "w",
+ type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Command_line_Options,
+ description: ts.Diagnostics.Watch_input_files,
},
{
- name: "mapRoot",
- type: "string",
- isFilePath: true,
- description: ts.Diagnostics.Specify_the_location_where_debugger_should_locate_map_files_instead_of_generated_locations,
- paramType: ts.Diagnostics.LOCATION,
+ name: "target",
+ shortName: "t",
+ type: ts.createMapFromTemplate({
+ "es3": 0,
+ "es5": 1,
+ "es6": 2,
+ "es2015": 2,
+ "es2016": 3,
+ "es2017": 4,
+ "esnext": 5,
+ }),
+ paramType: ts.Diagnostics.VERSION,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Specify_ECMAScript_target_version_Colon_ES3_default_ES5_ES2015_ES2016_ES2017_or_ESNEXT,
},
{
name: "module",
shortName: "m",
- type: ts.createMap({
+ type: ts.createMapFromTemplate({
"none": ts.ModuleKind.None,
"commonjs": ts.ModuleKind.CommonJS,
"amd": ts.ModuleKind.AMD,
@@ -50407,238 +54529,232 @@ var ts;
"es6": ts.ModuleKind.ES2015,
"es2015": ts.ModuleKind.ES2015,
}),
- description: ts.Diagnostics.Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015,
paramType: ts.Diagnostics.KIND,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Specify_module_code_generation_Colon_commonjs_amd_system_umd_or_es2015,
},
{
- name: "newLine",
- type: ts.createMap({
- "crlf": 0,
- "lf": 1
- }),
- description: ts.Diagnostics.Specify_the_end_of_line_sequence_to_be_used_when_emitting_files_Colon_CRLF_dos_or_LF_unix,
- paramType: ts.Diagnostics.NEWLINE,
- },
- {
- name: "noEmit",
- type: "boolean",
- description: ts.Diagnostics.Do_not_emit_outputs,
- },
- {
- name: "noEmitHelpers",
- type: "boolean"
- },
- {
- name: "noEmitOnError",
- type: "boolean",
- description: ts.Diagnostics.Do_not_emit_outputs_if_any_errors_were_reported,
- },
- {
- name: "noErrorTruncation",
- type: "boolean"
- },
- {
- name: "noImplicitAny",
- type: "boolean",
- description: ts.Diagnostics.Raise_error_on_expressions_and_declarations_with_an_implied_any_type,
- },
- {
- name: "noImplicitThis",
- type: "boolean",
- description: ts.Diagnostics.Raise_error_on_this_expressions_with_an_implied_any_type,
- },
- {
- name: "noUnusedLocals",
- type: "boolean",
- description: ts.Diagnostics.Report_errors_on_unused_locals,
+ name: "lib",
+ type: "list",
+ element: {
+ name: "lib",
+ type: ts.createMapFromTemplate({
+ "es5": "lib.es5.d.ts",
+ "es6": "lib.es2015.d.ts",
+ "es2015": "lib.es2015.d.ts",
+ "es7": "lib.es2016.d.ts",
+ "es2016": "lib.es2016.d.ts",
+ "es2017": "lib.es2017.d.ts",
+ "esnext": "lib.esnext.d.ts",
+ "dom": "lib.dom.d.ts",
+ "dom.iterable": "lib.dom.iterable.d.ts",
+ "webworker": "lib.webworker.d.ts",
+ "scripthost": "lib.scripthost.d.ts",
+ "es2015.core": "lib.es2015.core.d.ts",
+ "es2015.collection": "lib.es2015.collection.d.ts",
+ "es2015.generator": "lib.es2015.generator.d.ts",
+ "es2015.iterable": "lib.es2015.iterable.d.ts",
+ "es2015.promise": "lib.es2015.promise.d.ts",
+ "es2015.proxy": "lib.es2015.proxy.d.ts",
+ "es2015.reflect": "lib.es2015.reflect.d.ts",
+ "es2015.symbol": "lib.es2015.symbol.d.ts",
+ "es2015.symbol.wellknown": "lib.es2015.symbol.wellknown.d.ts",
+ "es2016.array.include": "lib.es2016.array.include.d.ts",
+ "es2017.object": "lib.es2017.object.d.ts",
+ "es2017.sharedmemory": "lib.es2017.sharedmemory.d.ts",
+ "es2017.string": "lib.es2017.string.d.ts",
+ "esnext.asynciterable": "lib.esnext.asynciterable.d.ts",
+ }),
+ },
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Specify_library_files_to_be_included_in_the_compilation_Colon
},
{
- name: "noUnusedParameters",
+ name: "allowJs",
type: "boolean",
- description: ts.Diagnostics.Report_errors_on_unused_parameters,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Allow_javascript_files_to_be_compiled
},
{
- name: "noLib",
+ name: "checkJs",
type: "boolean",
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Report_errors_in_js_files
},
{
- name: "noResolve",
- type: "boolean",
+ name: "jsx",
+ type: ts.createMapFromTemplate({
+ "preserve": 1,
+ "react-native": 3,
+ "react": 2
+ }),
+ paramType: ts.Diagnostics.KIND,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Specify_JSX_code_generation_Colon_preserve_react_native_or_react,
},
{
- name: "skipDefaultLibCheck",
+ name: "declaration",
+ shortName: "d",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Generates_corresponding_d_ts_file,
},
{
- name: "skipLibCheck",
+ name: "sourceMap",
type: "boolean",
- description: ts.Diagnostics.Skip_type_checking_of_declaration_files,
- },
- {
- name: "out",
- type: "string",
- isFilePath: false,
- paramType: ts.Diagnostics.FILE,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Generates_corresponding_map_file,
},
{
name: "outFile",
type: "string",
isFilePath: true,
- description: ts.Diagnostics.Concatenate_and_emit_output_to_single_file,
paramType: ts.Diagnostics.FILE,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Concatenate_and_emit_output_to_single_file,
},
{
name: "outDir",
type: "string",
isFilePath: true,
- description: ts.Diagnostics.Redirect_output_structure_to_the_directory,
paramType: ts.Diagnostics.DIRECTORY,
- },
- {
- name: "preserveConstEnums",
- type: "boolean",
- description: ts.Diagnostics.Do_not_erase_const_enum_declarations_in_generated_code
- },
- {
- name: "pretty",
- description: ts.Diagnostics.Stylize_errors_and_messages_using_color_and_context_experimental,
- type: "boolean"
- },
- {
- name: "project",
- shortName: "p",
- type: "string",
- isFilePath: true,
- description: ts.Diagnostics.Compile_the_project_in_the_given_directory,
- paramType: ts.Diagnostics.DIRECTORY
- },
- {
- name: "removeComments",
- type: "boolean",
- description: ts.Diagnostics.Do_not_emit_comments_to_output,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Redirect_output_structure_to_the_directory,
},
{
name: "rootDir",
type: "string",
isFilePath: true,
paramType: ts.Diagnostics.LOCATION,
+ category: ts.Diagnostics.Basic_Options,
description: ts.Diagnostics.Specify_the_root_directory_of_input_files_Use_to_control_the_output_directory_structure_with_outDir,
},
{
- name: "isolatedModules",
+ name: "removeComments",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Do_not_emit_comments_to_output,
},
{
- name: "sourceMap",
+ name: "noEmit",
type: "boolean",
- description: ts.Diagnostics.Generates_corresponding_map_file,
- },
- {
- name: "sourceRoot",
- type: "string",
- isFilePath: true,
- description: ts.Diagnostics.Specify_the_location_where_debugger_should_locate_TypeScript_files_instead_of_source_locations,
- paramType: ts.Diagnostics.LOCATION,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Do_not_emit_outputs,
},
{
- name: "suppressExcessPropertyErrors",
+ name: "importHelpers",
type: "boolean",
- description: ts.Diagnostics.Suppress_excess_property_checks_for_object_literals,
- experimental: true
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Import_emit_helpers_from_tslib
},
{
- name: "suppressImplicitAnyIndexErrors",
+ name: "downlevelIteration",
type: "boolean",
- description: ts.Diagnostics.Suppress_noImplicitAny_errors_for_indexing_objects_lacking_index_signatures,
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Provide_full_support_for_iterables_in_for_of_spread_and_destructuring_when_targeting_ES5_or_ES3
},
{
- name: "stripInternal",
+ name: "isolatedModules",
type: "boolean",
- description: ts.Diagnostics.Do_not_emit_declarations_for_code_that_has_an_internal_annotation,
- experimental: true
+ category: ts.Diagnostics.Basic_Options,
+ description: ts.Diagnostics.Transpile_each_file_as_a_separate_module_similar_to_ts_transpileModule
},
{
- name: "target",
- shortName: "t",
- type: ts.createMap({
- "es3": 0,
- "es5": 1,
- "es6": 2,
- "es2015": 2,
- "es2016": 3,
- "es2017": 4,
- "esnext": 5,
- }),
- description: ts.Diagnostics.Specify_ECMAScript_target_version_Colon_ES3_default_ES5_or_ES2015,
- paramType: ts.Diagnostics.VERSION,
+ name: "strict",
+ type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Strict_Type_Checking_Options,
+ description: ts.Diagnostics.Enable_all_strict_type_checking_options
},
{
- name: "version",
- shortName: "v",
+ name: "noImplicitAny",
type: "boolean",
- description: ts.Diagnostics.Print_the_compiler_s_version,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Strict_Type_Checking_Options,
+ description: ts.Diagnostics.Raise_error_on_expressions_and_declarations_with_an_implied_any_type,
},
{
- name: "watch",
- shortName: "w",
+ name: "strictNullChecks",
type: "boolean",
- description: ts.Diagnostics.Watch_input_files,
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Strict_Type_Checking_Options,
+ description: ts.Diagnostics.Enable_strict_null_checks
},
{
- name: "experimentalDecorators",
+ name: "noImplicitThis",
type: "boolean",
- description: ts.Diagnostics.Enables_experimental_support_for_ES7_decorators
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Strict_Type_Checking_Options,
+ description: ts.Diagnostics.Raise_error_on_this_expressions_with_an_implied_any_type,
},
{
- name: "emitDecoratorMetadata",
+ name: "alwaysStrict",
type: "boolean",
- experimental: true,
- description: ts.Diagnostics.Enables_experimental_support_for_emitting_type_metadata_for_decorators
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Strict_Type_Checking_Options,
+ description: ts.Diagnostics.Parse_in_strict_mode_and_emit_use_strict_for_each_source_file
},
{
- name: "moduleResolution",
- type: ts.createMap({
- "node": ts.ModuleResolutionKind.NodeJs,
- "classic": ts.ModuleResolutionKind.Classic,
- }),
- description: ts.Diagnostics.Specify_module_resolution_strategy_Colon_node_Node_js_or_classic_TypeScript_pre_1_6,
- paramType: ts.Diagnostics.STRATEGY,
+ name: "noUnusedLocals",
+ type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Additional_Checks,
+ description: ts.Diagnostics.Report_errors_on_unused_locals,
},
{
- name: "allowUnusedLabels",
+ name: "noUnusedParameters",
type: "boolean",
- description: ts.Diagnostics.Do_not_report_errors_on_unused_labels
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Additional_Checks,
+ description: ts.Diagnostics.Report_errors_on_unused_parameters,
},
{
name: "noImplicitReturns",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Additional_Checks,
description: ts.Diagnostics.Report_error_when_not_all_code_paths_in_function_return_a_value
},
{
name: "noFallthroughCasesInSwitch",
type: "boolean",
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Additional_Checks,
description: ts.Diagnostics.Report_errors_for_fallthrough_cases_in_switch_statement
},
{
- name: "allowUnreachableCode",
- type: "boolean",
- description: ts.Diagnostics.Do_not_report_errors_on_unreachable_code
- },
- {
- name: "forceConsistentCasingInFileNames",
- type: "boolean",
- description: ts.Diagnostics.Disallow_inconsistently_cased_references_to_the_same_file
+ name: "moduleResolution",
+ type: ts.createMapFromTemplate({
+ "node": ts.ModuleResolutionKind.NodeJs,
+ "classic": ts.ModuleResolutionKind.Classic,
+ }),
+ paramType: ts.Diagnostics.STRATEGY,
+ category: ts.Diagnostics.Module_Resolution_Options,
+ description: ts.Diagnostics.Specify_module_resolution_strategy_Colon_node_Node_js_or_classic_TypeScript_pre_1_6,
},
{
name: "baseUrl",
type: "string",
isFilePath: true,
+ category: ts.Diagnostics.Module_Resolution_Options,
description: ts.Diagnostics.Base_directory_to_resolve_non_absolute_module_names
},
{
name: "paths",
type: "object",
- isTSConfigOnly: true
+ isTSConfigOnly: true,
+ category: ts.Diagnostics.Module_Resolution_Options,
+ description: ts.Diagnostics.A_series_of_entries_which_re_map_imports_to_lookup_locations_relative_to_the_baseUrl
},
{
name: "rootDirs",
@@ -50648,7 +54764,9 @@ var ts;
name: "rootDirs",
type: "string",
isFilePath: true
- }
+ },
+ category: ts.Diagnostics.Module_Resolution_Options,
+ description: ts.Diagnostics.List_of_root_folders_whose_combined_content_represents_the_structure_of_the_project_at_runtime
},
{
name: "typeRoots",
@@ -50657,7 +54775,9 @@ var ts;
name: "typeRoots",
type: "string",
isFilePath: true
- }
+ },
+ category: ts.Diagnostics.Module_Resolution_Options,
+ description: ts.Diagnostics.List_of_folders_to_include_type_definitions_from
},
{
name: "types",
@@ -50666,88 +54786,253 @@ var ts;
name: "types",
type: "string"
},
+ showInSimplifiedHelpView: true,
+ category: ts.Diagnostics.Module_Resolution_Options,
description: ts.Diagnostics.Type_declaration_files_to_be_included_in_compilation
},
{
+ name: "allowSyntheticDefaultImports",
+ type: "boolean",
+ category: ts.Diagnostics.Module_Resolution_Options,
+ description: ts.Diagnostics.Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typechecking
+ },
+ {
+ name: "sourceRoot",
+ type: "string",
+ isFilePath: true,
+ paramType: ts.Diagnostics.LOCATION,
+ category: ts.Diagnostics.Source_Map_Options,
+ description: ts.Diagnostics.Specify_the_location_where_debugger_should_locate_TypeScript_files_instead_of_source_locations,
+ },
+ {
+ name: "mapRoot",
+ type: "string",
+ isFilePath: true,
+ paramType: ts.Diagnostics.LOCATION,
+ category: ts.Diagnostics.Source_Map_Options,
+ description: ts.Diagnostics.Specify_the_location_where_debugger_should_locate_map_files_instead_of_generated_locations,
+ },
+ {
+ name: "inlineSourceMap",
+ type: "boolean",
+ category: ts.Diagnostics.Source_Map_Options,
+ description: ts.Diagnostics.Emit_a_single_file_with_source_maps_instead_of_having_a_separate_file
+ },
+ {
+ name: "inlineSources",
+ type: "boolean",
+ category: ts.Diagnostics.Source_Map_Options,
+ description: ts.Diagnostics.Emit_the_source_alongside_the_sourcemaps_within_a_single_file_requires_inlineSourceMap_or_sourceMap_to_be_set
+ },
+ {
+ name: "experimentalDecorators",
+ type: "boolean",
+ category: ts.Diagnostics.Experimental_Options,
+ description: ts.Diagnostics.Enables_experimental_support_for_ES7_decorators
+ },
+ {
+ name: "emitDecoratorMetadata",
+ type: "boolean",
+ category: ts.Diagnostics.Experimental_Options,
+ description: ts.Diagnostics.Enables_experimental_support_for_emitting_type_metadata_for_decorators
+ },
+ {
+ name: "jsxFactory",
+ type: "string",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h
+ },
+ {
+ name: "diagnostics",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Show_diagnostic_information
+ },
+ {
+ name: "extendedDiagnostics",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Show_verbose_diagnostic_information
+ },
+ {
name: "traceResolution",
type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
description: ts.Diagnostics.Enable_tracing_of_the_name_resolution_process
},
{
- name: "allowJs",
+ name: "listFiles",
type: "boolean",
- description: ts.Diagnostics.Allow_javascript_files_to_be_compiled
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Print_names_of_files_part_of_the_compilation
},
{
- name: "allowSyntheticDefaultImports",
+ name: "listEmittedFiles",
type: "boolean",
- description: ts.Diagnostics.Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typechecking
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Print_names_of_generated_files_part_of_the_compilation
+ },
+ {
+ name: "out",
+ type: "string",
+ isFilePath: false,
+ category: ts.Diagnostics.Advanced_Options,
+ paramType: ts.Diagnostics.FILE,
+ description: ts.Diagnostics.Deprecated_Use_outFile_instead_Concatenate_and_emit_output_to_single_file,
+ },
+ {
+ name: "reactNamespace",
+ type: "string",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Deprecated_Use_jsxFactory_instead_Specify_the_object_invoked_for_createElement_when_targeting_react_JSX_emit
+ },
+ {
+ name: "skipDefaultLibCheck",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Deprecated_Use_skipLibCheck_instead_Skip_type_checking_of_default_library_declaration_files
+ },
+ {
+ name: "charset",
+ type: "string",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.The_character_set_of_the_input_files
+ },
+ {
+ name: "emitBOM",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files
+ },
+ {
+ name: "locale",
+ type: "string",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.The_locale_used_when_displaying_messages_to_the_user_e_g_en_us
+ },
+ {
+ name: "newLine",
+ type: ts.createMapFromTemplate({
+ "crlf": 0,
+ "lf": 1
+ }),
+ paramType: ts.Diagnostics.NEWLINE,
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Specify_the_end_of_line_sequence_to_be_used_when_emitting_files_Colon_CRLF_dos_or_LF_unix,
+ },
+ {
+ name: "noErrorTruncation",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_truncate_error_messages
+ },
+ {
+ name: "noLib",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_include_the_default_library_file_lib_d_ts
+ },
+ {
+ name: "noResolve",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_add_triple_slash_references_or_imported_modules_to_the_list_of_compiled_files
+ },
+ {
+ name: "stripInternal",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_emit_declarations_for_code_that_has_an_internal_annotation,
+ },
+ {
+ name: "disableSizeLimit",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Disable_size_limitations_on_JavaScript_projects
},
{
name: "noImplicitUseStrict",
type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
description: ts.Diagnostics.Do_not_emit_use_strict_directives_in_module_output
},
{
- name: "maxNodeModuleJsDepth",
- type: "number",
- description: ts.Diagnostics.The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files
+ name: "noEmitHelpers",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_generate_custom_helper_functions_like_extends_in_compiled_output
},
{
- name: "listEmittedFiles",
- type: "boolean"
+ name: "noEmitOnError",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_emit_outputs_if_any_errors_were_reported,
},
{
- name: "lib",
- type: "list",
- element: {
- name: "lib",
- type: ts.createMap({
- "es5": "lib.es5.d.ts",
- "es6": "lib.es2015.d.ts",
- "es2015": "lib.es2015.d.ts",
- "es7": "lib.es2016.d.ts",
- "es2016": "lib.es2016.d.ts",
- "es2017": "lib.es2017.d.ts",
- "dom": "lib.dom.d.ts",
- "dom.iterable": "lib.dom.iterable.d.ts",
- "webworker": "lib.webworker.d.ts",
- "scripthost": "lib.scripthost.d.ts",
- "es2015.core": "lib.es2015.core.d.ts",
- "es2015.collection": "lib.es2015.collection.d.ts",
- "es2015.generator": "lib.es2015.generator.d.ts",
- "es2015.iterable": "lib.es2015.iterable.d.ts",
- "es2015.promise": "lib.es2015.promise.d.ts",
- "es2015.proxy": "lib.es2015.proxy.d.ts",
- "es2015.reflect": "lib.es2015.reflect.d.ts",
- "es2015.symbol": "lib.es2015.symbol.d.ts",
- "es2015.symbol.wellknown": "lib.es2015.symbol.wellknown.d.ts",
- "es2016.array.include": "lib.es2016.array.include.d.ts",
- "es2017.object": "lib.es2017.object.d.ts",
- "es2017.sharedmemory": "lib.es2017.sharedmemory.d.ts",
- "es2017.string": "lib.es2017.string.d.ts",
- }),
- },
- description: ts.Diagnostics.Specify_library_files_to_be_included_in_the_compilation_Colon
+ name: "preserveConstEnums",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_erase_const_enum_declarations_in_generated_code
},
{
- name: "disableSizeLimit",
- type: "boolean"
+ name: "declarationDir",
+ type: "string",
+ isFilePath: true,
+ paramType: ts.Diagnostics.DIRECTORY,
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Output_directory_for_generated_declaration_files
},
{
- name: "strictNullChecks",
+ name: "skipLibCheck",
type: "boolean",
- description: ts.Diagnostics.Enable_strict_null_checks
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Skip_type_checking_of_declaration_files,
},
{
- name: "importHelpers",
+ name: "allowUnusedLabels",
type: "boolean",
- description: ts.Diagnostics.Import_emit_helpers_from_tslib
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_report_errors_on_unused_labels
},
{
- name: "alwaysStrict",
+ name: "allowUnreachableCode",
type: "boolean",
- description: ts.Diagnostics.Parse_in_strict_mode_and_emit_use_strict_for_each_source_file
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Do_not_report_errors_on_unreachable_code
+ },
+ {
+ name: "suppressExcessPropertyErrors",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Suppress_excess_property_checks_for_object_literals,
+ },
+ {
+ name: "suppressImplicitAnyIndexErrors",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Suppress_noImplicitAny_errors_for_indexing_objects_lacking_index_signatures,
+ },
+ {
+ name: "forceConsistentCasingInFileNames",
+ type: "boolean",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.Disallow_inconsistently_cased_references_to_the_same_file
+ },
+ {
+ name: "maxNodeModuleJsDepth",
+ type: "number",
+ category: ts.Diagnostics.Advanced_Options,
+ description: ts.Diagnostics.The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files
+ },
+ {
+ name: "plugins",
+ type: "list",
+ isTSConfigOnly: true,
+ element: {
+ name: "plugin",
+ type: "object"
+ },
+ description: ts.Diagnostics.List_of_language_service_plugins
}
];
ts.typeAcquisitionDeclarations = [
@@ -50779,8 +55064,7 @@ var ts;
ts.defaultInitCompilerOptions = {
module: ts.ModuleKind.CommonJS,
target: 1,
- noImplicitAny: false,
- sourceMap: false,
+ strict: true
};
var optionNameMapCache;
function convertEnableAutoDiscoveryToEnable(typeAcquisition) {
@@ -50802,9 +55086,9 @@ var ts;
var optionNameMap = ts.createMap();
var shortOptionNames = ts.createMap();
ts.forEach(ts.optionDeclarations, function (option) {
- optionNameMap[option.name.toLowerCase()] = option;
+ optionNameMap.set(option.name.toLowerCase(), option);
if (option.shortName) {
- shortOptionNames[option.shortName] = option.name;
+ shortOptionNames.set(option.shortName, option.name);
}
});
optionNameMapCache = { optionNameMap: optionNameMap, shortOptionNames: shortOptionNames };
@@ -50812,19 +55096,12 @@ var ts;
}
ts.getOptionNameMap = getOptionNameMap;
function createCompilerDiagnosticForInvalidCustomType(opt) {
- var namesOfType = Object.keys(opt.type).map(function (key) { return "'" + key + "'"; }).join(", ");
+ var namesOfType = ts.arrayFrom(opt.type.keys()).map(function (key) { return "'" + key + "'"; }).join(", ");
return ts.createCompilerDiagnostic(ts.Diagnostics.Argument_for_0_option_must_be_Colon_1, "--" + opt.name, namesOfType);
}
ts.createCompilerDiagnosticForInvalidCustomType = createCompilerDiagnosticForInvalidCustomType;
function parseCustomTypeOption(opt, value, errors) {
- var key = trimString((value || "")).toLowerCase();
- var map = opt.type;
- if (key in map) {
- return map[key];
- }
- else {
- errors.push(createCompilerDiagnosticForInvalidCustomType(opt));
- }
+ return convertJsonOptionOfCustomType(opt, trimString(value || ""), errors);
}
ts.parseCustomTypeOption = parseCustomTypeOption;
function parseListTypeOption(opt, value, errors) {
@@ -50868,11 +55145,12 @@ var ts;
}
else if (s.charCodeAt(0) === 45) {
s = s.slice(s.charCodeAt(1) === 45 ? 2 : 1).toLowerCase();
- if (s in shortOptionNames) {
- s = shortOptionNames[s];
+ var short = shortOptionNames.get(s);
+ if (short !== undefined) {
+ s = short;
}
- if (s in optionNameMap) {
- var opt = optionNameMap[s];
+ var opt = optionNameMap.get(s);
+ if (opt) {
if (opt.isTSConfigOnly) {
errors.push(ts.createCompilerDiagnostic(ts.Diagnostics.Option_0_can_only_be_specified_in_tsconfig_json_file, opt.name));
}
@@ -50977,7 +55255,7 @@ var ts;
}
}
ts.parseConfigFileTextToJson = parseConfigFileTextToJson;
- function generateTSConfig(options, fileNames) {
+ function generateTSConfig(options, fileNames, newLine) {
var compilerOptions = ts.extend(options, ts.defaultInitCompilerOptions);
var configurations = {
compilerOptions: serializeCompilerOptions(compilerOptions)
@@ -50985,7 +55263,7 @@ var ts;
if (fileNames && fileNames.length) {
configurations.files = fileNames;
}
- return configurations;
+ return writeConfigurations();
function getCustomTypeMapOfCommandLineOption(optionDefinition) {
if (optionDefinition.type === "string" || optionDefinition.type === "number" || optionDefinition.type === "boolean") {
return undefined;
@@ -50998,53 +55276,121 @@ var ts;
}
}
function getNameOfCompilerOptionValue(value, customTypeMap) {
- for (var key in customTypeMap) {
- if (customTypeMap[key] === value) {
+ return ts.forEachEntry(customTypeMap, function (mapValue, key) {
+ if (mapValue === value) {
return key;
}
- }
- return undefined;
+ });
}
function serializeCompilerOptions(options) {
- var result = ts.createMap();
+ var result = {};
var optionsNameMap = getOptionNameMap().optionNameMap;
- for (var name_42 in options) {
- if (ts.hasProperty(options, name_42)) {
- switch (name_42) {
- case "init":
- case "watch":
- case "version":
- case "help":
- case "project":
- break;
- default:
- var value = options[name_42];
- var optionDefinition = optionsNameMap[name_42.toLowerCase()];
- if (optionDefinition) {
- var customTypeMap = getCustomTypeMapOfCommandLineOption(optionDefinition);
- if (!customTypeMap) {
- result[name_42] = value;
- }
- else {
- if (optionDefinition.type === "list") {
- var convertedValue = [];
- for (var _i = 0, _a = value; _i < _a.length; _i++) {
- var element = _a[_i];
- convertedValue.push(getNameOfCompilerOptionValue(element, customTypeMap));
- }
- result[name_42] = convertedValue;
- }
- else {
- result[name_42] = getNameOfCompilerOptionValue(value, customTypeMap);
- }
+ for (var name in options) {
+ if (ts.hasProperty(options, name)) {
+ if (optionsNameMap.has(name) && optionsNameMap.get(name).category === ts.Diagnostics.Command_line_Options) {
+ continue;
+ }
+ var value = options[name];
+ var optionDefinition = optionsNameMap.get(name.toLowerCase());
+ if (optionDefinition) {
+ var customTypeMap = getCustomTypeMapOfCommandLineOption(optionDefinition);
+ if (!customTypeMap) {
+ result[name] = value;
+ }
+ else {
+ if (optionDefinition.type === "list") {
+ var convertedValue = [];
+ for (var _i = 0, _a = value; _i < _a.length; _i++) {
+ var element = _a[_i];
+ convertedValue.push(getNameOfCompilerOptionValue(element, customTypeMap));
}
+ result[name] = convertedValue;
}
- break;
+ else {
+ result[name] = getNameOfCompilerOptionValue(value, customTypeMap);
+ }
+ }
}
}
}
return result;
}
+ function getDefaultValueForOption(option) {
+ switch (option.type) {
+ case "number":
+ return 1;
+ case "boolean":
+ return true;
+ case "string":
+ return option.isFilePath ? "./" : "";
+ case "list":
+ return [];
+ case "object":
+ return {};
+ default:
+ return ts.arrayFrom(option.type.keys())[0];
+ }
+ }
+ function makePadding(paddingLength) {
+ return Array(paddingLength + 1).join(" ");
+ }
+ function writeConfigurations() {
+ var categorizedOptions = ts.reduceLeft(ts.filter(ts.optionDeclarations, function (o) { return o.category !== ts.Diagnostics.Command_line_Options && o.category !== ts.Diagnostics.Advanced_Options; }), function (memo, value) {
+ if (value.category) {
+ var name = ts.getLocaleSpecificMessage(value.category);
+ (memo[name] || (memo[name] = [])).push(value);
+ }
+ return memo;
+ }, {});
+ var marginLength = 0;
+ var seenKnownKeys = 0;
+ var nameColumn = [];
+ var descriptionColumn = [];
+ var knownKeysCount = ts.getOwnKeys(configurations.compilerOptions).length;
+ for (var category in categorizedOptions) {
+ if (nameColumn.length !== 0) {
+ nameColumn.push("");
+ descriptionColumn.push("");
+ }
+ nameColumn.push("/* " + category + " */");
+ descriptionColumn.push("");
+ for (var _i = 0, _a = categorizedOptions[category]; _i < _a.length; _i++) {
+ var option = _a[_i];
+ var optionName = void 0;
+ if (ts.hasProperty(configurations.compilerOptions, option.name)) {
+ optionName = "\"" + option.name + "\": " + JSON.stringify(configurations.compilerOptions[option.name]) + ((seenKnownKeys += 1) === knownKeysCount ? "" : ",");
+ }
+ else {
+ optionName = "// \"" + option.name + "\": " + JSON.stringify(getDefaultValueForOption(option)) + ",";
+ }
+ nameColumn.push(optionName);
+ descriptionColumn.push("/* " + (option.description && ts.getLocaleSpecificMessage(option.description) || option.name) + " */");
+ marginLength = Math.max(optionName.length, marginLength);
+ }
+ }
+ var tab = makePadding(2);
+ var result = [];
+ result.push("{");
+ result.push(tab + "\"compilerOptions\": {");
+ for (var i = 0; i < nameColumn.length; i++) {
+ var optionName = nameColumn[i];
+ var description = descriptionColumn[i];
+ result.push(tab + tab + optionName + makePadding(marginLength - optionName.length + 2) + description);
+ }
+ if (configurations.files && configurations.files.length) {
+ result.push(tab + "},");
+ result.push(tab + "\"files\": [");
+ for (var i = 0; i < configurations.files.length; i++) {
+ result.push("" + tab + tab + JSON.stringify(configurations.files[i]) + (i === configurations.files.length - 1 ? "" : ","));
+ }
+ result.push(tab + "]");
+ }
+ else {
+ result.push(tab + "}");
+ }
+ result.push("}");
+ return result.join(newLine);
+ }
}
ts.generateTSConfig = generateTSConfig;
function removeComments(jsonText) {
@@ -51064,10 +55410,12 @@ var ts;
}
return output;
}
- function parseJsonConfigFileContent(json, host, basePath, existingOptions, configFileName, resolutionStack) {
+ function parseJsonConfigFileContent(json, host, basePath, existingOptions, configFileName, resolutionStack, extraFileExtensions) {
if (existingOptions === void 0) { existingOptions = {}; }
if (resolutionStack === void 0) { resolutionStack = []; }
+ if (extraFileExtensions === void 0) { extraFileExtensions = []; }
var errors = [];
+ basePath = ts.normalizeSlashes(basePath);
var getCanonicalFileName = ts.createGetCanonicalFileName(host.useCaseSensitiveFileNames);
var resolvedPath = ts.toPath(configFileName || "", basePath, getCanonicalFileName);
if (resolutionStack.indexOf(resolvedPath) >= 0) {
@@ -51189,7 +55537,7 @@ var ts;
if (fileNames === undefined && includeSpecs === undefined) {
includeSpecs = ["**/*"];
}
- var result = matchFileNames(fileNames, includeSpecs, excludeSpecs, basePath, options, host, errors);
+ var result = matchFileNames(fileNames, includeSpecs, excludeSpecs, basePath, options, host, errors, extraFileExtensions);
if (result.fileNames.length === 0 && !ts.hasProperty(json, "files") && resolutionStack.length === 0) {
errors.push(ts.createCompilerDiagnostic(ts.Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2, configFileName || "tsconfig.json", JSON.stringify(includeSpecs || []), JSON.stringify(excludeSpecs || [])));
}
@@ -51240,8 +55588,8 @@ var ts;
}
var optionNameMap = ts.arrayToMap(optionDeclarations, function (opt) { return opt.name; });
for (var id in jsonOptions) {
- if (id in optionNameMap) {
- var opt = optionNameMap[id];
+ var opt = optionNameMap.get(id);
+ if (opt) {
defaultOptions[opt.name] = convertJsonOption(opt, jsonOptions[id], basePath, errors);
}
else {
@@ -51275,8 +55623,9 @@ var ts;
}
function convertJsonOptionOfCustomType(opt, value, errors) {
var key = value.toLowerCase();
- if (key in opt.type) {
- return opt.type[key];
+ var val = opt.type.get(key);
+ if (val !== undefined) {
+ return val;
}
else {
errors.push(createCompilerDiagnosticForInvalidCustomType(opt));
@@ -51293,7 +55642,7 @@ var ts;
var invalidDotDotAfterRecursiveWildcardPattern = /(^|\/)\*\*\/(.*\/)?\.\.($|\/)/;
var watchRecursivePattern = /\/[^/]*?[*?][^/]*\//;
var wildcardDirectoryPattern = /^[^*?]*(?=\/[^/]*[*?])/;
- function matchFileNames(fileNames, include, exclude, basePath, options, host, errors) {
+ function matchFileNames(fileNames, include, exclude, basePath, options, host, errors, extraFileExtensions) {
basePath = ts.normalizePath(basePath);
var keyMapper = host.useCaseSensitiveFileNames ? caseSensitiveKeyMapper : caseInsensitiveKeyMapper;
var literalFileMap = ts.createMap();
@@ -51305,12 +55654,12 @@ var ts;
exclude = validateSpecs(exclude, errors, true);
}
var wildcardDirectories = getWildcardDirectories(include, exclude, basePath, host.useCaseSensitiveFileNames);
- var supportedExtensions = ts.getSupportedExtensions(options);
+ var supportedExtensions = ts.getSupportedExtensions(options, extraFileExtensions);
if (fileNames) {
for (var _i = 0, fileNames_1 = fileNames; _i < fileNames_1.length; _i++) {
var fileName = fileNames_1[_i];
var file = ts.combinePaths(basePath, fileName);
- literalFileMap[keyMapper(file)] = file;
+ literalFileMap.set(keyMapper(file), file);
}
}
if (include && include.length > 0) {
@@ -51321,14 +55670,13 @@ var ts;
}
removeWildcardFilesWithLowerPriorityExtension(file, wildcardFileMap, supportedExtensions, keyMapper);
var key = keyMapper(file);
- if (!(key in literalFileMap) && !(key in wildcardFileMap)) {
- wildcardFileMap[key] = file;
+ if (!literalFileMap.has(key) && !wildcardFileMap.has(key)) {
+ wildcardFileMap.set(key, file);
}
}
}
- var literalFiles = ts.reduceProperties(literalFileMap, addFileToOutput, []);
- var wildcardFiles = ts.reduceProperties(wildcardFileMap, addFileToOutput, []);
- wildcardFiles.sort(host.useCaseSensitiveFileNames ? ts.compareStrings : ts.compareStringsCaseInsensitive);
+ var literalFiles = ts.arrayFrom(literalFileMap.values());
+ var wildcardFiles = ts.arrayFrom(wildcardFileMap.values());
return {
fileNames: literalFiles.concat(wildcardFiles),
wildcardDirectories: wildcardDirectories
@@ -51336,8 +55684,8 @@ var ts;
}
function validateSpecs(specs, errors, allowTrailingRecursion) {
var validSpecs = [];
- for (var _i = 0, specs_2 = specs; _i < specs_2.length; _i++) {
- var spec = specs_2[_i];
+ for (var _i = 0, specs_1 = specs; _i < specs_1.length; _i++) {
+ var spec = specs_1[_i];
if (!allowTrailingRecursion && invalidTrailingRecursionPattern.test(spec)) {
errors.push(ts.createCompilerDiagnostic(ts.Diagnostics.File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0, spec));
}
@@ -51356,7 +55704,7 @@ var ts;
function getWildcardDirectories(include, exclude, path, useCaseSensitiveFileNames) {
var rawExcludeRegex = ts.getRegularExpressionForWildcard(exclude, path, "exclude");
var excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames ? "" : "i");
- var wildcardDirectories = ts.createMap();
+ var wildcardDirectories = {};
if (include !== undefined) {
var recursiveKeys = [];
for (var _i = 0, include_1 = include; _i < include_1.length; _i++) {
@@ -51377,14 +55725,15 @@ var ts;
}
}
}
- for (var key in wildcardDirectories) {
- for (var _a = 0, recursiveKeys_1 = recursiveKeys; _a < recursiveKeys_1.length; _a++) {
- var recursiveKey = recursiveKeys_1[_a];
- if (key !== recursiveKey && ts.containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames)) {
- delete wildcardDirectories[key];
+ for (var key in wildcardDirectories)
+ if (ts.hasProperty(wildcardDirectories, key)) {
+ for (var _a = 0, recursiveKeys_1 = recursiveKeys; _a < recursiveKeys_1.length; _a++) {
+ var recursiveKey = recursiveKeys_1[_a];
+ if (key !== recursiveKey && ts.containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames)) {
+ delete wildcardDirectories[key];
+ }
}
}
- }
}
return wildcardDirectories;
}
@@ -51403,11 +55752,11 @@ var ts;
}
function hasFileWithHigherPriorityExtension(file, literalFiles, wildcardFiles, extensions, keyMapper) {
var extensionPriority = ts.getExtensionPriority(file, extensions);
- var adjustedExtensionPriority = ts.adjustExtensionPriority(extensionPriority);
+ var adjustedExtensionPriority = ts.adjustExtensionPriority(extensionPriority, extensions);
for (var i = 0; i < adjustedExtensionPriority; i++) {
var higherPriorityExtension = extensions[i];
var higherPriorityPath = keyMapper(ts.changeExtension(file, higherPriorityExtension));
- if (higherPriorityPath in literalFiles || higherPriorityPath in wildcardFiles) {
+ if (literalFiles.has(higherPriorityPath) || wildcardFiles.has(higherPriorityPath)) {
return true;
}
}
@@ -51415,17 +55764,13 @@ var ts;
}
function removeWildcardFilesWithLowerPriorityExtension(file, wildcardFiles, extensions, keyMapper) {
var extensionPriority = ts.getExtensionPriority(file, extensions);
- var nextExtensionPriority = ts.getNextLowestExtensionPriority(extensionPriority);
+ var nextExtensionPriority = ts.getNextLowestExtensionPriority(extensionPriority, extensions);
for (var i = nextExtensionPriority; i < extensions.length; i++) {
var lowerPriorityExtension = extensions[i];
var lowerPriorityPath = keyMapper(ts.changeExtension(file, lowerPriorityExtension));
- delete wildcardFiles[lowerPriorityPath];
+ wildcardFiles.delete(lowerPriorityPath);
}
}
- function addFileToOutput(output, file) {
- output.push(file);
- return output;
- }
function caseSensitiveKeyMapper(key) {
return key;
}
@@ -51451,7 +55796,7 @@ var ts;
}
}
function reportEmittedFiles(files) {
- if (!files || files.length == 0) {
+ if (!files || files.length === 0) {
return;
}
var currentDir = ts.sys.getCurrentDirectory();
@@ -51486,20 +55831,22 @@ var ts;
var gutterSeparator = " ";
var resetEscapeSequence = "\u001b[0m";
var ellipsis = "...";
- var categoryFormatMap = ts.createMap((_a = {},
- _a[ts.DiagnosticCategory.Warning] = yellowForegroundEscapeSequence,
- _a[ts.DiagnosticCategory.Error] = redForegroundEscapeSequence,
- _a[ts.DiagnosticCategory.Message] = blueForegroundEscapeSequence,
- _a));
+ function getCategoryFormat(category) {
+ switch (category) {
+ case ts.DiagnosticCategory.Warning: return yellowForegroundEscapeSequence;
+ case ts.DiagnosticCategory.Error: return redForegroundEscapeSequence;
+ case ts.DiagnosticCategory.Message: return blueForegroundEscapeSequence;
+ }
+ }
function formatAndReset(text, formatStyle) {
return formatStyle + text + resetEscapeSequence;
}
function reportDiagnosticWithColorAndContext(diagnostic, host) {
var output = "";
if (diagnostic.file) {
- var start = diagnostic.start, length_4 = diagnostic.length, file = diagnostic.file;
+ var start = diagnostic.start, length_5 = diagnostic.length, file = diagnostic.file;
var _a = ts.getLineAndCharacterOfPosition(file, start), firstLine = _a.line, firstLineChar = _a.character;
- var _b = ts.getLineAndCharacterOfPosition(file, start + length_4), lastLine = _b.line, lastLineChar = _b.character;
+ var _b = ts.getLineAndCharacterOfPosition(file, start + length_5), lastLine = _b.line, lastLineChar = _b.character;
var lastLineInFile = ts.getLineAndCharacterOfPosition(file, file.text.length).line;
var relativeFileName = host ? ts.convertToRelativePath(file.fileName, host.getCurrentDirectory(), function (fileName) { return host.getCanonicalFileName(fileName); }) : file.fileName;
var hasMoreThanFiveLines = (lastLine - firstLine) >= 4;
@@ -51539,7 +55886,7 @@ var ts;
output += ts.sys.newLine;
output += relativeFileName + "(" + (firstLine + 1) + "," + (firstLineChar + 1) + "): ";
}
- var categoryColor = categoryFormatMap[diagnostic.category];
+ var categoryColor = getCategoryFormat(diagnostic.category);
var category = ts.DiagnosticCategory[diagnostic.category].toLowerCase();
output += formatAndReset(category, categoryColor) + " TS" + diagnostic.code + ": " + ts.flattenDiagnosticMessageText(diagnostic.messageText, ts.sys.newLine);
output += ts.sys.newLine + ts.sys.newLine;
@@ -51551,7 +55898,7 @@ var ts;
var loc = ts.getLineAndCharacterOfPosition(diagnostic.file, diagnostic.start);
output += diagnostic.file.fileName + "(" + (loc.line + 1) + "," + (loc.character + 1) + "): ";
}
- output += "" + ts.flattenDiagnosticMessageText(diagnostic.messageText, ts.sys.newLine) + ts.sys.newLine;
+ output += "" + ts.flattenDiagnosticMessageText(diagnostic.messageText, ts.sys.newLine) + (ts.sys.newLine + ts.sys.newLine + ts.sys.newLine);
ts.sys.write(output);
}
function padLeft(s, length) {
@@ -51603,9 +55950,9 @@ var ts;
printVersion();
return ts.sys.exit(ts.ExitStatus.Success);
}
- if (commandLine.options.help) {
+ if (commandLine.options.help || commandLine.options.all) {
printVersion();
- printHelp();
+ printHelp(commandLine.options.all);
return ts.sys.exit(ts.ExitStatus.Success);
}
if (commandLine.options.project) {
@@ -51639,7 +55986,7 @@ var ts;
}
if (commandLine.fileNames.length === 0 && !configFileName) {
printVersion();
- printHelp();
+ printHelp(commandLine.options.all);
return ts.sys.exit(ts.ExitStatus.Success);
}
if (ts.isWatchSet(commandLine.options)) {
@@ -51652,7 +55999,7 @@ var ts;
}
if (ts.sys.watchDirectory && configFileName) {
var directory = ts.getDirectoryPath(configFileName);
- directoryWatcher = ts.sys.watchDirectory(directory == "" ? "." : directory, watchedDirectoryChanged, true);
+ directoryWatcher = ts.sys.watchDirectory(directory === "" ? "." : directory, watchedDirectoryChanged, true);
}
}
performCompilation();
@@ -51695,9 +56042,8 @@ var ts;
}
if (!directoryWatcher && ts.sys.watchDirectory && configFileName) {
var directory = ts.getDirectoryPath(configFileName);
- directoryWatcher = ts.sys.watchDirectory(directory == "" ? "." : directory, watchedDirectoryChanged, true);
+ directoryWatcher = ts.sys.watchDirectory(directory === "" ? "." : directory, watchedDirectoryChanged, true);
}
- ;
}
return configParseResult;
}
@@ -51730,9 +56076,11 @@ var ts;
reportWatchDiagnostic(ts.createCompilerDiagnostic(ts.Diagnostics.Compilation_complete_Watching_for_file_changes));
}
function cachedFileExists(fileName) {
- return fileName in cachedExistingFiles
- ? cachedExistingFiles[fileName]
- : cachedExistingFiles[fileName] = hostFileExists(fileName);
+ var fileExists = cachedExistingFiles.get(fileName);
+ if (fileExists === undefined) {
+ cachedExistingFiles.set(fileName, fileExists = hostFileExists(fileName));
+ }
+ return fileExists;
}
function getSourceFile(fileName, languageVersion, onError) {
if (cachedProgram) {
@@ -51884,17 +56232,17 @@ var ts;
var nameSize = 0;
var valueSize = 0;
for (var _i = 0, statistics_1 = statistics; _i < statistics_1.length; _i++) {
- var _a = statistics_1[_i], name_43 = _a.name, value = _a.value;
- if (name_43.length > nameSize) {
- nameSize = name_43.length;
+ var _a = statistics_1[_i], name = _a.name, value = _a.value;
+ if (name.length > nameSize) {
+ nameSize = name.length;
}
if (value.length > valueSize) {
valueSize = value.length;
}
}
for (var _b = 0, statistics_2 = statistics; _b < statistics_2.length; _b++) {
- var _c = statistics_2[_b], name_44 = _c.name, value = _c.value;
- ts.sys.write(padRight(name_44 + ":", nameSize + 2) + padLeft(value.toString(), valueSize) + ts.sys.newLine);
+ var _c = statistics_2[_b], name = _c.name, value = _c.value;
+ ts.sys.write(padRight(name + ":", nameSize + 2) + padLeft(value.toString(), valueSize) + ts.sys.newLine);
}
}
function reportStatisticalValue(name, value) {
@@ -51910,7 +56258,7 @@ var ts;
function printVersion() {
ts.sys.write(getDiagnosticText(ts.Diagnostics.Version_0, ts.version) + ts.sys.newLine);
}
- function printHelp() {
+ function printHelp(showAllOptions) {
var output = [];
var syntaxLength = getDiagnosticText(ts.Diagnostics.Syntax_Colon_0, "").length;
var examplesLength = getDiagnosticText(ts.Diagnostics.Examples_Colon_0, "").length;
@@ -51925,8 +56273,9 @@ var ts;
output.push(padding + "tsc @args.txt" + ts.sys.newLine);
output.push(ts.sys.newLine);
output.push(getDiagnosticText(ts.Diagnostics.Options_Colon) + ts.sys.newLine);
- var optsList = ts.filter(ts.optionDeclarations.slice(), function (v) { return !v.experimental; });
- optsList.sort(function (a, b) { return ts.compareValues(a.name.toLowerCase(), b.name.toLowerCase()); });
+ var optsList = showAllOptions ?
+ ts.optionDeclarations.slice().sort(function (a, b) { return ts.compareValues(a.name.toLowerCase(), b.name.toLowerCase()); }) :
+ ts.filter(ts.optionDeclarations.slice(), function (v) { return v.showInSimplifiedHelpView; });
marginLength = 0;
var usageColumn = [];
var descriptionColumn = [];
@@ -51948,13 +56297,9 @@ var ts;
var description = void 0;
if (option.name === "lib") {
description = getDiagnosticText(option.description);
- var options = [];
var element = option.element;
var typeMap = element.type;
- for (var key in typeMap) {
- options.push("'" + key + "'");
- }
- optionsDescriptionMap[description] = options;
+ optionsDescriptionMap.set(description, ts.arrayFrom(typeMap.keys()).map(function (key) { return "'" + key + "'"; }));
}
else {
description = getDiagnosticText(option.description);
@@ -51969,7 +56314,7 @@ var ts;
for (var i = 0; i < usageColumn.length; i++) {
var usage = usageColumn[i];
var description = descriptionColumn[i];
- var kindsList = optionsDescriptionMap[description];
+ var kindsList = optionsDescriptionMap.get(description);
output.push(usage + makePadding(marginLength - usage.length + 2) + description + ts.sys.newLine);
if (kindsList) {
output.push(makePadding(marginLength + 4));
@@ -52002,12 +56347,11 @@ var ts;
reportDiagnostic(ts.createCompilerDiagnostic(ts.Diagnostics.A_tsconfig_json_file_is_already_defined_at_Colon_0, file), undefined);
}
else {
- ts.sys.writeFile(file, JSON.stringify(ts.generateTSConfig(options, fileNames), undefined, 4));
+ ts.sys.writeFile(file, ts.generateTSConfig(options, fileNames, ts.sys.newLine));
reportDiagnostic(ts.createCompilerDiagnostic(ts.Diagnostics.Successfully_created_a_tsconfig_json_file), undefined);
}
return;
}
- var _a;
})(ts || (ts = {}));
if (ts.sys.tryEnableSourceMapsForHost && /^development$/i.test(ts.sys.getEnvironmentVariable("NODE_ENV"))) {
ts.sys.tryEnableSourceMapsForHost();