llvm-capstone/lldb/test
Michael Buch 2bf01d73f6
[lldb][DWARFASTParserClang] GetClangDeclForDIE: don't create VarDecl for static data members (#77155)
With DWARFv5, C++ static data members are represented as
`DW_TAG_variable`s (see `faa3a5ea9ae481da757dab1c95c589e2d5645982`).

In GetClangDeclForDIE, when trying to parse the `DW_AT_specification`
that a static data member's CU-level `DW_TAG_variable` points to, we
would try to `CreateVariableDeclaration`. Whereas previously it was a
no-op (for `DW_TAG_member`s). However, adding `VarDecls` to RecordDecls
for static data members should always be done in
`CreateStaticMemberVariable`. The test-case is an exapmle where we would
crash if we tried to create a `VarDecl` from within `GetClangDeclForDIE`
for a static data member.

This patch simply checks whether the `DW_TAG_variable` being parsed is a
static data member, and if so, trivially returns from
`GetClangDeclForDIE` (as we previously did for `DW_TAG_member`s).
2024-01-08 14:10:02 +00:00
..
API [lldb][test] Skip part of nested expressions test on Windows 2024-01-08 12:17:16 +00:00
Shell [lldb][DWARFASTParserClang] GetClangDeclForDIE: don't create VarDecl for static data members (#77155) 2024-01-08 14:10:02 +00:00
Unit
CMakeLists.txt [lldb] Add test dependency on the runtimes instead of the cxx target 2023-10-25 16:03:51 -07:00
lit.cfg.py
lit.site.cfg.py.in