mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
62 lines
1.4 KiB
Solidity
62 lines
1.4 KiB
Solidity
contract C {
|
|
bytes32 bhash;
|
|
address coin;
|
|
uint dif;
|
|
uint glimit;
|
|
uint number;
|
|
uint tstamp;
|
|
bytes mdata;
|
|
address sender;
|
|
bytes4 sig;
|
|
uint value;
|
|
uint gprice;
|
|
address origin;
|
|
|
|
function f() public payable {
|
|
bhash = blockhash(12);
|
|
coin = block.coinbase;
|
|
dif = block.difficulty;
|
|
glimit = block.gaslimit;
|
|
number = block.number;
|
|
tstamp = block.timestamp;
|
|
mdata = msg.data;
|
|
sender = msg.sender;
|
|
sig = msg.sig;
|
|
value = msg.value;
|
|
gprice = tx.gasprice;
|
|
origin = tx.origin;
|
|
|
|
fi();
|
|
|
|
assert(bhash == blockhash(12));
|
|
assert(coin == block.coinbase);
|
|
assert(dif == block.difficulty);
|
|
assert(glimit == block.gaslimit);
|
|
assert(number == block.number);
|
|
assert(tstamp == block.timestamp);
|
|
assert(mdata.length == msg.data.length);
|
|
assert(sender == msg.sender);
|
|
assert(sig == msg.sig);
|
|
assert(value == msg.value);
|
|
assert(gprice == tx.gasprice);
|
|
assert(origin == tx.origin);
|
|
}
|
|
|
|
function fi() internal view {
|
|
assert(bhash == blockhash(12));
|
|
assert(coin == block.coinbase);
|
|
assert(dif == block.difficulty);
|
|
assert(glimit == block.gaslimit);
|
|
assert(number == block.number);
|
|
assert(tstamp == block.timestamp);
|
|
assert(mdata.length == msg.data.length);
|
|
assert(sender == msg.sender);
|
|
assert(sig == msg.sig);
|
|
assert(value == msg.value);
|
|
assert(gprice == tx.gasprice);
|
|
assert(origin == tx.origin);
|
|
}
|
|
}
|
|
// ====
|
|
// SMTEngine: all
|