-
Notifications
You must be signed in to change notification settings - Fork 841
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* added comments on transfer hooks * added sort * added clearApprovalsAndEmitTransferEvent * added tokenBatchTransfer hooks * added _batchTransferFrom and safe variants * added ERC721ABatchTransferable extension and interface * formatting * added interface and ERC721ABatchTransferableMock * added ERC721ABatchTransferable tests (wip) * added approvalCheck * fixed duplicate call * comment * fixed next initialized * refactored lastInitPackedOwnership to use prevPackedOwnership * comments * ensured correctness of nextInitialized in slots of transferred token Ids * renamed variables * reverted to leave nextInitialized unchanged * comment * replace sort -> insertion sort * bump: prettier-plugin-solidity * prettier * added prettier-ignore * fixed nextTokenId in last array element * tests wip * refactor * updated BatchTransferable mock and extension * updated tests * add approval tests * lint * lint fix * restore original .prettierrc * fix * comments and refactor * added _batchBurn * added ERC721ABatchBurnable extension, interfaces and mock * fixed _batchBurn * fixed update of last tokenId + 1 * batchBurnable tests wip * refactor * fix * add auto-clearing of consecutive ids and set `nextInitialized` to false * batchTransfer tests refactor * tests wip * tests wip * comments * added extraData logic to batch mocks * updated batch tests * refactored ERC721A to use _updateTokenId * wip * comment * Add ERC721ABatchBurnableMock (#450) * change tokenIds in ascending order in test * removal of unneeded internal functions * prettier * removed batch transfer logic * changed _updateTokenId * fixed mock * fixed extension and mock * fixed tests and cleaned unused functions in mock * removed _updateTokenId * minor gas optimizations * comment * optimize: avoid potential double read from storage * removed bulkBurn from mock * optimization: reset _packedOwnerships for initialized sequential IDs * added tests for sequential ID clearing * added test for tokenIds in strictly ascending order * comment * optimize: keep track of prevTokenOwner to bypass duplicated logic * revert: resetting _packedOwnerships in initialized sequential IDs * cleanup * optimize: avoid potential double read from storage * refactor _batchTransfer logic * optimized and stacked not too deep * optimize: removed unneeded exists() via getApproved * removed unneeded functions and batchBurn
- Loading branch information
Showing
8 changed files
with
924 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,4 +10,4 @@ | |
} | ||
} | ||
] | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
// SPDX-License-Identifier: MIT | ||
// ERC721A Contracts v4.2.3 | ||
// Creator: Chiru Labs | ||
|
||
pragma solidity ^0.8.4; | ||
|
||
import '../ERC721A.sol'; | ||
import './IERC721ABatchTransferable.sol'; | ||
|
||
/** | ||
* @title ERC721ABatchTransferable. | ||
* | ||
* @dev ERC721A token optimized for batch transfers. | ||
*/ | ||
abstract contract ERC721ABatchTransferable is ERC721A, IERC721ABatchTransferable { | ||
function batchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds | ||
) public payable virtual override { | ||
_batchTransferFrom(from, to, tokenIds, true); | ||
} | ||
|
||
function safeBatchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds | ||
) public payable virtual override { | ||
_safeBatchTransferFrom(from, to, tokenIds, true); | ||
} | ||
|
||
function safeBatchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds, | ||
bytes memory _data | ||
) public payable virtual override { | ||
_safeBatchTransferFrom(from, to, tokenIds, _data, true); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
// SPDX-License-Identifier: MIT | ||
// ERC721A Contracts v4.2.3 | ||
// Creator: Chiru Labs | ||
|
||
pragma solidity ^0.8.4; | ||
|
||
import '../IERC721A.sol'; | ||
|
||
/** | ||
* @dev Interface of ERC721ABatchTransferable. | ||
*/ | ||
interface IERC721ABatchTransferable is IERC721A { | ||
/** | ||
* @dev Transfers `tokenIds` in batch from `from` to `to`. See {ERC721A-_batchTransferFrom}. | ||
* | ||
* Requirements: | ||
* | ||
* - `from` cannot be the zero address. | ||
* - `to` cannot be the zero address. | ||
* - `tokenIds` tokens must be owned by `from`. | ||
* - If the caller is not `from`, it must be approved to move these tokens | ||
* by either {approve} or {setApprovalForAll}. | ||
* | ||
* Emits a {Transfer} event for each transfer. | ||
*/ | ||
function batchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds | ||
) external payable; | ||
|
||
/** | ||
* @dev Equivalent to `safeBatchTransferFrom(from, to, tokenIds, '')`. | ||
*/ | ||
function safeBatchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds | ||
) external payable; | ||
|
||
/** | ||
* @dev Safely transfers `tokenIds` in batch from `from` to `to`. See {ERC721A-_safeBatchTransferFrom}. | ||
* | ||
* Requirements: | ||
* | ||
* - `from` cannot be the zero address. | ||
* - `to` cannot be the zero address. | ||
* - `tokenIds` tokens must be owned by `from`. | ||
* - If the caller is not `from`, it must be approved to move these tokens | ||
* by either {approve} or {setApprovalForAll}. | ||
* - If `to` refers to a smart contract, it must implement | ||
* {IERC721Receiver-onERC721Received}, which is called for each transferred token. | ||
* | ||
* Emits a {Transfer} event for each transfer. | ||
*/ | ||
function safeBatchTransferFrom( | ||
address from, | ||
address to, | ||
uint256[] memory tokenIds, | ||
bytes memory _data | ||
) external payable; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
// SPDX-License-Identifier: MIT | ||
// ERC721A Contracts v4.2.3 | ||
// Creator: Chiru Labs | ||
|
||
pragma solidity ^0.8.4; | ||
|
||
import '../extensions/IERC721ABatchTransferable.sol'; |
Oops, something went wrong.