summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Frontend/PCHReader.cpp2
-rw-r--r--clang/test/PCH/va_arg.c12
-rw-r--r--clang/test/PCH/va_arg.h8
3 files changed, 20 insertions, 2 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp
index 2e8e7dd287d..8889312090e 100644
--- a/clang/lib/Frontend/PCHReader.cpp
+++ b/clang/lib/Frontend/PCHReader.cpp
@@ -2369,7 +2369,6 @@ Stmt *PCHReader::ReadStmt() {
break;
case pch::EXPR_VA_ARG:
- // FIXME: untested; we need function bodies first
S = new (Context) VAArgExpr(Empty);
break;
@@ -2402,7 +2401,6 @@ Stmt *PCHReader::ReadStmt() {
break;
case pch::EXPR_BLOCK_DECL_REF:
- // FIXME: untested until we have statement and block support
S = new (Context) BlockDeclRefExpr(Empty);
break;
}
diff --git a/clang/test/PCH/va_arg.c b/clang/test/PCH/va_arg.c
new file mode 100644
index 00000000000..796be03b075
--- /dev/null
+++ b/clang/test/PCH/va_arg.c
@@ -0,0 +1,12 @@
+// Test this without pch.
+// RUN: clang-cc -triple=x86_64-unknown-freebsd7.0 -include %S/va_arg.h -fsyntax-only -ast-print -o - %s
+
+// Test with pch.
+// RUN: clang-cc -triple=x86_64-unknown-freebsd7.0 -emit-pch -o %t %S/va_arg.h &&
+// RUN: clang-cc -triple=x86_64-unknown-freebsd7.0 -include-pch %t -fsyntax-only -ast-print -o - %s
+
+char *g0(char** argv, int argc) { return argv[argc]; }
+
+char *g(char **argv) {
+ f(g0, argv, 1, 2, 3);
+}
diff --git a/clang/test/PCH/va_arg.h b/clang/test/PCH/va_arg.h
new file mode 100644
index 00000000000..4a8e5102bc6
--- /dev/null
+++ b/clang/test/PCH/va_arg.h
@@ -0,0 +1,8 @@
+// Header for PCH test va_arg.c
+
+typedef __builtin_va_list va_list;
+char *f (char * (*g) (char **, int), char **p, ...) {
+ char *s;
+ va_list v;
+ s = g (p, __builtin_va_arg(v, int));
+}
OpenPOWER on IntegriCloud