StandardToken.sol 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. pragma solidity ^0.4.0;
  2. import './ERC20.sol';
  3. import './SafeMath.sol';
  4. /**
  5. * ERC20 token
  6. *
  7. * https://github.com/ethereum/EIPs/issues/20
  8. * Based on code by FirstBlood:
  9. * https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
  10. */
  11. contract StandardToken is ERC20, SafeMath {
  12. mapping(address => uint256) balances;
  13. mapping (address => mapping (address => uint256)) allowed;
  14. uint256 public totalSupply;
  15. function transfer(address _to, uint256 _value) returns (bool success) {
  16. if (balances[msg.sender] < _value) {
  17. throw;
  18. }
  19. balances[msg.sender] = safeSub(balances[msg.sender], _value);
  20. balances[_to] = safeAdd(balances[_to], _value);
  21. Transfer(msg.sender, _to, _value);
  22. return true;
  23. }
  24. function transferFrom(address _from, address _to, uint256 _value) returns (bool success) {
  25. var _allowance = allowed[_from][msg.sender];
  26. if (balances[_from] < _value ||
  27. _allowance < _value) {
  28. throw;
  29. }
  30. balances[_to] = safeAdd(balances[_to], _value);
  31. balances[_from] = safeSub(balances[_from], _value);
  32. allowed[_from][msg.sender] = safeSub(_allowance, _value);
  33. Transfer(_from, _to, _value);
  34. return true;
  35. }
  36. function balanceOf(address _owner) constant returns (uint256 balance) {
  37. return balances[_owner];
  38. }
  39. function approve(address _spender, uint256 _value) returns (bool success) {
  40. allowed[msg.sender][_spender] = _value;
  41. Approval(msg.sender, _spender, _value);
  42. return true;
  43. }
  44. function allowance(address _owner, address _spender) constant returns (uint256 remaining) {
  45. return allowed[_owner][_spender];
  46. }
  47. }