ETH Price: $1,978.49 (-0.89%)

Transaction Decoder

Block:
9665224 at Mar-13-2020 08:24:52 PM +UTC
Transaction Fee:
0.000192425 ETH $0.38
Gas Used:
38,485 Gas / 5 Gwei

Emitted Events:

Account State Difference:

  Address   Before After State Difference Code
(Spark Pool)
112.899105307388752716 Eth112.899297732388752716 Eth0.000192425
0x80C549E8...4F14D23CA
0x8138B222...6eA0F64A8
7.1217930964 Eth
Nonce: 700
7.1216006714 Eth
Nonce: 701
0.000192425

Execution Trace

MyERC20.transfer( _to=0x6D6075AC1ae17ee04982d0e531A1C35A9e49e3Eb, _value=3292171414780000000000 ) => ( success=True )
pragma solidity ^0.5.16;

contract ERC20Basic {

    function balanceOf(address tokenOwner) external view returns (uint balance);
    function allowance(address tokenOwner, address spender) external view returns (uint remaining);
    function approve(address spender, uint tokens) external returns (bool success);

    function transfer(address to, uint tokens) external returns (bool success);
    function transferFrom(address from, address to, uint tokens) external returns (bool success);
    
    function setTotalSupply(uint256 _value) public returns (uint totalSupply);
    
    event Transfer(address indexed from, address indexed to, uint tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
}

contract MyERC20 is ERC20Basic {

    string public  name;
    string public  symbol;
    uint8 public constant decimals = 18;
    uint public totalSupply;
    mapping(address => uint256) internal _balances;
    mapping(address => mapping(address => uint256)) allowed;

    constructor(string memory _name, string memory _symbol, uint256 _initialSupply) public {
       name = _name;
       symbol = _symbol;
       totalSupply = setTotalSupply(_initialSupply);
       _balances[msg.sender] = totalSupply;
    }

    function setTotalSupply(uint256 _value) public returns (uint total) {
        return _value * 10 ** uint256(decimals);
    }
    
    function balanceOf(address tokenOwner) public view returns (uint balance) {
        return _balances[tokenOwner];
    }

    function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
        return allowed[_owner][_spender];
    }

  
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
        require(_to != address(0));
        require(allowed[_from][msg.sender] >= _value);
        require(_balances[_from] >= _value);
        require(_balances[ _to] + _value >= _balances[ _to]);
        _balances[_from] -= _value;
        _balances[_to] += _value;
        allowed[_from][msg.sender] -= _value;
        emit Transfer(msg.sender, _to, _value);
        return true;
    }

    function transfer(address _to, uint256 _value)  public returns (bool success) {
        require(_to != address(0));
        require(_balances[msg.sender] >= _value);
        require(_balances[ _to] + _value >= _balances[ _to]);
        _balances[msg.sender] -= _value;
        _balances[_to] += _value;
        emit Transfer(msg.sender, _to, _value);
        return true;
    }

    function approve(address _spender, uint256 _value) public returns (bool success) {
      allowed[msg.sender][_spender] = _value;
      emit Approval(msg.sender, _spender, _value);
      return true;
    }

}