Transaction Hash:
Block:
4979461 at Jan-27-2018 02:53:28 AM +UTC
Transaction Fee:
0.00104278 ETH
$2.51
Gas Used:
52,139 Gas / 20 Gwei
Emitted Events:
81 |
AllSportsCoin.Transfer( from=[Sender] 0x4b8ae88e4df8a751b220f0d8b151dc6300ebefb4, to=0xF52C34f9fcd23FE539Bb084fb7fc5b56212eADa1, value=391300000000000000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x2d0E95bd...5970eb9D3 | |||||
0x4B8Ae88e...300eBEFB4 |
42.946033209275314432 Eth
Nonce: 28
|
42.944990429275314432 Eth
Nonce: 29
| 0.00104278 | ||
0x52bc44d5...b7d7bE3b5
Miner
| (Nanopool) | 11,903.147705308187315287 Eth | 11,903.148748088187315287 Eth | 0.00104278 |
Execution Trace
AllSportsCoin.transfer( _to=0xF52C34f9fcd23FE539Bb084fb7fc5b56212eADa1, _value=391300000000000000000000 )
transfer[TokenERC20 (ln:77)]
_transfer[TokenERC20 (ln:78)]
Transfer[TokenERC20 (ln:64)]
pragma solidity ^0.4.16; contract owned { address public owner; function owned() public { owner = msg.sender; } modifier onlyOwner { require(msg.sender == owner); _; } } contract TokenERC20 { // Public variables of the token string public name; string public symbol; uint8 public decimals = 18; // 18 decimals is the strongly suggested default, avoid changing it uint256 public totalSupply; // This creates an array with all balances mapping (address => uint256) public balanceOf; // This generates a public event on the blockchain that will notify clients event Transfer(address indexed from, address indexed to, uint256 value); /** * Constrctor function * * Initializes contract with initial supply tokens to the creator of the contract */ function TokenERC20( uint256 initialSupply, string tokenName, string tokenSymbol ) public { totalSupply = initialSupply * 10 ** uint256(decimals); // Update total supply with the decimal amount balanceOf[msg.sender] = totalSupply; // Give the creator all initial tokens name = tokenName; // Set the name for display purposes symbol = tokenSymbol; // Set the symbol for display purposes } /** * Internal transfer, only can be called by this contract */ function _transfer(address _from, address _to, uint _value) internal { // Prevent transfer to 0x0 address. Use burn() instead require(_to != 0x0); // Check if the sender has enough require(balanceOf[_from] >= _value); // Check for overflows require(balanceOf[_to] + _value > balanceOf[_to]); // Save this for an assertion in the future uint previousBalances = balanceOf[_from] + balanceOf[_to]; // Subtract from the sender balanceOf[_from] -= _value; // Add the same to the recipient balanceOf[_to] += _value; Transfer(_from, _to, _value); // Asserts are used to use static analysis to find bugs in your code. They should never fail assert(balanceOf[_from] + balanceOf[_to] == previousBalances); } /** * Transfer tokens * * Send `_value` tokens to `_to` from your account * * @param _to The address of the recipient * @param _value the amount to send */ function transfer(address _to, uint256 _value) public { _transfer(msg.sender, _to, _value); } } /******************************************/ /* ALL SPORTS COIN STARTS HERE */ /******************************************/ contract AllSportsCoin is owned, TokenERC20 { /* Initializes contract with initial supply tokens to the creator of the contract */ function AllSportsCoin( ) TokenERC20(1500000000, "All Sports Coin", "SOC") public {} /* Internal transfer, only can be called by this contract */ function _transfer(address _from, address _to, uint _value) internal { require (_to != 0x0); // Prevent transfer to 0x0 address. Use burn() instead require (balanceOf[_from] >= _value); // Check if the sender has enough require (balanceOf[_to] + _value > balanceOf[_to]); // Check for overflows balanceOf[_from] -= _value; // Subtract from the sender balanceOf[_to] += _value; // Add the same to the recipient Transfer(_from, _to, _value); } }