aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2016-01-31 15:20:47 +0200
committerRiccardo Spagni <ric@spagni.net>2016-01-31 15:20:47 +0200
commit58f890652e86039e98dff2d48d217c9ea9e84eca (patch)
treedeb58a24d5202473ab5e8f43a80ad534ed7c8ad9 /src
parentMerge pull request #631 (diff)
parentwallet: guard against exception in process_blocks (diff)
downloadmonero-58f890652e86039e98dff2d48d217c9ea9e84eca.tar.xz
Merge pull request #632
2cf8b32 wallet: guard against exception in process_blocks (moneromooo-monero)
Diffstat (limited to 'src')
-rw-r--r--src/wallet/wallet2.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/wallet/wallet2.cpp b/src/wallet/wallet2.cpp
index 4758e13d0..28bc35feb 100644
--- a/src/wallet/wallet2.cpp
+++ b/src/wallet/wallet2.cpp
@@ -753,7 +753,15 @@ void wallet2::refresh(uint64_t start_height, uint64_t & blocks_fetched, bool& re
bool error = false;
pull_thread = std::thread([&]{pull_next_blocks(start_height, next_blocks_start_height, short_chain_history, blocks, next_blocks, error);});
- process_blocks(blocks_start_height, blocks, added_blocks);
+ try
+ {
+ process_blocks(blocks_start_height, blocks, added_blocks);
+ }
+ catch (...)
+ {
+ pull_thread.join();
+ throw;
+ }
blocks_fetched += added_blocks;
pull_thread.join();
if(!added_blocks)