Never suppress specifiers when printing the parameters of a function
declaration.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72613 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/AST/DeclPrinter.cpp b/lib/AST/DeclPrinter.cpp
index 72f9703..6412f75 100644
--- a/lib/AST/DeclPrinter.cpp
+++ b/lib/AST/DeclPrinter.cpp
@@ -296,6 +296,8 @@
     if (D->isVirtualAsWritten()) Out << "virtual ";
   }
 
+  PrintingPolicy SubPolicy(Policy);
+  SubPolicy.SuppressSpecifiers = false;
   std::string Proto = D->getNameAsString();
   if (isa<FunctionType>(D->getType().getTypePtr())) {
     const FunctionType *AFT = D->getType()->getAsFunctionType();
@@ -307,7 +309,7 @@
     Proto += "(";
     if (FT) {
       llvm::raw_string_ostream POut(Proto);
-      DeclPrinter ParamPrinter(POut, Context, Policy, Indentation);
+      DeclPrinter ParamPrinter(POut, Context, SubPolicy, Indentation);
       for (unsigned i = 0, e = D->getNumParams(); i != e; ++i) {
         if (i) POut << ", ";
         ParamPrinter.VisitParmVarDecl(D->getParamDecl(i));
@@ -342,17 +344,18 @@
       // This is a K&R function definition, so we need to print the
       // parameters.
       Out << '\n';
+      DeclPrinter ParamPrinter(Out, Context, SubPolicy, Indentation);
       Indentation += Policy.Indentation;
       for (unsigned i = 0, e = D->getNumParams(); i != e; ++i) {
         Indent();
-        VisitParmVarDecl(D->getParamDecl(i));
+        ParamPrinter.VisitParmVarDecl(D->getParamDecl(i));
         Out << ";\n";
       }
       Indentation -= Policy.Indentation;
     } else
       Out << ' ';
 
-    D->getBody(Context)->printPretty(Out, Context, 0, Policy, Indentation);
+    D->getBody(Context)->printPretty(Out, Context, 0, SubPolicy, Indentation);
     Out << '\n';
   }
 }