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