@ -114,45 +114,43 @@ void CZMQNotificationInterface::Shutdown()
}
}
void CZMQNotificationInterface : : UpdatedBlockTip ( const CBlockIndex * pindexNew , const CBlockIndex * pindexFork , bool fInitialDownload )
{
if ( fInitialDownload | | pindexNew = = pindexFork ) // In IBD or blocks were disconnected without any new ones
return ;
namespace {
for ( auto i = notifiers . begin ( ) ; i ! = notifiers . end ( ) ; )
{
CZMQAbstractNotifier * notifier = i - > get ( ) ;
if ( notifier - > NotifyBlock ( pindexNew ) )
{
i + + ;
}
else
{
template < typename Function >
void TryForEachAndRemoveFailed ( std : : list < std : : unique_ptr < CZMQAbstractNotifier > > & notifiers , const Function & func )
{
for ( auto i = notifiers . begin ( ) ; i ! = notifiers . end ( ) ; ) {
CZMQAbstractNotifier * notifier = i - > get ( ) ;
if ( func ( notifier ) ) {
+ + i ;
} else {
notifier - > Shutdown ( ) ;
i = notifiers . erase ( i ) ;
}
}
}
} // anonymous namespace
void CZMQNotificationInterface : : UpdatedBlockTip ( const CBlockIndex * pindexNew , const CBlockIndex * pindexFork , bool fInitialDownload )
{
if ( fInitialDownload | | pindexNew = = pindexFork ) // In IBD or blocks were disconnected without any new ones
return ;
TryForEachAndRemoveFailed ( notifiers , [ pindexNew ] ( CZMQAbstractNotifier * notifier ) {
return notifier - > NotifyBlock ( pindexNew ) ;
} ) ;
}
void CZMQNotificationInterface : : TransactionAddedToMempool ( const CTransactionRef & ptx )
{
// Used by BlockConnected and BlockDisconnected as well, because they're
// all the same external callback.
const CTransaction & tx = * ptx ;
for ( auto i = notifiers . begin ( ) ; i ! = notifiers . end ( ) ; )
{
CZMQAbstractNotifier * notifier = i - > get ( ) ;
if ( notifier - > NotifyTransaction ( tx ) )
{
i + + ;
}
else
{
notifier - > Shutdown ( ) ;
i = notifiers . erase ( i ) ;
}
}
TryForEachAndRemoveFailed ( notifiers , [ & tx ] ( CZMQAbstractNotifier * notifier ) {
return notifier - > NotifyTransaction ( tx ) ;
} ) ;
}
void CZMQNotificationInterface : : BlockConnected ( const std : : shared_ptr < const CBlock > & pblock , const CBlockIndex * pindexConnected )