diff options
author | Douglas Gregor <dgregor@apple.com> | 2012-02-21 00:37:24 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2012-02-21 00:37:24 +0000 |
commit | ccc1b5eebc6ca8a904c58c0468b9a71483b7c7cf (patch) | |
tree | e2665ec87aa0c270a52f40e66b19a6ca5b2f05f0 /lib/Parse/ParseDecl.cpp | |
parent | ef7844666b36226521e459d18f2834dacaa039e3 (diff) |
Implement name mangling for lambda expressions that occur within the
default arguments of function parameters. This simple-sounding task is
complicated greatly by two issues:
(1) Default arguments aren't actually a real context, so we need to
maintain extra state within lambda expressions to track when a
lambda was actually in a default argument.
(2) At the time that we parse a default argument, the FunctionDecl
doesn't exist yet, so lambda closure types end up in the enclosing
context. It's not clear that we ever want to change that, so instead
we introduce the notion of the "effective" context of a declaration
for the purposes of name mangling.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151011 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Parse/ParseDecl.cpp')
-rw-r--r-- | lib/Parse/ParseDecl.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Parse/ParseDecl.cpp b/lib/Parse/ParseDecl.cpp index 0b98274002..4193890021 100644 --- a/lib/Parse/ParseDecl.cpp +++ b/lib/Parse/ParseDecl.cpp @@ -4520,7 +4520,8 @@ void Parser::ParseParameterDeclarationClause( // The argument isn't actually potentially evaluated unless it is // used. EnterExpressionEvaluationContext Eval(Actions, - Sema::PotentiallyEvaluatedIfUsed); + Sema::PotentiallyEvaluatedIfUsed, + Param); ExprResult DefArgResult(ParseAssignmentExpression()); if (DefArgResult.isInvalid()) { |