mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-02-08 22:13:48 +01:00
use splice if queue is not semi-full
This commit is contained in:
parent
9bc595a9a2
commit
3f10f6651d
1 changed files with 16 additions and 8 deletions
|
@ -412,9 +412,11 @@ namespace transport
|
||||||
" is semi-full (size = ", m_SendQueue.size (), ", lag = ", queueLag / 1000, ", rtt = ", (int)m_RTT, ")");
|
" is semi-full (size = ", m_SendQueue.size (), ", lag = ", queueLag / 1000, ", rtt = ", (int)m_RTT, ")");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (isSemiFull)
|
||||||
|
{
|
||||||
for (auto it: msgs)
|
for (auto it: msgs)
|
||||||
{
|
{
|
||||||
if (isSemiFull && it->onDrop)
|
if (it->onDrop)
|
||||||
it->Drop (); // drop earlier because we can handle it
|
it->Drop (); // drop earlier because we can handle it
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -422,6 +424,12 @@ namespace transport
|
||||||
m_SendQueue.push_back (std::move (it));
|
m_SendQueue.push_back (std::move (it));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (auto& it: msgs) it->SetEnqueueTime (mts);
|
||||||
|
m_SendQueue.splice (m_SendQueue.end (), msgs);
|
||||||
|
}
|
||||||
if (IsEstablished ())
|
if (IsEstablished ())
|
||||||
{
|
{
|
||||||
SendQueue ();
|
SendQueue ();
|
||||||
|
|
Loading…
Add table
Reference in a new issue