Skip to content

Commit

Permalink
Merge pull request #17767 from tycho01/15768-generic-numeric-index-error
Browse files Browse the repository at this point in the history
loosen number index check, fixes #15768
  • Loading branch information
ahejlsberg authored Aug 14, 2017
2 parents 543e0af + 4268e13 commit a1cbeb2
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 7 deletions.
11 changes: 4 additions & 7 deletions src/compiler/checker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18761,13 +18761,10 @@ namespace ts {
if (isTypeAssignableTo(indexType, getIndexType(objectType))) {
return type;
}
// Check if we're indexing with a numeric type and the object type is a generic
// type with a constraint that has a numeric index signature.
if (maybeTypeOfKind(objectType, TypeFlags.TypeVariable) && isTypeAssignableToKind(indexType, TypeFlags.NumberLike)) {
const constraint = getBaseConstraintOfType(objectType);
if (constraint && getIndexInfoOfType(constraint, IndexKind.Number)) {
return type;
}
// Check if we're indexing with a numeric type and if either object or index types
// is a generic type with a constraint that has a numeric index signature.
if (getIndexInfoOfType(getApparentType(objectType), IndexKind.Number) && isTypeAssignableToKind(indexType, TypeFlags.NumberLike)) {
return type;
}
error(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
return type;
Expand Down
5 changes: 5 additions & 0 deletions tests/baselines/reference/genericNumberIndex.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
//// [genericNumberIndex.ts]
type X<I extends number> = ['a'][I];


//// [genericNumberIndex.js]
6 changes: 6 additions & 0 deletions tests/baselines/reference/genericNumberIndex.symbols
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
=== tests/cases/compiler/genericNumberIndex.ts ===
type X<I extends number> = ['a'][I];
>X : Symbol(X, Decl(genericNumberIndex.ts, 0, 0))
>I : Symbol(I, Decl(genericNumberIndex.ts, 0, 7))
>I : Symbol(I, Decl(genericNumberIndex.ts, 0, 7))

6 changes: 6 additions & 0 deletions tests/baselines/reference/genericNumberIndex.types
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
=== tests/cases/compiler/genericNumberIndex.ts ===
type X<I extends number> = ['a'][I];
>X : ["a"][I]
>I : I
>I : I

1 change: 1 addition & 0 deletions tests/cases/compiler/genericNumberIndex.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
type X<I extends number> = ['a'][I];

0 comments on commit a1cbeb2

Please sign in to comment.