-
Notifications
You must be signed in to change notification settings - Fork 13.4k
Expand file tree
/
Copy pathnarrowingTruthyObject.js
More file actions
61 lines (57 loc) · 1.36 KB
/
narrowingTruthyObject.js
File metadata and controls
61 lines (57 loc) · 1.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
//// [narrowingTruthyObject.ts]
function foo(x: unknown, b: boolean) {
if (typeof x === 'object') {
x.toString();
}
if (typeof x === 'object' && x) {
x.toString();
}
if (x && typeof x === 'object') {
x.toString();
}
if (b && x && typeof x === 'object') {
x.toString();
}
if (x && b && typeof x === 'object') {
x.toString();
}
if (x && b && b && typeof x === 'object') {
x.toString();
}
if (b && b && x && b && b && typeof x === 'object') {
x.toString();
}
}
// Repro from #36870
function f1(x: unknown): any {
return x && typeof x === 'object' && x.hasOwnProperty('x');
}
//// [narrowingTruthyObject.js]
"use strict";
function foo(x, b) {
if (typeof x === 'object') {
x.toString();
}
if (typeof x === 'object' && x) {
x.toString();
}
if (x && typeof x === 'object') {
x.toString();
}
if (b && x && typeof x === 'object') {
x.toString();
}
if (x && b && typeof x === 'object') {
x.toString();
}
if (x && b && b && typeof x === 'object') {
x.toString();
}
if (b && b && x && b && b && typeof x === 'object') {
x.toString();
}
}
// Repro from #36870
function f1(x) {
return x && typeof x === 'object' && x.hasOwnProperty('x');
}