From 050ee239fdef426ce01ea7bfb6266f97defffc94 Mon Sep 17 00:00:00 2001 From: arkpar Date: Mon, 6 Jul 2015 13:58:33 +0200 Subject: [PATCH] locking improvements --- libethereum/TransactionQueue.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/libethereum/TransactionQueue.cpp b/libethereum/TransactionQueue.cpp index 28a56cdf8..36d337e7b 100644 --- a/libethereum/TransactionQueue.cpp +++ b/libethereum/TransactionQueue.cpp @@ -361,10 +361,12 @@ void TransactionQueue::clear() void TransactionQueue::enqueue(RLP const& _data, h512 const& _nodeId) { - unique_lock l(x_queue); - unsigned itemCount = _data.itemCount(); - for (unsigned i = 0; i < itemCount; ++i) - m_unverified.emplace_back(UnverifiedTransaction(_data[i].data(), _nodeId)); + { + Guard l(x_queue); + unsigned itemCount = _data.itemCount(); + for (unsigned i = 0; i < itemCount; ++i) + m_unverified.emplace_back(UnverifiedTransaction(_data[i].data(), _nodeId)); + } m_queueReady.notify_all(); } @@ -385,7 +387,6 @@ void TransactionQueue::verifierBody() try { - Transaction t(work.transaction, CheckTransaction::Cheap); //Signature will be checked later ImportResult ir = import(t); m_onImport(ir, t.sha3(), work.nodeId);