]> granicus.if.org Git - clang/commitdiff
Fix PR 28885: Fix AST Printer output for the inherited constructor using
authorAlex Lorenz <arphaman@gmail.com>
Mon, 3 Oct 2016 12:22:17 +0000 (12:22 +0000)
committerAlex Lorenz <arphaman@gmail.com>
Mon, 3 Oct 2016 12:22:17 +0000 (12:22 +0000)
declarations.

This commit ensures that the correct record type is printed out for the
using declarations that represent C++ inherited constructors.
It fixes a regression introduced in r274049 which changed the name that's
stored in the using declarations that correspond to inherited constructors.

Differential Revision: https://reviews.llvm.org/D25131

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@283105 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/DeclPrinter.cpp
test/SemaCXX/cxx11-ast-print.cpp

index 7e786990becb1724a037488c8dbd69a650e3256d..6d47dd7b8837608be9f65e498139c9ea8774fb11 100644 (file)
@@ -1346,6 +1346,17 @@ void DeclPrinter::VisitUsingDecl(UsingDecl *D) {
   if (D->hasTypename())
     Out << "typename ";
   D->getQualifier()->print(Out, Policy);
+
+  // Use the correct record name when the using declaration is used for
+  // inheriting constructors.
+  for (const auto *Shadow : D->shadows()) {
+    if (const auto *ConstructorShadow =
+            dyn_cast<ConstructorUsingShadowDecl>(Shadow)) {
+      assert(Shadow->getDeclContext() == ConstructorShadow->getDeclContext());
+      Out << *ConstructorShadow->getNominatedBaseClass();
+      return;
+    }
+  }
   Out << *D;
 }
 
index 1eeb67a3d9b345735b4c0e149f027cb5142c31f4..9c617af4e95fd42409b18188cfc665dd0b09480f 100644 (file)
@@ -43,6 +43,14 @@ template <class C, C...> const char *operator"" _suffix();
 // CHECK: const char *PR23120 = operator""_suffix<char32_t, 66615>();
 const char *PR23120 = U"𐐷"_suffix;
 
+// PR28885
+struct A {
+  A();
+};
+struct B : A {
+  using A::A; // CHECK:      using A::A;
+};            // CHECK-NEXT: };
+
 // CHECK: ;
 ;
 // CHECK-NOT: ;