Contract Name:
EtherDOGEICO
Contract Source Code:
File 1 of 1 : EtherDOGEICO
contract EtherDOGEICO {
function name() constant returns (string) { return "EtherDOGE"; }
function symbol() constant returns (string) { return "eDOGE"; }
function decimals() constant returns (uint8) { return 4; }
uint256 public INITIAL_SUPPLY;
uint256 public totalSupply;
uint256 public totalContrib;
uint256 public rate;
address public owner; //init owner address
uint256 public amount;
function EtherDOGEICO() {
INITIAL_SUPPLY = 210000000000; //Starting EtherDOGE supply
totalSupply = 0;
totalContrib = 0;
rate = 210000000; //How many EtherDOGE tokens per ETH given
owner = msg.sender; //Make owner of contract the creator
balances[msg.sender] = INITIAL_SUPPLY; //Send owner of contract all starting tokens
}
//This function is called when Ether is sent to the contract address
//Even if 0 ether is sent.
function () payable {
uint256 tryAmount = div((mul(msg.value, rate)), 1 ether); //Don't let people buy more tokens than there are.
if (msg.value == 0 || msg.value < 0 || balanceOf(owner) < tryAmount) { //If zero ether is sent, kill. Do nothing.
revert();
}
amount = 0; //set the 'amount' var back to zero
amount = div((mul(msg.value, rate)), 1 ether); //take sent ether, multiply it by the rate then divide by 1 ether.
transferFrom(owner, msg.sender, amount); //Send tokens to buyer
totalSupply += amount; //Keep track of how many have been sold.
totalContrib = (totalContrib + msg.value);
amount = 0; //set the 'amount' var back to zero
owner.transfer(msg.value); //Send the ETH to contract owner.
}
event Transfer(address indexed _from, address indexed _to, uint256 _value);
mapping(address => uint256) balances;
function transfer(address _to, uint256 _value) returns (bool success) {
if (_value == 0) { return false; }
uint256 fromBalance = balances[msg.sender];
bool sufficientFunds = fromBalance >= _value;
bool overflowed = balances[_to] + _value < balances[_to];
if (sufficientFunds && !overflowed) {
balances[msg.sender] -= _value;
balances[_to] += _value;
Transfer(msg.sender, _to, _value);
return true;
} else { return false; }
}
function balanceOf(address _owner) constant returns (uint256) { return balances[_owner]; }
function transferFrom(address _from, address _to, uint256 _value) returns (bool success) {
if (_value == 0) { return false; }
uint256 fromBalance = balances[owner];
bool sufficientFunds = fromBalance >= _value;
if (sufficientFunds) {
balances[_to] += _value;
balances[_from] -= _value;
Transfer(_from, _to, _value);
return true;
} else { return false; }
}
function getStats() constant returns (uint256, uint256) {
return (totalSupply, totalContrib);
}
function mul(uint256 a, uint256 b) internal constant returns (uint256) {
uint256 c = a * b;
assert(a == 0 || c / a == b);
return c;
}
function div(uint256 a, uint256 b) internal constant returns (uint256) {
// assert(b > 0); // Solidity automatically throws when dividing by 0
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
function sub(uint256 a, uint256 b) internal constant returns (uint256) {
assert(b <= a);
return a - b;
}
function add(uint256 a, uint256 b) internal constant returns (uint256) {
uint256 c = a + b;
assert(c >= a);
return c;
}
}