]> granicus.if.org Git - clang/commitdiff
Cleanup ObjCSuperRefExpr (remove last usage and AST node:-).
authorSteve Naroff <snaroff@apple.com>
Sun, 10 Aug 2008 19:10:41 +0000 (19:10 +0000)
committerSteve Naroff <snaroff@apple.com>
Sun, 10 Aug 2008 19:10:41 +0000 (19:10 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@54617 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/AST/ExprObjC.h
include/clang/AST/StmtNodes.def
lib/AST/Expr.cpp
lib/AST/StmtPrinter.cpp
lib/AST/StmtSerialization.cpp
lib/Sema/SemaExpr.cpp

index ab4992cfe08fab67f10351ed2670c9d688a5389a..889b7c86b2008b06ea85b6388f191ce6fd6af598 100644 (file)
@@ -359,28 +359,6 @@ public:
   static ObjCMessageExpr* CreateImpl(llvm::Deserializer& D, ASTContext& C);
 };
 
-/// ObjCSuperRefExpr - A reference to super.
-class ObjCSuperRefExpr : public Expr {
-  SourceLocation Loc;
-public:
-  ObjCSuperRefExpr(QualType t, SourceLocation l) : 
-    Expr(ObjCSuperRefExprClass, t), Loc(l) {}
-  
-  virtual SourceRange getSourceRange() const { return SourceRange(Loc); }
-  
-  static bool classof(const Stmt *T) { 
-    return T->getStmtClass() == ObjCSuperRefExprClass; 
-  }
-  static bool classof(const ObjCSuperRefExpr *) { return true; }
-  
-  // Iterators
-  virtual child_iterator child_begin();
-  virtual child_iterator child_end();
-  
-  virtual void EmitImpl(llvm::Serializer& S) const;
-  static ObjCSuperRefExpr* CreateImpl(llvm::Deserializer& D, ASTContext& C);
-};
-
 }  // end namespace clang
 
 #endif
index 3f2b355ce39523d9446174372649b23f156cd91c..e4fa138f94b985030e09f66791ec91177ba36bbb 100644 (file)
@@ -101,11 +101,10 @@ STMT(73, ObjCSelectorExpr     , Expr)
 STMT(74, ObjCProtocolExpr     , Expr)
 STMT(75, ObjCIvarRefExpr      , Expr)
 STMT(76, ObjCPropertyRefExpr  , Expr)
-STMT(77, ObjCSuperRefExpr     , Expr)
 
 // Clang Extensions.
-STMT(78, OverloadExpr         , Expr)
-STMT(79, ShuffleVectorExpr    , Expr)
+STMT(77, OverloadExpr         , Expr)
+STMT(78, ShuffleVectorExpr    , Expr)
 
 LAST_EXPR(79)
 
index 8cf3b37e85dc10b57256c0a68c7f7982501eae8c..97e1897424291bbff7726a5fb50f7b6a6ab4126d 100644 (file)
@@ -1259,10 +1259,6 @@ Stmt::child_iterator ObjCIvarRefExpr::child_end() { return &Base+1; }
 Stmt::child_iterator ObjCPropertyRefExpr::child_begin() { return &Base; }
 Stmt::child_iterator ObjCPropertyRefExpr::child_end() { return &Base+1; }
 
-// ObjCSuperRefExpr
-Stmt::child_iterator ObjCSuperRefExpr::child_begin() { return child_iterator();}
-Stmt::child_iterator ObjCSuperRefExpr::child_end() { return child_iterator(); }
-
 // PredefinedExpr
 Stmt::child_iterator PredefinedExpr::child_begin() { return child_iterator(); }
 Stmt::child_iterator PredefinedExpr::child_end() { return child_iterator(); }
index a9818f8fcd8fb45640c5941a704b4864375a8f97..7cd00dab50d4af2f92ac0d73a3c7b6b96cfbdc01 100644 (file)
@@ -476,10 +476,6 @@ void StmtPrinter::VisitDeclRefExpr(DeclRefExpr *Node) {
   OS << Node->getDecl()->getName();
 }
 
-void StmtPrinter::VisitObjCSuperRefExpr(ObjCSuperRefExpr *Node) {
-  OS << "super";
-}
-
 void StmtPrinter::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) {
   if (Node->getBase()) {
     PrintExpr(Node->getBase());
index cc26b278c3c7c5cb49b4584494f2aa23724979f9..99ca10d5be4d36c2bb4abb8dc1d84d6625200340 100644 (file)
@@ -1089,17 +1089,6 @@ ObjCStringLiteral* ObjCStringLiteral::CreateImpl(Deserializer& D, ASTContext& C)
   return new ObjCStringLiteral(String,T,L);
 }
 
-void ObjCSuperRefExpr::EmitImpl(Serializer& S) const {
-  S.Emit(Loc);
-  S.Emit(getType());
-}
-
-ObjCSuperRefExpr* ObjCSuperRefExpr::CreateImpl(Deserializer& D, ASTContext& C) {
-  SourceLocation Loc = SourceLocation::ReadVal(D);
-  QualType T = QualType::ReadVal(D); 
-  return new ObjCSuperRefExpr(T, Loc); 
-}
-
 //===----------------------------------------------------------------------===//
 //   C++ Serialization
 //===----------------------------------------------------------------------===//
index b44fd877d65778a90453f447dae2d12c43131d16..f68f82b87d994a1fc8e40dfeb2649ea566c940e1 100644 (file)
@@ -332,10 +332,11 @@ Sema::ExprResult Sema::ActOnIdentifierExpr(Scope *S, SourceLocation Loc,
                                  static_cast<Expr*>(SelfExpr.Val), true, true);
       }
     }
+    // Needed to implement property "super.method" notation.
     if (SD == 0 && !strcmp(II.getName(), "super")) {
       QualType T = Context.getPointerType(Context.getObjCInterfaceType(
                      getCurMethodDecl()->getClassInterface()));
-      return new ObjCSuperRefExpr(T, Loc);
+      return new PredefinedExpr(Loc, T, PredefinedExpr::ObjCSuper);
     }
   }