* Merge ERC20Detailed into ERC20, make derived contracts abstract * Fix Create2 tests * Fix failing test * Default decimals to 18 * Add tests for setupDecimals * Add changelog entry * Update CHANGELOG.md * Update CHANGELOG.md * Replace isConstructor for !isContract * Update CHANGELOG.md Co-Authored-By: Francisco Giordano <frangio.1@gmail.com> Co-authored-by: Francisco Giordano <frangio.1@gmail.com>
26 lines
844 B
Solidity
26 lines
844 B
Solidity
pragma solidity ^0.6.0;
|
|
|
|
import "../utils/Create2.sol";
|
|
import "../introspection/ERC1820Implementer.sol";
|
|
|
|
contract Create2Impl {
|
|
function deploy(uint256 value, bytes32 salt, bytes memory code) public {
|
|
Create2.deploy(value, salt, code);
|
|
}
|
|
|
|
function deployERC1820Implementer(uint256 value, bytes32 salt) public {
|
|
// solhint-disable-next-line indent
|
|
Create2.deploy(value, salt, type(ERC1820Implementer).creationCode);
|
|
}
|
|
|
|
function computeAddress(bytes32 salt, bytes32 codeHash) public view returns (address) {
|
|
return Create2.computeAddress(salt, codeHash);
|
|
}
|
|
|
|
function computeAddressWithDeployer(bytes32 salt, bytes32 codeHash, address deployer) public pure returns (address) {
|
|
return Create2.computeAddress(salt, codeHash, deployer);
|
|
}
|
|
|
|
receive() payable external {}
|
|
}
|