From 66b55f91baf334d1ecdc1387df2b4145661f3058 Mon Sep 17 00:00:00 2001 From: Edward Hennis Date: Tue, 4 Aug 2015 17:16:31 -0400 Subject: [PATCH] Aggressive HashRouter cache expiration --- src/ripple/app/misc/HashRouter.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/ripple/app/misc/HashRouter.cpp b/src/ripple/app/misc/HashRouter.cpp index 1d1f30004..71e03c336 100644 --- a/src/ripple/app/misc/HashRouter.cpp +++ b/src/ripple/app/misc/HashRouter.cpp @@ -64,13 +64,13 @@ HashRouter::Entry& HashRouter::findCreateEntry (uint256 const& index, bool& crea int expireTime = now - mHoldTime; // See if any supressions need to be expired - std::map< int, std::list >::iterator it = mSuppressionTimes.begin (); + auto it = mSuppressionTimes.begin (); - if ((it != mSuppressionTimes.end ()) && (it->first <= expireTime)) + while ((it != mSuppressionTimes.end ()) && (it->first <= expireTime)) { for(auto const& lit : it->second) mSuppressionMap.erase (lit); - mSuppressionTimes.erase (it); + it = mSuppressionTimes.erase (it); } mSuppressionTimes[now].push_back (index);