diff --git a/src/services/findAllReferences.ts b/src/services/findAllReferences.ts index 394e487e2f0..e40a1f28161 100644 --- a/src/services/findAllReferences.ts +++ b/src/services/findAllReferences.ts @@ -1035,14 +1035,16 @@ namespace ts.FindAllReferences.Core { if (!(isMethodOrAccessor(member) && hasModifier(member, ModifierFlags.Static))) { continue; } - member.body!.forEachChild(function cb(node) { - if (node.kind === SyntaxKind.ThisKeyword) { - addRef(node); - } - else if (!isFunctionLike(node)) { - node.forEachChild(cb); - } - }); + if (member.body) { + member.body.forEachChild(function cb(node) { + if (node.kind === SyntaxKind.ThisKeyword) { + addRef(node); + } + else if (!isFunctionLike(node)) { + node.forEachChild(cb); + } + }); + } } } diff --git a/tests/cases/fourslash/findAllRefsDeclareClass.ts b/tests/cases/fourslash/findAllRefsDeclareClass.ts new file mode 100644 index 00000000000..9ef813634a5 --- /dev/null +++ b/tests/cases/fourslash/findAllRefsDeclareClass.ts @@ -0,0 +1,7 @@ +/// + +////declare class [|{| "isWriteAccess": true, "isDefinition": true |}C|] { +//// static m(): void; +////} + +verify.singleReferenceGroup("class C");