diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-03-01 23:42:00 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-03-01 23:42:00 +0000 |
| commit | 3854a55a179ba5b4ce3d398ab2be29798197b1e3 (patch) | |
| tree | 49a255dd62f340e76d211a05a8a0f6ea8fa16ce3 | |
| parent | d12af5dc69dd57de2059e62267e6da5544c6f646 (diff) | |
| download | bcm5719-llvm-3854a55a179ba5b4ce3d398ab2be29798197b1e3.tar.gz bcm5719-llvm-3854a55a179ba5b4ce3d398ab2be29798197b1e3.zip | |
c/objc: problem originally reported as an objective-c bug.
But it is in the underlying c part of clang. clang crashes
in IRGen when passing an incomplete type argument to
variadic function (instead of diagnosing the bug).
// rdar://10961370
llvm-svn: 151862
| -rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 6 | ||||
| -rw-r--r-- | clang/test/Sema/variadic-incomplete-arg-type.c | 12 |
2 files changed, 18 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 149201192f3..6deffa2abd3 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -587,6 +587,12 @@ ExprResult Sema::DefaultVariadicArgumentPromotion(Expr *E, VariadicCallType CT, E = Comma.get(); } } + // c++ rules are enfroced elsewhere. + if (!getLangOptions().CPlusPlus && + !E->getType()->isVoidType() && + RequireCompleteType(E->getExprLoc(), E->getType(), + diag::err_incomplete_type)) + return ExprError(); return Owned(E); } diff --git a/clang/test/Sema/variadic-incomplete-arg-type.c b/clang/test/Sema/variadic-incomplete-arg-type.c new file mode 100644 index 00000000000..1306173a0ef --- /dev/null +++ b/clang/test/Sema/variadic-incomplete-arg-type.c @@ -0,0 +1,12 @@ +// RUN: %clang_cc1 %s -fsyntax-only -verify +// rdar://10961370 + +typedef struct __CFError * CFErrorRef; // expected-note {{forward declaration of 'struct __CFError'}} + +void junk(int, ...); + +int main() +{ + CFErrorRef error; + junk(1, *error); // expected-error {{incomplete type 'struct __CFError' where a complete type is required}} +} |

