Warn on "void f(int a[10]) { sizeof(a); }"

llvm-svn: 133036
This commit is contained in:
Nico Weber 2011-06-15 02:47:03 +00:00
parent e8bbc10880
commit 0870debb8b
4 changed files with 50 additions and 0 deletions

View File

@ -115,6 +115,7 @@ def SignCompare : DiagGroup<"sign-compare">;
def : DiagGroup<"stack-protector">;
def : DiagGroup<"switch-default">;
def : DiagGroup<"synth">;
def SizeofArrayArgument : DiagGroup<"sizeof-array-argument">;
def TautologicalCompare : DiagGroup<"tautological-compare">;
def HeaderHygiene : DiagGroup<"header-hygiene">;
@ -248,6 +249,7 @@ def Most : DiagGroup<"most", [
ReturnType,
SelfAssignment,
Switch,
SizeofArrayArgument,
Trigraphs,
Uninitialized,
UnknownPragmas,

View File

@ -2602,6 +2602,10 @@ def warn_self_assignment : Warning<
"explicitly assigning a variable of type %0 to itself">,
InGroup<SelfAssignment>, DefaultIgnore;
def warn_sizeof_array_param : Warning<
"sizeof on array function parameter will return size of %0 instead of %1">,
InGroup<SizeofArrayArgument>;
def err_sizeof_nonfragile_interface : Error<
"invalid application of '%select{alignof|sizeof}1' to interface %0 in "
"non-fragile ABI">;

View File

@ -3160,6 +3160,20 @@ bool Sema::CheckUnaryExprOrTypeTraitOperand(Expr *Op,
Op->getSourceRange(), ExprKind))
return true;
if (ExprKind == UETT_SizeOf) {
if (DeclRefExpr *DeclRef = dyn_cast<DeclRefExpr>(Op->IgnoreParens())) {
if (ParmVarDecl *PVD = dyn_cast<ParmVarDecl>(DeclRef->getFoundDecl())) {
QualType OType = PVD->getOriginalType();
QualType Type = PVD->getType();
if (Type->isPointerType() && OType->isArrayType()) {
Diag(Op->getExprLoc(), diag::warn_sizeof_array_param)
<< Type << OType;
Diag(PVD->getLocation(), diag::note_declared_at);
}
}
}
}
return false;
}

View File

@ -0,0 +1,30 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
typedef int Arr[10];
typedef int trungl_int;
void f(int a[10], Arr arr) { // \
// expected-note {{declared here}} \
// expected-note {{declared here}} \
// expected-note {{declared here}} \
// expected-note {{declared here}}
/* Should warn. */
(void)sizeof(a); // \
// expected-warning{{sizeof on array function parameter will return size of 'int *' instead of 'int [10]'}}
(void)sizeof((((a)))); // \
// expected-warning{{sizeof on array function parameter will return size of 'int *' instead of 'int [10]'}}
(void)sizeof a; // \
// expected-warning{{sizeof on array function parameter will return size of 'int *' instead of 'int [10]'}}
(void)sizeof arr; // \
// expected-warning{{sizeof on array function parameter will return size of 'int *' instead of 'Arr' (aka 'int [10]')}}
/* Shouldn't warn. */
int b[10];
(void)sizeof b;
Arr brr;
(void)sizeof brr;
(void)sizeof(Arr);
(void)sizeof(int);
}