1 | import ts from 'typescript';
|
2 | import * as utils from './utils';
|
3 | export function getNameNode(node) {
|
4 | return utils.getValueOrUndefined(node.name);
|
5 | }
|
6 | export function getNameNodeOrThrow(node) {
|
7 | return utils.throwIfNullOrUndefined(getNameNode(node), 'name');
|
8 | }
|
9 | export function getName(node) {
|
10 | const name = getNameNode(node);
|
11 | if (name === undefined || ts.isObjectBindingPattern(name) || ts.isArrayBindingPattern(name)) {
|
12 | return undefined;
|
13 | }
|
14 | return name.getText();
|
15 | }
|
16 | export function getNameOrThrow(node) {
|
17 | return utils.throwIfNullOrUndefined(getName(node), 'name');
|
18 | }
|
19 | export function getPropertyNameNode(node) {
|
20 | return utils.getValueOrUndefined(node.propertyName);
|
21 | }
|
22 | export function getDotDotDotToken(node) {
|
23 | return utils.getValueOrUndefined(node.dotDotDotToken);
|
24 | }
|
25 | export function getText(node) {
|
26 | return node.getText();
|
27 | }
|
28 | export function getParentSyntaxList(node) {
|
29 | const parent = utils.getValueOrUndefined(node.parent);
|
30 | if (parent === undefined) {
|
31 | return undefined;
|
32 | }
|
33 | const { pos, end } = node;
|
34 | for (const child of parent.getChildren()) {
|
35 | if (child.pos > end || child === node) {
|
36 | return undefined;
|
37 | }
|
38 | if (child.kind === ts.SyntaxKind.SyntaxList && child.pos <= pos && child.end >= end) {
|
39 | return child;
|
40 | }
|
41 | }
|
42 | return undefined;
|
43 | }
|
44 | export function getParent(node) {
|
45 | const parent = utils.getValueOrUndefined(node.parent);
|
46 | return parent === undefined ? undefined : node.parent;
|
47 | }
|
48 | export function* getAncestors(node) {
|
49 | let parent = getParent(node);
|
50 | while (parent !== undefined) {
|
51 | yield parent;
|
52 | parent = getParent(parent);
|
53 | }
|
54 | }
|
55 | export function* getDescendants(node) {
|
56 | let children = getChildren(node);
|
57 | while (children.length > 0) {
|
58 | const mutableNextChildren = [];
|
59 | for (const child of children) {
|
60 | yield child;
|
61 | mutableNextChildren.push(...getChildren(child));
|
62 | }
|
63 | children = mutableNextChildren;
|
64 | }
|
65 | }
|
66 | export function* getDescendantsByKind(node, kind) {
|
67 | for (const descendant of getDescendants(node)) {
|
68 | if (descendant.kind === kind) {
|
69 | yield descendant;
|
70 | }
|
71 | }
|
72 | }
|
73 | function getTarget(symbol) {
|
74 | const target = symbol.target;
|
75 | return target === undefined ? symbol : target;
|
76 | }
|
77 | export function getSymbol(typeChecker, node) {
|
78 | const symbol = utils.getValueOrUndefined(node.symbol);
|
79 | if (symbol !== undefined) {
|
80 | return getTarget(symbol);
|
81 | }
|
82 | const typeCheckerSymbol = utils.getValueOrUndefined(typeChecker.getSymbolAtLocation(node));
|
83 | if (typeCheckerSymbol !== undefined) {
|
84 | return getTarget(typeCheckerSymbol);
|
85 | }
|
86 | const nameNode = getNameNode(node);
|
87 | if (nameNode !== undefined) {
|
88 | return getSymbol(typeChecker, nameNode);
|
89 | }
|
90 | return undefined;
|
91 | }
|
92 | export function getSymbolOrThrow(typeChecker, node) {
|
93 | return utils.throwIfNullOrUndefined(getSymbol(typeChecker, node), 'symbol');
|
94 | }
|
95 | function getChildren(node) {
|
96 | return node.getChildren();
|
97 | }
|
98 | export function getFirstChild(node) {
|
99 | const children = getChildren(node);
|
100 | return utils.getValueOrUndefined(children[0]);
|
101 | }
|
102 | export function getFirstChildByKind(node, kind) {
|
103 | const children = getChildren(node);
|
104 | return children.find((value) => value.kind === kind);
|
105 | }
|
106 | export function getFirstAncestorByKind(node, kind) {
|
107 | for (const ancestor of getAncestors(node)) {
|
108 | if (ancestor.kind === kind) {
|
109 | return ancestor;
|
110 | }
|
111 | }
|
112 | return undefined;
|
113 | }
|
114 | export function getFirstAncestorByKindOrThrow(node, kind) {
|
115 | return utils.throwIfNullOrUndefined(getFirstAncestorByKind(node, kind), 'ancestor');
|
116 | }
|
117 | export function getFirstAncestorByTest(node, isNode) {
|
118 | for (const ancestor of getAncestors(node)) {
|
119 | if (isNode(ancestor)) {
|
120 | return ancestor;
|
121 | }
|
122 | }
|
123 | return undefined;
|
124 | }
|
125 | export function getFirstAncestorByTestOrThrow(node, isNode) {
|
126 | return utils.throwIfNullOrUndefined(getFirstAncestorByTest(node, isNode), 'ancestor');
|
127 | }
|
128 | export function getFirstDescendantByKind(node, kind) {
|
129 | for (const ancestor of getDescendants(node)) {
|
130 | if (ancestor.kind === kind) {
|
131 | return ancestor;
|
132 | }
|
133 | }
|
134 | return undefined;
|
135 | }
|
136 | function hasNodeFlag(node, flag) {
|
137 | return (node.flags & flag) !== 0;
|
138 | }
|
139 | export function isGlobalAugmentation(node) {
|
140 | return hasNodeFlag(node, ts.NodeFlags.GlobalAugmentation);
|
141 | }
|
142 | export function getSourceFile(node) {
|
143 | return node.getSourceFile();
|
144 | }
|
145 | export function getPos(node) {
|
146 | return node.pos;
|
147 | }
|
148 | export function getEnd(node) {
|
149 | return node.end;
|
150 | }
|
151 | export function getChildAtPos(node, pos) {
|
152 | if (pos < getPos(node) || pos >= getEnd(node)) {
|
153 | return undefined;
|
154 | }
|
155 | return getChildren(node).find((child) => pos >= getPos(child) && pos < getEnd(child));
|
156 | }
|
157 | export function getDescendantAtPos(nodeIn, pos) {
|
158 | let node;
|
159 | while (true) {
|
160 | const nextNode = getChildAtPos(node === undefined ? nodeIn : node, pos);
|
161 | if (nextNode === undefined) {
|
162 | return node;
|
163 | }
|
164 | node = nextNode;
|
165 | }
|
166 | }
|
167 | export function isPartOfTypeNode(node) {
|
168 | return ts.isPartOfTypeNode(node);
|
169 | }
|
170 |
|
171 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,YAAY,CAAC;AAC5B,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AAiBjC,MAAM,UAAU,WAAW,CAAC,IAAS;IACnC,OAAO,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC9C,CAAC;AAKD,MAAM,UAAU,kBAAkB,CAAC,IAAS;IAC1C,OAAO,KAAK,CAAC,sBAAsB,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;AACjE,CAAC;AAOD,MAAM,UAAU,OAAO,CAAC,IAAS;IAC/B,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAiE,CAAC;IAC/F,IAAI,IAAI,KAAK,SAAS,IAAI,EAAE,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,qBAAqB,CAAC,IAAI,CAAC,EAAE;QAC3F,OAAO,SAAS,CAAC;KAClB;IAED,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,IAAkH;IAGlH,OAAO,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,IAAW,CAAC,EAAE,MAAM,CAAC,CAAC;AACpE,CAAC;AAID,MAAM,UAAU,mBAAmB,CAA4B,IAAiC;IAC9F,OAAO,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACtD,CAAC;AAID,MAAM,UAAU,iBAAiB,CAAC,IAAwB;IACxD,OAAO,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAAa;IACnC,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,IAAa;IAC/C,MAAM,MAAM,GAAG,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtD,IAAI,MAAM,KAAK,SAAS,EAAE;QACxB,OAAO,SAAS,CAAC;KAClB;IAED,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;IAE1B,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,WAAW,EAAE,EAAE;QACxC,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,KAAK,KAAK,IAAI,EAAE;YACrC,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,KAAK,CAAC,IAAI,KAAK,EAAE,CAAC,UAAU,CAAC,UAAU,IAAI,KAAK,CAAC,GAAG,IAAI,GAAG,IAAI,KAAK,CAAC,GAAG,IAAI,GAAG,EAAE;YACnF,OAAO,KAAK,CAAC;SACd;KACF;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,SAAS,CACvB,IAAW;IAEX,MAAM,MAAM,GAAG,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAGtD,OAAO,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAE,IAAI,CAAC,MAAc,CAAC;AACjE,CAAC;AAED,MAAM,SAAS,CAAC,CAAC,YAAY,CAAC,IAAa;IACzC,IAAI,MAAM,GAAG,SAAS,CAAC,IAAI,CAAwB,CAAC;IAEpD,OAAO,MAAM,KAAK,SAAS,EAAE;QAC3B,MAAM,MAAM,CAAC;QACb,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;KAC5B;AACH,CAAC;AAED,MAAM,SAAS,CAAC,CAAC,cAAc,CAAC,IAAa;IAC3C,IAAI,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAEjC,OAAO,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;QAC1B,MAAM,mBAAmB,GAAc,EAAE,CAAC;QAE1C,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;YAC5B,MAAM,KAAK,CAAC;YACZ,mBAAmB,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;SACjD;QAED,QAAQ,GAAG,mBAAmB,CAAC;KAChC;AACH,CAAC;AAED,MAAM,SAAS,CAAC,CAAC,oBAAoB,CACnC,IAAa,EACb,IAAkE;IAGlE,KAAK,MAAM,UAAU,IAAI,cAAc,CAAC,IAAI,CAAC,EAAE;QAC7C,IAAI,UAAU,CAAC,IAAI,KAAK,IAAI,EAAE;YAC5B,MAAM,UAAmB,CAAC;SAC3B;KACF;AACH,CAAC;AAED,SAAS,SAAS,CAAC,MAAiB;IAClC,MAAM,MAAM,GAAI,MAAc,CAAC,MAAM,CAAC;IAEtC,OAAO,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;AAChD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,WAA2B,EAAE,IAAa;IAElE,MAAM,MAAM,GAAG,KAAK,CAAC,mBAAmB,CAAE,IAAY,CAAC,MAAM,CAAC,CAAC;IAC/D,IAAI,MAAM,KAAK,SAAS,EAAE;QACxB,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC;KAC1B;IAED,MAAM,iBAAiB,GAAG,KAAK,CAAC,mBAAmB,CAAC,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3F,IAAI,iBAAiB,KAAK,SAAS,EAAE;QACnC,OAAO,SAAS,CAAC,iBAAiB,CAAC,CAAC;KACrC;IAED,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IACnC,IAAI,QAAQ,KAAK,SAAS,EAAE;QAC1B,OAAO,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;KACzC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,WAA2B,EAAE,IAAa;IACzE,OAAO,KAAK,CAAC,sBAAsB,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC;AAC9E,CAAC;AAED,SAAS,WAAW,CAAC,IAAa;IAChC,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAa;IACzC,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAEnC,OAAO,KAAK,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;AAChD,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,IAAa,EACb,IAAkE;IAElE,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAEnC,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,KAAK,EAAkB,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;AACvE,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,IAAa,EACb,IAAkE;IAGlE,KAAK,MAAM,QAAQ,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE;QACzC,IAAI,QAAQ,CAAC,IAAI,KAAK,IAAI,EAAE;YAC1B,OAAO,QAAiB,CAAC;SAC1B;KACF;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,6BAA6B,CAC3C,IAAa,EACb,IAAkE;IAGlE,OAAO,KAAK,CAAC,sBAAsB,CAAC,sBAAsB,CAAQ,IAAI,EAAE,IAAW,CAAC,EAAE,UAAU,CAAC,CAAC;AACpG,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,IAAa,EACb,MAA0C;IAG1C,KAAK,MAAM,QAAQ,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE;QACzC,IAAI,MAAM,CAAC,QAAQ,CAAC,EAAE;YACpB,OAAO,QAAQ,CAAC;SACjB;KACF;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,6BAA6B,CAC3C,IAAa,EACb,MAA0C;IAG1C,OAAO,KAAK,CAAC,sBAAsB,CAAC,sBAAsB,CAAQ,IAAI,EAAE,MAAM,CAAC,EAAE,UAAU,CAAC,CAAC;AAC/F,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,IAAa,EACb,IAAkE;IAGlE,KAAK,MAAM,QAAQ,IAAI,cAAc,CAAC,IAAI,CAAC,EAAE;QAC3C,IAAI,QAAQ,CAAC,IAAI,KAAK,IAAI,EAAE;YAC1B,OAAO,QAAiB,CAAC;SAC1B;KACF;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,WAAW,CAAC,IAAa,EAAE,IAAkB;IAEpD,OAAO,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,IAAa;IAChD,OAAO,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAa;IACzC,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,IAAa;IAClC,OAAO,IAAI,CAAC,GAAG,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,IAAa;IAClC,OAAO,IAAI,CAAC,GAAG,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAa,EAAE,GAAW;IACtD,IAAI,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;QAC7C,OAAO,SAAS,CAAC;KAClB;IAED,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;AACxF,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,MAAe,EAAE,GAAW;IAC7D,IAAI,IAAyB,CAAC;IAE9B,OAAO,IAAI,EAAE;QACX,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QACxE,IAAI,QAAQ,KAAK,SAAS,EAAE;YAC1B,OAAO,IAAI,CAAC;SACb;QAED,IAAI,GAAG,QAAQ,CAAC;KACjB;AACH,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,IAAa;IAE5C,OAAQ,EAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;AAC5C,CAAC","file":"neo-one-ts-utils/src/node.js","sourcesContent":["// tslint:disable no-any\nimport ts from 'typescript';\nimport * as utils from './utils';\n\ntype NamedNode = ts.Node & { readonly name: ts.Identifier };\ntype NameableNode = ts.Node & { readonly name?: ts.Identifier };\nexport type PropertyNamedNode = ts.Node & { readonly name: ts.PropertyName };\ntype PropertyNameableNode = ts.Node & { readonly name?: ts.PropertyName };\ntype BindingNamedNode = ts.Node & { readonly name: ts.BindingName };\ntype BindingNameableNode = ts.Node & { readonly name?: ts.BindingName };\nexport type AnyNameableNode = NameableNode | PropertyNameableNode | BindingNameableNode;\n\nexport function getNameNode(node: NamedNode): ts.Identifier;\nexport function getNameNode(node: PropertyNamedNode): ts.PropertyName;\nexport function getNameNode(node: BindingNamedNode): ts.BindingName;\nexport function getNameNode(node: NameableNode): ts.Identifier | undefined;\nexport function getNameNode(node: PropertyNameableNode): ts.PropertyName | undefined;\nexport function getNameNode(node: BindingNameableNode): ts.BindingName | undefined;\nexport function getNameNode(node: AnyNameableNode): ts.Identifier | ts.PropertyName | ts.BindingName | undefined;\nexport function getNameNode(node: any): ts.Identifier | ts.PropertyName | ts.BindingName | undefined {\n  return utils.getValueOrUndefined(node.name);\n}\n\nexport function getNameNodeOrThrow(node: NameableNode | NamedNode): ts.Identifier;\nexport function getNameNodeOrThrow(node: PropertyNameableNode | PropertyNamedNode): ts.PropertyName;\nexport function getNameNodeOrThrow(node: BindingNameableNode | BindingNamedNode): ts.BindingName;\nexport function getNameNodeOrThrow(node: any): ts.Identifier | ts.PropertyName | ts.BindingName {\n  return utils.throwIfNullOrUndefined(getNameNode(node), 'name');\n}\n\nexport function getName(node: NamedNode | PropertyNamedNode): string;\nexport function getName(\n  node: NameableNode | PropertyNameableNode | BindingNameableNode | BindingNamedNode,\n): string | undefined;\n// tslint:disable-next-line no-any\nexport function getName(node: any): string | undefined {\n  const name = getNameNode(node) as ts.Identifier | ts.PropertyName | ts.BindingName | undefined;\n  if (name === undefined || ts.isObjectBindingPattern(name) || ts.isArrayBindingPattern(name)) {\n    return undefined;\n  }\n\n  return name.getText();\n}\n\nexport function getNameOrThrow(\n  node: NameableNode | NamedNode | PropertyNameableNode | PropertyNamedNode | BindingNameableNode | BindingNamedNode,\n): string {\n  // tslint:disable-next-line no-any\n  return utils.throwIfNullOrUndefined(getName(node as any), 'name');\n}\n\ntype PropertyNameNameableNode<T extends ts.PropertyName> = ts.Node & { readonly propertyName?: T };\n\nexport function getPropertyNameNode<T extends ts.PropertyName>(node: PropertyNameNameableNode<T>): T | undefined {\n  return utils.getValueOrUndefined(node.propertyName);\n}\n\ntype DotDotDotTokenNode = ts.Node & { readonly dotDotDotToken?: ts.DotDotDotToken };\n\nexport function getDotDotDotToken(node: DotDotDotTokenNode): ts.DotDotDotToken | undefined {\n  return utils.getValueOrUndefined(node.dotDotDotToken);\n}\n\nexport function getText(node: ts.Node): string {\n  return node.getText();\n}\n\nexport function getParentSyntaxList(node: ts.Node) {\n  const parent = utils.getValueOrUndefined(node.parent);\n  if (parent === undefined) {\n    return undefined;\n  }\n\n  const { pos, end } = node;\n  // tslint:disable-next-line no-loop-statement\n  for (const child of parent.getChildren()) {\n    if (child.pos > end || child === node) {\n      return undefined;\n    }\n\n    if (child.kind === ts.SyntaxKind.SyntaxList && child.pos <= pos && child.end >= end) {\n      return child;\n    }\n  }\n\n  return undefined; // shouldn't happen\n}\n\nexport function getParent<TNode extends ts.Node>(\n  node: TNode,\n): TNode extends { readonly parent?: infer TParent | null } ? TParent : never {\n  const parent = utils.getValueOrUndefined(node.parent);\n\n  // tslint:disable-next-line no-any\n  return parent === undefined ? undefined : (node.parent as any);\n}\n\nexport function* getAncestors(node: ts.Node): IterableIterator<ts.Node> {\n  let parent = getParent(node) as ts.Node | undefined;\n  // tslint:disable-next-line no-loop-statement\n  while (parent !== undefined) {\n    yield parent;\n    parent = getParent(parent);\n  }\n}\n\nexport function* getDescendants(node: ts.Node): IterableIterator<ts.Node> {\n  let children = getChildren(node);\n  // tslint:disable-next-line no-loop-statement\n  while (children.length > 0) {\n    const mutableNextChildren: ts.Node[] = [];\n    // tslint:disable-next-line no-loop-statement\n    for (const child of children) {\n      yield child;\n      mutableNextChildren.push(...getChildren(child));\n    }\n\n    children = mutableNextChildren;\n  }\n}\n\nexport function* getDescendantsByKind<TNode extends ts.Node>(\n  node: ts.Node,\n  kind: TNode extends { readonly kind: infer TKind } ? TKind : never,\n): IterableIterator<TNode> {\n  // tslint:disable-next-line no-loop-statement\n  for (const descendant of getDescendants(node)) {\n    if (descendant.kind === kind) {\n      yield descendant as TNode;\n    }\n  }\n}\n\nfunction getTarget(symbol: ts.Symbol): ts.Symbol {\n  const target = (symbol as any).target;\n\n  return target === undefined ? symbol : target;\n}\n\nexport function getSymbol(typeChecker: ts.TypeChecker, node: ts.Node): ts.Symbol | undefined {\n  // tslint:disable-next-line no-any\n  const symbol = utils.getValueOrUndefined((node as any).symbol);\n  if (symbol !== undefined) {\n    return getTarget(symbol);\n  }\n\n  const typeCheckerSymbol = utils.getValueOrUndefined(typeChecker.getSymbolAtLocation(node));\n  if (typeCheckerSymbol !== undefined) {\n    return getTarget(typeCheckerSymbol);\n  }\n\n  const nameNode = getNameNode(node);\n  if (nameNode !== undefined) {\n    return getSymbol(typeChecker, nameNode);\n  }\n\n  return undefined;\n}\n\nexport function getSymbolOrThrow(typeChecker: ts.TypeChecker, node: ts.Node): ts.Symbol {\n  return utils.throwIfNullOrUndefined(getSymbol(typeChecker, node), 'symbol');\n}\n\nfunction getChildren(node: ts.Node): readonly ts.Node[] {\n  return node.getChildren();\n}\n\nexport function getFirstChild(node: ts.Node): ts.Node | undefined {\n  const children = getChildren(node);\n\n  return utils.getValueOrUndefined(children[0]);\n}\n\nexport function getFirstChildByKind<TNode extends ts.Node>(\n  node: ts.Node,\n  kind: TNode extends { readonly kind: infer TKind } ? TKind : never,\n): TNode | undefined {\n  const children = getChildren(node);\n\n  return children.find((value): value is TNode => value.kind === kind);\n}\n\nexport function getFirstAncestorByKind<TNode extends ts.Node>(\n  node: ts.Node,\n  kind: TNode extends { readonly kind: infer TKind } ? TKind : never,\n): TNode | undefined {\n  // tslint:disable-next-line no-loop-statement\n  for (const ancestor of getAncestors(node)) {\n    if (ancestor.kind === kind) {\n      return ancestor as TNode;\n    }\n  }\n\n  return undefined;\n}\n\nexport function getFirstAncestorByKindOrThrow<TNode extends ts.Node>(\n  node: ts.Node,\n  kind: TNode extends { readonly kind: infer TKind } ? TKind : never,\n): TNode {\n  // tslint:disable-next-line no-any\n  return utils.throwIfNullOrUndefined(getFirstAncestorByKind<TNode>(node, kind as any), 'ancestor');\n}\n\nexport function getFirstAncestorByTest<TNode extends ts.Node>(\n  node: ts.Node,\n  isNode: (value: ts.Node) => value is TNode,\n): TNode | undefined {\n  // tslint:disable-next-line no-loop-statement\n  for (const ancestor of getAncestors(node)) {\n    if (isNode(ancestor)) {\n      return ancestor;\n    }\n  }\n\n  return undefined;\n}\n\nexport function getFirstAncestorByTestOrThrow<TNode extends ts.Node>(\n  node: ts.Node,\n  isNode: (value: ts.Node) => value is TNode,\n): TNode {\n  // tslint:disable-next-line no-any\n  return utils.throwIfNullOrUndefined(getFirstAncestorByTest<TNode>(node, isNode), 'ancestor');\n}\n\nexport function getFirstDescendantByKind<TNode extends ts.Node>(\n  node: ts.Node,\n  kind: TNode extends { readonly kind: infer TKind } ? TKind : never,\n): TNode | undefined {\n  // tslint:disable-next-line no-loop-statement\n  for (const ancestor of getDescendants(node)) {\n    if (ancestor.kind === kind) {\n      return ancestor as TNode;\n    }\n  }\n\n  return undefined;\n}\n\nfunction hasNodeFlag(node: ts.Node, flag: ts.NodeFlags): boolean {\n  // tslint:disable-next-line no-bitwise\n  return (node.flags & flag) !== 0;\n}\n\nexport function isGlobalAugmentation(node: ts.Node): boolean {\n  return hasNodeFlag(node, ts.NodeFlags.GlobalAugmentation);\n}\n\nexport function getSourceFile(node: ts.Node): ts.SourceFile {\n  return node.getSourceFile();\n}\n\nexport function getPos(node: ts.Node): number {\n  return node.pos;\n}\n\nexport function getEnd(node: ts.Node): number {\n  return node.end;\n}\n\nexport function getChildAtPos(node: ts.Node, pos: number): ts.Node | undefined {\n  if (pos < getPos(node) || pos >= getEnd(node)) {\n    return undefined;\n  }\n\n  return getChildren(node).find((child) => pos >= getPos(child) && pos < getEnd(child));\n}\n\nexport function getDescendantAtPos(nodeIn: ts.Node, pos: number): ts.Node | undefined {\n  let node: ts.Node | undefined;\n  // tslint:disable-next-line no-loop-statement\n  while (true) {\n    const nextNode = getChildAtPos(node === undefined ? nodeIn : node, pos);\n    if (nextNode === undefined) {\n      return node;\n    }\n\n    node = nextNode;\n  }\n}\n\nexport function isPartOfTypeNode(node: ts.Node): boolean {\n  // tslint:disable-next-line no-any\n  return (ts as any).isPartOfTypeNode(node);\n}\n"]}
|