我正在尝试使用ERC1155的git存储库创建一个开泽平令牌。
我正在尝试编写contract.sol文件,但是我遇到了一些错误。
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC1155/ERC1155.sol";
contract KapilERC1155Token is ERC1155 {
uint256 public constant GOLD = 0;
uint256 public constant SILVER = 1;
uint256 public constant THORS_HAMMER = 2;
uint256 public constant SWORD = 3;
uint256 public constant SHIELD = 4;
constructor() ERC1155("https://game.example/api/item/{id}.json") {
_mint(msg.sender, GOLD, 10**18, "");
_mint(msg.sender, SILVER, 10**27, "");
_mint(msg.sender, THORS_HAMMER, 1, "");
_mint(msg.sender, SWORD, 10**9, "");
_mint(msg.sender, SHIELD, 10**9, "");
}
function getBalance(address account, uint256 id) external {
_mint(account, id);
}
}上面是我的密码。以下是我的错误
TypeError: Wrong argument count for function call: 2 arguments given but expected 4.
--> ERC1155token.sol:22:14:
|
22 | _mint(account, id);
| ^^^^^^^^^^^^^^^^^^我可以理解,我在_mint()中使用的getbalance()需要4个参数,参数如下。
address account,
uint256 id,
uint256 amount,
bytes memory data_mint()是-
function _mint(
address account,
uint256 id,
uint256 amount,
bytes memory data
) 因此,我尝试传递4个参数,并在传递第三个参数时获得新的错误。
function getBalance(address account, uint256 id, uint256 amount) external {
_mint(account, id, amount);
}我所犯的错误-
TypeError: Wrong argument count for function call: 3 arguments given but expected 4.
--> ERC1155token.sol:22:14:
|
22 | _mint(account, id, amount);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^这根本不起作用。所以我所做的。我使用了在openzepplin(https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC1155/ERC1155.sol)合同中定义的相同函数,这是我在合同中继承的。
function balanceOf(address account, uint256 id) external{
_mint(account, id);
}这给了我另一个错误,见下文。
第一-
TypeError: Overriding function is missing "override" specifier.
--> ERC1155token.sol:21:10:
|
21 | function balanceOf(address account, uint256 id) external{
| ^ (Relevant source part starts here and spans across multiple lines).
Note: Overridden function is here:
--> https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC1155/ERC1155.sol:69:5:
|
69 | function balanceOf(address account, uint256 id) public view virtual override returns (uint256) {
| ^ (Relevant source part starts here and spans across multiple lines).现在,我在创建ERC1155令牌时完全被困住了。我在找人帮忙。最后一件事是我用混编编辑器来写我的合同。
发布于 2021-08-05 07:44:24
为什么_mint在getBalance函数中
1. You need to write mint function cause it is internal函数薄荷(地址帐户,uint256 id,uint256金额)公开{_mint(帐户,id,amount,"");}
https://stackoverflow.com/questions/68661290
复制相似问题