diff --git a/clang/lib/AST/DeclCXX.cpp b/clang/lib/AST/DeclCXX.cpp index adcd3f9aa92e826545ea6e84f52509bedd936cb5..96423104065be8e3f7fd3545a6528a84469aa53d 100644 --- a/clang/lib/AST/DeclCXX.cpp +++ b/clang/lib/AST/DeclCXX.cpp @@ -609,6 +609,19 @@ CXXConstructorDecl::setBaseOrMemberInitializers( } if (HasDependentBaseInit) { + // FIXME. This does not preserve the ordering of the initializers. + // Try (with -Wreorder) + // template struct A {}; + // template struct B : A { + // B() : x1(10), A() {} + // int x1; + // }; + // B x; + // On seeing one dependent type, we should essentially exit this routine + // while preserving user-declared initializer list. When this routine is + // called during instantiatiation process, this routine will rebuild the + // oderdered initializer list correctly. + // If we have a dependent base initialization, we can't determine the // association between initializers and bases; just dump the known // initializers into the list, and don't try to deal with other bases.