More Sema check for constructor's member initializer along
authorFariborz Jahanian <fjahanian@apple.com>
Fri, 24 Jul 2009 20:28:49 +0000 (20:28 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Fri, 24 Jul 2009 20:28:49 +0000 (20:28 +0000)
with type conversion to fix ir-gen crash.

llvm-svn: 77000

clang/include/clang/Basic/DiagnosticSemaKinds.td
clang/lib/Sema/SemaDeclCXX.cpp
clang/test/SemaCXX/constructor-initializer.cpp

index 881e9d90a10a90625deafb0aaff14ca442fb797e..9031a6ec9cc8bb5dea9830ea9ec34fe29d9884eb 100644 (file)
@@ -1664,6 +1664,8 @@ def error_multiple_base_initialization : Error <
 def err_mem_init_not_member_or_class : Error<
   "member initializer %0 does not name a non-static data member or base "
   "class">;
+def err_mem_initializer_mismatch : Error<
+  "Too many arguments for member initializer %0">;
 
 def warn_field_initialized : Warning<
   "member '%0' will be initialized after">,
index d5c8c3d3fce5105e3327be8490a1145a9a162c9b..7b0c9c6ca470556b586281bc208dbef706356bce 100644 (file)
@@ -725,6 +725,15 @@ Sema::ActOnMemInitializer(DeclPtrTy ConstructorD,
         C = PerformInitializationByConstructor(
               FieldType, (Expr **)Args, NumArgs, IdLoc, 
               SourceRange(IdLoc, RParenLoc), Member->getDeclName(), IK_Direct);
+      else if (NumArgs != 1)
+        return Diag(IdLoc, diag::err_mem_initializer_mismatch) 
+                    << MemberOrBase << SourceRange(IdLoc, RParenLoc);
+      else {
+        Expr * NewExp = (Expr*)Args[0];
+        if (PerformCopyInitialization(NewExp, FieldType, "passing"))
+          return true;
+        Args[0] = NewExp;
+      }
       // FIXME: Perform direct initialization of the member.
       return new (Context) CXXBaseOrMemberInitializer(Member, (Expr **)Args, 
                                                       NumArgs, C, IdLoc);
index 71d38a1438baf9d13c333b88bb5895f1372dbddc..3909cd984ddaa27cf393f6ee7fd6eca9dddd93dc 100644 (file)
@@ -98,8 +98,7 @@ struct Current : Derived {
 };
 
                         // FIXME. This is bad message!
-struct M {             // expected-note {{candidate function}} \
-                        // expected-note {{candidate function}}
+struct M { 
   M(int i, int j);     // expected-note {{candidate function}} \
                        // // expected-note {{candidate function}}
 };
@@ -115,4 +114,11 @@ struct P : M  { // expected-error {{default constructor for 'struct M' is missin
   M m; // expected-error {{default constructor for 'struct M' is missing in initialization of mamber}}
 };
 
+struct Q {
+  Q() : f1(1,2),       // expected-error {{Too many arguments for member initializer 'f1'}}
+        pf(0.0)  { }   // expected-error {{incompatible type passing 'double', expected 'float *'}}
+  float f1;
+
+  float *pf;
+};