Finish up variadic methods/messages.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@44172 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/AST/Expr.cpp b/AST/Expr.cpp
index 10f0895..fa1a3c9 100644
--- a/AST/Expr.cpp
+++ b/AST/Expr.cpp
@@ -898,14 +898,14 @@
ObjCMessageExpr::ObjCMessageExpr(Expr *receiver, Selector selInfo,
QualType retType, ObjcMethodDecl *mproto,
SourceLocation LBrac, SourceLocation RBrac,
- Expr **ArgExprs)
+ Expr **ArgExprs, unsigned nargs)
: Expr(ObjCMessageExprClass, retType), SelName(selInfo),
MethodProto(mproto), ClassName(0) {
- unsigned numArgs = selInfo.getNumArgs();
- SubExprs = new Expr*[numArgs+1];
+ NumArgs = nargs;
+ SubExprs = new Expr*[NumArgs+1];
SubExprs[RECEIVER] = receiver;
- if (numArgs) {
- for (unsigned i = 0; i != numArgs; ++i)
+ if (NumArgs) {
+ for (unsigned i = 0; i != NumArgs; ++i)
SubExprs[i+ARGS_START] = static_cast<Expr *>(ArgExprs[i]);
}
LBracloc = LBrac;
@@ -917,14 +917,14 @@
ObjCMessageExpr::ObjCMessageExpr(IdentifierInfo *clsName, Selector selInfo,
QualType retType, ObjcMethodDecl *mproto,
SourceLocation LBrac, SourceLocation RBrac,
- Expr **ArgExprs)
+ Expr **ArgExprs, unsigned nargs)
: Expr(ObjCMessageExprClass, retType), SelName(selInfo),
MethodProto(mproto), ClassName(clsName) {
- unsigned numArgs = selInfo.getNumArgs();
- SubExprs = new Expr*[numArgs+1];
+ NumArgs = nargs;
+ SubExprs = new Expr*[NumArgs+1];
SubExprs[RECEIVER] = 0;
- if (numArgs) {
- for (unsigned i = 0; i != numArgs; ++i)
+ if (NumArgs) {
+ for (unsigned i = 0; i != NumArgs; ++i)
SubExprs[i+ARGS_START] = static_cast<Expr *>(ArgExprs[i]);
}
LBracloc = LBrac;