|
@ -86,24 +86,27 @@ void WhisperPeer::sendMessages() |
|
|
RLPStream amalg; |
|
|
RLPStream amalg; |
|
|
unsigned n = 0; |
|
|
unsigned n = 0; |
|
|
|
|
|
|
|
|
Guard l(x_unseen); |
|
|
|
|
|
while (m_unseen.size()) |
|
|
|
|
|
{ |
|
|
{ |
|
|
auto p = *m_unseen.begin(); |
|
|
Guard l(x_unseen); |
|
|
m_unseen.erase(m_unseen.begin()); |
|
|
while (m_unseen.size()) |
|
|
host()->streamMessage(p.second, amalg); |
|
|
{ |
|
|
n++; |
|
|
auto p = *m_unseen.begin(); |
|
|
|
|
|
m_unseen.erase(m_unseen.begin()); |
|
|
|
|
|
host()->streamMessage(p.second, amalg); |
|
|
|
|
|
n++; |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (n) |
|
|
if (!n) |
|
|
|
|
|
// pause for a bit if no messages to send - this is horrible and broken.
|
|
|
|
|
|
// the message subsystem should really just keep pumping out messages while m_unseen.size() and there's bandwidth for them.
|
|
|
|
|
|
this_thread::sleep_for(chrono::milliseconds(20)); |
|
|
|
|
|
|
|
|
{ |
|
|
{ |
|
|
RLPStream s; |
|
|
RLPStream s; |
|
|
prep(s, MessagesPacket, n).appendRaw(amalg.out(), n); |
|
|
prep(s, MessagesPacket, n).appendRaw(amalg.out(), n); |
|
|
sealAndSend(s); |
|
|
sealAndSend(s); |
|
|
} |
|
|
} |
|
|
else |
|
|
|
|
|
// just pause if no messages to send
|
|
|
|
|
|
this_thread::sleep_for(chrono::milliseconds(100)); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void WhisperPeer::noteNewMessage(h256 _h, Message const& _m) |
|
|
void WhisperPeer::noteNewMessage(h256 _h, Message const& _m) |
|
|