Skip to content

Commit 2c9900f

Browse files
TypeScript Botweswigham
TypeScript Bot
andauthored
🤖 Pick PR microsoft#38273 (Harden node builder APIs to no long...) into release-3.9 (microsoft#38333)
* Cherry-pick PR microsoft#38273 into release-3.9 Component commits: c80c177 Harden node builder APIs to no longer return `undefined` for a node when `NodeBuilderFlags.IgnoreErrors` is provided * Undo API changes for release branch Co-authored-by: Wesley Wigham <[email protected]> Co-authored-by: Wesley Wigham <[email protected]>
1 parent 90f12d6 commit 2c9900f

8 files changed

+39
-14
lines changed

‎src/compiler/checker.ts

+7-3
Original file line numberDiff line numberDiff line change
@@ -4210,8 +4210,12 @@ namespace ts {
42104210
context.flags &= ~NodeBuilderFlags.InTypeAlias;
42114211

42124212
if (!type) {
4213-
context.encounteredError = true;
4214-
return undefined!; // TODO: GH#18217
4213+
if (!(context.flags & NodeBuilderFlags.AllowEmptyUnionOrIntersection)) {
4214+
context.encounteredError = true;
4215+
return undefined!; // TODO: GH#18217
4216+
}
4217+
context.approximateLength += 3;
4218+
return createKeywordTypeNode(SyntaxKind.AnyKeyword);
42154219
}
42164220

42174221
if (!(context.flags & NodeBuilderFlags.NoTypeReduction)) {
@@ -5931,7 +5935,7 @@ namespace ts {
59315935
function serializeSymbolWorker(symbol: Symbol, isPrivate: boolean, propertyAsAlias: boolean) {
59325936
const symbolName = unescapeLeadingUnderscores(symbol.escapedName);
59335937
const isDefault = symbol.escapedName === InternalSymbolName.Default;
5934-
if (isStringANonContextualKeyword(symbolName) && !isDefault) {
5938+
if (!(context.flags & NodeBuilderFlags.AllowAnonymousIdentifier) && isStringANonContextualKeyword(symbolName) && !isDefault) {
59355939
// Oh no. We cannot use this symbol's name as it's name... It's likely some jsdoc had an invalid name like `export` or `default` :(
59365940
context.encounteredError = true;
59375941
// TODO: Issue error via symbol tracker?

‎src/compiler/types.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -3436,13 +3436,13 @@ namespace ts {
34363436
// TODO: GH#18217 `xToDeclaration` calls are frequently asserted as defined.
34373437
/** Note that the resulting nodes cannot be checked. */
34383438
typeToTypeNode(type: Type, enclosingDeclaration?: Node, flags?: NodeBuilderFlags): TypeNode | undefined;
3439-
/* @internal */ typeToTypeNode(type: Type, enclosingDeclaration?: Node, flags?: NodeBuilderFlags, tracker?: SymbolTracker): TypeNode | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
3439+
/* @internal */ typeToTypeNode(type: Type, enclosingDeclaration: Node | undefined, flags: NodeBuilderFlags | undefined, tracker?: SymbolTracker): TypeNode | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
34403440
/** Note that the resulting nodes cannot be checked. */
34413441
signatureToSignatureDeclaration(signature: Signature, kind: SyntaxKind, enclosingDeclaration?: Node, flags?: NodeBuilderFlags): SignatureDeclaration & {typeArguments?: NodeArray<TypeNode>} | undefined;
3442-
/* @internal */ signatureToSignatureDeclaration(signature: Signature, kind: SyntaxKind, enclosingDeclaration?: Node, flags?: NodeBuilderFlags, tracker?: SymbolTracker): SignatureDeclaration & {typeArguments?: NodeArray<TypeNode>} | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
3442+
/* @internal */ signatureToSignatureDeclaration(signature: Signature, kind: SyntaxKind, enclosingDeclaration: Node | undefined, flags: NodeBuilderFlags | undefined, tracker?: SymbolTracker): SignatureDeclaration & {typeArguments?: NodeArray<TypeNode>} | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
34433443
/** Note that the resulting nodes cannot be checked. */
34443444
indexInfoToIndexSignatureDeclaration(indexInfo: IndexInfo, kind: IndexKind, enclosingDeclaration?: Node, flags?: NodeBuilderFlags): IndexSignatureDeclaration | undefined;
3445-
/* @internal */ indexInfoToIndexSignatureDeclaration(indexInfo: IndexInfo, kind: IndexKind, enclosingDeclaration?: Node, flags?: NodeBuilderFlags, tracker?: SymbolTracker): IndexSignatureDeclaration | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
3445+
/* @internal */ indexInfoToIndexSignatureDeclaration(indexInfo: IndexInfo, kind: IndexKind, enclosingDeclaration: Node | undefined, flags: NodeBuilderFlags | undefined, tracker?: SymbolTracker): IndexSignatureDeclaration | undefined; // eslint-disable-line @typescript-eslint/unified-signatures
34463446
/** Note that the resulting nodes cannot be checked. */
34473447
symbolToEntityName(symbol: Symbol, meaning: SymbolFlags, enclosingDeclaration?: Node, flags?: NodeBuilderFlags): EntityName | undefined;
34483448
/** Note that the resulting nodes cannot be checked. */

‎src/services/codefixes/convertToAsyncFunction.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -282,7 +282,7 @@ namespace ts.codefix {
282282
varDeclIdentifier = getSynthesizedDeepClone(possibleNameForVarDecl.identifier);
283283
const typeArray: Type[] = possibleNameForVarDecl.types;
284284
const unionType = transformer.checker.getUnionType(typeArray, UnionReduction.Subtype);
285-
const unionTypeNode = transformer.isInJSFile ? undefined : transformer.checker.typeToTypeNode(unionType);
285+
const unionTypeNode = transformer.isInJSFile ? undefined : transformer.checker.typeToTypeNode(unionType, /*enclosingDeclaration*/ undefined, /*flags*/ undefined);
286286
const varDecl = [createVariableDeclaration(varDeclIdentifier, unionTypeNode)];
287287
varDeclList = createVariableStatement(/*modifiers*/ undefined, createVariableDeclarationList(varDecl, NodeFlags.Let));
288288
}

‎src/services/codefixes/fixAddMissingMember.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -230,11 +230,11 @@ namespace ts.codefix {
230230
const binaryExpression = token.parent.parent as BinaryExpression;
231231
const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left;
232232
const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression)));
233-
typeNode = checker.typeToTypeNode(widenedType, classDeclaration);
233+
typeNode = checker.typeToTypeNode(widenedType, classDeclaration, /*flags*/ undefined);
234234
}
235235
else {
236236
const contextualType = checker.getContextualType(token.parent as Expression);
237-
typeNode = contextualType ? checker.typeToTypeNode(contextualType) : undefined;
237+
typeNode = contextualType ? checker.typeToTypeNode(contextualType, /*enclosingDeclaration*/ undefined, /*flags*/ undefined) : undefined;
238238
}
239239
return typeNode || createKeywordTypeNode(SyntaxKind.AnyKeyword);
240240
}

‎src/services/codefixes/fixJSDocTypes.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ namespace ts.codefix {
4040
});
4141

4242
function doChange(changes: textChanges.ChangeTracker, sourceFile: SourceFile, oldTypeNode: TypeNode, newType: Type, checker: TypeChecker): void {
43-
changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode(newType, /*enclosingDeclaration*/ oldTypeNode)!); // TODO: GH#18217
43+
changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode(newType, /*enclosingDeclaration*/ oldTypeNode, /*flags*/ undefined)!); // TODO: GH#18217
4444
}
4545

4646
function getInfo(sourceFile: SourceFile, pos: number, checker: TypeChecker): { readonly typeNode: TypeNode, readonly type: Type } | undefined {

‎src/services/signatureHelp.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -580,7 +580,7 @@ namespace ts.SignatureHelp {
580580
const printer = createPrinter({ removeComments: true });
581581
const typeParameterParts = mapToDisplayParts(writer => {
582582
if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) {
583-
const args = createNodeArray(candidateSignature.typeParameters.map(p => checker.typeParameterToDeclaration(p, enclosingDeclaration)!));
583+
const args = createNodeArray(candidateSignature.typeParameters.map(p => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags)!));
584584
printer.writeList(ListFormat.TypeParameters, args, sourceFile, writer);
585585
}
586586
});
@@ -599,7 +599,7 @@ namespace ts.SignatureHelp {
599599

600600
function createSignatureHelpParameterForTypeParameter(typeParameter: TypeParameter, checker: TypeChecker, enclosingDeclaration: Node, sourceFile: SourceFile, printer: Printer): SignatureHelpParameter {
601601
const displayParts = mapToDisplayParts(writer => {
602-
const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration)!;
602+
const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)!;
603603
printer.writeNode(EmitHint.Unspecified, param, sourceFile, writer);
604604
});
605605
return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false };

‎src/services/symbolDisplay.ts

+4-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
/* @internal */
22
namespace ts.SymbolDisplay {
3+
const symbolDisplayNodeBuilderFlags = NodeBuilderFlags.OmitParameterModifiers | NodeBuilderFlags.IgnoreErrors | NodeBuilderFlags.UseAliasDefinedOutsideCurrentScope;
4+
35
// TODO(drosen): use contextual SemanticMeaning.
46
export function getSymbolKind(typeChecker: TypeChecker, symbol: Symbol, location: Node): ScriptElementKind {
57
const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location);
@@ -471,7 +473,7 @@ namespace ts.SymbolDisplay {
471473
// If the type is type parameter, format it specially
472474
if (type.symbol && type.symbol.flags & SymbolFlags.TypeParameter) {
473475
const typeParameterParts = mapToDisplayParts(writer => {
474-
const param = typeChecker.typeParameterToDeclaration(type as TypeParameter, enclosingDeclaration)!;
476+
const param = typeChecker.typeParameterToDeclaration(type as TypeParameter, enclosingDeclaration, symbolDisplayNodeBuilderFlags)!;
475477
getPrinter().writeNode(EmitHint.Unspecified, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer);
476478
});
477479
addRange(displayParts, typeParameterParts);
@@ -631,7 +633,7 @@ namespace ts.SymbolDisplay {
631633

632634
function writeTypeParametersOfSymbol(symbol: Symbol, enclosingDeclaration: Node | undefined) {
633635
const typeParameterParts = mapToDisplayParts(writer => {
634-
const params = typeChecker.symbolToTypeParameterDeclarations(symbol, enclosingDeclaration);
636+
const params = typeChecker.symbolToTypeParameterDeclarations(symbol, enclosingDeclaration, symbolDisplayNodeBuilderFlags);
635637
getPrinter().writeList(ListFormat.TypeParameters, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer);
636638
});
637639
addRange(displayParts, typeParameterParts);
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
/// <reference path="fourslash.ts" />
2+
3+
// @Filename: /node_modules/foo/node_modules/bar/index.d.ts
4+
////export interface SomeType {
5+
//// x?: number;
6+
////}
7+
// @Filename: /node_modules/foo/index.d.ts
8+
////import { SomeType } from "bar";
9+
////export function func<T extends SomeType>(param: T): void;
10+
////export function func<T extends SomeType>(param: T, other: T): void;
11+
// @Filename: /usage.ts
12+
////import { func } from "foo";
13+
////func({/*1*/});
14+
15+
verify.signatureHelp({
16+
marker: "1",
17+
overloadsCount: 2,
18+
text: "func(param: {}): void"
19+
});

0 commit comments

Comments
 (0)