summaryrefslogtreecommitdiff
path: root/compilerplugins
diff options
context:
space:
mode:
Diffstat (limited to 'compilerplugins')
-rw-r--r--compilerplugins/clang/defaultparams.cxx26
1 files changed, 15 insertions, 11 deletions
diff --git a/compilerplugins/clang/defaultparams.cxx b/compilerplugins/clang/defaultparams.cxx
index 76cbeed2abaa..4127aa305ba9 100644
--- a/compilerplugins/clang/defaultparams.cxx
+++ b/compilerplugins/clang/defaultparams.cxx
@@ -25,10 +25,10 @@ public:
virtual void run() override { TraverseDecl(compiler.getASTContext().getTranslationUnitDecl()); }
- bool VisitCallExpr(const CallExpr * callExpr);
+ bool VisitCallExpr(CallExpr * callExpr);
};
-bool DefaultParams::VisitCallExpr(const CallExpr * callExpr) {
+bool DefaultParams::VisitCallExpr(CallExpr * callExpr) {
if (ignoreLocation(callExpr)) {
return true;
}
@@ -40,18 +40,22 @@ bool DefaultParams::VisitCallExpr(const CallExpr * callExpr) {
}
const FunctionDecl* functionDecl = callExpr->getDirectCallee()->getCanonicalDecl();
unsigned i = callExpr->getNumArgs() - 1;
- const Expr* arg = callExpr->getArg(i);
+ Expr* arg = callExpr->getArg(i);
// variadic functions
if (i >= functionDecl->getNumParams()) {
return true;
}
+ if (arg->isDefaultArgument()) {
+ return true;
+ }
+ // ignore this, it seems to trigger an infinite recursion
+ if (isa<UnaryExprOrTypeTraitExpr>(arg))
+ return true;
const ParmVarDecl* parmVarDecl = functionDecl->getParamDecl(i);
const Expr* defaultArgExpr = parmVarDecl->getDefaultArg();
- if (!arg->isDefaultArgument() &&
- arg->isIntegerConstantExpr(compiler.getASTContext()) &&
- parmVarDecl->hasDefaultArg() &&
- !parmVarDecl->hasUninstantiatedDefaultArg() &&
- defaultArgExpr->isIntegerConstantExpr(compiler.getASTContext()))
+ if (parmVarDecl->hasDefaultArg() &&
+ defaultArgExpr &&
+ defaultArgExpr->getType()->isIntegralType(compiler.getASTContext()))
{
APSInt x1, x2;
if (arg->EvaluateAsInt(x1, compiler.getASTContext()) &&
@@ -63,17 +67,17 @@ bool DefaultParams::VisitCallExpr(const CallExpr * callExpr) {
"not necessary to pass this argument, it defaults to the same value",
arg->getSourceRange().getBegin())
<< arg->getSourceRange();
- report(
+ /*report(
DiagnosticsEngine::Warning,
"default method parameter declaration here",
parmVarDecl->getSourceRange().getBegin())
- << parmVarDecl->getSourceRange();
+ << parmVarDecl->getSourceRange();*/
}
}
return true;
}
-loplugin::Plugin::Registration< DefaultParams > X("defaultparams", false);
+loplugin::Plugin::Registration< DefaultParams > X("defaultparams");
}