diff options
author | Chris Lattner <sabre@nondot.org> | 2008-04-10 02:22:51 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-04-10 02:22:51 +0000 |
commit | 8123a95c33b792d35c2e4992ba6e27882748fb0d (patch) | |
tree | 33cd02a28ced427832214e01d1cfdca997f262b3 /lib/AST | |
parent | 05cbe1a44e6143d44aac0e769ba120e8c45f34ce (diff) |
Several improvements from Doug Gregor related to default
argument handling. I'll fix up the c89 (void) thing next.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@49459 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST')
-rw-r--r-- | lib/AST/Decl.cpp | 13 | ||||
-rw-r--r-- | lib/AST/Expr.cpp | 3 | ||||
-rw-r--r-- | lib/AST/ExprCXX.cpp | 4 |
3 files changed, 17 insertions, 3 deletions
diff --git a/lib/AST/Decl.cpp b/lib/AST/Decl.cpp index afe4fcd37f..2ef31e42e5 100644 --- a/lib/AST/Decl.cpp +++ b/lib/AST/Decl.cpp @@ -385,6 +385,19 @@ void FunctionDecl::setParams(ParmVarDecl **NewParamInfo, unsigned NumParams) { } } +/// getMinRequiredArguments - Returns the minimum number of arguments +/// needed to call this function. This may be fewer than the number of +/// function parameters, if some of the parameters have default +/// arguments. +unsigned FunctionDecl::getMinRequiredArguments() const { + unsigned NumRequiredArgs = getNumParams(); + while (NumRequiredArgs > 0 + && getParamDecl(NumRequiredArgs-1)->getDefaultArg()) + --NumRequiredArgs; + + return NumRequiredArgs; +} + //===----------------------------------------------------------------------===// // RecordDecl Implementation //===----------------------------------------------------------------------===// diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index 0287aa0831..35bea75045 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -1021,7 +1021,8 @@ bool Expr::isNullPointerConstant(ASTContext &Ctx) const { // Accept ((void*)0) as a null pointer constant, as many other // implementations do. return PE->getSubExpr()->isNullPointerConstant(Ctx); - } else if (const CXXDefaultArgExpr *DefaultArg = dyn_cast<CXXDefaultArgExpr>(this)) { + } else if (const CXXDefaultArgExpr *DefaultArg + = dyn_cast<CXXDefaultArgExpr>(this)) { // See through default argument expressions return DefaultArg->getExpr()->isNullPointerConstant(Ctx); } diff --git a/lib/AST/ExprCXX.cpp b/lib/AST/ExprCXX.cpp index 03faf8b8b5..323fdd67a1 100644 --- a/lib/AST/ExprCXX.cpp +++ b/lib/AST/ExprCXX.cpp @@ -48,8 +48,8 @@ Stmt::child_iterator CXXThrowExpr::child_end() { // CXXDefaultArgExpr Stmt::child_iterator CXXDefaultArgExpr::child_begin() { - return reinterpret_cast<Stmt**>(Param->getDefaultArg()); + return child_iterator(); } Stmt::child_iterator CXXDefaultArgExpr::child_end() { - return reinterpret_cast<Stmt**>(Param->getDefaultArg())+1; + return child_iterator(); } |