* Consolidted ERC20 Interface and Implementation Files * Fixed CanReclaimToken's tests to use StandardTokenMock instead of BasicTokenMock * Changed token's variable type in TokenTimelock to ERC20 * Merged the StandardBurnableToken with BurnableToken since it now inherits from StandardToken; Fixed TokenTimelock so it uses SafeERC20 for ERC20 * Fixed variable type for _token in TokenTimelock constructor * Fixed linting warning in BurnableToken * Added back burnFrom tests.
45 lines
856 B
Solidity
45 lines
856 B
Solidity
pragma solidity ^0.4.24;
|
|
|
|
import "./StandardToken.sol";
|
|
import "./ERC20.sol";
|
|
|
|
|
|
/**
|
|
* @title SafeERC20
|
|
* @dev Wrappers around ERC20 operations that throw on failure.
|
|
* To use this library you can add a `using SafeERC20 for ERC20;` statement to your contract,
|
|
* which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
|
|
*/
|
|
library SafeERC20 {
|
|
function safeTransfer(
|
|
ERC20 _token,
|
|
address _to,
|
|
uint256 _value
|
|
)
|
|
internal
|
|
{
|
|
require(_token.transfer(_to, _value));
|
|
}
|
|
|
|
function safeTransferFrom(
|
|
ERC20 _token,
|
|
address _from,
|
|
address _to,
|
|
uint256 _value
|
|
)
|
|
internal
|
|
{
|
|
require(_token.transferFrom(_from, _to, _value));
|
|
}
|
|
|
|
function safeApprove(
|
|
ERC20 _token,
|
|
address _spender,
|
|
uint256 _value
|
|
)
|
|
internal
|
|
{
|
|
require(_token.approve(_spender, _value));
|
|
}
|
|
}
|