summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2010-08-16 17:27:13 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2010-08-16 17:27:13 +0000
commita3ae3eb6901ea74dc7c4e1f656fc8e64fe36034e (patch)
tree009183a2daab227c9a0bc2a2a7954b1bdd05ead1
parent33aee3934acfa83de7bff57d653113c188a0f148 (diff)
downloadbcm5719-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.cpp3
-rw-r--r--clang/test/CodeGenCXX/anonymous-union-member-initializer.cpp12
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;
OpenPOWER on IntegriCloud