diff options
author | Dominic Chen <d.c.ddcc@gmail.com> | 2016-11-15 01:40:58 +0000 |
---|---|---|
committer | Dominic Chen <d.c.ddcc@gmail.com> | 2016-11-15 01:40:58 +0000 |
commit | e3733bc53e2b99e224a39d28fd7ddce994c56e5e (patch) | |
tree | 72b1c099275d1f04ef7952ad35cf18a0b1ad2c58 /clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp | |
parent | 6f6e4dbd5dacf9ec1c43921bad76d5a3b3ab67b0 (diff) | |
download | bcm5719-llvm-e3733bc53e2b99e224a39d28fd7ddce994c56e5e.tar.gz bcm5719-llvm-e3733bc53e2b99e224a39d28fd7ddce994c56e5e.zip |
[analyzer] Minor optimization: avoid setting state if unchanged
Summary: Split out optimization from D26061
Reviewers: zaks.anna, dcoughlin
Subscribers: cfe-commits
Differential Revision: https://reviews.llvm.org/D26642
llvm-svn: 286925
Diffstat (limited to 'clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp b/clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp index 4c98f2544b9..a312350a7f3 100644 --- a/clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp +++ b/clang/lib/StaticAnalyzer/Core/RangeConstraintManager.cpp @@ -398,17 +398,19 @@ ConditionTruthVal RangeConstraintManager::checkNull(ProgramStateRef State, ProgramStateRef RangeConstraintManager::removeDeadBindings(ProgramStateRef state, SymbolReaper& SymReaper) { - + bool Changed = false; ConstraintRangeTy CR = state->get<ConstraintRange>(); - ConstraintRangeTy::Factory& CRFactory = state->get_context<ConstraintRange>(); + ConstraintRangeTy::Factory &CRFactory = state->get_context<ConstraintRange>(); for (ConstraintRangeTy::iterator I = CR.begin(), E = CR.end(); I != E; ++I) { SymbolRef sym = I.getKey(); - if (SymReaper.maybeDead(sym)) + if (SymReaper.maybeDead(sym)) { + Changed = true; CR = CRFactory.remove(CR, sym); + } } - return state->set<ConstraintRange>(CR); + return Changed ? state->set<ConstraintRange>(CR) : state; } RangeSet |