Skip to content

Commit

Permalink
Object.keys/entries: remove keyof & string intersections
Browse files Browse the repository at this point in the history
Now that keyof T only returns string or string subtypes (microsoft#12425),
there’s no need to do keyof T & string.
  • Loading branch information
ethanresnick committed Nov 27, 2016
1 parent 944625a commit 29105a6
Show file tree
Hide file tree
Showing 7 changed files with 50 additions and 55 deletions.
2 changes: 1 addition & 1 deletion src/lib/es2017.object.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@ interface ObjectConstructor {
* @param o Object that contains the properties and methods. This can be an object that you created or an existing Document Object Model (DOM) object.
*/
entries<T>(o: Array<T>): [string, T][];
entries<T extends { [key: string]: any }, K extends keyof T>(o: T): [keyof T & string, T[K]][];
entries<T extends { [key: string]: any }, K extends keyof T>(o: T): [keyof T, T[K]][];
entries(o: any): [string, any][];
}
2 changes: 1 addition & 1 deletion src/lib/es5.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ interface ObjectConstructor {
* @param o Object that contains the properties and methods. This can be an object that you created or an existing Document Object Model (DOM) object.
*/
keys<T>(o: Array<T>): string[];
keys<T extends { [key: string]: any }>(o: T): (keyof T & string)[];
keys<T extends { [key: string]: any }>(o: T): (keyof T)[];
keys(o: any): string[];
}

Expand Down
18 changes: 8 additions & 10 deletions tests/baselines/reference/useObjectValuesAndEntries1.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,14 @@ for (var x of Object.values(o)) {
let y = x;
}

var entries = Object.entries(o); // <-- entries: [('a' & string) | ('b' & string), number][]
var entries = Object.entries(o); // <-- entries: ['a' | 'b', number][]
var entries1 = Object.entries(1); // <-- entries: [string, any][]
var entries2 = Object.entries({a: true, b: 2}) // [('a' & string) | ('b' & string), number | boolean][]
var entries3 = Object.entries({}) // [string, any][]
var entries2 = Object.entries({a: true, b: 2}) // [('a' | 'b'), number | boolean][]
var entries3 = Object.entries({}) // [never, any][]
var entries4 = Object.entries([1, 2, 3, 4]); // [string, number][]

// type below should be [string | (string & number), any] NOT [string | number, any]
var x2: { [index: string]: any } = {1: 2};
var entries5 = Object.entries(x2);
var entries5 = Object.entries(x2); // [string, any][]


//// [useObjectValuesAndEntries1.js]
Expand All @@ -23,11 +22,10 @@ for (var _i = 0, _a = Object.values(o); _i < _a.length; _i++) {
var x = _a[_i];
var y = x;
}
var entries = Object.entries(o); // <-- entries: [('a' & string) | ('b' & string), number][]
var entries = Object.entries(o); // <-- entries: ['a' | 'b', number][]
var entries1 = Object.entries(1); // <-- entries: [string, any][]
var entries2 = Object.entries({ a: true, b: 2 }); // [('a' & string) | ('b' & string), number | boolean][]
var entries3 = Object.entries({}); // [string, any][]
var entries2 = Object.entries({ a: true, b: 2 }); // [('a' | 'b'), number | boolean][]
var entries3 = Object.entries({}); // [never, any][]
var entries4 = Object.entries([1, 2, 3, 4]); // [string, number][]
// type below should be [string | (string & number), any] NOT [string | number, any]
var x2 = { 1: 2 };
var entries5 = Object.entries(x2);
var entries5 = Object.entries(x2); // [string, any][]
17 changes: 8 additions & 9 deletions tests/baselines/reference/useObjectValuesAndEntries1.symbols
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ for (var x of Object.values(o)) {
>x : Symbol(x, Decl(useObjectValuesAndEntries1.ts, 3, 8))
}

var entries = Object.entries(o); // <-- entries: [('a' & string) | ('b' & string), number][]
var entries = Object.entries(o); // <-- entries: ['a' | 'b', number][]
>entries : Symbol(entries, Decl(useObjectValuesAndEntries1.ts, 7, 3))
>Object.entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
Expand All @@ -30,15 +30,15 @@ var entries1 = Object.entries(1); // <-- entries: [string, any][]
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
>entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))

var entries2 = Object.entries({a: true, b: 2}) // [('a' & string) | ('b' & string), number | boolean][]
var entries2 = Object.entries({a: true, b: 2}) // [('a' | 'b'), number | boolean][]
>entries2 : Symbol(entries2, Decl(useObjectValuesAndEntries1.ts, 9, 3))
>Object.entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
>entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>a : Symbol(a, Decl(useObjectValuesAndEntries1.ts, 9, 31))
>b : Symbol(b, Decl(useObjectValuesAndEntries1.ts, 9, 39))

var entries3 = Object.entries({}) // [string, any][]
var entries3 = Object.entries({}) // [never, any][]
>entries3 : Symbol(entries3, Decl(useObjectValuesAndEntries1.ts, 10, 3))
>Object.entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
Expand All @@ -50,15 +50,14 @@ var entries4 = Object.entries([1, 2, 3, 4]); // [string, number][]
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
>entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))

// type below should be [string | (string & number), any] NOT [string | number, any]
var x2: { [index: string]: any } = {1: 2};
>x2 : Symbol(x2, Decl(useObjectValuesAndEntries1.ts, 14, 3))
>index : Symbol(index, Decl(useObjectValuesAndEntries1.ts, 14, 11))
>x2 : Symbol(x2, Decl(useObjectValuesAndEntries1.ts, 13, 3))
>index : Symbol(index, Decl(useObjectValuesAndEntries1.ts, 13, 11))

var entries5 = Object.entries(x2);
>entries5 : Symbol(entries5, Decl(useObjectValuesAndEntries1.ts, 15, 3))
var entries5 = Object.entries(x2); // [string, any][]
>entries5 : Symbol(entries5, Decl(useObjectValuesAndEntries1.ts, 14, 3))
>Object.entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>Object : Symbol(Object, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
>entries : Symbol(ObjectConstructor.entries, Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --), Decl(lib.es2017.object.d.ts, --, --))
>x2 : Symbol(x2, Decl(useObjectValuesAndEntries1.ts, 14, 3))
>x2 : Symbol(x2, Decl(useObjectValuesAndEntries1.ts, 13, 3))

49 changes: 24 additions & 25 deletions tests/baselines/reference/useObjectValuesAndEntries1.types
Original file line number Diff line number Diff line change
Expand Up @@ -21,66 +21,65 @@ for (var x of Object.values(o)) {
>x : number
}

var entries = Object.entries(o); // <-- entries: [('a' & string) | ('b' & string), number][]
>entries : [("a" & string) | ("b" & string), number][]
>Object.entries(o) : [("a" & string) | ("b" & string), number][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
var entries = Object.entries(o); // <-- entries: ['a' | 'b', number][]
>entries : ["a" | "b", number][]
>Object.entries(o) : ["a" | "b", number][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>o : { a: number; b: number; }

var entries1 = Object.entries(1); // <-- entries: [string, any][]
>entries1 : [string, any][]
>Object.entries(1) : [string, any][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>1 : 1

var entries2 = Object.entries({a: true, b: 2}) // [('a' & string) | ('b' & string), number | boolean][]
>entries2 : [("a" & string) | ("b" & string), number | boolean][]
>Object.entries({a: true, b: 2}) : [("a" & string) | ("b" & string), number | boolean][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
var entries2 = Object.entries({a: true, b: 2}) // [('a' | 'b'), number | boolean][]
>entries2 : ["a" | "b", number | boolean][]
>Object.entries({a: true, b: 2}) : ["a" | "b", number | boolean][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>{a: true, b: 2} : { a: true; b: number; }
>a : boolean
>true : true
>b : number
>2 : 2

var entries3 = Object.entries({}) // [string, any][]
>entries3 : [string, any][]
>Object.entries({}) : [string, any][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
var entries3 = Object.entries({}) // [never, any][]
>entries3 : [never, any][]
>Object.entries({}) : [never, any][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>{} : {}

var entries4 = Object.entries([1, 2, 3, 4]); // [string, number][]
>entries4 : [string, number][]
>Object.entries([1, 2, 3, 4]) : [string, number][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>[1, 2, 3, 4] : number[]
>1 : 1
>2 : 2
>3 : 3
>4 : 4

// type below should be [string | (string & number), any] NOT [string | number, any]
var x2: { [index: string]: any } = {1: 2};
>x2 : { [index: string]: any; }
>index : string
>{1: 2} : { 1: number; }
>2 : 2

var entries5 = Object.entries(x2);
>entries5 : [string | (number & string), any][]
>Object.entries(x2) : [string | (number & string), any][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
var entries5 = Object.entries(x2); // [string, any][]
>entries5 : [string, any][]
>Object.entries(x2) : [string, any][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>x2 : { [index: string]: any; }

8 changes: 4 additions & 4 deletions tests/baselines/reference/useObjectValuesAndEntries4.types
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,10 @@ for (var x of Object.values(o)) {
}

var entries = Object.entries(o);
>entries : [("a" & string) | ("b" & string), number][]
>Object.entries(o) : [("a" & string) | ("b" & string), number][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : ["a" | "b", number][]
>Object.entries(o) : ["a" | "b", number][]
>Object.entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>Object : ObjectConstructor
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T & string, T[K]][]; (o: any): [string, any][]; }
>entries : { <T>(o: T[]): [string, T][]; <T extends { [key: string]: any; }, K extends keyof T>(o: T): [keyof T, T[K]][]; (o: any): [string, any][]; }
>o : { a: number; b: number; }

9 changes: 4 additions & 5 deletions tests/cases/conformance/es2017/useObjectValuesAndEntries1.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,11 @@ for (var x of Object.values(o)) {
let y = x;
}

var entries = Object.entries(o); // <-- entries: [('a' & string) | ('b' & string), number][]
var entries = Object.entries(o); // <-- entries: ['a' | 'b', number][]
var entries1 = Object.entries(1); // <-- entries: [string, any][]
var entries2 = Object.entries({a: true, b: 2}) // [('a' & string) | ('b' & string), number | boolean][]
var entries3 = Object.entries({}) // [string, any][]
var entries2 = Object.entries({a: true, b: 2}) // [('a' | 'b'), number | boolean][]
var entries3 = Object.entries({}) // [never, any][]
var entries4 = Object.entries([1, 2, 3, 4]); // [string, number][]

// type below should be [string | (string & number), any] NOT [string | number, any]
var x2: { [index: string]: any } = {1: 2};
var entries5 = Object.entries(x2);
var entries5 = Object.entries(x2); // [string, any][]

0 comments on commit 29105a6

Please sign in to comment.