This revision was automatically updated to reflect the committed changes. Closed by commit rG4aaa97700377: [Sema] Fix missing warning on initializer lists on field initializers with… (authored by zequanwu).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D85574/new/ https://reviews.llvm.org/D85574 Files: clang/lib/Sema/SemaDeclCXX.cpp clang/test/SemaCXX/uninitialized.cpp Index: clang/test/SemaCXX/uninitialized.cpp =================================================================== --- clang/test/SemaCXX/uninitialized.cpp +++ clang/test/SemaCXX/uninitialized.cpp @@ -1303,6 +1303,20 @@ d3{ d3.b, num } // expected-warning{{uninitialized}} {} }; + + struct E { + E(); + E foo(); + E* operator->(); + }; + + struct F { F(E); }; + + struct EFComposed { + F f; + E e; + EFComposed() : f{ e->foo() }, e() {} // expected-warning{{uninitialized}} + }; } namespace template_class { Index: clang/lib/Sema/SemaDeclCXX.cpp =================================================================== --- clang/lib/Sema/SemaDeclCXX.cpp +++ clang/lib/Sema/SemaDeclCXX.cpp @@ -3577,8 +3577,10 @@ Base = SubME->getBase(); } - if (!isa<CXXThisExpr>(Base->IgnoreParenImpCasts())) + if (!isa<CXXThisExpr>(Base->IgnoreParenImpCasts())) { + Visit(Base); return; + } if (AddressOf && AllPODFields) return;
Index: clang/test/SemaCXX/uninitialized.cpp =================================================================== --- clang/test/SemaCXX/uninitialized.cpp +++ clang/test/SemaCXX/uninitialized.cpp @@ -1303,6 +1303,20 @@ d3{ d3.b, num } // expected-warning{{uninitialized}} {} }; + + struct E { + E(); + E foo(); + E* operator->(); + }; + + struct F { F(E); }; + + struct EFComposed { + F f; + E e; + EFComposed() : f{ e->foo() }, e() {} // expected-warning{{uninitialized}} + }; } namespace template_class { Index: clang/lib/Sema/SemaDeclCXX.cpp =================================================================== --- clang/lib/Sema/SemaDeclCXX.cpp +++ clang/lib/Sema/SemaDeclCXX.cpp @@ -3577,8 +3577,10 @@ Base = SubME->getBase(); } - if (!isa<CXXThisExpr>(Base->IgnoreParenImpCasts())) + if (!isa<CXXThisExpr>(Base->IgnoreParenImpCasts())) { + Visit(Base); return; + } if (AddressOf && AllPODFields) return;
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits