aboutsummaryrefslogtreecommitdiff
path: root/src/cryptonote_core/checkpoints_create.cpp
diff options
context:
space:
mode:
authormoneromooo-monero <moneromooo-monero@users.noreply.github.com>2015-12-25 22:13:38 +0000
committermoneromooo-monero <moneromooo-monero@users.noreply.github.com>2015-12-25 22:13:38 +0000
commitf33a88cfc17177e3a079ee2226df9674dfa2d138 (patch)
tree29f622729d96ee5ede660e54e5452f7861c124cb /src/cryptonote_core/checkpoints_create.cpp
parentblockchain: fix an off by one error in unlocked time check (diff)
downloadmonero-f33a88cfc17177e3a079ee2226df9674dfa2d138.tar.xz
blockchain: fix a few block addition bugs
If the block reward was too high, the verification failed flag was set, but the function continued. The code which was supposed to trap this flag and return failure failed to trap it, and, while the block was not added to the chain, the function would return success. The reason for avoiding returning when the block reward problem was detected was to be able to return any transactions to the pool if needed. This is now mooted by moving the transaction return code to a separate function, which is now called at all appropriate points, making the logic much simpler, and hopefully correct now. We also move the hard fork version check after the prev_id check, as block which does not go on the top of the chain might not have the expected version there, without being invalid just for this reason. Last, we trap the case where a block fails to be added due to using already spent key images, to set the verification failed flag.
Diffstat (limited to 'src/cryptonote_core/checkpoints_create.cpp')
0 files changed, 0 insertions, 0 deletions