diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-06-21 18:04:54 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-06-21 18:04:54 +0000 |
| commit | a9b3cae8fda062142d0044b38359241a17081e2a (patch) | |
| tree | 1466e0cabe9a783730f7cf0efd307badc800cce1 /clang/lib | |
| parent | 552b52f49dceb71a73676ce65b3add81141f583f (diff) | |
| download | bcm5719-llvm-a9b3cae8fda062142d0044b38359241a17081e2a.tar.gz bcm5719-llvm-a9b3cae8fda062142d0044b38359241a17081e2a.zip | |
Switch 'super' from being a weird cast thing to being a predefined expr node.
Patch by David Chisnall with objc rewriter and stmtdumper updates from me.
llvm-svn: 52580
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/AST/StmtDumper.cpp | 18 | ||||
| -rw-r--r-- | clang/lib/AST/StmtPrinter.cpp | 3 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaExprObjC.cpp | 8 |
3 files changed, 12 insertions, 17 deletions
diff --git a/clang/lib/AST/StmtDumper.cpp b/clang/lib/AST/StmtDumper.cpp index 6a65fbbf897..c8f72602ef2 100644 --- a/clang/lib/AST/StmtDumper.cpp +++ b/clang/lib/AST/StmtDumper.cpp @@ -311,17 +311,13 @@ void StmtDumper::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) { void StmtDumper::VisitPreDefinedExpr(PreDefinedExpr *Node) { DumpExpr(Node); switch (Node->getIdentType()) { - default: - assert(0 && "unknown case"); - case PreDefinedExpr::Func: - fprintf(F, " __func__"); - break; - case PreDefinedExpr::Function: - fprintf(F, " __FUNCTION__"); - break; - case PreDefinedExpr::PrettyFunction: - fprintf(F, " __PRETTY_FUNCTION__"); - break; + default: assert(0 && "unknown case"); + case PreDefinedExpr::Func: fprintf(F, " __func__"); break; + case PreDefinedExpr::Function: fprintf(F, " __FUNCTION__"); break; + case PreDefinedExpr::PrettyFunction: fprintf(F, " __PRETTY_FUNCTION__");break; + case PreDefinedExpr::ObjCSelf: fprintf(F, "self"); break; + case PreDefinedExpr::ObjCCmd: fprintf(F, "_cmd"); break; + case PreDefinedExpr::ObjCSuper: fprintf(F, "super"); break; } } diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp index dc686f9bf59..53f31028be3 100644 --- a/clang/lib/AST/StmtPrinter.cpp +++ b/clang/lib/AST/StmtPrinter.cpp @@ -509,6 +509,9 @@ void StmtPrinter::VisitPreDefinedExpr(PreDefinedExpr *Node) { case PreDefinedExpr::PrettyFunction: OS << "__PRETTY_FUNCTION__"; break; + case PreDefinedExpr::ObjCSuper: + OS << "super"; + break; } } diff --git a/clang/lib/Sema/SemaExprObjC.cpp b/clang/lib/Sema/SemaExprObjC.cpp index 1f21ee0ec57..920457e00c6 100644 --- a/clang/lib/Sema/SemaExprObjC.cpp +++ b/clang/lib/Sema/SemaExprObjC.cpp @@ -149,14 +149,10 @@ Sema::ExprResult Sema::ActOnClassMessage( return Diag(lbrac, diag::error_no_super_class, CurMethodDecl->getClassInterface()->getName()); if (CurMethodDecl->isInstance()) { - // Synthesize a cast to the super class. This hack allows us to loosely - // represent super without creating a special expression node. - IdentifierInfo &II = Context.Idents.get("self"); - ExprResult ReceiverExpr = ActOnIdentifierExpr(S, lbrac, II, false); QualType superTy = Context.getObjCInterfaceType(ClassDecl); superTy = Context.getPointerType(superTy); - ReceiverExpr = ActOnCastExpr(SourceLocation(), superTy.getAsOpaquePtr(), - SourceLocation(), ReceiverExpr.Val); + ExprResult ReceiverExpr = new PreDefinedExpr(SourceLocation(), superTy, + PreDefinedExpr::ObjCSuper); // We are really in an instance method, redirect. return ActOnInstanceMessage(ReceiverExpr.Val, Sel, lbrac, rbrac, Args, NumArgs); |

