diff options
| author | John McCall <rjmccall@apple.com> | 2010-11-23 20:48:44 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2010-11-23 20:48:44 +0000 |
| commit | feb624a435932b9c7888cc3a0a80b683f72a8554 (patch) | |
| tree | 035426fe397a76b3251a7f907dbcb620bdb1108c /clang/lib/Sema/SemaTemplate.cpp | |
| parent | ab7be6e43c878f4192cdac764677304757d95d71 (diff) | |
| download | bcm5719-llvm-feb624a435932b9c7888cc3a0a80b683f72a8554.tar.gz bcm5719-llvm-feb624a435932b9c7888cc3a0a80b683f72a8554.zip | |
A few tweaks to the value-kind computation:
- Default argument expressions pick up the value kind of the incoming
expression, not the value kind of the parameter it initializes.
- When building a template argument for substitution, A::x is an rvalue
if x is an instance method.
- Anonymous struct/union paths pick up value kind the same way that
normal member accesses do; extract out a common code path for this.
Enable the value-kind assertion, now that it passes self-host.
llvm-svn: 120055
Diffstat (limited to 'clang/lib/Sema/SemaTemplate.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaTemplate.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaTemplate.cpp b/clang/lib/Sema/SemaTemplate.cpp index daa1e726a06..53d7c10ede7 100644 --- a/clang/lib/Sema/SemaTemplate.cpp +++ b/clang/lib/Sema/SemaTemplate.cpp @@ -3365,9 +3365,17 @@ Sema::BuildExpressionFromDeclTemplateArgument(const TemplateArgument &Arg, ClassType.getTypePtr()); CXXScopeSpec SS; SS.setScopeRep(Qualifier); + + // The actual value-ness of this is unimportant, but for + // internal consistency's sake, references to instance methods + // are r-values. + ExprValueKind VK = VK_LValue; + if (isa<CXXMethodDecl>(VD) && cast<CXXMethodDecl>(VD)->isInstance()) + VK = VK_RValue; + ExprResult RefExpr = BuildDeclRefExpr(VD, VD->getType().getNonReferenceType(), - VK_LValue, + VK, Loc, &SS); if (RefExpr.isInvalid()) |

