aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Lex/ModuleMap.cpp
diff options
context:
space:
mode:
authorSirraide <aeternalmail@gmail.com>2024-03-13 18:49:44 +0100
committerGitHub <noreply@github.com>2024-03-13 18:49:44 +0100
commitbd77a26e9a15981114e9802d83047f42631125a2 (patch)
treec764ff1e4f8290847e8157591a85291e5d30b6b2 /clang/lib/Lex/ModuleMap.cpp
parent175b533720956017bb18d1280362f6890ee15b05 (diff)
downloadllvm-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