Michael137 wrote:

> It's not clear to me whether `TypeSystem::DeclContextIsContainedInLookup` 
> provides such a guarantee. Implementation suggests that it's only interested 
> in direct `DeclContext`, maybe ignoring transparent decl contexts like inline 
> namespace it already handles. I hope reviewers can clarify this.

We use `DeclContextIsContainedInLookup` to make sure that if, e.g., a user ran 
`expr A::B::C`, then the type we find for `C` is in fact a child of `B` which 
is a child of `A`. So it really is just a way to walk up a context hierarchy 
directly and check that the hierarchy in DWARF matches the hierarchy in 
`clang::DeclContext`. As you say, it also supports inline namespaces, but that 
only came later as we needed it to make namespaces work during expression 
evaluation. It seems to me that this function developed organically with the 
needs of the expression evaluator/type lookup, and its purpose was always 
really to just do a directed is-contained check. While I don't think this will 
be change (since lookup is already fragile things probably rely on it being 
this way), it would make sense to document this in the 
`DeclContextIsContainedInLookup` contract and add tests for it so it's future 
proof. But that could be done outside of this PR in my opinion.

https://github.com/llvm/llvm-project/pull/68705
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to