r233074 - Revert "Diagnose declspecs occuring after virt-specifier-seq and generate fixit hints"

Ehsan Akhgari ehsan.akhgari at gmail.com
Tue Mar 24 06:25:26 PDT 2015


Author: ehsan
Date: Tue Mar 24 08:25:26 2015
New Revision: 233074

URL: http://llvm.org/viewvc/llvm-project?rev=233074&view=rev
Log:
Revert "Diagnose declspecs occuring after virt-specifier-seq and generate fixit hints"

This reverts commit 2131e63e2fdff7c831ab3bfe31facf2e3ebab03d.

Modified:
    cfe/trunk/include/clang/Basic/DiagnosticParseKinds.td
    cfe/trunk/include/clang/Parse/Parser.h
    cfe/trunk/include/clang/Sema/DeclSpec.h
    cfe/trunk/lib/Parse/ParseDecl.cpp
    cfe/trunk/lib/Parse/ParseDeclCXX.cpp
    cfe/trunk/lib/Sema/DeclSpec.cpp
    cfe/trunk/test/FixIt/fixit-cxx0x.cpp

Modified: cfe/trunk/include/clang/Basic/DiagnosticParseKinds.td
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticParseKinds.td?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticParseKinds.td (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticParseKinds.td Tue Mar 24 08:25:26 2015
@@ -183,8 +183,6 @@ def warn_attribute_no_decl : Warning<
   "attribute %0 ignored, because it is not attached to a declaration">, 
   InGroup<IgnoredAttributes>;
 def err_expected_method_body : Error<"expected method body">;
-def err_declspec_after_virtspec : Error<
-  "'%0' qualifier may not appear after the virtual specifier '%1'">;
 def err_invalid_token_after_toplevel_declarator : Error<
   "expected ';' after top level declarator">;
 def err_invalid_token_after_declarator_suggest_equal : Error<

Modified: cfe/trunk/include/clang/Parse/Parser.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Parse/Parser.h?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/include/clang/Parse/Parser.h (original)
+++ cfe/trunk/include/clang/Parse/Parser.h Tue Mar 24 08:25:26 2015
@@ -2293,8 +2293,6 @@ private:
                                                  VirtSpecifiers &VS,
                                                  ExprResult &BitfieldSize,
                                                  LateParsedAttrList &LateAttrs);
-  void MaybeParseAndDiagnoseDeclSpecAfterCXX11VirtSpecifierSeq(Declarator &D,
-                                                               VirtSpecifiers &VS);
   void ParseCXXClassMemberDeclaration(AccessSpecifier AS, AttributeList *Attr,
                   const ParsedTemplateInfo &TemplateInfo = ParsedTemplateInfo(),
                   ParsingDeclRAIIObject *DiagsFromTParams = nullptr);

Modified: cfe/trunk/include/clang/Sema/DeclSpec.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Sema/DeclSpec.h?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/include/clang/Sema/DeclSpec.h (original)
+++ cfe/trunk/include/clang/Sema/DeclSpec.h Tue Mar 24 08:25:26 2015
@@ -2180,7 +2180,7 @@ public:
     VS_Sealed = 4
   };
 
-  VirtSpecifiers() : Specifiers(0), LastSpecifier(VS_None) { }
+  VirtSpecifiers() : Specifiers(0) { }
 
   bool SetSpecifier(Specifier VS, SourceLocation Loc,
                     const char *&PrevSpec);
@@ -2198,16 +2198,12 @@ public:
 
   static const char *getSpecifierName(Specifier VS);
 
-  SourceLocation getFirstLocation() const { return FirstLocation; }
   SourceLocation getLastLocation() const { return LastLocation; }
-  Specifier getLastSpecifier() const { return LastSpecifier; }
   
 private:
   unsigned Specifiers;
-  Specifier LastSpecifier;
 
   SourceLocation VS_overrideLoc, VS_finalLoc;
-  SourceLocation FirstLocation;
   SourceLocation LastLocation;
 };
 

Modified: cfe/trunk/lib/Parse/ParseDecl.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Parse/ParseDecl.cpp?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/lib/Parse/ParseDecl.cpp (original)
+++ cfe/trunk/lib/Parse/ParseDecl.cpp Tue Mar 24 08:25:26 2015
@@ -5329,7 +5329,7 @@ void Parser::ParseFunctionDeclarator(Dec
     if (getLangOpts().CPlusPlus) {
       // FIXME: Accept these components in any order, and produce fixits to
       // correct the order if the user gets it wrong. Ideally we should deal
-      // with the pure-specifier in the same way.
+      // with the virt-specifier-seq and pure-specifier in the same way.
 
       // Parse cv-qualifier-seq[opt].
       ParseTypeQualifierListOpt(DS, AR_NoAttributesParsed,

Modified: cfe/trunk/lib/Parse/ParseDeclCXX.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Parse/ParseDeclCXX.cpp?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/lib/Parse/ParseDeclCXX.cpp (original)
+++ cfe/trunk/lib/Parse/ParseDeclCXX.cpp Tue Mar 24 08:25:26 2015
@@ -2037,13 +2037,10 @@ bool Parser::ParseCXXMemberDeclaratorBef
     BitfieldSize = ParseConstantExpression();
     if (BitfieldSize.isInvalid())
       SkipUntil(tok::comma, StopAtSemi | StopBeforeMatch);
-  } else {
+  } else
     ParseOptionalCXX11VirtSpecifierSeq(
         VS, getCurrentClass().IsInterface,
         DeclaratorInfo.getDeclSpec().getFriendSpecLoc());
-    if (!VS.isUnset())
-      MaybeParseAndDiagnoseDeclSpecAfterCXX11VirtSpecifierSeq(DeclaratorInfo, VS);
-  }
 
   // If a simple-asm-expr is present, parse it.
   if (Tok.is(tok::kw_asm)) {
@@ -2074,7 +2071,6 @@ bool Parser::ParseCXXMemberDeclaratorBef
           Diag(Attr->getLoc(), diag::warn_gcc_attribute_location);
         Attr = Attr->getNext();
       }
-      MaybeParseAndDiagnoseDeclSpecAfterCXX11VirtSpecifierSeq(DeclaratorInfo, VS);
     }
   }
 
@@ -2088,50 +2084,6 @@ bool Parser::ParseCXXMemberDeclaratorBef
   return false;
 }
 
-/// \brief Look for declaration specifiers possibly occurring after C++11
-/// virt-specifier-seq and diagnose them.
-void Parser::MaybeParseAndDiagnoseDeclSpecAfterCXX11VirtSpecifierSeq(
-    Declarator &D,
-    VirtSpecifiers &VS) {
-  DeclSpec DS(AttrFactory);
-
-  // GNU-style and C++11 attributes are not allowed here, but they will be
-  // handled by the caller.  Diagnose everything else.
-  ParseTypeQualifierListOpt(DS, AR_NoAttributesParsed, false);
-  D.ExtendWithDeclSpec(DS);
-
-  if (DS.getTypeQualifiers() != DeclSpec::TQ_unspecified) {
-    auto DeclSpecCheck = [&] (DeclSpec::TQ TypeQual,
-                              const char *FixItName,
-                              SourceLocation SpecLoc,
-                              unsigned* QualifierLoc) {
-      FixItHint Insertion;
-      auto &Function = D.getFunctionTypeInfo();
-      if (DS.getTypeQualifiers() & TypeQual) {
-        if (!(Function.TypeQuals & TypeQual)) {
-          std::string Name(FixItName);
-          Name += " ";
-          Insertion = FixItHint::CreateInsertion(VS.getFirstLocation(), Name.c_str());
-          Function.TypeQuals |= TypeQual;
-          *QualifierLoc = SpecLoc.getRawEncoding();
-        }
-        Diag(SpecLoc, diag::err_declspec_after_virtspec)
-          << FixItName
-          << VirtSpecifiers::getSpecifierName(VS.getLastSpecifier())
-          << FixItHint::CreateRemoval(SpecLoc)
-          << Insertion;
-      }
-    };
-    auto &Function = D.getFunctionTypeInfo();
-    DeclSpecCheck(DeclSpec::TQ_const, "const", DS.getConstSpecLoc(),
-                  &Function.ConstQualifierLoc);
-    DeclSpecCheck(DeclSpec::TQ_volatile, "volatile", DS.getVolatileSpecLoc(),
-                  &Function.VolatileQualifierLoc);
-    DeclSpecCheck(DeclSpec::TQ_restrict, "restrict", DS.getRestrictSpecLoc(),
-                  &Function.RestrictQualifierLoc);
-  }
-}
-
 /// ParseCXXClassMemberDeclaration - Parse a C++ class member declaration.
 ///
 ///       member-declaration:

Modified: cfe/trunk/lib/Sema/DeclSpec.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/DeclSpec.cpp?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/DeclSpec.cpp (original)
+++ cfe/trunk/lib/Sema/DeclSpec.cpp Tue Mar 24 08:25:26 2015
@@ -1220,10 +1220,7 @@ void UnqualifiedId::setOperatorFunctionI
 
 bool VirtSpecifiers::SetSpecifier(Specifier VS, SourceLocation Loc,
                                   const char *&PrevSpec) {
-  if (!FirstLocation.isValid())
-    FirstLocation = Loc;
   LastLocation = Loc;
-  LastSpecifier = VS;
   
   if (Specifiers & VS) {
     PrevSpec = getSpecifierName(VS);

Modified: cfe/trunk/test/FixIt/fixit-cxx0x.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/FixIt/fixit-cxx0x.cpp?rev=233074&r1=233073&r2=233074&view=diff
==============================================================================
--- cfe/trunk/test/FixIt/fixit-cxx0x.cpp (original)
+++ cfe/trunk/test/FixIt/fixit-cxx0x.cpp Tue Mar 24 08:25:26 2015
@@ -158,14 +158,3 @@ namespace MisplacedParameterPack {
   template <int... N...> // expected-error {{'...' must immediately precede declared identifier}}
   void redundantEllipsisInNonTypeTemplateParameter();
 }
-
-namespace MisplacedDeclSpecAfterVirtSpec {
-  struct B {
-    virtual void f();
-    virtual void f() volatile const;
-  };
-  struct D : B {
-    virtual void f() override;
-    virtual void f() override final const volatile; // expected-error {{'const' qualifier may not appear after the virtual specifier 'final'}} expected-error {{'volatile' qualifier may not appear after the virtual specifier 'final'}}
-  };
-}





More information about the cfe-commits mailing list