|
| 1 | +=== tests/cases/compiler/inferenceDoesNotAddUndefinedOrNull.ts === |
| 2 | +interface NodeArray<T extends Node> extends ReadonlyArray<T> {} |
| 3 | +>NodeArray : Symbol(NodeArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 0)) |
| 4 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 20)) |
| 5 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 6 | +>ReadonlyArray : Symbol(ReadonlyArray, Decl(lib.es5.d.ts, --, --)) |
| 7 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 20)) |
| 8 | + |
| 9 | +interface Node { |
| 10 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 11 | + |
| 12 | + forEachChild<T>(cbNode: (node: Node) => T | undefined, cbNodeArray?: (nodes: NodeArray<Node>) => T | undefined): T | undefined; |
| 13 | +>forEachChild : Symbol(Node.forEachChild, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 2, 16)) |
| 14 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 17)) |
| 15 | +>cbNode : Symbol(cbNode, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 20)) |
| 16 | +>node : Symbol(node, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 29)) |
| 17 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 18 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 17)) |
| 19 | +>cbNodeArray : Symbol(cbNodeArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 58)) |
| 20 | +>nodes : Symbol(nodes, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 74)) |
| 21 | +>NodeArray : Symbol(NodeArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 0)) |
| 22 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 23 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 17)) |
| 24 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 3, 17)) |
| 25 | +} |
| 26 | + |
| 27 | +declare function toArray<T>(value: T | T[]): T[]; |
| 28 | +>toArray : Symbol(toArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 4, 1), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 49)) |
| 29 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 25)) |
| 30 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 28)) |
| 31 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 25)) |
| 32 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 25)) |
| 33 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 25)) |
| 34 | + |
| 35 | +declare function toArray<T>(value: T | readonly T[]): readonly T[]; |
| 36 | +>toArray : Symbol(toArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 4, 1), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 49)) |
| 37 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 25)) |
| 38 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 28)) |
| 39 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 25)) |
| 40 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 25)) |
| 41 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 25)) |
| 42 | + |
| 43 | +function flatMapChildren<T>(node: Node, cb: (child: Node) => readonly T[] | T | undefined): readonly T[] { |
| 44 | +>flatMapChildren : Symbol(flatMapChildren, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 7, 67)) |
| 45 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 25)) |
| 46 | +>node : Symbol(node, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 28)) |
| 47 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 48 | +>cb : Symbol(cb, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 39)) |
| 49 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 45)) |
| 50 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 51 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 25)) |
| 52 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 25)) |
| 53 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 25)) |
| 54 | + |
| 55 | + const result: T[] = []; |
| 56 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 10, 9)) |
| 57 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 25)) |
| 58 | + |
| 59 | + node.forEachChild(child => { |
| 60 | +>node.forEachChild : Symbol(Node.forEachChild, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 2, 16)) |
| 61 | +>node : Symbol(node, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 28)) |
| 62 | +>forEachChild : Symbol(Node.forEachChild, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 2, 16)) |
| 63 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 11, 22)) |
| 64 | + |
| 65 | + const value = cb(child); |
| 66 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 12, 13)) |
| 67 | +>cb : Symbol(cb, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 9, 39)) |
| 68 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 11, 22)) |
| 69 | + |
| 70 | + if (value !== undefined) { |
| 71 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 12, 13)) |
| 72 | +>undefined : Symbol(undefined) |
| 73 | + |
| 74 | + result.push(...toArray(value)); |
| 75 | +>result.push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --)) |
| 76 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 10, 9)) |
| 77 | +>push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --)) |
| 78 | +>toArray : Symbol(toArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 4, 1), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 49)) |
| 79 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 12, 13)) |
| 80 | + } |
| 81 | + }); |
| 82 | + return result; |
| 83 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 10, 9)) |
| 84 | +} |
| 85 | + |
| 86 | +function flatMapChildren2<T>(node: Node, cb: (child: Node) => readonly T[] | T | null): readonly T[] { |
| 87 | +>flatMapChildren2 : Symbol(flatMapChildren2, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 18, 1)) |
| 88 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 26)) |
| 89 | +>node : Symbol(node, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 29)) |
| 90 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 91 | +>cb : Symbol(cb, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 40)) |
| 92 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 46)) |
| 93 | +>Node : Symbol(Node, Decl(lib.dom.d.ts, --, --), Decl(lib.dom.d.ts, --, --), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 0, 63)) |
| 94 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 26)) |
| 95 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 26)) |
| 96 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 26)) |
| 97 | + |
| 98 | + const result: T[] = []; |
| 99 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 21, 9)) |
| 100 | +>T : Symbol(T, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 26)) |
| 101 | + |
| 102 | + node.forEachChild(child => { |
| 103 | +>node.forEachChild : Symbol(Node.forEachChild, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 2, 16)) |
| 104 | +>node : Symbol(node, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 29)) |
| 105 | +>forEachChild : Symbol(Node.forEachChild, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 2, 16)) |
| 106 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 22, 22)) |
| 107 | + |
| 108 | + const value = cb(child); |
| 109 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 23, 13)) |
| 110 | +>cb : Symbol(cb, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 20, 40)) |
| 111 | +>child : Symbol(child, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 22, 22)) |
| 112 | + |
| 113 | + if (value !== null) { |
| 114 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 23, 13)) |
| 115 | + |
| 116 | + result.push(...toArray(value)); |
| 117 | +>result.push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --)) |
| 118 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 21, 9)) |
| 119 | +>push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --)) |
| 120 | +>toArray : Symbol(toArray, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 4, 1), Decl(inferenceDoesNotAddUndefinedOrNull.ts, 6, 49)) |
| 121 | +>value : Symbol(value, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 23, 13)) |
| 122 | + } |
| 123 | + }); |
| 124 | + return result; |
| 125 | +>result : Symbol(result, Decl(inferenceDoesNotAddUndefinedOrNull.ts, 21, 9)) |
| 126 | +} |
| 127 | + |
0 commit comments