]> granicus.if.org Git - clang/commitdiff
Fix this for real.
authorAnders Carlsson <andersca@mac.com>
Fri, 28 Aug 2009 16:57:08 +0000 (16:57 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 28 Aug 2009 16:57:08 +0000 (16:57 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@80377 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/AST/DeclCXX.h
lib/AST/DeclCXX.cpp
lib/Sema/SemaDeclCXX.cpp
lib/Sema/SemaOverload.cpp
test/SemaCXX/cast-explicit-ctor.cpp

index 37a6d68f1bee47fd280f79d46ead84c835c4e5f0..c89ba8597a27cd624a4d8dde6c796ca8bb82047e 100644 (file)
@@ -1068,7 +1068,7 @@ public:
   /// isConvertingConstructor - Whether this constructor is a
   /// converting constructor (C++ [class.conv.ctor]), which can be
   /// used for user-defined conversions.
-  bool isConvertingConstructor() const;
+  bool isConvertingConstructor(bool AllowExplicit) const;
 
   // Implement isa/cast/dyncast/etc.
   static bool classof(const Decl *D) { 
index 46acf67d2952c1d936c2ef78cd8930a2cd5f8688..d41e0965bcedcf45f0d9703f89f04563e217e8e4 100644 (file)
@@ -489,14 +489,14 @@ CXXConstructorDecl::isCopyConstructor(ASTContext &Context,
   return true;
 }
 
-bool CXXConstructorDecl::isConvertingConstructor() const {
+bool CXXConstructorDecl::isConvertingConstructor(bool AllowExplicit) const {
   // C++ [class.conv.ctor]p1:
   //   A constructor declared without the function-specifier explicit
   //   that can be called with a single parameter specifies a
   //   conversion from the type of its first parameter to the type of
   //   its class. Such a constructor is called a converting
   //   constructor.
-  if (isExplicit())
+  if (isExplicit() && !AllowExplicit)
     return false;
 
   return (getNumParams() == 0 && 
index 31dc8b92c0b5682afa625d8b506fb53fa64a134e..377a9deb41051d314a0ec698beff14e680bb43a5 100644 (file)
@@ -2785,7 +2785,8 @@ Sema::PerformInitializationByConstructor(QualType ClassType,
       Constructor = cast<CXXConstructorDecl>(*Con);
 
     if ((Kind == IK_Direct) ||
-        (Kind == IK_Copy && Constructor->isConvertingConstructor()) ||
+        (Kind == IK_Copy && 
+         Constructor->isConvertingConstructor(/*AllowExplicit=*/false)) ||
         (Kind == IK_Default && Constructor->isDefaultConstructor())) {
       if (ConstructorTmpl)
         AddTemplateOverloadCandidate(ConstructorTmpl, false, 0, 0, 
index ab1062f370bcf19b084bb4f99ae710b980e58be4..f22c1177e645bc1b4bb7a94ff74849588ddedae0 100644 (file)
@@ -1394,7 +1394,7 @@ bool Sema::IsUserDefinedConversion(Expr *From, QualType ToType,
           Constructor = cast<CXXConstructorDecl>(*Con);
         
         if (!Constructor->isInvalidDecl() &&
-            Constructor->isConvertingConstructor()) {
+            Constructor->isConvertingConstructor(AllowExplicit)) {
           if (ConstructorTmpl)
             AddTemplateOverloadCandidate(ConstructorTmpl, false, 0, 0, &From, 
                                          1, CandidateSet,
index 1064758635d146a6f8ebd2a17b0bc69360899331..62134ae658dbfa32c66c2be2411ed76a678ce91d 100644 (file)
@@ -1,5 +1,5 @@
 // RUN: clang-cc -fsyntax-only -verify %s
-struct B { B(bool); };
+struct B { explicit B(bool); };
 void f() { 
   (void)(B)true;
   (void)B(true);