diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-08-16 17:27:13 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-08-16 17:27:13 +0000 |
| commit | a3ae3eb6901ea74dc7c4e1f656fc8e64fe36034e (patch) | |
| tree | 009183a2daab227c9a0bc2a2a7954b1bdd05ead1 | |
| parent | 33aee3934acfa83de7bff57d653113c188a0f148 (diff) | |
| download | bcm5719-llvm-a3ae3eb6901ea74dc7c4e1f656fc8e64fe36034e.tar.gz bcm5719-llvm-a3ae3eb6901ea74dc7c4e1f656fc8e64fe36034e.zip | |
Fix initialization for members of anonymous struct in a union.
llvm-svn: 111159
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 3 | ||||
| -rw-r--r-- | clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp | 12 |
2 files changed, 15 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index a1a84667595..1d0b4a9450f 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -1798,6 +1798,9 @@ static bool CollectFieldInitializer(BaseAndFieldInfo &Info, // Once we've initialized a field of an anonymous union, the union // field in the class is also initialized, so exit immediately. return false; + } else if ((*FA)->isAnonymousStructOrUnion()) { + if (CollectFieldInitializer(Info, Top, *FA)) + return true; } } diff --git a/clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp b/clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp index a4da2c04fd7..9ba38052e17 100644 --- a/clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp +++ b/clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp @@ -78,3 +78,15 @@ namespace test3 { // CHECK-NEXT: [[CVALUE:%.*]] = getelementptr inbounds {{.*}} [[STRUCT]], i32 0, i32 0 // CHECK-NEXT: store i8* null, void i8** [[CVALUE]] } + +struct S { + // CHECK: store i32 42 + // CHECK: store i32 55 + S() : x(42), y(55) {} + union { + struct { + int x; + union { int y; }; + }; + }; +} s; |

