Files
clang-p2996/lldb/test/API/commands/expression/namespace-alias/TestInlineNamespaceAlias.py
Michael Buch 6e10e6cb8f Reland "[lldb][DWARFASTParserClang] Correctly resolve imported namespaces during expression evaluation"
This relands a patch previously reverted
in `181d6e24ca3c09bfd6ec7c3b20affde3e5ea9b40`.
This wasn't quite working on Linux because we
weren't populating the manual DWARF index with
`DW_TAG_imported_declaration`. The relanded patch
does this.

**Summary**

This patch makes the expression evaluator understand
namespace aliases.

This will become important once `std::ranges` become
more widespread since `std::views` is defined as:

```
namespace std {
namespace ranges::views {}

namespace views = ranges::views;
}
```

**Testing**

* Added API test

Differential Revision: https://reviews.llvm.org/D143398
2023-02-13 16:58:05 +00:00

38 lines
1.2 KiB
Python

"""
Test that we correctly handle namespace
expression evaluation through namespace
aliases.
"""
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class TestInlineNamespace(TestBase):
def do_test(self, params):
self.build()
lldbutil.run_to_source_breakpoint(self,
"return A::B::C::a", lldb.SBFileSpec("main.cpp"))
self.expect_expr("A::C::a", result_type="int", result_value="-1")
self.expect_expr("A::D::a", result_type="int", result_value="-1")
self.expect_expr("A::C::func()", result_type="int", result_value="0")
self.expect_expr("A::D::func()", result_type="int", result_value="0")
self.expect_expr("E::C::a", result_type="int", result_value="-1")
self.expect_expr("E::D::a", result_type="int", result_value="-1")
self.expect_expr("F::a", result_type="int", result_value="-1")
self.expect_expr("G::a", result_type="int", result_value="-1")
@skipIf(debug_info=no_match(["dsym"]))
def test_dsym(self):
self.do_test({})
@skipIf(debug_info="dsym")
def test_dwarf(self):
self.do_test(dict(CFLAGS_EXTRAS="-gdwarf-5 -gpubnames"))