aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-02-12 09:21:08 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-02-12 09:21:08 +0000
commitadadd8db2aba32f689e7057d8b7ce004be30685b (patch)
tree30ef163338f229d8813c36f5e939a4c1ed444342
parentbe9eb0937c667e2823971966adf960f86d3985d6 (diff)
Fix va_arg bug noticed by Eli, __builtin_va_arg is not an l-value
designating an object. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64371 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/AST/Expr.cpp2
-rw-r--r--test/Sema/varargs.c8
2 files changed, 9 insertions, 1 deletions
diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp
index 95a6a349f3..7b06a3c1ce 100644
--- a/lib/AST/Expr.cpp
+++ b/lib/AST/Expr.cpp
@@ -565,7 +565,7 @@ Expr::isLvalueResult Expr::isLvalue(ASTContext &Ctx) const {
case PredefinedExprClass:
return LV_Valid;
case VAArgExprClass:
- return LV_Valid;
+ return LV_NotObjectType;
case CXXDefaultArgExprClass:
return cast<CXXDefaultArgExpr>(this)->getExpr()->isLvalue(Ctx);
case CXXConditionDeclExprClass:
diff --git a/test/Sema/varargs.c b/test/Sema/varargs.c
index ae21c208eb..b340177f9c 100644
--- a/test/Sema/varargs.c
+++ b/test/Sema/varargs.c
@@ -52,3 +52,11 @@ foo(__builtin_va_list authors, ...) {
__builtin_va_end (authors);
}
+void f7(int a, ...) {
+ __builtin_va_list ap;
+ __builtin_va_start(ap, a);
+ // FIXME: This error message is sub-par.
+ __builtin_va_arg(ap, int) = 1; // expected-error {{non-object type 'int' is not assignable}}
+ int *x = &__builtin_va_arg(ap, int); // expected-error {{address expression must be an lvalue or a function designator}}
+ __builtin_va_end(ap);
+}