Skip to content

Commit 1f7f67d

Browse files
author
Andy Hanson
committed
Type arguments to formatStringFromArgs as strings instead of implicitly stringifying
1 parent 97e90b5 commit 1f7f67d

File tree

8 files changed

+35
-36
lines changed

8 files changed

+35
-36
lines changed

src/compiler/checker.ts

Lines changed: 9 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -368,7 +368,7 @@ namespace ts {
368368
return emitResolver;
369369
}
370370

371-
function error(location: Node, message: DiagnosticMessage, arg0?: any, arg1?: any, arg2?: any): void {
371+
function error(location: Node, message: DiagnosticMessage, arg0?: string, arg1?: string, arg2?: string): void {
372372
const diagnostic = location
373373
? createDiagnosticForNode(location, message, arg0, arg1, arg2)
374374
: createCompilerDiagnostic(message, arg0, arg1, arg2);
@@ -3004,7 +3004,8 @@ namespace ts {
30043004
: elementType;
30053005
if (!type) {
30063006
if (isTupleType(parentType)) {
3007-
error(declaration, Diagnostics.Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2, typeToString(parentType), getTypeReferenceArity(<TypeReference>parentType), pattern.elements.length);
3007+
error(declaration, Diagnostics.Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2,
3008+
typeToString(parentType), getTypeReferenceArity(<TypeReference>parentType).toString(), pattern.elements.length.toString());
30083009
}
30093010
else {
30103011
error(declaration, Diagnostics.Type_0_has_no_property_1, typeToString(parentType), propName);
@@ -5103,7 +5104,7 @@ namespace ts {
51035104
const typeParameters = type.localTypeParameters;
51045105
if (typeParameters) {
51055106
if (!node.typeArguments || node.typeArguments.length !== typeParameters.length) {
5106-
error(node, Diagnostics.Generic_type_0_requires_1_type_argument_s, typeToString(type, /*enclosingDeclaration*/ undefined, TypeFormatFlags.WriteArrayAsGenericType), typeParameters.length);
5107+
error(node, Diagnostics.Generic_type_0_requires_1_type_argument_s, typeToString(type, /*enclosingDeclaration*/ undefined, TypeFormatFlags.WriteArrayAsGenericType), typeParameters.length.toString());
51075108
return unknownType;
51085109
}
51095110
// In a type reference, the outer type parameters of the referenced class or interface are automatically
@@ -5127,7 +5128,7 @@ namespace ts {
51275128
const typeParameters = links.typeParameters;
51285129
if (typeParameters) {
51295130
if (!node.typeArguments || node.typeArguments.length !== typeParameters.length) {
5130-
error(node, Diagnostics.Generic_type_0_requires_1_type_argument_s, symbolToString(symbol), typeParameters.length);
5131+
error(node, Diagnostics.Generic_type_0_requires_1_type_argument_s, symbolToString(symbol), typeParameters.length.toString());
51315132
return unknownType;
51325133
}
51335134
const typeArguments = map(node.typeArguments, getTypeFromTypeNodeNoAlias);
@@ -5270,7 +5271,7 @@ namespace ts {
52705271
return arity ? emptyGenericType : emptyObjectType;
52715272
}
52725273
if (((<InterfaceType>type).typeParameters ? (<InterfaceType>type).typeParameters.length : 0) !== arity) {
5273-
error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbol.name, arity);
5274+
error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbol.name, arity.toString());
52745275
return arity ? emptyGenericType : emptyObjectType;
52755276
}
52765277
return <ObjectType>type;
@@ -8537,7 +8538,7 @@ namespace ts {
85378538
// An evolving array type tracks the element types that have so far been seen in an
85388539
// 'x.push(value)' or 'x[n] = value' operation along the control flow graph. Evolving
85398540
// array types are ultimately converted into manifest array types (using getFinalArrayType)
8540-
// and never escape the getFlowTypeOfReference function.
8541+
// and never escape the getFlowTypeOfReference function.
85418542
function createEvolvingArrayType(elementType: Type): AnonymousType {
85428543
const result = <AnonymousType>createObjectType(TypeFlags.Anonymous);
85438544
result.elementType = elementType;
@@ -13630,7 +13631,8 @@ namespace ts {
1363013631
// such as NodeCheckFlags.LexicalThis on "this"expression.
1363113632
checkExpression(element);
1363213633
if (isTupleType(sourceType)) {
13633-
error(element, Diagnostics.Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2, typeToString(sourceType), getTypeReferenceArity(<TypeReference>sourceType), elements.length);
13634+
error(element, Diagnostics.Tuple_type_0_with_length_1_cannot_be_assigned_to_tuple_with_length_2,
13635+
typeToString(sourceType), getTypeReferenceArity(<TypeReference>sourceType).toString(), elements.length.toString());
1363413636
}
1363513637
else {
1363613638
error(element, Diagnostics.Type_0_has_no_property_1, typeToString(sourceType), propName);

src/compiler/commandLineParser.ts

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -515,10 +515,7 @@ namespace ts {
515515

516516
/* @internal */
517517
export function createCompilerDiagnosticForInvalidCustomType(opt: CommandLineOptionOfCustomType): Diagnostic {
518-
const namesOfType: string[] = [];
519-
for (const key in opt.type) {
520-
namesOfType.push(` '${key}'`);
521-
}
518+
const namesOfType = Object.keys(opt.type).map(key => `'${key}'`).join(", ");
522519
return createCompilerDiagnostic(Diagnostics.Argument_for_0_option_must_be_Colon_1, `--${opt.name}`, namesOfType);
523520
}
524521

src/compiler/core.ts

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -940,7 +940,7 @@ namespace ts {
940940
}
941941
}
942942

943-
function formatStringFromArgs(text: string, args: { [index: number]: any; }, baseIndex?: number): string {
943+
function formatStringFromArgs(text: string, args: { [index: number]: string; }, baseIndex?: number): string {
944944
baseIndex = baseIndex || 0;
945945

946946
return text.replace(/{(\d+)}/g, (match, index?) => args[+index + baseIndex]);
@@ -952,7 +952,7 @@ namespace ts {
952952
return localizedDiagnosticMessages && localizedDiagnosticMessages[message.key] || message.message;
953953
}
954954

955-
export function createFileDiagnostic(file: SourceFile, start: number, length: number, message: DiagnosticMessage, ...args: any[]): Diagnostic;
955+
export function createFileDiagnostic(file: SourceFile, start: number, length: number, message: DiagnosticMessage, ...args: string[]): Diagnostic;
956956
export function createFileDiagnostic(file: SourceFile, start: number, length: number, message: DiagnosticMessage): Diagnostic {
957957
const end = start + length;
958958

@@ -992,7 +992,7 @@ namespace ts {
992992
return text;
993993
}
994994

995-
export function createCompilerDiagnostic(message: DiagnosticMessage, ...args: any[]): Diagnostic;
995+
export function createCompilerDiagnostic(message: DiagnosticMessage, ...args: string[]): Diagnostic;
996996
export function createCompilerDiagnostic(message: DiagnosticMessage): Diagnostic {
997997
let text = getLocaleSpecificMessage(message);
998998

src/compiler/utilities.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -503,7 +503,7 @@ namespace ts {
503503
return getFullWidth(name) === 0 ? "(Missing)" : getTextOfNode(name);
504504
}
505505

506-
export function createDiagnosticForNode(node: Node, message: DiagnosticMessage, arg0?: any, arg1?: any, arg2?: any): Diagnostic {
506+
export function createDiagnosticForNode(node: Node, message: DiagnosticMessage, arg0?: string, arg1?: string, arg2?: string): Diagnostic {
507507
const sourceFile = getSourceFileOfNode(node);
508508
const span = getErrorSpanForNode(sourceFile, node);
509509
return createFileDiagnostic(sourceFile, span.start, span.length, message, arg0, arg1, arg2);

src/harness/unittests/commandLineParsing.ts

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -60,7 +60,7 @@ namespace ts {
6060
assertParseResult(["--lib", "es5,invalidOption", "0.ts"],
6161
{
6262
errors: [{
63-
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
63+
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
6464
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
6565
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
6666

@@ -87,7 +87,7 @@ namespace ts {
8787
start: undefined,
8888
length: undefined,
8989
}, {
90-
messageText: "Argument for '--jsx' option must be: 'preserve', 'react'",
90+
messageText: "Argument for '--jsx' option must be: 'preserve', 'react'",
9191
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
9292
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
9393

@@ -113,7 +113,7 @@ namespace ts {
113113
start: undefined,
114114
length: undefined,
115115
}, {
116-
messageText: "Argument for '--module' option must be: 'none', 'commonjs', 'amd', 'system', 'umd', 'es6', 'es2015'",
116+
messageText: "Argument for '--module' option must be: 'none', 'commonjs', 'amd', 'system', 'umd', 'es6', 'es2015'",
117117
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
118118
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
119119

@@ -139,7 +139,7 @@ namespace ts {
139139
start: undefined,
140140
length: undefined,
141141
}, {
142-
messageText: "Argument for '--newLine' option must be: 'crlf', 'lf'",
142+
messageText: "Argument for '--newLine' option must be: 'crlf', 'lf'",
143143
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
144144
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
145145

@@ -165,7 +165,7 @@ namespace ts {
165165
start: undefined,
166166
length: undefined,
167167
}, {
168-
messageText: "Argument for '--target' option must be: 'es3', 'es5', 'es6', 'es2015', 'es2016', 'es2017'",
168+
messageText: "Argument for '--target' option must be: 'es3', 'es5', 'es6', 'es2015', 'es2016', 'es2017'",
169169
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
170170
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
171171

@@ -191,7 +191,7 @@ namespace ts {
191191
start: undefined,
192192
length: undefined,
193193
}, {
194-
messageText: "Argument for '--moduleResolution' option must be: 'node', 'classic'",
194+
messageText: "Argument for '--moduleResolution' option must be: 'node', 'classic'",
195195
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
196196
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
197197

@@ -263,7 +263,7 @@ namespace ts {
263263
assertParseResult(["--lib", "es5,", "es7", "0.ts"],
264264
{
265265
errors: [{
266-
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
266+
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
267267
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
268268
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
269269

@@ -283,7 +283,7 @@ namespace ts {
283283
assertParseResult(["--lib", "es5, ", "es7", "0.ts"],
284284
{
285285
errors: [{
286-
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
286+
messageText: "Argument for '--lib' option must be: 'es5', 'es6', 'es2015', 'es7', 'es2016', 'es2017', 'dom', 'dom.iterable', 'webworker', 'scripthost', 'es2015.core', 'es2015.collection', 'es2015.generator', 'es2015.iterable', 'es2015.promise', 'es2015.proxy', 'es2015.reflect', 'es2015.symbol', 'es2015.symbol.wellknown', 'es2016.array.include', 'es2017.object', 'es2017.sharedmemory'",
287287
category: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.category,
288288
code: ts.Diagnostics.Argument_for_0_option_must_be_Colon_1.code,
289289

0 commit comments

Comments
 (0)