diff options
author | Sirraide <aeternalmail@gmail.com> | 2024-03-13 18:49:44 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-13 18:49:44 +0100 |
commit | bd77a26e9a15981114e9802d83047f42631125a2 (patch) | |
tree | c764ff1e4f8290847e8157591a85291e5d30b6b2 /clang/lib/Lex/ModuleMap.cpp | |
parent | 175b533720956017bb18d1280362f6890ee15b05 (diff) | |
download | llvm-bd77a26e9a15981114e9802d83047f42631125a2.zip llvm-bd77a26e9a15981114e9802d83047f42631125a2.tar.gz llvm-bd77a26e9a15981114e9802d83047f42631125a2.tar.bz2 |
[Clang][Sema] Properly get captured 'this' pointer in lambdas with an explicit object parameter in constant evaluator (#81102)
There were some bugs wrt explicit object parameters in lambdas in the
constant evaluator:
- The code evaluating a `CXXThisExpr` wasn’t checking for explicit
object parameters at all and thus assumed that there was no `this` in
the current context because the lambda didn’t have one, even though we
were in a member function and had captured its `this`.
- The code retrieving captures as lvalues *did* account for explicit
object parameters, but it did not handle the case of the explicit object
parameter being passed by value rather than by reference.
This fixes #80997.
---------
Co-authored-by: cor3ntin <corentinjabot@gmail.com>
Co-authored-by: Aaron Ballman <aaron@aaronballman.com>
Diffstat (limited to 'clang/lib/Lex/ModuleMap.cpp')
0 files changed, 0 insertions, 0 deletions