我正在用openZeppelin编写一份NFT铸币合同,它有两个函数可以创建标记。薄荷和reserveMint。每个函数可以在不同的时间以不同的顺序相互独立地调用,直到totalSupply运行完为止。reserveMint可以被调用,直到_reserve用完为止。
我遇到的问题是,毕竟,totalSupply显示为29而不是30。有30种代币。第一次tokenID从0开始,最后一次tokenID以29结束。这很好。我怎样才能确保合同中的totalSupply是30。我不想混淆用户谁看合同,认为只有29个被铸造。
谢谢!
uint256 private _reserve = 10;
uint256 public constant totalSupply = 20;
function mint(uint256 numberOfTokens) public payable {
uint256 supply = totalSupply();
require( numberOfTokens <= 20, "You can mint 20 at a time." );
require( supply + numberOfTokens < (totalSupply - _reserve), "Exceeds total supply" );
require( msg.value >= Price * numberOfTokens, "Ether sent is not correct" );
for(uint256 i; i < numberOfTokens; i++){
_safeMint( msg.sender, supply + i );
}
}
function reserveMint(address _to, uint256 _amount) external onlyOwner() {
require( _amount <= _reserve, "Exceeds reserved supply" );
uint256 supply = totalSupply();
for(uint256 i; i < _amount; i++){
_safeMint( _to, supply + i );
}
_reserve -= _amount;
}发布于 2021-08-03 07:56:04
让我们看一下您的代码:
uint256 public constant totalSupply = 20;
...
function reserveMint(address _to, uint256 _amount) external onlyOwner() {
require( _amount <= _reserve, "Exceeds reserved supply" );
uint256 supply = totalSupply();
for(uint256 i; i < _amount; i++){
_safeMint( _to, supply + i );
}
_reserve -= _amount;
}从totalSupply of 20开始。然后,for循环初始化变量i。这将被初始化为零(固体中的所有变量都初始化为它们的零ish表示:0、address(0)、false等)。因此,在for循环的第一次迭代中,当调用_safeMint时,它将以_to和supply + 0作为参数进行调用,这意味着它正在创建到第20个时隙,这已经被计算过了。
您可能希望使用以下方法初始化for循环:
for(uint256 i=1; i <= _amount; i++){而不是将i初始化为零。(还有很多其他的解决方案,但这是我们推荐的方案。)除此之外,代码看起来应该像预期的那样工作。编码愉快!
https://ethereum.stackexchange.com/questions/106536
复制相似问题