mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
New Proof-of-Work.
This commit is contained in:
parent
14067cb7ed
commit
366b9e8b71
56
block.cpp
56
block.cpp
@ -131,8 +131,12 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
// find new valid nonce
|
// find new valid nonce
|
||||||
ProofOfWork pow;
|
ProofOfWork pow;
|
||||||
MineInfo ret;
|
MineInfo ret;
|
||||||
while (!ProofOfWork::verify(blockFromFields.headerHash(WithoutNonce), blockFromFields.nonce, blockFromFields.difficulty))
|
ProofOfWork::Proof proof;
|
||||||
tie(ret, blockFromFields.nonce) = pow.mine(blockFromFields.headerHash(WithoutNonce), blockFromFields.difficulty, 1000, true, true);
|
while (!ProofOfWork::verify(blockFromFields))
|
||||||
|
{
|
||||||
|
tie(ret, proof) = pow.mine(blockFromFields, 1000, true, true);
|
||||||
|
ProofOfWork::assignResult(proof, blockFromFields);
|
||||||
|
}
|
||||||
|
|
||||||
//update genesis block in json file
|
//update genesis block in json file
|
||||||
o["genesisBlockHeader"].get_obj()["stateRoot"] = toString(blockFromFields.stateRoot);
|
o["genesisBlockHeader"].get_obj()["stateRoot"] = toString(blockFromFields.stateRoot);
|
||||||
@ -211,7 +215,7 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
o["transactions"] = txArray;
|
o["transactions"] = txArray;
|
||||||
o["rlp"] = "0x" + toHex(state.blockData());
|
o["rlp"] = "0x" + toHex(state.blockData());
|
||||||
|
|
||||||
BlockInfo current_BlockHeader = state.info();
|
BlockInfo currentBlockHeader = state.info();
|
||||||
|
|
||||||
// overwrite blockheader with (possible wrong) data from "blockheader" in filler;
|
// overwrite blockheader with (possible wrong) data from "blockheader" in filler;
|
||||||
|
|
||||||
@ -220,7 +224,7 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
if (o["blockHeader"].get_obj().size() != 14)
|
if (o["blockHeader"].get_obj().size() != 14)
|
||||||
{
|
{
|
||||||
|
|
||||||
BlockInfo tmp = current_BlockHeader;
|
BlockInfo tmp = currentBlockHeader;
|
||||||
|
|
||||||
if (o["blockHeader"].get_obj().count("parentHash"))
|
if (o["blockHeader"].get_obj().count("parentHash"))
|
||||||
tmp.parentHash = h256(o["blockHeader"].get_obj()["parentHash"].get_str());
|
tmp.parentHash = h256(o["blockHeader"].get_obj()["parentHash"].get_str());
|
||||||
@ -263,14 +267,18 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
|
|
||||||
// find new valid nonce
|
// find new valid nonce
|
||||||
|
|
||||||
if (tmp != current_BlockHeader)
|
if (tmp != currentBlockHeader)
|
||||||
{
|
{
|
||||||
current_BlockHeader = tmp;
|
currentBlockHeader = tmp;
|
||||||
cout << "new header!\n";
|
cout << "new header!\n";
|
||||||
ProofOfWork pow;
|
ProofOfWork pow;
|
||||||
MineInfo ret;
|
MineInfo ret;
|
||||||
while (!ProofOfWork::verify(current_BlockHeader.headerHash(WithoutNonce), current_BlockHeader.nonce, current_BlockHeader.difficulty))
|
ProofOfWork::Proof proof;
|
||||||
tie(ret, current_BlockHeader.nonce) = pow.mine(current_BlockHeader.headerHash(WithoutNonce), current_BlockHeader.difficulty, 10000, true, true);
|
while (!ProofOfWork::verify(currentBlockHeader))
|
||||||
|
{
|
||||||
|
tie(ret, proof) = pow.mine(currentBlockHeader, 10000, true, true);
|
||||||
|
ProofOfWork::assignResult(proof, currentBlockHeader);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -278,27 +286,27 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
// take the blockheader as is
|
// take the blockheader as is
|
||||||
const bytes c_blockRLP = createBlockRLPFromFields(o["blockHeader"].get_obj());
|
const bytes c_blockRLP = createBlockRLPFromFields(o["blockHeader"].get_obj());
|
||||||
const RLP c_bRLP(c_blockRLP);
|
const RLP c_bRLP(c_blockRLP);
|
||||||
current_BlockHeader.populateFromHeader(c_bRLP, false);
|
currentBlockHeader.populateFromHeader(c_bRLP, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// write block header
|
// write block header
|
||||||
|
|
||||||
mObject oBlockHeader;
|
mObject oBlockHeader;
|
||||||
oBlockHeader["parentHash"] = toString(current_BlockHeader.parentHash);
|
oBlockHeader["parentHash"] = toString(currentBlockHeader.parentHash);
|
||||||
oBlockHeader["uncleHash"] = toString(current_BlockHeader.sha3Uncles);
|
oBlockHeader["uncleHash"] = toString(currentBlockHeader.sha3Uncles);
|
||||||
oBlockHeader["coinbase"] = toString(current_BlockHeader.coinbaseAddress);
|
oBlockHeader["coinbase"] = toString(currentBlockHeader.coinbaseAddress);
|
||||||
oBlockHeader["stateRoot"] = toString(current_BlockHeader.stateRoot);
|
oBlockHeader["stateRoot"] = toString(currentBlockHeader.stateRoot);
|
||||||
oBlockHeader["transactionsTrie"] = toString(current_BlockHeader.transactionsRoot);
|
oBlockHeader["transactionsTrie"] = toString(currentBlockHeader.transactionsRoot);
|
||||||
oBlockHeader["receiptTrie"] = toString(current_BlockHeader.receiptsRoot);
|
oBlockHeader["receiptTrie"] = toString(currentBlockHeader.receiptsRoot);
|
||||||
oBlockHeader["bloom"] = toString(current_BlockHeader.logBloom);
|
oBlockHeader["bloom"] = toString(currentBlockHeader.logBloom);
|
||||||
oBlockHeader["difficulty"] = toString(current_BlockHeader.difficulty);
|
oBlockHeader["difficulty"] = toString(currentBlockHeader.difficulty);
|
||||||
oBlockHeader["number"] = toString(current_BlockHeader.number);
|
oBlockHeader["number"] = toString(currentBlockHeader.number);
|
||||||
oBlockHeader["gasLimit"] = toString(current_BlockHeader.gasLimit);
|
oBlockHeader["gasLimit"] = toString(currentBlockHeader.gasLimit);
|
||||||
oBlockHeader["gasUsed"] = toString(current_BlockHeader.gasUsed);
|
oBlockHeader["gasUsed"] = toString(currentBlockHeader.gasUsed);
|
||||||
oBlockHeader["timestamp"] = toString(current_BlockHeader.timestamp);
|
oBlockHeader["timestamp"] = toString(currentBlockHeader.timestamp);
|
||||||
oBlockHeader["extraData"] = toHex(current_BlockHeader.extraData);
|
oBlockHeader["extraData"] = toHex(currentBlockHeader.extraData);
|
||||||
oBlockHeader["nonce"] = toString(current_BlockHeader.nonce);
|
oBlockHeader["nonce"] = toString(currentBlockHeader.nonce);
|
||||||
|
|
||||||
o["blockHeader"] = oBlockHeader;
|
o["blockHeader"] = oBlockHeader;
|
||||||
|
|
||||||
@ -318,7 +326,7 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
|
|||||||
}
|
}
|
||||||
|
|
||||||
RLPStream rlpStream2;
|
RLPStream rlpStream2;
|
||||||
current_BlockHeader.streamRLP(rlpStream2, WithNonce);
|
currentBlockHeader.streamRLP(rlpStream2, WithNonce);
|
||||||
|
|
||||||
RLPStream block2(3);
|
RLPStream block2(3);
|
||||||
block2.appendRaw(rlpStream2.out());
|
block2.appendRaw(rlpStream2.out());
|
||||||
|
@ -30,6 +30,7 @@ using namespace dev::eth;
|
|||||||
|
|
||||||
int daggerTest()
|
int daggerTest()
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
cnote << "Testing ProofOfWork...";
|
cnote << "Testing ProofOfWork...";
|
||||||
// Test dagger
|
// Test dagger
|
||||||
{
|
{
|
||||||
@ -46,6 +47,7 @@ int daggerTest()
|
|||||||
cout << hex << ProofOfWork().eval((h256)(u256)1, (h256)(u256)1);
|
cout << hex << ProofOfWork().eval((h256)(u256)1, (h256)(u256)1);
|
||||||
cout << " " << dec << duration_cast<milliseconds>(steady_clock::now() - s).count() << " ms" << endl;
|
cout << " " << dec << duration_cast<milliseconds>(steady_clock::now() - s).count() << " ms" << endl;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -437,10 +437,11 @@ class WebThreeStubClient : public jsonrpc::Client
|
|||||||
else
|
else
|
||||||
throw jsonrpc::JsonRpcException(jsonrpc::Errors::ERROR_CLIENT_INVALID_RESPONSE, result.toStyledString());
|
throw jsonrpc::JsonRpcException(jsonrpc::Errors::ERROR_CLIENT_INVALID_RESPONSE, result.toStyledString());
|
||||||
}
|
}
|
||||||
bool eth_submitWork(const std::string& param1) throw (jsonrpc::JsonRpcException)
|
bool eth_submitWork(const std::string& param1, const std::string& param2) throw (jsonrpc::JsonRpcException)
|
||||||
{
|
{
|
||||||
Json::Value p;
|
Json::Value p;
|
||||||
p.append(param1);
|
p.append(param1);
|
||||||
|
p.append(param2);
|
||||||
Json::Value result = this->CallMethod("eth_submitWork",p);
|
Json::Value result = this->CallMethod("eth_submitWork",p);
|
||||||
if (result.isBool())
|
if (result.isBool())
|
||||||
return result.asBool();
|
return result.asBool();
|
||||||
|
Loading…
Reference in New Issue
Block a user