diff options
| author | Douglas Gregor <dgregor@apple.com> | 2009-03-27 23:40:29 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2009-03-27 23:40:29 +0000 |
| commit | 8aa6bf5b8e38296387117d52df42b7e7dcebcfc4 (patch) | |
| tree | be84c064960ee9b833bfd503fe22290c6d9b744e | |
| parent | 6fcec6652539125311e63131188ff871ba3f6318 (diff) | |
| download | bcm5719-llvm-8aa6bf5b8e38296387117d52df42b7e7dcebcfc4.tar.gz bcm5719-llvm-8aa6bf5b8e38296387117d52df42b7e7dcebcfc4.zip | |
Fix <rdar://problem/6724396>, where we were silently dropping
GNU-style array designators, causing us to emit broken initializers.
llvm-svn: 67878
| -rw-r--r-- | clang/lib/Parse/ParseInit.cpp | 3 | ||||
| -rw-r--r-- | clang/test/CodeGen/designated-initializers.c | 7 |
2 files changed, 8 insertions, 2 deletions
diff --git a/clang/lib/Parse/ParseInit.cpp b/clang/lib/Parse/ParseInit.cpp index bf31e7bb856..3a42e50a9ca 100644 --- a/clang/lib/Parse/ParseInit.cpp +++ b/clang/lib/Parse/ParseInit.cpp @@ -210,7 +210,8 @@ Parser::OwningExprResult Parser::ParseInitializerWithPotentialDesignator() { (Desig.getDesignator(0).isArrayDesignator() || Desig.getDesignator(0).isArrayRangeDesignator())) { Diag(Tok, diag::ext_gnu_missing_equal_designator); - return ParseInitializer(); + return Actions.ActOnDesignatedInitializer(Desig, SourceLocation(), + true, ParseInitializer()); } Diag(Tok, diag::err_expected_equal_designator); diff --git a/clang/test/CodeGen/designated-initializers.c b/clang/test/CodeGen/designated-initializers.c index 94d446c4e0e..46693392866 100644 --- a/clang/test/CodeGen/designated-initializers.c +++ b/clang/test/CodeGen/designated-initializers.c @@ -1,4 +1,5 @@ -// RUN: clang-cc -triple i386-unknown-unknown %s -emit-llvm -o - | grep "<{ i8\* null, i32 1024 }>" +// RUN: clang-cc -triple i386-unknown-unknown %s -emit-llvm -o - | grep "<{ i8\* null, i32 1024 }>" && +// RUN: clang-cc -triple i386-unknown-unknown %s -emit-llvm -o - | grep "i32 0, i32 22" struct foo { void *a; @@ -14,3 +15,7 @@ int main(int argc, char **argv) .b = 1024, }; } + +int b[2] = { + [1] 22 +}; |

