Patch to implement AST generation for objective-c's @selector expression.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43038 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/AST/ASTContext.cpp b/AST/ASTContext.cpp
index 366966f..4c06e7c 100644
--- a/AST/ASTContext.cpp
+++ b/AST/ASTContext.cpp
@@ -856,6 +856,20 @@
IdStructType = rec;
}
+void ASTContext::setObjcSelType(TypedefDecl *TD)
+{
+ assert(ObjcSelType.isNull() && "'SEL' type already set!");
+
+ ObjcSelType = getTypedefType(TD);
+
+ // typedef struct objc_selector *SEL;
+ const PointerType *ptr = TD->getUnderlyingType()->getAsPointerType();
+ assert(ptr && "'SEL' incorrectly typed");
+ const RecordType *rec = ptr->getPointeeType()->getAsStructureType();
+ assert(rec && "'SEL' incorrectly typed");
+ SelStructType = rec;
+}
+
void ASTContext::setObjcConstantStringInterface(ObjcInterfaceDecl *Decl) {
assert(ObjcConstantStringType.isNull() &&
"'NSConstantString' type already set!");
diff --git a/AST/Expr.cpp b/AST/Expr.cpp
index f2e351a..5cd56cc 100644
--- a/AST/Expr.cpp
+++ b/AST/Expr.cpp
@@ -1079,6 +1079,10 @@
Stmt::child_iterator ObjCEncodeExpr::child_begin() { return NULL; }
Stmt::child_iterator ObjCEncodeExpr::child_end() { return NULL; }
+// ObjCSelectorExpr
+Stmt::child_iterator ObjCSelectorExpr::child_begin() { return NULL; }
+Stmt::child_iterator ObjCSelectorExpr::child_end() { return NULL; }
+
// ObjCMessageExpr
Stmt::child_iterator ObjCMessageExpr::child_begin() {
return reinterpret_cast<Stmt**>(&SubExprs[0]);
diff --git a/AST/StmtDumper.cpp b/AST/StmtDumper.cpp
index 410890c..bd5c615 100644
--- a/AST/StmtDumper.cpp
+++ b/AST/StmtDumper.cpp
@@ -128,6 +128,7 @@
// ObjC
void VisitObjCEncodeExpr(ObjCEncodeExpr *Node);
+ void VisitObjCSelectorExpr(ObjCSelectorExpr *Node);
};
}
@@ -406,6 +407,19 @@
DumpType(Node->getEncodedType());
}
+void StmtDumper::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
+ DumpExpr(Node);
+
+ fprintf(F, " ");
+ Selector &selector = Node->getSelector();
+ if (selector.isUnarySelector())
+ fprintf(F, "%s", selector.getIdentifierInfoForSlot(0)->getName());
+ else {
+ for (unsigned i = 0, e = Node->getNumArgs(); i != e; ++i)
+ fprintf(F, "%s:", selector.getIdentifierInfoForSlot(i)->getName());
+ }
+}
+
//===----------------------------------------------------------------------===//
// Stmt method implementations
//===----------------------------------------------------------------------===//
diff --git a/AST/StmtPrinter.cpp b/AST/StmtPrinter.cpp
index 9b4ad11..783368e 100644
--- a/AST/StmtPrinter.cpp
+++ b/AST/StmtPrinter.cpp
@@ -620,6 +620,18 @@
OS << Node->getEncodedType().getAsString() << ")";
}
+void StmtPrinter::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
+ OS << "@selector(";
+ Selector &selector = Node->getSelector();
+ if (selector.isUnarySelector())
+ OS << " " << selector.getIdentifierInfoForSlot(0)->getName();
+ else {
+ for (unsigned i = 0, e = Node->getNumArgs(); i != e; ++i)
+ OS << selector.getIdentifierInfoForSlot(i)->getName() << ":";
+ }
+ OS << ")";
+}
+
void StmtPrinter::VisitObjCMessageExpr(ObjCMessageExpr *Mess) {
OS << "[";
Expr *receiver = Mess->getReceiver();