* Update to ganache-cli v6.1.0 and truffle v4.1.0 * Update to stable version of ganache-cli * fix: update event emission warning - Fix event emission warnings for solidity 4.21 after truffle has been updated to use this version * fix pr review comments * update to truffle v4.1.5 * update package-lock * add additional emit keywords * update solidity-coverage to 0.4.15 * update to solium 1.1.6 * fix MerkleProof coverage analysis by testing through wrapper * change version pragma to ^0.4.21 * fix solium linting errors
49 lines
1.4 KiB
Solidity
49 lines
1.4 KiB
Solidity
pragma solidity ^0.4.21;
|
|
|
|
import "./StandardToken.sol";
|
|
import "../../ownership/Ownable.sol";
|
|
|
|
|
|
/**
|
|
* @title Mintable token
|
|
* @dev Simple ERC20 Token example, with mintable token creation
|
|
* @dev Issue: * https://github.com/OpenZeppelin/zeppelin-solidity/issues/120
|
|
* Based on code by TokenMarketNet: https://github.com/TokenMarketNet/ico/blob/master/contracts/MintableToken.sol
|
|
*/
|
|
contract MintableToken is StandardToken, Ownable {
|
|
event Mint(address indexed to, uint256 amount);
|
|
event MintFinished();
|
|
|
|
bool public mintingFinished = false;
|
|
|
|
|
|
modifier canMint() {
|
|
require(!mintingFinished);
|
|
_;
|
|
}
|
|
|
|
/**
|
|
* @dev Function to mint tokens
|
|
* @param _to The address that will receive the minted tokens.
|
|
* @param _amount The amount of tokens to mint.
|
|
* @return A boolean that indicates if the operation was successful.
|
|
*/
|
|
function mint(address _to, uint256 _amount) onlyOwner canMint public returns (bool) {
|
|
totalSupply_ = totalSupply_.add(_amount);
|
|
balances[_to] = balances[_to].add(_amount);
|
|
emit Mint(_to, _amount);
|
|
emit Transfer(address(0), _to, _amount);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @dev Function to stop minting new tokens.
|
|
* @return True if the operation was successful.
|
|
*/
|
|
function finishMinting() onlyOwner canMint public returns (bool) {
|
|
mintingFinished = true;
|
|
emit MintFinished();
|
|
return true;
|
|
}
|
|
}
|