Browse Source

Bug fixes.

cl-refactor
Gav Wood 11 years ago
parent
commit
4db12bc10f
  1. 12
      alethzero/MainWin.cpp
  2. 1
      libethereum/Instruction.cpp

12
alethzero/MainWin.cpp

@ -37,6 +37,8 @@ using eth::compileLisp;
using eth::disassemble; using eth::disassemble;
using eth::formatBalance; using eth::formatBalance;
using eth::fromHex; using eth::fromHex;
using eth::sha3;
using eth::left160;
using eth::right160; using eth::right160;
using eth::simpleDebugOut; using eth::simpleDebugOut;
using eth::toLog2; using eth::toLog2;
@ -287,7 +289,7 @@ void Main::refresh(bool _override)
QString("%2 +> %3: %1 [%4]") QString("%2 +> %3: %1 [%4]")
.arg(formatBalance(t.value).c_str()) .arg(formatBalance(t.value).c_str())
.arg(render(t.safeSender())) .arg(render(t.safeSender()))
.arg(render(right160(t.sha3()))) .arg(render(left160(sha3(rlpList(t.safeSender(), t.nonce)))))
.arg((unsigned)t.nonce); .arg((unsigned)t.nonce);
ui->transactionQueue->addItem(s); ui->transactionQueue->addItem(s);
} }
@ -313,7 +315,7 @@ void Main::refresh(bool _override)
QString(" %2 +> %3: %1 [%4]") QString(" %2 +> %3: %1 [%4]")
.arg(formatBalance(t.value).c_str()) .arg(formatBalance(t.value).c_str())
.arg(render(t.safeSender())) .arg(render(t.safeSender()))
.arg(render(right160(t.sha3()))) .arg(render(left160(sha3(rlpList(t.safeSender(), t.nonce)))))
.arg((unsigned)t.nonce); .arg((unsigned)t.nonce);
QListWidgetItem* txItem = new QListWidgetItem(s, ui->blocks); QListWidgetItem* txItem = new QListWidgetItem(s, ui->blocks);
txItem->setData(Qt::UserRole, QByteArray((char const*)h.data(), h.size)); txItem->setData(Qt::UserRole, QByteArray((char const*)h.data(), h.size));
@ -390,13 +392,13 @@ void Main::on_blocks_currentItemChanged()
{ {
unsigned txi = item->data(Qt::UserRole + 1).toInt(); unsigned txi = item->data(Qt::UserRole + 1).toInt();
Transaction tx(block[1][txi].data()); Transaction tx(block[1][txi].data());
h256 th = tx.sha3(); auto ss = tx.safeSender();
h256 th = sha3(rlpList(ss, tx.nonce));
s << "<h3>" << th << "</h3>"; s << "<h3>" << th << "</h3>";
s << "<h4>" << h << "[<b>" << txi << "</b>]</h4>"; s << "<h4>" << h << "[<b>" << txi << "</b>]</h4>";
auto ss = tx.safeSender();
s << "<br/>From: <b>" << pretty(ss).toStdString() << "</b> " << ss; s << "<br/>From: <b>" << pretty(ss).toStdString() << "</b> " << ss;
if (tx.isCreation()) if (tx.isCreation())
s << "<br/>Creates: <b>" << pretty(right160(th)).toStdString() << "</b> " << right160(th); s << "<br/>Creates: <b>" << pretty(left160(th)).toStdString() << "</b> " << left160(th);
else else
s << "<br/>To: <b>" << pretty(tx.receiveAddress).toStdString() << "</b> " << tx.receiveAddress; s << "<br/>To: <b>" << pretty(tx.receiveAddress).toStdString() << "</b> " << tx.receiveAddress;
s << "<br/>Value: <b>" << formatBalance(tx.value) << "</b>"; s << "<br/>Value: <b>" << formatBalance(tx.value) << "</b>";

1
libethereum/Instruction.cpp

@ -529,6 +529,7 @@ static int compileLispFragment(char const*& d, char const* e, bool _quiet, bytes
return false; return false;
unsigned startLocation = (unsigned)o_code.size(); unsigned startLocation = (unsigned)o_code.size();
o_locs.push_back(startLocation);
// First fragment - predicate // First fragment - predicate
appendCode(o_code, o_locs, codes[0], locs[0]); appendCode(o_code, o_locs, codes[0], locs[0]);

Loading…
Cancel
Save