typescript 5.5.0-dev.20240603 → 5.5.1-rc
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/tsc.js +76 -51
- package/lib/typescript.js +86 -58
- package/package.json +2 -2
package/lib/tsc.js
CHANGED
|
@@ -18,7 +18,7 @@ and limitations under the License.
|
|
|
18
18
|
|
|
19
19
|
// src/compiler/corePublic.ts
|
|
20
20
|
var versionMajorMinor = "5.5";
|
|
21
|
-
var version =
|
|
21
|
+
var version = "5.5.1-rc";
|
|
22
22
|
|
|
23
23
|
// src/compiler/core.ts
|
|
24
24
|
var emptyArray = [];
|
|
@@ -51544,10 +51544,11 @@ function createTypeChecker(host) {
|
|
|
51544
51544
|
return result ? setTextRange2(context, result, node) : void 0;
|
|
51545
51545
|
}
|
|
51546
51546
|
function createRecoveryBoundary() {
|
|
51547
|
+
let trackedSymbols;
|
|
51547
51548
|
let unreportedErrors;
|
|
51548
51549
|
const oldTracker = context.tracker;
|
|
51549
51550
|
const oldTrackedSymbols = context.trackedSymbols;
|
|
51550
|
-
context.trackedSymbols =
|
|
51551
|
+
context.trackedSymbols = void 0;
|
|
51551
51552
|
const oldEncounteredError = context.encounteredError;
|
|
51552
51553
|
context.tracker = new SymbolTrackerImpl(context, {
|
|
51553
51554
|
...oldTracker.inner,
|
|
@@ -51567,17 +51568,7 @@ function createTypeChecker(host) {
|
|
|
51567
51568
|
markError(() => oldTracker.reportNonSerializableProperty(name));
|
|
51568
51569
|
},
|
|
51569
51570
|
trackSymbol(sym, decl, meaning) {
|
|
51570
|
-
|
|
51571
|
-
sym,
|
|
51572
|
-
decl,
|
|
51573
|
-
meaning,
|
|
51574
|
-
/*shouldComputeAliasesToMakeVisible*/
|
|
51575
|
-
false
|
|
51576
|
-
);
|
|
51577
|
-
if (accessibility.accessibility !== 0 /* Accessible */) {
|
|
51578
|
-
(context.trackedSymbols ?? (context.trackedSymbols = [])).push([sym, decl, meaning]);
|
|
51579
|
-
return true;
|
|
51580
|
-
}
|
|
51571
|
+
(trackedSymbols ?? (trackedSymbols = [])).push([sym, decl, meaning]);
|
|
51581
51572
|
return false;
|
|
51582
51573
|
},
|
|
51583
51574
|
moduleResolverHost: context.tracker.moduleResolverHost
|
|
@@ -51591,13 +51582,12 @@ function createTypeChecker(host) {
|
|
|
51591
51582
|
(unreportedErrors ?? (unreportedErrors = [])).push(unreportedError);
|
|
51592
51583
|
}
|
|
51593
51584
|
function startRecoveryScope2() {
|
|
51594
|
-
|
|
51595
|
-
const initialTrackedSymbolsTop = ((_a = context.trackedSymbols) == null ? void 0 : _a.length) ?? 0;
|
|
51585
|
+
const trackedSymbolsTop = (trackedSymbols == null ? void 0 : trackedSymbols.length) ?? 0;
|
|
51596
51586
|
const unreportedErrorsTop = (unreportedErrors == null ? void 0 : unreportedErrors.length) ?? 0;
|
|
51597
51587
|
return () => {
|
|
51598
51588
|
hadError = false;
|
|
51599
|
-
if (
|
|
51600
|
-
|
|
51589
|
+
if (trackedSymbols) {
|
|
51590
|
+
trackedSymbols.length = trackedSymbolsTop;
|
|
51601
51591
|
}
|
|
51602
51592
|
if (unreportedErrors) {
|
|
51603
51593
|
unreportedErrors.length = unreportedErrorsTop;
|
|
@@ -51606,14 +51596,13 @@ function createTypeChecker(host) {
|
|
|
51606
51596
|
}
|
|
51607
51597
|
function finalizeBoundary2() {
|
|
51608
51598
|
context.tracker = oldTracker;
|
|
51609
|
-
const newTrackedSymbols = context.trackedSymbols;
|
|
51610
51599
|
context.trackedSymbols = oldTrackedSymbols;
|
|
51611
51600
|
context.encounteredError = oldEncounteredError;
|
|
51612
51601
|
unreportedErrors == null ? void 0 : unreportedErrors.forEach((fn) => fn());
|
|
51613
51602
|
if (hadError) {
|
|
51614
51603
|
return false;
|
|
51615
51604
|
}
|
|
51616
|
-
|
|
51605
|
+
trackedSymbols == null ? void 0 : trackedSymbols.forEach(
|
|
51617
51606
|
([symbol, enclosingDeclaration, meaning]) => context.tracker.trackSymbol(
|
|
51618
51607
|
symbol,
|
|
51619
51608
|
enclosingDeclaration,
|
|
@@ -51626,6 +51615,57 @@ function createTypeChecker(host) {
|
|
|
51626
51615
|
function onEnterNewScope(node) {
|
|
51627
51616
|
return enterNewScope(context, node, getParametersInScope(node), getTypeParametersInScope(node));
|
|
51628
51617
|
}
|
|
51618
|
+
function tryVisitSimpleTypeNode(node) {
|
|
51619
|
+
const innerNode = skipTypeParentheses(node);
|
|
51620
|
+
switch (innerNode.kind) {
|
|
51621
|
+
case 183 /* TypeReference */:
|
|
51622
|
+
return tryVisitTypeReference(innerNode);
|
|
51623
|
+
case 186 /* TypeQuery */:
|
|
51624
|
+
return tryVisitTypeQuery(innerNode);
|
|
51625
|
+
case 199 /* IndexedAccessType */:
|
|
51626
|
+
return tryVisitIndexedAccess(innerNode);
|
|
51627
|
+
case 198 /* TypeOperator */:
|
|
51628
|
+
const typeOperatorNode = innerNode;
|
|
51629
|
+
if (typeOperatorNode.operator === 143 /* KeyOfKeyword */) {
|
|
51630
|
+
return tryVisitKeyOf(typeOperatorNode);
|
|
51631
|
+
}
|
|
51632
|
+
}
|
|
51633
|
+
return visitNode(node, visitExistingNodeTreeSymbols, isTypeNode);
|
|
51634
|
+
}
|
|
51635
|
+
function tryVisitIndexedAccess(node) {
|
|
51636
|
+
const resultObjectType = tryVisitSimpleTypeNode(node.objectType);
|
|
51637
|
+
if (resultObjectType === void 0) {
|
|
51638
|
+
return void 0;
|
|
51639
|
+
}
|
|
51640
|
+
return factory.updateIndexedAccessTypeNode(node, resultObjectType, visitNode(node.indexType, visitExistingNodeTreeSymbols, isTypeNode));
|
|
51641
|
+
}
|
|
51642
|
+
function tryVisitKeyOf(node) {
|
|
51643
|
+
Debug.assertEqual(node.operator, 143 /* KeyOfKeyword */);
|
|
51644
|
+
const type = tryVisitSimpleTypeNode(node.type);
|
|
51645
|
+
if (type === void 0) {
|
|
51646
|
+
return void 0;
|
|
51647
|
+
}
|
|
51648
|
+
return factory.updateTypeOperatorNode(node, type);
|
|
51649
|
+
}
|
|
51650
|
+
function tryVisitTypeQuery(node) {
|
|
51651
|
+
const { introducesError, node: exprName } = trackExistingEntityName(node.exprName, context);
|
|
51652
|
+
if (!introducesError) {
|
|
51653
|
+
return factory.updateTypeQueryNode(
|
|
51654
|
+
node,
|
|
51655
|
+
exprName,
|
|
51656
|
+
visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode)
|
|
51657
|
+
);
|
|
51658
|
+
}
|
|
51659
|
+
const serializedName = serializeTypeName(
|
|
51660
|
+
context,
|
|
51661
|
+
node.exprName,
|
|
51662
|
+
/*isTypeOf*/
|
|
51663
|
+
true
|
|
51664
|
+
);
|
|
51665
|
+
if (serializedName) {
|
|
51666
|
+
return setTextRange2(context, serializedName, node.exprName);
|
|
51667
|
+
}
|
|
51668
|
+
}
|
|
51629
51669
|
function tryVisitTypeReference(node) {
|
|
51630
51670
|
if (canReuseTypeNode(context, node)) {
|
|
51631
51671
|
const { introducesError, node: newName } = trackExistingEntityName(node.typeName, context);
|
|
@@ -51759,13 +51799,13 @@ function createTypeChecker(host) {
|
|
|
51759
51799
|
visitNode(node.default, visitExistingNodeTreeSymbols, isTypeNode)
|
|
51760
51800
|
);
|
|
51761
51801
|
}
|
|
51762
|
-
if (isIndexedAccessTypeNode(node)
|
|
51763
|
-
const
|
|
51764
|
-
if (!
|
|
51802
|
+
if (isIndexedAccessTypeNode(node)) {
|
|
51803
|
+
const result = tryVisitIndexedAccess(node);
|
|
51804
|
+
if (!result) {
|
|
51765
51805
|
hadError = true;
|
|
51766
51806
|
return node;
|
|
51767
51807
|
}
|
|
51768
|
-
return
|
|
51808
|
+
return result;
|
|
51769
51809
|
}
|
|
51770
51810
|
if (isTypeReferenceNode(node)) {
|
|
51771
51811
|
const result = tryVisitTypeReference(node);
|
|
@@ -51808,25 +51848,12 @@ function createTypeChecker(host) {
|
|
|
51808
51848
|
return visited;
|
|
51809
51849
|
}
|
|
51810
51850
|
if (isTypeQueryNode(node)) {
|
|
51811
|
-
const
|
|
51812
|
-
if (
|
|
51813
|
-
const serializedName = serializeTypeName(
|
|
51814
|
-
context,
|
|
51815
|
-
node.exprName,
|
|
51816
|
-
/*isTypeOf*/
|
|
51817
|
-
true
|
|
51818
|
-
);
|
|
51819
|
-
if (serializedName) {
|
|
51820
|
-
return setTextRange2(context, serializedName, node.exprName);
|
|
51821
|
-
}
|
|
51851
|
+
const result = tryVisitTypeQuery(node);
|
|
51852
|
+
if (!result) {
|
|
51822
51853
|
hadError = true;
|
|
51823
51854
|
return node;
|
|
51824
51855
|
}
|
|
51825
|
-
return
|
|
51826
|
-
node,
|
|
51827
|
-
exprName,
|
|
51828
|
-
visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode)
|
|
51829
|
-
);
|
|
51856
|
+
return result;
|
|
51830
51857
|
}
|
|
51831
51858
|
if (isComputedPropertyName(node) && isEntityNameExpression(node.expression)) {
|
|
51832
51859
|
const { node: result, introducesError } = trackExistingEntityName(node.expression, context);
|
|
@@ -51891,14 +51918,12 @@ function createTypeChecker(host) {
|
|
|
51891
51918
|
return node;
|
|
51892
51919
|
}
|
|
51893
51920
|
} else if (node.operator === 143 /* KeyOfKeyword */) {
|
|
51894
|
-
|
|
51895
|
-
|
|
51896
|
-
|
|
51897
|
-
|
|
51898
|
-
return node;
|
|
51899
|
-
}
|
|
51900
|
-
return factory.updateTypeOperatorNode(node, type);
|
|
51921
|
+
const result = tryVisitKeyOf(node);
|
|
51922
|
+
if (!result) {
|
|
51923
|
+
hadError = true;
|
|
51924
|
+
return node;
|
|
51901
51925
|
}
|
|
51926
|
+
return result;
|
|
51902
51927
|
}
|
|
51903
51928
|
}
|
|
51904
51929
|
return visitEachChild2(node, visitExistingNodeTreeSymbols);
|
|
@@ -121523,7 +121548,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
121523
121548
|
}
|
|
121524
121549
|
return Version.zero;
|
|
121525
121550
|
}
|
|
121526
|
-
function checkDeprecations(deprecatedIn, removedIn, createDiagnostic, fn) {
|
|
121551
|
+
function checkDeprecations(deprecatedIn, stopsWorkingIn, removedIn, createDiagnostic, fn) {
|
|
121527
121552
|
const deprecatedInVersion = new Version(deprecatedIn);
|
|
121528
121553
|
const removedInVersion = new Version(removedIn);
|
|
121529
121554
|
const typescriptVersion = new Version(typeScriptVersion2 || versionMajorMinor);
|
|
@@ -121540,9 +121565,9 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
121540
121565
|
}
|
|
121541
121566
|
} else {
|
|
121542
121567
|
if (value === void 0) {
|
|
121543
|
-
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error, name,
|
|
121568
|
+
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error, name, stopsWorkingIn, deprecatedIn);
|
|
121544
121569
|
} else {
|
|
121545
|
-
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error, name, value,
|
|
121570
|
+
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error, name, value, stopsWorkingIn, deprecatedIn);
|
|
121546
121571
|
}
|
|
121547
121572
|
}
|
|
121548
121573
|
});
|
|
@@ -121578,7 +121603,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
121578
121603
|
);
|
|
121579
121604
|
}
|
|
121580
121605
|
}
|
|
121581
|
-
checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
121606
|
+
checkDeprecations("5.0", "5.5", "6.0", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
121582
121607
|
if (options.target === 0 /* ES3 */) {
|
|
121583
121608
|
createDeprecatedDiagnostic("target", "ES3");
|
|
121584
121609
|
}
|
|
@@ -121630,7 +121655,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
121630
121655
|
function createDiagnostic(_name, _value, _useInstead, message, ...args) {
|
|
121631
121656
|
createDiagnosticForReference(parentFile, index, message, ...args);
|
|
121632
121657
|
}
|
|
121633
|
-
checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
121658
|
+
checkDeprecations("5.0", "5.5", "6.0", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
121634
121659
|
if (ref.prepend) {
|
|
121635
121660
|
createDeprecatedDiagnostic("prepend");
|
|
121636
121661
|
}
|
package/lib/typescript.js
CHANGED
|
@@ -2371,7 +2371,7 @@ module.exports = __toCommonJS(typescript_exports);
|
|
|
2371
2371
|
|
|
2372
2372
|
// src/compiler/corePublic.ts
|
|
2373
2373
|
var versionMajorMinor = "5.5";
|
|
2374
|
-
var version =
|
|
2374
|
+
var version = "5.5.1-rc";
|
|
2375
2375
|
var Comparison = /* @__PURE__ */ ((Comparison3) => {
|
|
2376
2376
|
Comparison3[Comparison3["LessThan"] = -1] = "LessThan";
|
|
2377
2377
|
Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo";
|
|
@@ -56313,10 +56313,11 @@ function createTypeChecker(host) {
|
|
|
56313
56313
|
return result ? setTextRange2(context, result, node) : void 0;
|
|
56314
56314
|
}
|
|
56315
56315
|
function createRecoveryBoundary() {
|
|
56316
|
+
let trackedSymbols;
|
|
56316
56317
|
let unreportedErrors;
|
|
56317
56318
|
const oldTracker = context.tracker;
|
|
56318
56319
|
const oldTrackedSymbols = context.trackedSymbols;
|
|
56319
|
-
context.trackedSymbols =
|
|
56320
|
+
context.trackedSymbols = void 0;
|
|
56320
56321
|
const oldEncounteredError = context.encounteredError;
|
|
56321
56322
|
context.tracker = new SymbolTrackerImpl(context, {
|
|
56322
56323
|
...oldTracker.inner,
|
|
@@ -56336,17 +56337,7 @@ function createTypeChecker(host) {
|
|
|
56336
56337
|
markError(() => oldTracker.reportNonSerializableProperty(name));
|
|
56337
56338
|
},
|
|
56338
56339
|
trackSymbol(sym, decl, meaning) {
|
|
56339
|
-
|
|
56340
|
-
sym,
|
|
56341
|
-
decl,
|
|
56342
|
-
meaning,
|
|
56343
|
-
/*shouldComputeAliasesToMakeVisible*/
|
|
56344
|
-
false
|
|
56345
|
-
);
|
|
56346
|
-
if (accessibility.accessibility !== 0 /* Accessible */) {
|
|
56347
|
-
(context.trackedSymbols ?? (context.trackedSymbols = [])).push([sym, decl, meaning]);
|
|
56348
|
-
return true;
|
|
56349
|
-
}
|
|
56340
|
+
(trackedSymbols ?? (trackedSymbols = [])).push([sym, decl, meaning]);
|
|
56350
56341
|
return false;
|
|
56351
56342
|
},
|
|
56352
56343
|
moduleResolverHost: context.tracker.moduleResolverHost
|
|
@@ -56360,13 +56351,12 @@ function createTypeChecker(host) {
|
|
|
56360
56351
|
(unreportedErrors ?? (unreportedErrors = [])).push(unreportedError);
|
|
56361
56352
|
}
|
|
56362
56353
|
function startRecoveryScope2() {
|
|
56363
|
-
|
|
56364
|
-
const initialTrackedSymbolsTop = ((_a = context.trackedSymbols) == null ? void 0 : _a.length) ?? 0;
|
|
56354
|
+
const trackedSymbolsTop = (trackedSymbols == null ? void 0 : trackedSymbols.length) ?? 0;
|
|
56365
56355
|
const unreportedErrorsTop = (unreportedErrors == null ? void 0 : unreportedErrors.length) ?? 0;
|
|
56366
56356
|
return () => {
|
|
56367
56357
|
hadError = false;
|
|
56368
|
-
if (
|
|
56369
|
-
|
|
56358
|
+
if (trackedSymbols) {
|
|
56359
|
+
trackedSymbols.length = trackedSymbolsTop;
|
|
56370
56360
|
}
|
|
56371
56361
|
if (unreportedErrors) {
|
|
56372
56362
|
unreportedErrors.length = unreportedErrorsTop;
|
|
@@ -56375,14 +56365,13 @@ function createTypeChecker(host) {
|
|
|
56375
56365
|
}
|
|
56376
56366
|
function finalizeBoundary2() {
|
|
56377
56367
|
context.tracker = oldTracker;
|
|
56378
|
-
const newTrackedSymbols = context.trackedSymbols;
|
|
56379
56368
|
context.trackedSymbols = oldTrackedSymbols;
|
|
56380
56369
|
context.encounteredError = oldEncounteredError;
|
|
56381
56370
|
unreportedErrors == null ? void 0 : unreportedErrors.forEach((fn) => fn());
|
|
56382
56371
|
if (hadError) {
|
|
56383
56372
|
return false;
|
|
56384
56373
|
}
|
|
56385
|
-
|
|
56374
|
+
trackedSymbols == null ? void 0 : trackedSymbols.forEach(
|
|
56386
56375
|
([symbol, enclosingDeclaration, meaning]) => context.tracker.trackSymbol(
|
|
56387
56376
|
symbol,
|
|
56388
56377
|
enclosingDeclaration,
|
|
@@ -56395,6 +56384,57 @@ function createTypeChecker(host) {
|
|
|
56395
56384
|
function onEnterNewScope(node) {
|
|
56396
56385
|
return enterNewScope(context, node, getParametersInScope(node), getTypeParametersInScope(node));
|
|
56397
56386
|
}
|
|
56387
|
+
function tryVisitSimpleTypeNode(node) {
|
|
56388
|
+
const innerNode = skipTypeParentheses(node);
|
|
56389
|
+
switch (innerNode.kind) {
|
|
56390
|
+
case 183 /* TypeReference */:
|
|
56391
|
+
return tryVisitTypeReference(innerNode);
|
|
56392
|
+
case 186 /* TypeQuery */:
|
|
56393
|
+
return tryVisitTypeQuery(innerNode);
|
|
56394
|
+
case 199 /* IndexedAccessType */:
|
|
56395
|
+
return tryVisitIndexedAccess(innerNode);
|
|
56396
|
+
case 198 /* TypeOperator */:
|
|
56397
|
+
const typeOperatorNode = innerNode;
|
|
56398
|
+
if (typeOperatorNode.operator === 143 /* KeyOfKeyword */) {
|
|
56399
|
+
return tryVisitKeyOf(typeOperatorNode);
|
|
56400
|
+
}
|
|
56401
|
+
}
|
|
56402
|
+
return visitNode(node, visitExistingNodeTreeSymbols, isTypeNode);
|
|
56403
|
+
}
|
|
56404
|
+
function tryVisitIndexedAccess(node) {
|
|
56405
|
+
const resultObjectType = tryVisitSimpleTypeNode(node.objectType);
|
|
56406
|
+
if (resultObjectType === void 0) {
|
|
56407
|
+
return void 0;
|
|
56408
|
+
}
|
|
56409
|
+
return factory.updateIndexedAccessTypeNode(node, resultObjectType, visitNode(node.indexType, visitExistingNodeTreeSymbols, isTypeNode));
|
|
56410
|
+
}
|
|
56411
|
+
function tryVisitKeyOf(node) {
|
|
56412
|
+
Debug.assertEqual(node.operator, 143 /* KeyOfKeyword */);
|
|
56413
|
+
const type = tryVisitSimpleTypeNode(node.type);
|
|
56414
|
+
if (type === void 0) {
|
|
56415
|
+
return void 0;
|
|
56416
|
+
}
|
|
56417
|
+
return factory.updateTypeOperatorNode(node, type);
|
|
56418
|
+
}
|
|
56419
|
+
function tryVisitTypeQuery(node) {
|
|
56420
|
+
const { introducesError, node: exprName } = trackExistingEntityName(node.exprName, context);
|
|
56421
|
+
if (!introducesError) {
|
|
56422
|
+
return factory.updateTypeQueryNode(
|
|
56423
|
+
node,
|
|
56424
|
+
exprName,
|
|
56425
|
+
visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode)
|
|
56426
|
+
);
|
|
56427
|
+
}
|
|
56428
|
+
const serializedName = serializeTypeName(
|
|
56429
|
+
context,
|
|
56430
|
+
node.exprName,
|
|
56431
|
+
/*isTypeOf*/
|
|
56432
|
+
true
|
|
56433
|
+
);
|
|
56434
|
+
if (serializedName) {
|
|
56435
|
+
return setTextRange2(context, serializedName, node.exprName);
|
|
56436
|
+
}
|
|
56437
|
+
}
|
|
56398
56438
|
function tryVisitTypeReference(node) {
|
|
56399
56439
|
if (canReuseTypeNode(context, node)) {
|
|
56400
56440
|
const { introducesError, node: newName } = trackExistingEntityName(node.typeName, context);
|
|
@@ -56528,13 +56568,13 @@ function createTypeChecker(host) {
|
|
|
56528
56568
|
visitNode(node.default, visitExistingNodeTreeSymbols, isTypeNode)
|
|
56529
56569
|
);
|
|
56530
56570
|
}
|
|
56531
|
-
if (isIndexedAccessTypeNode(node)
|
|
56532
|
-
const
|
|
56533
|
-
if (!
|
|
56571
|
+
if (isIndexedAccessTypeNode(node)) {
|
|
56572
|
+
const result = tryVisitIndexedAccess(node);
|
|
56573
|
+
if (!result) {
|
|
56534
56574
|
hadError = true;
|
|
56535
56575
|
return node;
|
|
56536
56576
|
}
|
|
56537
|
-
return
|
|
56577
|
+
return result;
|
|
56538
56578
|
}
|
|
56539
56579
|
if (isTypeReferenceNode(node)) {
|
|
56540
56580
|
const result = tryVisitTypeReference(node);
|
|
@@ -56577,25 +56617,12 @@ function createTypeChecker(host) {
|
|
|
56577
56617
|
return visited;
|
|
56578
56618
|
}
|
|
56579
56619
|
if (isTypeQueryNode(node)) {
|
|
56580
|
-
const
|
|
56581
|
-
if (
|
|
56582
|
-
const serializedName = serializeTypeName(
|
|
56583
|
-
context,
|
|
56584
|
-
node.exprName,
|
|
56585
|
-
/*isTypeOf*/
|
|
56586
|
-
true
|
|
56587
|
-
);
|
|
56588
|
-
if (serializedName) {
|
|
56589
|
-
return setTextRange2(context, serializedName, node.exprName);
|
|
56590
|
-
}
|
|
56620
|
+
const result = tryVisitTypeQuery(node);
|
|
56621
|
+
if (!result) {
|
|
56591
56622
|
hadError = true;
|
|
56592
56623
|
return node;
|
|
56593
56624
|
}
|
|
56594
|
-
return
|
|
56595
|
-
node,
|
|
56596
|
-
exprName,
|
|
56597
|
-
visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode)
|
|
56598
|
-
);
|
|
56625
|
+
return result;
|
|
56599
56626
|
}
|
|
56600
56627
|
if (isComputedPropertyName(node) && isEntityNameExpression(node.expression)) {
|
|
56601
56628
|
const { node: result, introducesError } = trackExistingEntityName(node.expression, context);
|
|
@@ -56660,14 +56687,12 @@ function createTypeChecker(host) {
|
|
|
56660
56687
|
return node;
|
|
56661
56688
|
}
|
|
56662
56689
|
} else if (node.operator === 143 /* KeyOfKeyword */) {
|
|
56663
|
-
|
|
56664
|
-
|
|
56665
|
-
|
|
56666
|
-
|
|
56667
|
-
return node;
|
|
56668
|
-
}
|
|
56669
|
-
return factory.updateTypeOperatorNode(node, type);
|
|
56690
|
+
const result = tryVisitKeyOf(node);
|
|
56691
|
+
if (!result) {
|
|
56692
|
+
hadError = true;
|
|
56693
|
+
return node;
|
|
56670
56694
|
}
|
|
56695
|
+
return result;
|
|
56671
56696
|
}
|
|
56672
56697
|
}
|
|
56673
56698
|
return visitEachChild2(node, visitExistingNodeTreeSymbols);
|
|
@@ -126531,7 +126556,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
126531
126556
|
}
|
|
126532
126557
|
return Version.zero;
|
|
126533
126558
|
}
|
|
126534
|
-
function checkDeprecations(deprecatedIn, removedIn, createDiagnostic, fn) {
|
|
126559
|
+
function checkDeprecations(deprecatedIn, stopsWorkingIn, removedIn, createDiagnostic, fn) {
|
|
126535
126560
|
const deprecatedInVersion = new Version(deprecatedIn);
|
|
126536
126561
|
const removedInVersion = new Version(removedIn);
|
|
126537
126562
|
const typescriptVersion = new Version(typeScriptVersion3 || versionMajorMinor);
|
|
@@ -126548,9 +126573,9 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
126548
126573
|
}
|
|
126549
126574
|
} else {
|
|
126550
126575
|
if (value === void 0) {
|
|
126551
|
-
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error, name,
|
|
126576
|
+
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error, name, stopsWorkingIn, deprecatedIn);
|
|
126552
126577
|
} else {
|
|
126553
|
-
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error, name, value,
|
|
126578
|
+
createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error, name, value, stopsWorkingIn, deprecatedIn);
|
|
126554
126579
|
}
|
|
126555
126580
|
}
|
|
126556
126581
|
});
|
|
@@ -126586,7 +126611,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
126586
126611
|
);
|
|
126587
126612
|
}
|
|
126588
126613
|
}
|
|
126589
|
-
checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
126614
|
+
checkDeprecations("5.0", "5.5", "6.0", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
126590
126615
|
if (options.target === 0 /* ES3 */) {
|
|
126591
126616
|
createDeprecatedDiagnostic("target", "ES3");
|
|
126592
126617
|
}
|
|
@@ -126638,7 +126663,7 @@ function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _config
|
|
|
126638
126663
|
function createDiagnostic(_name, _value, _useInstead, message, ...args) {
|
|
126639
126664
|
createDiagnosticForReference(parentFile, index, message, ...args);
|
|
126640
126665
|
}
|
|
126641
|
-
checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
126666
|
+
checkDeprecations("5.0", "5.5", "6.0", createDiagnostic, (createDeprecatedDiagnostic) => {
|
|
126642
126667
|
if (ref.prepend) {
|
|
126643
126668
|
createDeprecatedDiagnostic("prepend");
|
|
126644
126669
|
}
|
|
@@ -136867,12 +136892,12 @@ function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) {
|
|
|
136867
136892
|
);
|
|
136868
136893
|
return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end));
|
|
136869
136894
|
}
|
|
136870
|
-
function getReplacementSpanForContextToken(contextToken) {
|
|
136895
|
+
function getReplacementSpanForContextToken(contextToken, position) {
|
|
136871
136896
|
if (!contextToken) return void 0;
|
|
136872
136897
|
switch (contextToken.kind) {
|
|
136873
136898
|
case 11 /* StringLiteral */:
|
|
136874
136899
|
case 15 /* NoSubstitutionTemplateLiteral */:
|
|
136875
|
-
return createTextSpanFromStringLiteralLikeContent(contextToken);
|
|
136900
|
+
return createTextSpanFromStringLiteralLikeContent(contextToken, position);
|
|
136876
136901
|
default:
|
|
136877
136902
|
return createTextSpanFromNode(contextToken);
|
|
136878
136903
|
}
|
|
@@ -136880,11 +136905,11 @@ function getReplacementSpanForContextToken(contextToken) {
|
|
|
136880
136905
|
function createTextSpanFromNode(node, sourceFile, endNode2) {
|
|
136881
136906
|
return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd());
|
|
136882
136907
|
}
|
|
136883
|
-
function createTextSpanFromStringLiteralLikeContent(node) {
|
|
136908
|
+
function createTextSpanFromStringLiteralLikeContent(node, position) {
|
|
136884
136909
|
let replacementEnd = node.getEnd() - 1;
|
|
136885
136910
|
if (node.isUnterminated) {
|
|
136886
136911
|
if (node.getStart() === replacementEnd) return void 0;
|
|
136887
|
-
replacementEnd = node.getEnd();
|
|
136912
|
+
replacementEnd = Math.min(position, node.getEnd());
|
|
136888
136913
|
}
|
|
136889
136914
|
return createTextSpanFromBounds(node.getStart() + 1, replacementEnd);
|
|
136890
136915
|
}
|
|
@@ -158687,6 +158712,7 @@ function withContext(context, typePrintMode, cb) {
|
|
|
158687
158712
|
textChanges: changeTracker.getChanges()
|
|
158688
158713
|
};
|
|
158689
158714
|
function addTypeAnnotation(span) {
|
|
158715
|
+
context.cancellationToken.throwIfCancellationRequested();
|
|
158690
158716
|
const nodeWithDiag = getTokenAtPosition(sourceFile, span.start);
|
|
158691
158717
|
const expandoFunction = findExpandoFunction(nodeWithDiag);
|
|
158692
158718
|
if (expandoFunction) {
|
|
@@ -158758,6 +158784,7 @@ function withContext(context, typePrintMode, cb) {
|
|
|
158758
158784
|
return factory.createAsExpression(factory.createSatisfiesExpression(node, getSynthesizedDeepClone(type)), type);
|
|
158759
158785
|
}
|
|
158760
158786
|
function addInlineAssertion(span) {
|
|
158787
|
+
context.cancellationToken.throwIfCancellationRequested();
|
|
158761
158788
|
const nodeWithDiag = getTokenAtPosition(sourceFile, span.start);
|
|
158762
158789
|
const expandoFunction = findExpandoFunction(nodeWithDiag);
|
|
158763
158790
|
if (expandoFunction) return;
|
|
@@ -158815,6 +158842,7 @@ function withContext(context, typePrintMode, cb) {
|
|
|
158815
158842
|
return [Diagnostics.Add_satisfies_and_an_inline_type_assertion_with_0, typeToStringForDiag(typeNode)];
|
|
158816
158843
|
}
|
|
158817
158844
|
function extractAsVariable(span) {
|
|
158845
|
+
context.cancellationToken.throwIfCancellationRequested();
|
|
158818
158846
|
const nodeWithDiag = getTokenAtPosition(sourceFile, span.start);
|
|
158819
158847
|
const targetNode = findBestFittingNode(nodeWithDiag, span);
|
|
158820
158848
|
if (!targetNode || isValueSignatureDeclaration(targetNode) || isValueSignatureDeclaration(targetNode.parent)) return;
|
|
@@ -163311,7 +163339,7 @@ function createCompletionEntry(symbol, sortText, replacementToken, contextToken,
|
|
|
163311
163339
|
var _a, _b;
|
|
163312
163340
|
let insertText;
|
|
163313
163341
|
let filterText;
|
|
163314
|
-
let replacementSpan = getReplacementSpanForContextToken(replacementToken);
|
|
163342
|
+
let replacementSpan = getReplacementSpanForContextToken(replacementToken, position);
|
|
163315
163343
|
let data;
|
|
163316
163344
|
let isSnippet;
|
|
163317
163345
|
let source = getSourceFromOrigin(origin);
|
|
@@ -166305,7 +166333,7 @@ function convertStringLiteralCompletions(completion, contextToken, sourceFile, h
|
|
|
166305
166333
|
if (completion === void 0) {
|
|
166306
166334
|
return void 0;
|
|
166307
166335
|
}
|
|
166308
|
-
const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken);
|
|
166336
|
+
const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken, position);
|
|
166309
166337
|
switch (completion.kind) {
|
|
166310
166338
|
case 0 /* Paths */:
|
|
166311
166339
|
return convertPathCompletions(completion.paths);
|
|
@@ -166359,7 +166387,7 @@ function convertStringLiteralCompletions(completion, contextToken, sourceFile, h
|
|
|
166359
166387
|
kindModifiers: "" /* none */,
|
|
166360
166388
|
kind: "string" /* string */,
|
|
166361
166389
|
sortText: SortText.LocationPriority,
|
|
166362
|
-
replacementSpan: getReplacementSpanForContextToken(contextToken)
|
|
166390
|
+
replacementSpan: getReplacementSpanForContextToken(contextToken, position)
|
|
166363
166391
|
}));
|
|
166364
166392
|
return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries };
|
|
166365
166393
|
}
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "typescript",
|
|
3
3
|
"author": "Microsoft Corp.",
|
|
4
4
|
"homepage": "https://www.typescriptlang.org/",
|
|
5
|
-
"version": "5.5.
|
|
5
|
+
"version": "5.5.1-rc",
|
|
6
6
|
"license": "Apache-2.0",
|
|
7
7
|
"description": "TypeScript is a language for application scale JavaScript development",
|
|
8
8
|
"keywords": [
|
|
@@ -112,5 +112,5 @@
|
|
|
112
112
|
"node": "20.1.0",
|
|
113
113
|
"npm": "8.19.4"
|
|
114
114
|
},
|
|
115
|
-
"gitHead": "
|
|
115
|
+
"gitHead": "f7bf3b22310485b1235754236ead4c242e96ccec"
|
|
116
116
|
}
|