//===----------------------------------------------------------------------===//
static void ActionDeadStores(AnalysisManager& mgr) {
- CheckDeadStores(*mgr.getCFG(), mgr.getContext(), *mgr.getParentMap(),
+ CheckDeadStores(*mgr.getCFG(), mgr.getContext(),
+ *mgr.getLiveVariables(), *mgr.getParentMap(),
mgr.getDiagnostic());
}
class BugType;
class LangOptions;
class ParentMap;
+class LiveVariables;
void CheckDeadStores(CFG& cfg, ASTContext &Ctx, ParentMap& Parents,
Diagnostic &Diags);
+ void CheckDeadStores(CFG& cfg, ASTContext &Ctx, LiveVariables& L,
+ ParentMap& Parents, Diagnostic &Diags);
+
void CheckUninitializedValues(CFG& cfg, ASTContext& Ctx, Diagnostic& Diags,
bool FullUninitTaint=false);
ParentMap& Parents, Diagnostic &Diags) {
LiveVariables L(cfg);
L.runOnCFG(cfg);
+ CheckDeadStores(cfg, Ctx, L, Parents, Diags);
+}
+
+void clang::CheckDeadStores(CFG& cfg, ASTContext &Ctx, LiveVariables& L,
+ ParentMap& Parents, Diagnostic &Diags) {
+
DeadStoreObs A(Ctx, Diags, Diags.getClient(), Parents);
L.runOnAllBlocks(cfg, &A);
}