diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-08-13 18:42:40 +0000 | 
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-08-13 18:42:40 +0000 | 
| commit | 1063a71e43ef4f7b24ccd5f66757d58ef5ed5b44 (patch) | |
| tree | 29804043d63f497a0974e5e9bafee5636629524e /clang/lib/Sema | |
| parent | 540bc01f500e353d3233edb799b1b5d868633c48 (diff) | |
| download | bcm5719-llvm-1063a71e43ef4f7b24ccd5f66757d58ef5ed5b44.tar.gz bcm5719-llvm-1063a71e43ef4f7b24ccd5f66757d58ef5ed5b44.zip | |
The unused warnings extravaganza continues. Warn for:
-static variables
-variables in anonymous namespace (fixes rdar://7794535)
-static data members in anonymous namespace
-static data members specializations in anonymous namespace
llvm-svn: 111027
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/Sema.cpp | 36 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 24 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | 4 | 
3 files changed, 51 insertions, 13 deletions
| diff --git a/clang/lib/Sema/Sema.cpp b/clang/lib/Sema/Sema.cpp index 76e059138e6..df9bb07cf94 100644 --- a/clang/lib/Sema/Sema.cpp +++ b/clang/lib/Sema/Sema.cpp @@ -241,15 +241,33 @@ static bool ShouldRemoveFromUnused(Sema *SemaRef, const DeclaratorDecl *D) {      return true;    if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { -    // For functions, UnusedFileScopedDecls stores the first declaration. +    // UnusedFileScopedDecls stores the first declaration. +    // The declaration may have become definition so check again. +    const FunctionDecl *DeclToCheck; +    if (FD->hasBody(DeclToCheck)) +      return !SemaRef->ShouldWarnIfUnusedFileScopedDecl(DeclToCheck); +      // Later redecls may add new information resulting in not having to warn,      // so check again. -    const FunctionDecl *DeclToCheck; -    if (!FD->hasBody(DeclToCheck)) -      DeclToCheck = FD->getMostRecentDeclaration(); +    DeclToCheck = FD->getMostRecentDeclaration();      if (DeclToCheck != FD)        return !SemaRef->ShouldWarnIfUnusedFileScopedDecl(DeclToCheck);    } + +  if (const VarDecl *VD = dyn_cast<VarDecl>(D)) { +    // UnusedFileScopedDecls stores the first declaration. +    // The declaration may have become definition so check again. +    const VarDecl *DeclToCheck = VD->getDefinition();  +    if (DeclToCheck) +      return !SemaRef->ShouldWarnIfUnusedFileScopedDecl(DeclToCheck); + +    // Later redecls may add new information resulting in not having to warn, +    // so check again. +    DeclToCheck = VD->getMostRecentDeclaration(); +    if (DeclToCheck != VD) +      return !SemaRef->ShouldWarnIfUnusedFileScopedDecl(DeclToCheck); +  } +    return false;  } @@ -358,9 +376,13 @@ void Sema::ActOnEndOfTranslationUnit() {          DiagD = FD;        Diag(DiagD->getLocation(), diag::warn_unused_function)              << DiagD->getDeclName(); -    } else -      Diag((*I)->getLocation(), diag::warn_unused_variable) -            << cast<VarDecl>(*I)->getDeclName(); +    } else { +      const VarDecl *DiagD = cast<VarDecl>(*I)->getDefinition(); +      if (!DiagD) +        DiagD = cast<VarDecl>(*I); +      Diag(DiagD->getLocation(), diag::warn_unused_variable) +            << DiagD->getDeclName(); +    }    }  } diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index cf6f20f60ae..a37d25a1436 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -523,15 +523,17 @@ static void RemoveUsingDecls(LookupResult &R) {  bool Sema::ShouldWarnIfUnusedFileScopedDecl(const DeclaratorDecl *D) const {    assert(D); +    if (D->isInvalidDecl() || D->isUsed() || D->hasAttr<UnusedAttr>())      return false; -  if (D->getLinkage() == ExternalLinkage) -    return false;    // Ignore class templates. -  if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(D)) -    if (MD->getParent()->getDescribedClassTemplate()) -      return false; +  if (D->getDeclContext()->isDependentContext()) +    return false; + +  // We warn for unused decls internal to the translation unit. +  if (D->getLinkage() == ExternalLinkage) +    return false;    if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {      if (FD->isThisDeclarationADefinition()) @@ -539,6 +541,10 @@ bool Sema::ShouldWarnIfUnusedFileScopedDecl(const DeclaratorDecl *D) const {      return true;     } +  if (const VarDecl *VD = dyn_cast<VarDecl>(D)) +    if (VD->isFileVarDecl()) +      return !Context.DeclMustBeEmitted(VD); +     return false;   } @@ -552,6 +558,12 @@ bool Sema::ShouldWarnIfUnusedFileScopedDecl(const DeclaratorDecl *D) const {        return; // First should already be in the vector.    } +  if (const VarDecl *VD = dyn_cast<VarDecl>(D)) { +    const VarDecl *First = VD->getFirstDeclaration(); +    if (VD != First && ShouldWarnIfUnusedFileScopedDecl(First)) +      return; // First should already be in the vector. +  } +     if (ShouldWarnIfUnusedFileScopedDecl(D))       UnusedFileScopedDecls.push_back(D);   } @@ -2758,6 +2770,8 @@ Sema::ActOnVariableDeclarator(Scope* S, Declarator& D, DeclContext* DC,    if (NewVD->getLinkage() == ExternalLinkage && !DC->isRecord())      AddPushedVisibilityAttribute(NewVD); +  MarkUnusedFileScopedDecl(NewVD); +    return NewVD;  } diff --git a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp index a48f1e06b83..115eefbe5ee 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp @@ -449,7 +449,9 @@ Decl *TemplateDeclInstantiator::VisitVarDecl(VarDecl *D) {    // Diagnose unused local variables.    if (!Var->isInvalidDecl() && Owner->isFunctionOrMethod() && !Var->isUsed())      SemaRef.DiagnoseUnusedDecl(Var); -   + +  SemaRef.MarkUnusedFileScopedDecl(Var); +    return Var;  } | 

