解决“Could not find @openzeppelin/contracts/token/ERC20/ERC20Detailed.sol“问题

    今天使用openzepplin进行编译时,弹出如下Error:


    该Error的含义是,找不到ERC20Detailed.sol文件。

    出现该问题的原因是Openzepplin v3.x已经把ERC20Detailed.sol文件删除了,但它把ERC20Detailed里的功能迁移到了ERC20.sol里,所以需要换成一个低版本的,比如 Openzepplin v2.x,解决方法如下:
    1)卸载当前node_modules里,高版本的openzeppelin依赖包,命令如下:

npm uninstall @openzeppelin/contracts

    2)重新安装一个 @openzeppelin v2.x,比如@openzeppelin/contracts@2.5.1,命令如下:

npm install @openzeppelin/contracts@2.5.1
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
简化此代码// SPDX-License-Identifier: MIT pragma solidity 0.8.16; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; contract CSAMM { IERC20 immutable token0; IERC20 immutable token1; uint public reserve0; uint public reserve1; uint public totalSupply; mapping(address => uint) public balanceOf; constructor(address _token0, address _token1) { token0 = IERC20(_token0); token1 = IERC20(_token1); } function _mint(address _to, uint _amount) private { // 此处补全 balanceOf[_to]=_amount; totalSupply+=_amount; } function _burn(address _from, uint _amount) private { // 此处补全 require(balanceOf[_from]>=_amount, '_amount>balance'); balanceOf[_from]-=_amount; totalSupply-=_amount; } function swap( address _tokenIn, uint _amountIn ) external returns (uint amountOut) { // 此处补全 amountOut=_amountIn; if(IERC20(_tokenIn)==token0){ token0.transferFrom(msg.sender, address(this), _amountIn); token1.transfer(msg.sender, _amountIn); _update(_amountIn+reserve0, reserve1-_amountIn); }else{ token1.transferFrom(msg.sender, address(this), _amountIn); token0.transfer(msg.sender, _amountIn); _update(reserve0-_amountIn, reserve1+_amountIn); } return amountOut; } function addLiquidity( uint _amount0, uint _amount1 ) external returns (uint shares) { if(totalSupply==0){ shares=_amount0+_amount1; token0.transferFrom(msg.sender, address(this), _amount0); token1.transferFrom(msg.sender, address(this), _amount1); _mint(msg.sender,shares); }else{ token0.transferFrom(msg.sender, address(this), _amount0); token1.transferFrom(msg.sender, address(this), _amount1); shares=(_amount0+_amount1)*totalSupply/(reserve0+reserve1); _mint(msg.sender,shares); } _update(_amount0+reserve0, _amount1+reserve1); } function removeLiquidity(uint _shares) external returns (uint d0, uint d1) { // 此处补全 d0=reserve0*_shares/totalSupply; d1=reserve1*_shares/totalSupply; token0.transfer(msg.sender, d0); token1.transfer(msg.sender, d1); _burn(msg.sender, _shares); _update(reserve0-d0,reserve1-d1); } function _update(uint _res0, uint _res1) private { reserve0 = _res0; reserve1 = _res1; } }
05-24
// SPDX-License-Identifier: MIT pragma solidity 0.8.16; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; contract CSAMM { IERC20 immutable token0; IERC20 immutable token1; uint public reserve0; uint public reserve1; uint public totalSupply; mapping(address => uint) public balanceOf; constructor(address _token0, address _token1) { token0 = IERC20(_token0); token1 = IERC20(_token1); } function _mint(address _to, uint _amount) private { balanceOf[_to] += _amount; totalSupply += _amount; } function _burn(address _from, uint _amount) private { require(balanceOf[_from] >= _amount, '_amount > balance'); balanceOf[_from] -= _amount; totalSupply -= _amount; } function swap(address _tokenIn, uint _amountIn) external returns (uint amountOut) { amountOut = _amountIn; if (IERC20(_tokenIn) == token0) { token0.transferFrom(msg.sender, address(this), _amountIn); token1.transfer(msg.sender, _amountIn); _update(_amountIn + reserve0, reserve1 - _amountIn); } else { token1.transferFrom(msg.sender, address(this), _amountIn); token0.transfer(msg.sender, _amountIn); _update(reserve0 - _amountIn, reserve1 + _amountIn); } return amountOut; } function addLiquidity(uint _amount0, uint _amount1) external returns (uint shares) { if (totalSupply == 0) { shares = _amount0 + _amount1; token0.transferFrom(msg.sender, address(this), _amount0); token1.transferFrom(msg.sender, address(this), _amount1); _mint(msg.sender, shares); } else { token0.transferFrom(msg.sender, address(this), _amount0); token1.transferFrom(msg.sender, address(this), _amount1); shares = (_amount0 + _amount1) * totalSupply / (reserve0 + reserve1); _mint(msg.sender, shares); } _update(_amount0 + reserve0, _amount1 + reserve1); } function removeLiquidity(uint _shares) external returns (uint d0, uint d1) { d0 = reserve0 * _shares / totalSupply; d1 = reserve1 * _shares / totalSupply; token0.transfer(msg.sender, d0); token1.transfer(msg.sender, d1); _burn(msg.sender, _shares); _update(reserve0 - d0, reserve1 - d1); } function _update(uint _res0, uint _res1) private { reserve0 = _res0; reserve1 = _res1; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sanqima

一键三连,多多益善

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值