lang: Type safe bumps (#2542)
This commit is contained in:
parent
721eb7a3be
commit
243ab75738
|
@ -46,6 +46,7 @@ The minor version will be incremented upon a breaking change and the patch versi
|
|||
|
||||
### Breaking
|
||||
|
||||
- lang: Switch to type safe bumps in context ([#2542](https://github.com/coral-xyz/anchor/pull/2542)).
|
||||
- syn: `idl` feature has been replaced with `idl-build`, `idl-parse` and `idl-types` features ([#2011](https://github.com/coral-xyz/anchor/pull/2011)).
|
||||
- syn: IDL `parse` method now returns `Result<Idl>` instead of `Result<Option<Idl>>` ([#2582](https://github.com/coral-xyz/anchor/pull/2582)).
|
||||
- spl: Update `mpl-token-metadata` dependency to use the client SDK instead of the program crate ([#2632](https://github.com/coral-xyz/anchor/pull/2632)).
|
||||
|
|
|
@ -16,9 +16,9 @@ The programs and their tests are located in [/tests/bench](https://github.com/co
|
|||
|
||||
Solana version: 1.17.0
|
||||
|
||||
| Program | Binary Size | +/- |
|
||||
| ------- | ----------- | ---------------------- |
|
||||
| bench | 1,075,688 | 🟢 **-78,048 (6.76%)** |
|
||||
| Program | Binary Size | +/- |
|
||||
| ------- | ----------- | ----------------------- |
|
||||
| bench | 1,049,608 | 🟢 **-104,128 (9.03%)** |
|
||||
|
||||
### Notable changes
|
||||
|
||||
|
|
|
@ -18,93 +18,93 @@ Solana version: 1.17.0
|
|||
|
||||
| Instruction | Compute Units | +/- |
|
||||
| --------------------------- | ------------- | ---------------------- |
|
||||
| accountInfo1 | 680 | 🟢 **-335 (33.00%)** |
|
||||
| accountInfo2 | 1,083 | 🟢 **-392 (26.58%)** |
|
||||
| accountInfo4 | 1,535 | 🟢 **-429 (21.84%)** |
|
||||
| accountInfo8 | 2,774 | 🟢 **-1,067 (27.78%)** |
|
||||
| accountInfo1 | 584 | 🟢 **-431 (42.46%)** |
|
||||
| accountInfo2 | 824 | 🟢 **-651 (44.14%)** |
|
||||
| accountInfo4 | 1,319 | 🟢 **-645 (32.84%)** |
|
||||
| accountInfo8 | 2,531 | 🟢 **-1,310 (34.11%)** |
|
||||
| accountEmptyInit1 | 5,521 | 🟢 **-296 (5.09%)** |
|
||||
| accountEmpty1 | 815 | 🟢 **-334 (29.07%)** |
|
||||
| accountEmpty1 | 777 | 🟢 **-372 (32.38%)** |
|
||||
| accountEmptyInit2 | 10,111 | 🟢 **-291 (2.80%)** |
|
||||
| accountEmpty2 | 1,366 | 🟢 **-388 (22.12%)** |
|
||||
| accountEmpty2 | 1,207 | 🟢 **-547 (31.19%)** |
|
||||
| accountEmptyInit4 | 19,044 | 🟢 **-464 (2.38%)** |
|
||||
| accountEmpty4 | 2,120 | 🟢 **-420 (16.54%)** |
|
||||
| accountEmpty4 | 2,074 | 🟢 **-466 (18.35%)** |
|
||||
| accountEmptyInit8 | 37,265 | - |
|
||||
| accountEmpty8 | 3,967 | 🟢 **-1,049 (20.91%)** |
|
||||
| accountSizedInit1 | 5,626 | 🟢 **-298 (5.03%)** |
|
||||
| accountSized1 | 820 | 🟢 **-394 (32.45%)** |
|
||||
| accountSized1 | 786 | 🟢 **-428 (35.26%)** |
|
||||
| accountSizedInit2 | 10,322 | 🟢 **-358 (3.35%)** |
|
||||
| accountSized2 | 1,411 | 🟢 **-462 (24.67%)** |
|
||||
| accountSized2 | 1,234 | 🟢 **-639 (34.12%)** |
|
||||
| accountSizedInit4 | 19,462 | 🟢 **-508 (2.54%)** |
|
||||
| accountSized4 | 2,181 | 🟢 **-581 (21.04%)** |
|
||||
| accountSized4 | 2,135 | 🟢 **-627 (22.70%)** |
|
||||
| accountSizedInit8 | 38,122 | - |
|
||||
| accountSized8 | 4,104 | 🟢 **-1,249 (23.33%)** |
|
||||
| accountUnsizedInit1 | 5,742 | 🟢 **-310 (5.12%)** |
|
||||
| accountUnsized1 | 859 | 🟢 **-479 (35.80%)** |
|
||||
| accountUnsized1 | 821 | 🟢 **-517 (38.64%)** |
|
||||
| accountUnsizedInit2 | 10,551 | 🟢 **-378 (3.46%)** |
|
||||
| accountUnsized2 | 1,364 | 🟢 **-414 (23.28%)** |
|
||||
| accountUnsized2 | 1,312 | 🟢 **-466 (26.21%)** |
|
||||
| accountUnsizedInit4 | 19,927 | 🟢 **-412 (2.03%)** |
|
||||
| accountUnsized4 | 2,341 | 🟢 **-795 (25.35%)** |
|
||||
| accountUnsized4 | 2,315 | 🟢 **-821 (26.18%)** |
|
||||
| accountUnsizedInit8 | 38,699 | 🟢 **-397 (1.02%)** |
|
||||
| accountUnsized8 | 4,456 | 🟢 **-1,496 (25.13%)** |
|
||||
| boxedAccountEmptyInit1 | 5,624 | 🟢 **-410 (6.79%)** |
|
||||
| boxedAccountEmpty1 | 888 | - |
|
||||
| boxedAccountEmptyInit2 | 10,221 | 🟢 **-412 (3.87%)** |
|
||||
| boxedAccountEmpty2 | 1,401 | - |
|
||||
| boxedAccountEmptyInit1 | 5,452 | 🟢 **-582 (9.65%)** |
|
||||
| boxedAccountEmpty1 | 866 | 🟢 **-22 (2.48%)** |
|
||||
| boxedAccountEmptyInit2 | 10,051 | 🟢 **-582 (5.47%)** |
|
||||
| boxedAccountEmpty2 | 1,377 | 🟢 **-24 (1.71%)** |
|
||||
| boxedAccountEmptyInit4 | 19,030 | 🟢 **-281 (1.46%)** |
|
||||
| boxedAccountEmpty4 | 2,424 | - |
|
||||
| boxedAccountEmpty4 | 2,396 | 🟢 **-28 (1.16%)** |
|
||||
| boxedAccountEmptyInit8 | 37,136 | - |
|
||||
| boxedAccountEmpty8 | 4,527 | 🟢 **-132 (2.83%)** |
|
||||
| boxedAccountSizedInit1 | 5,718 | 🟢 **-412 (6.72%)** |
|
||||
| boxedAccountSized1 | 917 | - |
|
||||
| boxedAccountSizedInit2 | 10,412 | 🟢 **-416 (3.84%)** |
|
||||
| boxedAccountSized2 | 1,463 | - |
|
||||
| boxedAccountEmpty8 | 4,472 | 🟢 **-187 (4.01%)** |
|
||||
| boxedAccountSizedInit1 | 5,546 | 🟢 **-584 (9.53%)** |
|
||||
| boxedAccountSized1 | 895 | 🟢 **-22 (2.40%)** |
|
||||
| boxedAccountSizedInit2 | 10,242 | 🟢 **-586 (5.41%)** |
|
||||
| boxedAccountSized2 | 1,439 | 🟢 **-24 (1.64%)** |
|
||||
| boxedAccountSizedInit4 | 19,414 | 🟢 **-289 (1.47%)** |
|
||||
| boxedAccountSized4 | 2,543 | - |
|
||||
| boxedAccountSized4 | 2,515 | 🟢 **-28 (1.10%)** |
|
||||
| boxedAccountSizedInit8 | 37,919 | - |
|
||||
| boxedAccountSized8 | 4,766 | 🟢 **-132 (2.69%)** |
|
||||
| boxedAccountSized8 | 4,711 | 🟢 **-187 (3.82%)** |
|
||||
| boxedAccountUnsizedInit1 | 5,823 | 🟢 **-417 (6.68%)** |
|
||||
| boxedAccountUnsized1 | 972 | - |
|
||||
| boxedAccountUnsized1 | 950 | 🟢 **-22 (2.26%)** |
|
||||
| boxedAccountUnsizedInit2 | 10,621 | 🟢 **-427 (3.86%)** |
|
||||
| boxedAccountUnsized2 | 1,570 | - |
|
||||
| boxedAccountUnsized2 | 1,549 | 🟢 **-21 (1.34%)** |
|
||||
| boxedAccountUnsizedInit4 | 19,825 | 🟢 **-313 (1.55%)** |
|
||||
| boxedAccountUnsized4 | 2,768 | - |
|
||||
| boxedAccountUnsized4 | 2,737 | 🟢 **-31 (1.12%)** |
|
||||
| boxedAccountUnsizedInit8 | 38,791 | 🟢 **-9 (0.02%)** |
|
||||
| boxedAccountUnsized8 | 5,207 | 🟢 **-140 (2.62%)** |
|
||||
| boxedInterfaceAccountMint1 | 2,159 | 🟢 **-137 (5.97%)** |
|
||||
| boxedInterfaceAccountMint1 | 2,137 | 🟢 **-159 (6.93%)** |
|
||||
| boxedInterfaceAccountMint2 | 3,849 | 🟢 **-280 (6.78%)** |
|
||||
| boxedInterfaceAccountMint4 | 7,215 | 🟢 **-568 (7.30%)** |
|
||||
| boxedInterfaceAccountMint8 | 14,044 | 🟢 **-1,237 (8.10%)** |
|
||||
| boxedInterfaceAccountToken1 | 2,088 | 🔴 **+65 (3.21%)** |
|
||||
| boxedInterfaceAccountToken1 | 2,066 | 🔴 **+43 (2.13%)** |
|
||||
| boxedInterfaceAccountToken2 | 3,706 | 🔴 **+124 (3.46%)** |
|
||||
| boxedInterfaceAccountToken4 | 6,932 | 🔴 **+240 (3.59%)** |
|
||||
| boxedInterfaceAccountToken8 | 13,477 | 🔴 **+379 (2.89%)** |
|
||||
| interfaceAccountMint1 | 2,574 | 🔴 **+210 (8.88%)** |
|
||||
| interfaceAccountMint2 | 4,410 | 🟢 **-620 (12.33%)** |
|
||||
| interfaceAccountMint4 | 8,313 | 🟢 **-1,490 (15.20%)** |
|
||||
| interfaceAccountMint1 | 2,313 | 🟢 **-51 (2.16%)** |
|
||||
| interfaceAccountMint2 | 4,270 | 🟢 **-760 (15.11%)** |
|
||||
| interfaceAccountMint4 | 8,185 | 🟢 **-1,618 (16.51%)** |
|
||||
| interfaceAccountMint8 | 16,007 | 🟢 **-2,393 (13.01%)** |
|
||||
| interfaceAccountToken1 | 2,137 | 🔴 **+46 (2.20%)** |
|
||||
| interfaceAccountToken2 | 4,032 | 🔴 **+84 (2.13%)** |
|
||||
| interfaceAccountToken1 | 2,059 | 🟢 **-32 (1.53%)** |
|
||||
| interfaceAccountToken2 | 3,958 | 🔴 **+10 (0.25%)** |
|
||||
| interfaceAccountToken4 | 7,816 | 🔴 **+269 (3.56%)** |
|
||||
| interface1 | 726 | 🟢 **-333 (31.44%)** |
|
||||
| interface2 | 1,093 | 🟢 **-386 (26.10%)** |
|
||||
| interface4 | 1,484 | 🟢 **-416 (21.89%)** |
|
||||
| interface1 | 691 | 🟢 **-368 (34.75%)** |
|
||||
| interface2 | 940 | 🟢 **-539 (36.44%)** |
|
||||
| interface4 | 1,450 | 🟢 **-450 (23.68%)** |
|
||||
| interface8 | 2,605 | 🟢 **-1,041 (28.55%)** |
|
||||
| program1 | 720 | 🟢 **-333 (31.62%)** |
|
||||
| program2 | 1,081 | 🟢 **-386 (26.31%)** |
|
||||
| program4 | 1,462 | 🟢 **-416 (22.15%)** |
|
||||
| program1 | 685 | 🟢 **-368 (34.95%)** |
|
||||
| program2 | 928 | 🟢 **-539 (36.74%)** |
|
||||
| program4 | 1,428 | 🟢 **-450 (23.96%)** |
|
||||
| program8 | 2,557 | 🟢 **-1,041 (28.93%)** |
|
||||
| signer1 | 683 | 🟢 **-335 (32.91%)** |
|
||||
| signer2 | 1,092 | 🟢 **-392 (26.42%)** |
|
||||
| signer4 | 1,555 | 🟢 **-429 (21.62%)** |
|
||||
| signer8 | 2,813 | 🟢 **-1,067 (27.50%)** |
|
||||
| systemAccount1 | 737 | 🟢 **-335 (31.25%)** |
|
||||
| systemAccount2 | 1,198 | 🟢 **-392 (24.65%)** |
|
||||
| systemAccount4 | 1,766 | 🟢 **-429 (19.54%)** |
|
||||
| systemAccount8 | 3,238 | 🟢 **-1,067 (24.79%)** |
|
||||
| uncheckedAccount1 | 679 | 🟢 **-335 (33.04%)** |
|
||||
| uncheckedAccount2 | 1,083 | 🟢 **-392 (26.58%)** |
|
||||
| uncheckedAccount4 | 1,536 | 🟢 **-429 (21.83%)** |
|
||||
| uncheckedAccount8 | 2,774 | 🟢 **-1,067 (27.78%)** |
|
||||
| signer1 | 621 | 🟢 **-397 (39.00%)** |
|
||||
| signer2 | 895 | 🟢 **-589 (39.69%)** |
|
||||
| signer4 | 1,455 | 🟢 **-529 (26.66%)** |
|
||||
| signer8 | 2,721 | 🟢 **-1,159 (29.87%)** |
|
||||
| systemAccount1 | 675 | 🟢 **-397 (37.03%)** |
|
||||
| systemAccount2 | 1,001 | 🟢 **-589 (37.04%)** |
|
||||
| systemAccount4 | 1,666 | 🟢 **-529 (24.10%)** |
|
||||
| systemAccount8 | 3,146 | 🟢 **-1,159 (26.92%)** |
|
||||
| uncheckedAccount1 | 583 | 🟢 **-431 (42.50%)** |
|
||||
| uncheckedAccount2 | 824 | 🟢 **-651 (44.14%)** |
|
||||
| uncheckedAccount4 | 1,320 | 🟢 **-645 (32.82%)** |
|
||||
| uncheckedAccount8 | 2,531 | 🟢 **-1,310 (34.11%)** |
|
||||
|
||||
### Notable changes
|
||||
|
||||
|
|
|
@ -16,95 +16,95 @@ The programs and their tests are located in [/tests/bench](https://github.com/co
|
|||
|
||||
Solana version: 1.17.0
|
||||
|
||||
| Instruction | Stack Memory | +/- |
|
||||
| ------------------------------ | ------------ | -------------------- |
|
||||
| account_info1 | 272 | 🟢 **-56 (17.07%)** |
|
||||
| account_info2 | 320 | 🟢 **-56 (14.89%)** |
|
||||
| account_info4 | 416 | 🟢 **-144 (25.71%)** |
|
||||
| account_info8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| account_empty_init1 | 400 | 🟢 **-192 (32.43%)** |
|
||||
| account_empty_init2 | 480 | 🟢 **-80 (14.29%)** |
|
||||
| account_empty_init4 | 528 | 🟢 **-104 (16.46%)** |
|
||||
| account_empty_init8 | 720 | 🟢 **-104 (12.62%)** |
|
||||
| account_empty1 | 272 | 🟢 **-48 (15.00%)** |
|
||||
| account_empty2 | 320 | 🟢 **-48 (13.04%)** |
|
||||
| account_empty4 | 416 | 🟢 **-136 (24.64%)** |
|
||||
| account_empty8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| account_sized_init1 | 408 | 🟢 **-192 (32.00%)** |
|
||||
| account_sized_init2 | 496 | 🟢 **-56 (10.14%)** |
|
||||
| account_sized_init4 | 560 | 🟢 **-104 (15.66%)** |
|
||||
| account_sized_init8 | 784 | 🟢 **-104 (11.71%)** |
|
||||
| account_sized1 | 280 | 🟢 **-48 (14.63%)** |
|
||||
| account_sized2 | 336 | 🟢 **-56 (14.29%)** |
|
||||
| account_sized4 | 448 | 🟢 **-120 (21.13%)** |
|
||||
| account_sized8 | 672 | 🟢 **-120 (15.15%)** |
|
||||
| account_unsized_init1 | 424 | 🟢 **-200 (32.05%)** |
|
||||
| account_unsized_init2 | 528 | 🟢 **-56 (9.59%)** |
|
||||
| account_unsized_init4 | 624 | 🟢 **-104 (14.29%)** |
|
||||
| account_unsized_init8 | 912 | 🟢 **-104 (10.24%)** |
|
||||
| account_unsized1 | 296 | 🟢 **-48 (13.95%)** |
|
||||
| account_unsized2 | 368 | 🟢 **-88 (19.30%)** |
|
||||
| account_unsized4 | 512 | 🟢 **-120 (18.99%)** |
|
||||
| account_unsized8 | 800 | 🟢 **-120 (13.04%)** |
|
||||
| boxed_account_empty_init1 | 360 | 🟢 **-192 (34.78%)** |
|
||||
| boxed_account_empty_init2 | 400 | - |
|
||||
| boxed_account_empty_init4 | 368 | 🟢 **-64 (14.81%)** |
|
||||
| boxed_account_empty_init8 | 400 | 🟢 **-96 (19.35%)** |
|
||||
| boxed_account_empty1 | 232 | 🟢 **-88 (27.50%)** |
|
||||
| boxed_account_empty2 | 240 | 🟢 **-80 (25.00%)** |
|
||||
| boxed_account_empty4 | 256 | 🟢 **-64 (20.00%)** |
|
||||
| boxed_account_empty8 | 288 | 🟢 **-48 (14.29%)** |
|
||||
| boxed_account_sized_init1 | 360 | 🟢 **-192 (34.78%)** |
|
||||
| boxed_account_sized_init2 | 400 | - |
|
||||
| boxed_account_sized_init4 | 368 | 🟢 **-64 (14.81%)** |
|
||||
| boxed_account_sized_init8 | 400 | 🟢 **-96 (19.35%)** |
|
||||
| boxed_account_sized1 | 232 | 🟢 **-88 (27.50%)** |
|
||||
| boxed_account_sized2 | 240 | 🟢 **-80 (25.00%)** |
|
||||
| boxed_account_sized4 | 256 | 🟢 **-64 (20.00%)** |
|
||||
| boxed_account_sized8 | 288 | 🟢 **-48 (14.29%)** |
|
||||
| boxed_account_unsized_init1 | 360 | 🟢 **-192 (34.78%)** |
|
||||
| boxed_account_unsized_init2 | 400 | - |
|
||||
| boxed_account_unsized_init4 | 368 | 🟢 **-64 (14.81%)** |
|
||||
| boxed_account_unsized_init8 | 400 | 🟢 **-96 (19.35%)** |
|
||||
| boxed_account_unsized1 | 232 | 🟢 **-88 (27.50%)** |
|
||||
| boxed_account_unsized2 | 240 | 🟢 **-80 (25.00%)** |
|
||||
| boxed_account_unsized4 | 256 | 🟢 **-64 (20.00%)** |
|
||||
| boxed_account_unsized8 | 288 | 🟢 **-48 (14.29%)** |
|
||||
| boxed_interface_account_mint1 | 232 | 🟢 **-88 (27.50%)** |
|
||||
| boxed_interface_account_mint2 | 240 | 🟢 **-80 (25.00%)** |
|
||||
| boxed_interface_account_mint4 | 256 | 🟢 **-64 (20.00%)** |
|
||||
| boxed_interface_account_mint8 | 288 | 🟢 **-48 (14.29%)** |
|
||||
| boxed_interface_account_token1 | 232 | 🟢 **-88 (27.50%)** |
|
||||
| boxed_interface_account_token2 | 240 | 🟢 **-80 (25.00%)** |
|
||||
| boxed_interface_account_token4 | 256 | 🟢 **-64 (20.00%)** |
|
||||
| boxed_interface_account_token8 | 288 | 🟢 **-48 (14.29%)** |
|
||||
| interface_account_mint1 | 392 | 🟢 **-112 (22.22%)** |
|
||||
| interface_account_mint2 | 560 | 🟢 **-120 (17.65%)** |
|
||||
| interface_account_mint4 | 896 | 🟢 **-120 (11.81%)** |
|
||||
| interface_account_mint8 | 1,568 | 🟢 **-120 (7.11%)** |
|
||||
| interface_account_token1 | 480 | 🟢 **-200 (29.41%)** |
|
||||
| interface_account_token2 | 736 | 🟢 **-120 (14.02%)** |
|
||||
| interface_account_token4 | 1,248 | 🟢 **-120 (8.77%)** |
|
||||
| interface1 | 272 | 🟢 **-48 (15.00%)** |
|
||||
| interface2 | 320 | 🟢 **-48 (13.04%)** |
|
||||
| interface4 | 416 | 🟢 **-136 (24.64%)** |
|
||||
| interface8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| program1 | 272 | 🟢 **-48 (15.00%)** |
|
||||
| program2 | 320 | 🟢 **-48 (13.04%)** |
|
||||
| program4 | 416 | 🟢 **-136 (24.64%)** |
|
||||
| program8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| signer1 | 272 | 🟢 **-56 (17.07%)** |
|
||||
| signer2 | 320 | 🟢 **-56 (14.89%)** |
|
||||
| signer4 | 416 | 🟢 **-144 (25.71%)** |
|
||||
| signer8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| system_account1 | 272 | 🟢 **-56 (17.07%)** |
|
||||
| system_account2 | 320 | 🟢 **-56 (14.89%)** |
|
||||
| system_account4 | 416 | 🟢 **-144 (25.71%)** |
|
||||
| system_account8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| unchecked_account1 | 272 | 🟢 **-56 (17.07%)** |
|
||||
| unchecked_account2 | 320 | 🟢 **-56 (14.89%)** |
|
||||
| unchecked_account4 | 416 | 🟢 **-144 (25.71%)** |
|
||||
| unchecked_account8 | 608 | 🟢 **-120 (16.48%)** |
|
||||
| Instruction | Stack Memory | +/- |
|
||||
| ------------------------------ | ------------ | ---------------------- |
|
||||
| account_info1 | 128 | 🟢 **-200 (60.98%)** |
|
||||
| account_info2 | 128 | 🟢 **-248 (65.96%)** |
|
||||
| account_info4 | 128 | 🟢 **-432 (77.14%)** |
|
||||
| account_info8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| account_empty_init1 | 320 | 🟢 **-272 (45.95%)** |
|
||||
| account_empty_init2 | 400 | 🟢 **-160 (28.57%)** |
|
||||
| account_empty_init4 | 448 | 🟢 **-184 (29.11%)** |
|
||||
| account_empty_init8 | 640 | 🟢 **-184 (22.33%)** |
|
||||
| account_empty1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| account_empty2 | 128 | 🟢 **-240 (65.22%)** |
|
||||
| account_empty4 | 128 | 🟢 **-424 (76.81%)** |
|
||||
| account_empty8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| account_sized_init1 | 328 | 🟢 **-272 (45.33%)** |
|
||||
| account_sized_init2 | 416 | 🟢 **-136 (24.64%)** |
|
||||
| account_sized_init4 | 480 | 🟢 **-184 (27.71%)** |
|
||||
| account_sized_init8 | 704 | 🟢 **-184 (20.72%)** |
|
||||
| account_sized1 | 128 | 🟢 **-200 (60.98%)** |
|
||||
| account_sized2 | 128 | 🟢 **-264 (67.35%)** |
|
||||
| account_sized4 | 128 | 🟢 **-440 (77.46%)** |
|
||||
| account_sized8 | 128 | 🟢 **-664 (83.84%)** |
|
||||
| account_unsized_init1 | 344 | 🟢 **-280 (44.87%)** |
|
||||
| account_unsized_init2 | 448 | 🟢 **-136 (23.29%)** |
|
||||
| account_unsized_init4 | 544 | 🟢 **-184 (25.27%)** |
|
||||
| account_unsized_init8 | 832 | 🟢 **-184 (18.11%)** |
|
||||
| account_unsized1 | 128 | 🟢 **-216 (62.79%)** |
|
||||
| account_unsized2 | 128 | 🟢 **-328 (71.93%)** |
|
||||
| account_unsized4 | 128 | 🟢 **-504 (79.75%)** |
|
||||
| account_unsized8 | 128 | 🟢 **-792 (86.09%)** |
|
||||
| boxed_account_empty_init1 | 176 | 🟢 **-376 (68.12%)** |
|
||||
| boxed_account_empty_init2 | 208 | 🟢 **-192 (48.00%)** |
|
||||
| boxed_account_empty_init4 | 288 | 🟢 **-144 (33.33%)** |
|
||||
| boxed_account_empty_init8 | 320 | 🟢 **-176 (35.48%)** |
|
||||
| boxed_account_empty1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| boxed_account_empty2 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_account_empty4 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_account_empty8 | 128 | 🟢 **-208 (61.90%)** |
|
||||
| boxed_account_sized_init1 | 176 | 🟢 **-376 (68.12%)** |
|
||||
| boxed_account_sized_init2 | 208 | 🟢 **-192 (48.00%)** |
|
||||
| boxed_account_sized_init4 | 288 | 🟢 **-144 (33.33%)** |
|
||||
| boxed_account_sized_init8 | 320 | 🟢 **-176 (35.48%)** |
|
||||
| boxed_account_sized1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| boxed_account_sized2 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_account_sized4 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_account_sized8 | 128 | 🟢 **-208 (61.90%)** |
|
||||
| boxed_account_unsized_init1 | 280 | 🟢 **-272 (49.28%)** |
|
||||
| boxed_account_unsized_init2 | 320 | 🟢 **-80 (20.00%)** |
|
||||
| boxed_account_unsized_init4 | 288 | 🟢 **-144 (33.33%)** |
|
||||
| boxed_account_unsized_init8 | 320 | 🟢 **-176 (35.48%)** |
|
||||
| boxed_account_unsized1 | 152 | 🟢 **-168 (52.50%)** |
|
||||
| boxed_account_unsized2 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_account_unsized4 | 176 | 🟢 **-144 (45.00%)** |
|
||||
| boxed_account_unsized8 | 192 | 🟢 **-144 (42.86%)** |
|
||||
| boxed_interface_account_mint1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| boxed_interface_account_mint2 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_interface_account_mint4 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_interface_account_mint8 | 128 | 🟢 **-208 (61.90%)** |
|
||||
| boxed_interface_account_token1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| boxed_interface_account_token2 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_interface_account_token4 | 144 | 🟢 **-176 (55.00%)** |
|
||||
| boxed_interface_account_token8 | 128 | 🟢 **-208 (61.90%)** |
|
||||
| interface_account_mint1 | 128 | 🟢 **-376 (74.60%)** |
|
||||
| interface_account_mint2 | 128 | 🟢 **-552 (81.18%)** |
|
||||
| interface_account_mint4 | 128 | 🟢 **-888 (87.40%)** |
|
||||
| interface_account_mint8 | 128 | 🟢 **-1,560 (92.42%)** |
|
||||
| interface_account_token1 | 128 | 🟢 **-552 (81.18%)** |
|
||||
| interface_account_token2 | 128 | 🟢 **-728 (85.05%)** |
|
||||
| interface_account_token4 | 128 | 🟢 **-1,240 (90.64%)** |
|
||||
| interface1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| interface2 | 128 | 🟢 **-240 (65.22%)** |
|
||||
| interface4 | 128 | 🟢 **-424 (76.81%)** |
|
||||
| interface8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| program1 | 128 | 🟢 **-192 (60.00%)** |
|
||||
| program2 | 128 | 🟢 **-240 (65.22%)** |
|
||||
| program4 | 128 | 🟢 **-424 (76.81%)** |
|
||||
| program8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| signer1 | 128 | 🟢 **-200 (60.98%)** |
|
||||
| signer2 | 128 | 🟢 **-248 (65.96%)** |
|
||||
| signer4 | 128 | 🟢 **-432 (77.14%)** |
|
||||
| signer8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| system_account1 | 128 | 🟢 **-200 (60.98%)** |
|
||||
| system_account2 | 128 | 🟢 **-248 (65.96%)** |
|
||||
| system_account4 | 128 | 🟢 **-432 (77.14%)** |
|
||||
| system_account8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
| unchecked_account1 | 128 | 🟢 **-200 (60.98%)** |
|
||||
| unchecked_account2 | 128 | 🟢 **-248 (65.96%)** |
|
||||
| unchecked_account4 | 128 | 🟢 **-432 (77.14%)** |
|
||||
| unchecked_account8 | 128 | 🟢 **-600 (82.42%)** |
|
||||
|
||||
### Notable changes
|
||||
|
||||
|
|
|
@ -128,7 +128,7 @@ pub mod game {
|
|||
panic!();
|
||||
}
|
||||
user_stats.name = name;
|
||||
user_stats.bump = *ctx.bumps.get("user_stats").unwrap();
|
||||
user_stats.bump = ctx.bumps.user_stats;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
@ -158,7 +158,7 @@ pub struct CreateUserStats<'info> {
|
|||
|
||||
In the account validation struct we use `seeds` together with `init` to create a PDA with the desired seeds.
|
||||
Additionally, we add an empty `bump` constraint to signal to anchor that it should find the canonical bump itself.
|
||||
Then, in the handler, we call `ctx.bumps.get("user_stats")` to get the bump anchor found and save it to the user stats
|
||||
Then, in the handler, we call `ctx.bumps.user_stats` to get the bump anchor found and save it to the user stats
|
||||
account as an extra property.
|
||||
|
||||
If we then want to use the created pda in a different instruction, we can add a new validation struct (This will check that the `user_stats` account is the pda created by running `hash(seeds, user_stats.bump, game_program_id)`):
|
||||
|
|
|
@ -9,7 +9,7 @@ pub mod basic_4 {
|
|||
|
||||
pub fn initialize(ctx: Context<Initialize>) -> Result<()> {
|
||||
let counter = ctx.accounts.counter.deref_mut();
|
||||
let bump = *ctx.bumps.get("counter").ok_or(ErrorCode::CannotGetBump)?;
|
||||
let bump = ctx.bumps.counter;
|
||||
|
||||
*counter = Counter {
|
||||
authority: *ctx.accounts.authority.key,
|
||||
|
@ -73,6 +73,4 @@ impl Counter {
|
|||
pub enum ErrorCode {
|
||||
#[msg("You are not authorized to perform this action.")]
|
||||
Unauthorized,
|
||||
#[msg("Cannot get the bump.")]
|
||||
CannotGetBump,
|
||||
}
|
||||
|
|
|
@ -154,13 +154,12 @@ pub fn emit_cpi(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
|
|||
|
||||
let authority = EventAuthority::get();
|
||||
let authority_name = authority.name_token_stream();
|
||||
let authority_name_str = authority.name;
|
||||
let authority_seeds = authority.seeds;
|
||||
|
||||
proc_macro::TokenStream::from(quote! {
|
||||
{
|
||||
let authority_info = ctx.accounts.#authority_name.to_account_info();
|
||||
let authority_bump = *ctx.bumps.get(#authority_name_str).unwrap();
|
||||
let authority_bump = ctx.bumps.#authority_name;
|
||||
|
||||
let disc = anchor_lang::event::EVENT_IX_TAG_LE;
|
||||
let inner_data = anchor_lang::Event::data(&#event_struct);
|
||||
|
|
|
@ -10,7 +10,7 @@ use solana_program::account_info::AccountInfo;
|
|||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use solana_program::system_program;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::fmt;
|
||||
use std::ops::{Deref, DerefMut};
|
||||
|
||||
|
@ -334,7 +334,7 @@ impl<'a, T: AccountSerialize + AccountDeserialize + Owner + Clone> Account<'a, T
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: AccountSerialize + AccountDeserialize + Owner + Clone> Accounts<'info>
|
||||
impl<'info, B, T: AccountSerialize + AccountDeserialize + Owner + Clone> Accounts<'info, B>
|
||||
for Account<'info, T>
|
||||
where
|
||||
T: AccountSerialize + AccountDeserialize + Owner + Clone,
|
||||
|
@ -344,7 +344,7 @@ where
|
|||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -7,14 +7,14 @@ use crate::{Accounts, AccountsExit, Key, Result, ToAccountInfos, ToAccountMetas}
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
|
||||
impl<'info> Accounts<'info> for AccountInfo<'info> {
|
||||
impl<'info, B> Accounts<'info, B> for AccountInfo<'info> {
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -11,7 +11,7 @@ use solana_program::account_info::AccountInfo;
|
|||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::cell::{Ref, RefMut};
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::fmt;
|
||||
use std::io::Write;
|
||||
use std::marker::PhantomData;
|
||||
|
@ -214,13 +214,13 @@ impl<'info, T: ZeroCopy + Owner> AccountLoader<'info, T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: ZeroCopy + Owner> Accounts<'info> for AccountLoader<'info, T> {
|
||||
impl<'info, B, T: ZeroCopy + Owner> Accounts<'info, B> for AccountLoader<'info, T> {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -17,15 +17,15 @@ use crate::{Accounts, AccountsClose, AccountsExit, Result, ToAccountInfos, ToAcc
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::ops::Deref;
|
||||
|
||||
impl<'info, T: Accounts<'info>> Accounts<'info> for Box<T> {
|
||||
impl<'info, B, T: Accounts<'info, B>> Accounts<'info, B> for Box<T> {
|
||||
fn try_accounts(
|
||||
program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
ix_data: &[u8],
|
||||
bumps: &mut BTreeMap<String, u8>,
|
||||
bumps: &mut B,
|
||||
reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
T::try_accounts(program_id, accounts, ix_data, bumps, reallocs).map(Box::new)
|
||||
|
|
|
@ -9,7 +9,7 @@ use crate::{
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::ops::Deref;
|
||||
|
||||
/// Type validating that the account is one of a set of given Programs
|
||||
|
@ -105,13 +105,13 @@ impl<'info, T> AsRef<AccountInfo<'info>> for Interface<'info, T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: CheckId> Accounts<'info> for Interface<'info, T> {
|
||||
impl<'info, B, T: CheckId> Accounts<'info, B> for Interface<'info, T> {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -10,7 +10,7 @@ use solana_program::account_info::AccountInfo;
|
|||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use solana_program::system_program;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::fmt;
|
||||
use std::ops::{Deref, DerefMut};
|
||||
|
||||
|
@ -241,7 +241,7 @@ impl<'a, T: AccountSerialize + AccountDeserialize + CheckOwner + Clone> Interfac
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: AccountSerialize + AccountDeserialize + CheckOwner + Clone> Accounts<'info>
|
||||
impl<'info, B, T: AccountSerialize + AccountDeserialize + CheckOwner + Clone> Accounts<'info, B>
|
||||
for InterfaceAccount<'info, T>
|
||||
{
|
||||
#[inline(never)]
|
||||
|
@ -249,7 +249,7 @@ impl<'info, T: AccountSerialize + AccountDeserialize + CheckOwner + Clone> Accou
|
|||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
//! }
|
||||
//! ```
|
||||
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
|
||||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
|
@ -18,12 +18,12 @@ use crate::{
|
|||
error::ErrorCode, Accounts, AccountsClose, AccountsExit, Result, ToAccountInfos, ToAccountMetas,
|
||||
};
|
||||
|
||||
impl<'info, T: Accounts<'info>> Accounts<'info> for Option<T> {
|
||||
impl<'info, B, T: Accounts<'info, B>> Accounts<'info, B> for Option<T> {
|
||||
fn try_accounts(
|
||||
program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
ix_data: &[u8],
|
||||
bumps: &mut BTreeMap<String, u8>,
|
||||
bumps: &mut B,
|
||||
reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -8,7 +8,7 @@ use solana_program::account_info::AccountInfo;
|
|||
use solana_program::bpf_loader_upgradeable::{self, UpgradeableLoaderState};
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::convert::TryFrom;
|
||||
use std::fmt;
|
||||
use std::marker::PhantomData;
|
||||
|
@ -140,13 +140,13 @@ impl<'a, T: Id> TryFrom<&AccountInfo<'a>> for Program<'a, T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: Id> Accounts<'info> for Program<'info, T> {
|
||||
impl<'info, B, T: Id> Accounts<'info, B> for Program<'info, T> {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -4,7 +4,7 @@ use crate::{Accounts, AccountsExit, Key, Result, ToAccountInfos, ToAccountMetas}
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::ops::Deref;
|
||||
|
||||
/// Type validating that the account signed the transaction. No other ownership
|
||||
|
@ -54,13 +54,13 @@ impl<'info> Signer<'info> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info> Accounts<'info> for Signer<'info> {
|
||||
impl<'info, B> Accounts<'info, B> for Signer<'info> {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -6,7 +6,7 @@ use solana_program::account_info::AccountInfo;
|
|||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use solana_program::system_program;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::ops::Deref;
|
||||
|
||||
/// Type validating that the account is owned by the system program
|
||||
|
@ -33,13 +33,13 @@ impl<'info> SystemAccount<'info> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info> Accounts<'info> for SystemAccount<'info> {
|
||||
impl<'info, B> Accounts<'info, B> for SystemAccount<'info> {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -5,7 +5,7 @@ use crate::{Accounts, AccountsExit, Key, Result, ToAccountInfos, ToAccountMetas}
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::fmt;
|
||||
use std::ops::{Deref, DerefMut};
|
||||
|
||||
|
@ -65,12 +65,12 @@ impl<'info, T: solana_program::sysvar::Sysvar> Clone for Sysvar<'info, T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: solana_program::sysvar::Sysvar> Accounts<'info> for Sysvar<'info, T> {
|
||||
impl<'info, B, T: solana_program::sysvar::Sysvar> Accounts<'info, B> for Sysvar<'info, T> {
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -6,7 +6,7 @@ use crate::{Accounts, AccountsExit, Key, Result, ToAccountInfos, ToAccountMetas}
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
use std::ops::Deref;
|
||||
|
||||
/// Explicit wrapper for AccountInfo types to emphasize
|
||||
|
@ -20,12 +20,12 @@ impl<'info> UncheckedAccount<'info> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info> Accounts<'info> for UncheckedAccount<'info> {
|
||||
impl<'info, B> Accounts<'info, B> for UncheckedAccount<'info> {
|
||||
fn try_accounts(
|
||||
_program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
_ix_data: &[u8],
|
||||
_bumps: &mut BTreeMap<String, u8>,
|
||||
_bumps: &mut B,
|
||||
_reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
if accounts.is_empty() {
|
||||
|
|
|
@ -1,10 +1,9 @@
|
|||
//! Data structures that are used to provide non-argument inputs to program endpoints
|
||||
|
||||
use crate::{Accounts, ToAccountInfos, ToAccountMetas};
|
||||
use crate::{Accounts, Bumps, ToAccountInfos, ToAccountMetas};
|
||||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::BTreeMap;
|
||||
use std::fmt;
|
||||
|
||||
/// Provides non-argument inputs to the program.
|
||||
|
@ -22,7 +21,7 @@ use std::fmt;
|
|||
/// Ok(())
|
||||
/// }
|
||||
/// ```
|
||||
pub struct Context<'a, 'b, 'c, 'info, T> {
|
||||
pub struct Context<'a, 'b, 'c, 'info, T: Bumps> {
|
||||
/// Currently executing program id.
|
||||
pub program_id: &'a Pubkey,
|
||||
/// Deserialized accounts.
|
||||
|
@ -33,10 +32,14 @@ pub struct Context<'a, 'b, 'c, 'info, T> {
|
|||
/// Bump seeds found during constraint validation. This is provided as a
|
||||
/// convenience so that handlers don't have to recalculate bump seeds or
|
||||
/// pass them in as arguments.
|
||||
pub bumps: BTreeMap<String, u8>,
|
||||
/// Type is the bumps struct generated by #[derive(Accounts)]
|
||||
pub bumps: T::Bumps,
|
||||
}
|
||||
|
||||
impl<'a, 'b, 'c, 'info, T: fmt::Debug> fmt::Debug for Context<'a, 'b, 'c, 'info, T> {
|
||||
impl<'a, 'b, 'c, 'info, T> fmt::Debug for Context<'a, 'b, 'c, 'info, T>
|
||||
where
|
||||
T: fmt::Debug + Bumps,
|
||||
{
|
||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||
f.debug_struct("Context")
|
||||
.field("program_id", &self.program_id)
|
||||
|
@ -47,12 +50,15 @@ impl<'a, 'b, 'c, 'info, T: fmt::Debug> fmt::Debug for Context<'a, 'b, 'c, 'info,
|
|||
}
|
||||
}
|
||||
|
||||
impl<'a, 'b, 'c, 'info, T: Accounts<'info>> Context<'a, 'b, 'c, 'info, T> {
|
||||
impl<'a, 'b, 'c, 'info, T> Context<'a, 'b, 'c, 'info, T>
|
||||
where
|
||||
T: Bumps + Accounts<'info, T::Bumps>,
|
||||
{
|
||||
pub fn new(
|
||||
program_id: &'a Pubkey,
|
||||
accounts: &'b mut T,
|
||||
remaining_accounts: &'c [AccountInfo<'info>],
|
||||
bumps: BTreeMap<String, u8>,
|
||||
bumps: T::Bumps,
|
||||
) -> Self {
|
||||
Self {
|
||||
program_id,
|
||||
|
|
|
@ -27,8 +27,7 @@ use bytemuck::{Pod, Zeroable};
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::io::Write;
|
||||
use std::{collections::BTreeSet, fmt::Debug, io::Write};
|
||||
|
||||
mod account_meta;
|
||||
pub mod accounts;
|
||||
|
@ -74,7 +73,30 @@ pub type Result<T> = std::result::Result<T, error::Error>;
|
|||
/// maintain any invariants required for the program to run securely. In most
|
||||
/// cases, it's recommended to use the [`Accounts`](./derive.Accounts.html)
|
||||
/// derive macro to implement this trait.
|
||||
pub trait Accounts<'info>: ToAccountMetas + ToAccountInfos<'info> + Sized {
|
||||
///
|
||||
/// Generics:
|
||||
/// - `B`: the type of the PDA bumps cache struct generated by the `Accounts` struct.
|
||||
/// For example,
|
||||
/// ```rust,ignore
|
||||
/// pub struct Example<'info> {
|
||||
/// #[account(
|
||||
/// init,
|
||||
/// seeds = [...],
|
||||
/// bump,
|
||||
/// )]
|
||||
/// pub pda_1: UncheckedAccount<'info>,
|
||||
/// pub not_pda: UncheckedAccount<'info>,
|
||||
/// }
|
||||
/// ```
|
||||
///
|
||||
/// generates:
|
||||
///
|
||||
/// ```rust,ignore
|
||||
/// pub struct ExampleBumps {
|
||||
/// pub pda_1: u8,
|
||||
/// }
|
||||
/// ```
|
||||
pub trait Accounts<'info, B>: ToAccountMetas + ToAccountInfos<'info> + Sized {
|
||||
/// Returns the validated accounts struct. What constitutes "valid" is
|
||||
/// program dependent. However, users of these types should never have to
|
||||
/// worry about account substitution attacks. For example, if a program
|
||||
|
@ -90,11 +112,17 @@ pub trait Accounts<'info>: ToAccountMetas + ToAccountInfos<'info> + Sized {
|
|||
program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
ix_data: &[u8],
|
||||
bumps: &mut BTreeMap<String, u8>,
|
||||
bumps: &mut B,
|
||||
reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self>;
|
||||
}
|
||||
|
||||
/// Associated bump seeds for `Accounts`.
|
||||
pub trait Bumps {
|
||||
/// Struct to hold account bump seeds.
|
||||
type Bumps: Sized + Debug;
|
||||
}
|
||||
|
||||
/// The exit procedure for an account. Any cleanup or persistence to storage
|
||||
/// should be done here.
|
||||
pub trait AccountsExit<'info>: ToAccountMetas + ToAccountInfos<'info> {
|
||||
|
|
|
@ -2,7 +2,7 @@ use crate::{Accounts, Result, ToAccountInfos, ToAccountMetas};
|
|||
use solana_program::account_info::AccountInfo;
|
||||
use solana_program::instruction::AccountMeta;
|
||||
use solana_program::pubkey::Pubkey;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::BTreeSet;
|
||||
|
||||
impl<'info, T: ToAccountInfos<'info>> ToAccountInfos<'info> for Vec<T> {
|
||||
fn to_account_infos(&self) -> Vec<AccountInfo<'info>> {
|
||||
|
@ -20,12 +20,12 @@ impl<T: ToAccountMetas> ToAccountMetas for Vec<T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<'info, T: Accounts<'info>> Accounts<'info> for Vec<T> {
|
||||
impl<'info, B, T: Accounts<'info, B>> Accounts<'info, B> for Vec<T> {
|
||||
fn try_accounts(
|
||||
program_id: &Pubkey,
|
||||
accounts: &mut &[AccountInfo<'info>],
|
||||
ix_data: &[u8],
|
||||
bumps: &mut BTreeMap<String, u8>,
|
||||
bumps: &mut B,
|
||||
reallocs: &mut BTreeSet<Pubkey>,
|
||||
) -> Result<Self> {
|
||||
let mut vec: Vec<T> = Vec::new();
|
||||
|
@ -79,7 +79,7 @@ mod tests {
|
|||
false,
|
||||
Epoch::default(),
|
||||
);
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = TestBumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts = &[account1, account2][..];
|
||||
let parsed_accounts =
|
||||
|
@ -93,7 +93,7 @@ mod tests {
|
|||
#[should_panic]
|
||||
fn test_accounts_trait_for_vec_empty() {
|
||||
let program_id = Pubkey::default();
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = TestBumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts = &[][..];
|
||||
Vec::<Test>::try_accounts(&program_id, &mut accounts, &[], &mut bumps, &mut reallocs)
|
||||
|
|
|
@ -0,0 +1,89 @@
|
|||
use crate::{
|
||||
codegen::accounts::{generics, ParsedGenerics},
|
||||
*,
|
||||
};
|
||||
use std::fmt::Display;
|
||||
|
||||
use super::constraints;
|
||||
|
||||
pub fn generate_bumps_name<T: Display>(anchor_ident: &T) -> Ident {
|
||||
Ident::new(&format!("{}Bumps", anchor_ident), Span::call_site())
|
||||
}
|
||||
|
||||
pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
||||
let name = &accs.ident;
|
||||
let bumps_name = generate_bumps_name(name);
|
||||
let ParsedGenerics {
|
||||
combined_generics,
|
||||
trait_generics: _,
|
||||
struct_generics,
|
||||
where_clause,
|
||||
} = generics(accs);
|
||||
|
||||
let (bump_fields, bump_default_fields): (
|
||||
Vec<proc_macro2::TokenStream>,
|
||||
Vec<proc_macro2::TokenStream>,
|
||||
) = accs
|
||||
.fields
|
||||
.iter()
|
||||
.filter_map(|af| {
|
||||
let ident = af.ident();
|
||||
|
||||
match af {
|
||||
AccountField::Field(f) => {
|
||||
let constraints = constraints::linearize(&f.constraints);
|
||||
let bump_field = quote!(pub #ident: u8);
|
||||
let bump_default_field = quote!(#ident: u8::MAX);
|
||||
|
||||
for c in constraints.iter() {
|
||||
// Verify this in super::constraints
|
||||
// The bump is only cached if
|
||||
// - PDA is marked as init
|
||||
// - PDA is not init, but marked with bump without a target
|
||||
|
||||
match c {
|
||||
Constraint::Seeds(c) => {
|
||||
if !c.is_init && c.bump.is_none() {
|
||||
return Some((bump_field, bump_default_field));
|
||||
}
|
||||
}
|
||||
Constraint::Init(c) => {
|
||||
if c.seeds.is_some() {
|
||||
return Some((bump_field, bump_default_field));
|
||||
}
|
||||
}
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
None
|
||||
}
|
||||
AccountField::CompositeField(s) => {
|
||||
let comp_bumps_struct = generate_bumps_name(&s.symbol);
|
||||
let bumps = quote!(pub #ident: #comp_bumps_struct);
|
||||
let bumps_default = quote!(#ident: #comp_bumps_struct::default());
|
||||
|
||||
Some((bumps, bumps_default))
|
||||
}
|
||||
}
|
||||
})
|
||||
.unzip();
|
||||
|
||||
quote! {
|
||||
#[derive(Debug)]
|
||||
pub struct #bumps_name {
|
||||
#(#bump_fields),*
|
||||
}
|
||||
|
||||
impl Default for #bumps_name {
|
||||
fn default() -> Self {
|
||||
#bumps_name {
|
||||
#(#bump_default_fields),*
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<#combined_generics> anchor_lang::Bumps for #name<#struct_generics> #where_clause {
|
||||
type Bumps = #bumps_name;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -482,7 +482,7 @@ fn generate_constraint_init_group(
|
|||
&[#maybe_seeds_plus_comma],
|
||||
__program_id,
|
||||
);
|
||||
__bumps.insert(#name_str.to_string(), __bump);
|
||||
__bumps.#field = __bump;
|
||||
#validate_pda
|
||||
},
|
||||
quote! {
|
||||
|
@ -882,7 +882,7 @@ fn generate_constraint_seeds(f: &Field, c: &ConstraintSeedsGroup) -> proc_macro2
|
|||
&[#maybe_seeds_plus_comma],
|
||||
&#deriving_program_id,
|
||||
);
|
||||
__bumps.insert(#name_str.to_string(), __bump);
|
||||
__bumps.#name = __bump;
|
||||
},
|
||||
// Bump target given. Use it.
|
||||
Some(b) => quote! {
|
||||
|
|
|
@ -7,6 +7,7 @@ use syn::{GenericParam, PredicateLifetime, WhereClause, WherePredicate};
|
|||
|
||||
mod __client_accounts;
|
||||
mod __cpi_client_accounts;
|
||||
mod bumps;
|
||||
mod constraints;
|
||||
mod exit;
|
||||
mod to_account_infos;
|
||||
|
@ -18,6 +19,7 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
|||
let impl_to_account_infos = to_account_infos::generate(accs);
|
||||
let impl_to_account_metas = to_account_metas::generate(accs);
|
||||
let impl_exit = exit::generate(accs);
|
||||
let bumps_struct = bumps::generate(accs);
|
||||
|
||||
let __client_accounts_mod = __client_accounts::generate(accs);
|
||||
let __cpi_client_accounts_mod = __cpi_client_accounts::generate(accs);
|
||||
|
@ -27,6 +29,7 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
|||
#impl_to_account_infos
|
||||
#impl_to_account_metas
|
||||
#impl_exit
|
||||
#bumps_struct
|
||||
|
||||
#__client_accounts_mod
|
||||
#__cpi_client_accounts_mod
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
use crate::codegen::accounts::{constraints, generics, ParsedGenerics};
|
||||
use crate::codegen::accounts::{bumps, constraints, generics, ParsedGenerics};
|
||||
use crate::{AccountField, AccountsStruct};
|
||||
use quote::quote;
|
||||
use syn::Expr;
|
||||
|
@ -25,7 +25,7 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
|||
quote! {
|
||||
#[cfg(feature = "anchor-debug")]
|
||||
::solana_program::log::sol_log(stringify!(#name));
|
||||
let #name: #ty = anchor_lang::Accounts::try_accounts(__program_id, __accounts, __ix_data, __bumps, __reallocs)?;
|
||||
let #name: #ty = anchor_lang::Accounts::try_accounts(__program_id, __accounts, __ix_data, &mut __bumps.#name, __reallocs)?;
|
||||
}
|
||||
}
|
||||
AccountField::Field(f) => {
|
||||
|
@ -82,6 +82,7 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
|||
|
||||
let constraints = generate_constraints(accs);
|
||||
let accounts_instance = generate_accounts_instance(accs);
|
||||
let bumps_struct_name = bumps::generate_bumps_name(&accs.ident);
|
||||
|
||||
let ix_de = match &accs.instruction_api {
|
||||
None => quote! {},
|
||||
|
@ -115,13 +116,13 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
|
|||
|
||||
quote! {
|
||||
#[automatically_derived]
|
||||
impl<#combined_generics> anchor_lang::Accounts<#trait_generics> for #name<#struct_generics> #where_clause {
|
||||
impl<#combined_generics> anchor_lang::Accounts<#trait_generics, #bumps_struct_name> for #name<#struct_generics> #where_clause {
|
||||
#[inline(never)]
|
||||
fn try_accounts(
|
||||
__program_id: &anchor_lang::solana_program::pubkey::Pubkey,
|
||||
__accounts: &mut &[anchor_lang::solana_program::account_info::AccountInfo<'info>],
|
||||
__ix_data: &[u8],
|
||||
__bumps: &mut std::collections::BTreeMap<String, u8>,
|
||||
__bumps: &mut #bumps_struct_name,
|
||||
__reallocs: &mut std::collections::BTreeSet<anchor_lang::solana_program::pubkey::Pubkey>,
|
||||
) -> anchor_lang::Result<Self> {
|
||||
// Deserialize instruction, if declared.
|
||||
|
|
|
@ -29,7 +29,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
|
||||
match ix {
|
||||
anchor_lang::idl::IdlInstruction::Create { data_len } => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlCreateAccounts as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlCreateAccounts::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -37,7 +37,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::Resize { data_len } => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlResizeAccount as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlResizeAccount::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -45,7 +45,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::Close => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlCloseAccount as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlCloseAccount::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -53,7 +53,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::CreateBuffer => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlCreateBuffer as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlCreateBuffer::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -61,7 +61,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::Write { data } => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlAccounts as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlAccounts::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -69,7 +69,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::SetAuthority { new_authority } => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlAccounts as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlAccounts::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -77,7 +77,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
accounts.exit(program_id)?;
|
||||
},
|
||||
anchor_lang::idl::IdlInstruction::SetBuffer => {
|
||||
let mut bumps = std::collections::BTreeMap::new();
|
||||
let mut bumps = <IdlSetBuffer as anchor_lang::Bumps>::Bumps::default();
|
||||
let mut reallocs = std::collections::BTreeSet::new();
|
||||
let mut accounts =
|
||||
IdlSetBuffer::try_accounts(program_id, &mut accounts, &[], &mut bumps, &mut reallocs)?;
|
||||
|
@ -126,7 +126,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
|
|||
let instruction::#variant_arm = ix;
|
||||
|
||||
// Bump collector.
|
||||
let mut __bumps = std::collections::BTreeMap::new();
|
||||
let mut __bumps = <#anchor as anchor_lang::Bumps>::Bumps::default();
|
||||
|
||||
let mut __reallocs = std::collections::BTreeSet::new();
|
||||
|
||||
|
|
|
@ -51,9 +51,9 @@ pub mod auction_house {
|
|||
let associated_token_program = &ctx.accounts.associated_token_program;
|
||||
let rent = &ctx.accounts.rent;
|
||||
|
||||
auction_house.treasury_bump = *ctx.bumps.get("auction_house_treasury").unwrap();
|
||||
auction_house.bump = *ctx.bumps.get("auction_house").unwrap();
|
||||
auction_house.fee_payer_bump = *ctx.bumps.get("auction_house_fee_account").unwrap();
|
||||
auction_house.treasury_bump = ctx.bumps.auction_house_treasury;
|
||||
auction_house.bump = ctx.bumps.auction_house;
|
||||
auction_house.fee_payer_bump = ctx.bumps.auction_house_fee_account;
|
||||
|
||||
if seller_fee_basis_points > 10000 {
|
||||
return err!(ErrorCode::InvalidBasisPoints);
|
||||
|
@ -147,7 +147,7 @@ pub mod auction_house {
|
|||
];
|
||||
let wallet_key = wallet.key();
|
||||
|
||||
let escrow_payment_bump = *ctx.bumps.get("escrow_payment_account").unwrap();
|
||||
let escrow_payment_bump = ctx.bumps.escrow_payment_account;
|
||||
let escrow_signer_seeds = [
|
||||
PREFIX.as_bytes(),
|
||||
auction_house_key.as_ref(),
|
||||
|
@ -254,7 +254,7 @@ pub mod auction_house {
|
|||
return err!(ErrorCode::NoValidSignerPresent);
|
||||
}
|
||||
|
||||
let escrow_payment_bump = *ctx.bumps.get("escrow_payment_account").unwrap();
|
||||
let escrow_payment_bump = ctx.bumps.escrow_payment_account;
|
||||
|
||||
let escrow_signer_seeds = [
|
||||
PREFIX.as_bytes(),
|
||||
|
@ -419,7 +419,7 @@ pub mod auction_house {
|
|||
)?;
|
||||
}
|
||||
|
||||
let trade_state_bump = *ctx.bumps.get("seller_trade_state").unwrap();
|
||||
let trade_state_bump = ctx.bumps.seller_trade_state;
|
||||
|
||||
let ts_info = seller_trade_state.to_account_info();
|
||||
if ts_info.data_is_empty() {
|
||||
|
@ -536,8 +536,8 @@ pub mod auction_house {
|
|||
let system_program = &ctx.accounts.system_program;
|
||||
let rent = &ctx.accounts.rent;
|
||||
|
||||
let trade_state_bump = *ctx.bumps.get("buyer_trade_state").unwrap();
|
||||
let escrow_payment_bump = *ctx.bumps.get("escrow_payment_account").unwrap();
|
||||
let trade_state_bump = ctx.bumps.buyer_trade_state;
|
||||
let escrow_payment_bump = ctx.bumps.escrow_payment_account;
|
||||
|
||||
let auction_house_key = auction_house.key();
|
||||
let seeds = [
|
||||
|
@ -671,7 +671,7 @@ pub mod auction_house {
|
|||
let token_account = &ctx.accounts.token_account;
|
||||
let token_mint = &ctx.accounts.token_mint;
|
||||
let metadata = &ctx.accounts.metadata;
|
||||
let treasury_mint = &ctx.accounts.treasury_mint;
|
||||
let treasury_mint = &ctx.accounts.treasury_mint.to_account_info();
|
||||
let seller_payment_receipt_account = &ctx.accounts.seller_payment_receipt_account;
|
||||
let buyer_receipt_token_account = &ctx.accounts.buyer_receipt_token_account;
|
||||
let escrow_payment_account = &ctx.accounts.escrow_payment_account;
|
||||
|
@ -691,8 +691,8 @@ pub mod auction_house {
|
|||
let ata_clone = associated_token_program.to_account_info();
|
||||
let token_clone = token_program.to_account_info();
|
||||
|
||||
let escrow_payment_bump = *ctx.bumps.get("escrow_payment_account").unwrap();
|
||||
let program_as_signer_bump = *ctx.bumps.get("program_as_signer").unwrap();
|
||||
let escrow_payment_bump = ctx.bumps.escrow_payment_account;
|
||||
let program_as_signer_bump = ctx.bumps.program_as_signer;
|
||||
|
||||
let is_native = treasury_mint.key() == spl_token::native_mint::id();
|
||||
|
||||
|
@ -1450,7 +1450,8 @@ pub struct ExecuteSale<'info> {
|
|||
token_mint: UncheckedAccount<'info>,
|
||||
metadata: UncheckedAccount<'info>,
|
||||
// cannot mark these as real Accounts or else we blow stack size limit
|
||||
treasury_mint: UncheckedAccount<'info>,
|
||||
//TODO revert this change in a near future
|
||||
treasury_mint: Box<Account<'info, Mint>>,
|
||||
#[account(mut)]
|
||||
seller_payment_receipt_account: UncheckedAccount<'info>,
|
||||
#[account(mut)]
|
||||
|
@ -1461,7 +1462,7 @@ pub struct ExecuteSale<'info> {
|
|||
seeds=[
|
||||
PREFIX.as_bytes(),
|
||||
authority.key.as_ref(),
|
||||
treasury_mint.key.as_ref(),
|
||||
treasury_mint.key().as_ref(),
|
||||
],
|
||||
bump=auction_house.bump,
|
||||
has_one=authority,
|
||||
|
|
|
@ -375,185 +375,185 @@
|
|||
"solanaVersion": "1.17.0",
|
||||
"result": {
|
||||
"binarySize": {
|
||||
"bench": 1075688
|
||||
"bench": 1049608
|
||||
},
|
||||
"computeUnits": {
|
||||
"accountInfo1": 680,
|
||||
"accountInfo2": 1083,
|
||||
"accountInfo4": 1535,
|
||||
"accountInfo8": 2774,
|
||||
"accountInfo1": 584,
|
||||
"accountInfo2": 824,
|
||||
"accountInfo4": 1319,
|
||||
"accountInfo8": 2531,
|
||||
"accountEmptyInit1": 5521,
|
||||
"accountEmpty1": 815,
|
||||
"accountEmpty1": 777,
|
||||
"accountEmptyInit2": 10111,
|
||||
"accountEmpty2": 1366,
|
||||
"accountEmpty2": 1207,
|
||||
"accountEmptyInit4": 19044,
|
||||
"accountEmpty4": 2120,
|
||||
"accountEmpty4": 2074,
|
||||
"accountEmptyInit8": 37265,
|
||||
"accountEmpty8": 3967,
|
||||
"accountSizedInit1": 5626,
|
||||
"accountSized1": 820,
|
||||
"accountSized1": 786,
|
||||
"accountSizedInit2": 10322,
|
||||
"accountSized2": 1411,
|
||||
"accountSized2": 1234,
|
||||
"accountSizedInit4": 19462,
|
||||
"accountSized4": 2181,
|
||||
"accountSized4": 2135,
|
||||
"accountSizedInit8": 38122,
|
||||
"accountSized8": 4104,
|
||||
"accountUnsizedInit1": 5742,
|
||||
"accountUnsized1": 859,
|
||||
"accountUnsized1": 821,
|
||||
"accountUnsizedInit2": 10551,
|
||||
"accountUnsized2": 1364,
|
||||
"accountUnsized2": 1312,
|
||||
"accountUnsizedInit4": 19927,
|
||||
"accountUnsized4": 2341,
|
||||
"accountUnsized4": 2315,
|
||||
"accountUnsizedInit8": 38699,
|
||||
"accountUnsized8": 4456,
|
||||
"boxedAccountEmptyInit1": 5624,
|
||||
"boxedAccountEmpty1": 888,
|
||||
"boxedAccountEmptyInit2": 10221,
|
||||
"boxedAccountEmpty2": 1401,
|
||||
"boxedAccountEmptyInit1": 5452,
|
||||
"boxedAccountEmpty1": 866,
|
||||
"boxedAccountEmptyInit2": 10051,
|
||||
"boxedAccountEmpty2": 1377,
|
||||
"boxedAccountEmptyInit4": 19030,
|
||||
"boxedAccountEmpty4": 2424,
|
||||
"boxedAccountEmpty4": 2396,
|
||||
"boxedAccountEmptyInit8": 37136,
|
||||
"boxedAccountEmpty8": 4527,
|
||||
"boxedAccountSizedInit1": 5718,
|
||||
"boxedAccountSized1": 917,
|
||||
"boxedAccountSizedInit2": 10412,
|
||||
"boxedAccountSized2": 1463,
|
||||
"boxedAccountEmpty8": 4472,
|
||||
"boxedAccountSizedInit1": 5546,
|
||||
"boxedAccountSized1": 895,
|
||||
"boxedAccountSizedInit2": 10242,
|
||||
"boxedAccountSized2": 1439,
|
||||
"boxedAccountSizedInit4": 19414,
|
||||
"boxedAccountSized4": 2543,
|
||||
"boxedAccountSized4": 2515,
|
||||
"boxedAccountSizedInit8": 37919,
|
||||
"boxedAccountSized8": 4766,
|
||||
"boxedAccountSized8": 4711,
|
||||
"boxedAccountUnsizedInit1": 5823,
|
||||
"boxedAccountUnsized1": 972,
|
||||
"boxedAccountUnsized1": 950,
|
||||
"boxedAccountUnsizedInit2": 10621,
|
||||
"boxedAccountUnsized2": 1570,
|
||||
"boxedAccountUnsized2": 1549,
|
||||
"boxedAccountUnsizedInit4": 19825,
|
||||
"boxedAccountUnsized4": 2768,
|
||||
"boxedAccountUnsized4": 2737,
|
||||
"boxedAccountUnsizedInit8": 38791,
|
||||
"boxedAccountUnsized8": 5207,
|
||||
"boxedInterfaceAccountMint1": 2159,
|
||||
"boxedInterfaceAccountMint1": 2137,
|
||||
"boxedInterfaceAccountMint2": 3849,
|
||||
"boxedInterfaceAccountMint4": 7215,
|
||||
"boxedInterfaceAccountMint8": 14044,
|
||||
"boxedInterfaceAccountToken1": 2088,
|
||||
"boxedInterfaceAccountToken1": 2066,
|
||||
"boxedInterfaceAccountToken2": 3706,
|
||||
"boxedInterfaceAccountToken4": 6932,
|
||||
"boxedInterfaceAccountToken8": 13477,
|
||||
"interfaceAccountMint1": 2574,
|
||||
"interfaceAccountMint2": 4410,
|
||||
"interfaceAccountMint4": 8313,
|
||||
"interfaceAccountMint1": 2313,
|
||||
"interfaceAccountMint2": 4270,
|
||||
"interfaceAccountMint4": 8185,
|
||||
"interfaceAccountMint8": 16007,
|
||||
"interfaceAccountToken1": 2137,
|
||||
"interfaceAccountToken2": 4032,
|
||||
"interfaceAccountToken1": 2059,
|
||||
"interfaceAccountToken2": 3958,
|
||||
"interfaceAccountToken4": 7816,
|
||||
"interface1": 726,
|
||||
"interface2": 1093,
|
||||
"interface4": 1484,
|
||||
"interface1": 691,
|
||||
"interface2": 940,
|
||||
"interface4": 1450,
|
||||
"interface8": 2605,
|
||||
"program1": 720,
|
||||
"program2": 1081,
|
||||
"program4": 1462,
|
||||
"program1": 685,
|
||||
"program2": 928,
|
||||
"program4": 1428,
|
||||
"program8": 2557,
|
||||
"signer1": 683,
|
||||
"signer2": 1092,
|
||||
"signer4": 1555,
|
||||
"signer8": 2813,
|
||||
"systemAccount1": 737,
|
||||
"systemAccount2": 1198,
|
||||
"systemAccount4": 1766,
|
||||
"systemAccount8": 3238,
|
||||
"uncheckedAccount1": 679,
|
||||
"uncheckedAccount2": 1083,
|
||||
"uncheckedAccount4": 1536,
|
||||
"uncheckedAccount8": 2774
|
||||
"signer1": 621,
|
||||
"signer2": 895,
|
||||
"signer4": 1455,
|
||||
"signer8": 2721,
|
||||
"systemAccount1": 675,
|
||||
"systemAccount2": 1001,
|
||||
"systemAccount4": 1666,
|
||||
"systemAccount8": 3146,
|
||||
"uncheckedAccount1": 583,
|
||||
"uncheckedAccount2": 824,
|
||||
"uncheckedAccount4": 1320,
|
||||
"uncheckedAccount8": 2531
|
||||
},
|
||||
"stackMemory": {
|
||||
"account_info1": 272,
|
||||
"account_info2": 320,
|
||||
"account_info4": 416,
|
||||
"account_info8": 608,
|
||||
"account_empty_init1": 400,
|
||||
"account_empty_init2": 480,
|
||||
"account_empty_init4": 528,
|
||||
"account_empty_init8": 720,
|
||||
"account_empty1": 272,
|
||||
"account_empty2": 320,
|
||||
"account_empty4": 416,
|
||||
"account_empty8": 608,
|
||||
"account_sized_init1": 408,
|
||||
"account_sized_init2": 496,
|
||||
"account_sized_init4": 560,
|
||||
"account_sized_init8": 784,
|
||||
"account_sized1": 280,
|
||||
"account_sized2": 336,
|
||||
"account_sized4": 448,
|
||||
"account_sized8": 672,
|
||||
"account_unsized_init1": 424,
|
||||
"account_unsized_init2": 528,
|
||||
"account_unsized_init4": 624,
|
||||
"account_unsized_init8": 912,
|
||||
"account_unsized1": 296,
|
||||
"account_unsized2": 368,
|
||||
"account_unsized4": 512,
|
||||
"account_unsized8": 800,
|
||||
"boxed_account_empty_init1": 360,
|
||||
"boxed_account_empty_init2": 400,
|
||||
"boxed_account_empty_init4": 368,
|
||||
"boxed_account_empty_init8": 400,
|
||||
"boxed_account_empty1": 232,
|
||||
"boxed_account_empty2": 240,
|
||||
"boxed_account_empty4": 256,
|
||||
"boxed_account_empty8": 288,
|
||||
"boxed_account_sized_init1": 360,
|
||||
"boxed_account_sized_init2": 400,
|
||||
"boxed_account_sized_init4": 368,
|
||||
"boxed_account_sized_init8": 400,
|
||||
"boxed_account_sized1": 232,
|
||||
"boxed_account_sized2": 240,
|
||||
"boxed_account_sized4": 256,
|
||||
"boxed_account_sized8": 288,
|
||||
"boxed_account_unsized_init1": 360,
|
||||
"boxed_account_unsized_init2": 400,
|
||||
"boxed_account_unsized_init4": 368,
|
||||
"boxed_account_unsized_init8": 400,
|
||||
"boxed_account_unsized1": 232,
|
||||
"boxed_account_unsized2": 240,
|
||||
"boxed_account_unsized4": 256,
|
||||
"boxed_account_unsized8": 288,
|
||||
"boxed_interface_account_mint1": 232,
|
||||
"boxed_interface_account_mint2": 240,
|
||||
"boxed_interface_account_mint4": 256,
|
||||
"boxed_interface_account_mint8": 288,
|
||||
"boxed_interface_account_token1": 232,
|
||||
"boxed_interface_account_token2": 240,
|
||||
"boxed_interface_account_token4": 256,
|
||||
"boxed_interface_account_token8": 288,
|
||||
"interface_account_mint1": 392,
|
||||
"interface_account_mint2": 560,
|
||||
"interface_account_mint4": 896,
|
||||
"interface_account_mint8": 1568,
|
||||
"interface_account_token1": 480,
|
||||
"interface_account_token2": 736,
|
||||
"interface_account_token4": 1248,
|
||||
"interface1": 272,
|
||||
"interface2": 320,
|
||||
"interface4": 416,
|
||||
"interface8": 608,
|
||||
"program1": 272,
|
||||
"program2": 320,
|
||||
"program4": 416,
|
||||
"program8": 608,
|
||||
"signer1": 272,
|
||||
"signer2": 320,
|
||||
"signer4": 416,
|
||||
"signer8": 608,
|
||||
"system_account1": 272,
|
||||
"system_account2": 320,
|
||||
"system_account4": 416,
|
||||
"system_account8": 608,
|
||||
"unchecked_account1": 272,
|
||||
"unchecked_account2": 320,
|
||||
"unchecked_account4": 416,
|
||||
"unchecked_account8": 608
|
||||
"account_info1": 128,
|
||||
"account_info2": 128,
|
||||
"account_info4": 128,
|
||||
"account_info8": 128,
|
||||
"account_empty_init1": 320,
|
||||
"account_empty_init2": 400,
|
||||
"account_empty_init4": 448,
|
||||
"account_empty_init8": 640,
|
||||
"account_empty1": 128,
|
||||
"account_empty2": 128,
|
||||
"account_empty4": 128,
|
||||
"account_empty8": 128,
|
||||
"account_sized_init1": 328,
|
||||
"account_sized_init2": 416,
|
||||
"account_sized_init4": 480,
|
||||
"account_sized_init8": 704,
|
||||
"account_sized1": 128,
|
||||
"account_sized2": 128,
|
||||
"account_sized4": 128,
|
||||
"account_sized8": 128,
|
||||
"account_unsized_init1": 344,
|
||||
"account_unsized_init2": 448,
|
||||
"account_unsized_init4": 544,
|
||||
"account_unsized_init8": 832,
|
||||
"account_unsized1": 128,
|
||||
"account_unsized2": 128,
|
||||
"account_unsized4": 128,
|
||||
"account_unsized8": 128,
|
||||
"boxed_account_empty_init1": 176,
|
||||
"boxed_account_empty_init2": 208,
|
||||
"boxed_account_empty_init4": 288,
|
||||
"boxed_account_empty_init8": 320,
|
||||
"boxed_account_empty1": 128,
|
||||
"boxed_account_empty2": 144,
|
||||
"boxed_account_empty4": 144,
|
||||
"boxed_account_empty8": 128,
|
||||
"boxed_account_sized_init1": 176,
|
||||
"boxed_account_sized_init2": 208,
|
||||
"boxed_account_sized_init4": 288,
|
||||
"boxed_account_sized_init8": 320,
|
||||
"boxed_account_sized1": 128,
|
||||
"boxed_account_sized2": 144,
|
||||
"boxed_account_sized4": 144,
|
||||
"boxed_account_sized8": 128,
|
||||
"boxed_account_unsized_init1": 280,
|
||||
"boxed_account_unsized_init2": 320,
|
||||
"boxed_account_unsized_init4": 288,
|
||||
"boxed_account_unsized_init8": 320,
|
||||
"boxed_account_unsized1": 152,
|
||||
"boxed_account_unsized2": 144,
|
||||
"boxed_account_unsized4": 176,
|
||||
"boxed_account_unsized8": 192,
|
||||
"boxed_interface_account_mint1": 128,
|
||||
"boxed_interface_account_mint2": 144,
|
||||
"boxed_interface_account_mint4": 144,
|
||||
"boxed_interface_account_mint8": 128,
|
||||
"boxed_interface_account_token1": 128,
|
||||
"boxed_interface_account_token2": 144,
|
||||
"boxed_interface_account_token4": 144,
|
||||
"boxed_interface_account_token8": 128,
|
||||
"interface_account_mint1": 128,
|
||||
"interface_account_mint2": 128,
|
||||
"interface_account_mint4": 128,
|
||||
"interface_account_mint8": 128,
|
||||
"interface_account_token1": 128,
|
||||
"interface_account_token2": 128,
|
||||
"interface_account_token4": 128,
|
||||
"interface1": 128,
|
||||
"interface2": 128,
|
||||
"interface4": 128,
|
||||
"interface8": 128,
|
||||
"program1": 128,
|
||||
"program2": 128,
|
||||
"program4": 128,
|
||||
"program8": 128,
|
||||
"signer1": 128,
|
||||
"signer2": 128,
|
||||
"signer4": 128,
|
||||
"signer8": 128,
|
||||
"system_account1": 128,
|
||||
"system_account2": 128,
|
||||
"system_account4": 128,
|
||||
"system_account8": 128,
|
||||
"unchecked_account1": 128,
|
||||
"unchecked_account2": 128,
|
||||
"unchecked_account4": 128,
|
||||
"unchecked_account8": 128
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -11,7 +11,7 @@ pub mod chat {
|
|||
pub fn create_user(ctx: Context<CreateUser>, name: String) -> Result<()> {
|
||||
ctx.accounts.user.name = name;
|
||||
ctx.accounts.user.authority = *ctx.accounts.authority.key;
|
||||
ctx.accounts.user.bump = *ctx.bumps.get("user").unwrap();
|
||||
ctx.accounts.user.bump = ctx.bumps.user;
|
||||
Ok(())
|
||||
}
|
||||
pub fn create_chat_room(ctx: Context<CreateChatRoom>, name: String) -> Result<()> {
|
||||
|
|
|
@ -8,7 +8,7 @@ pub mod relations_derivation {
|
|||
|
||||
pub fn init_base(ctx: Context<InitBase>) -> Result<()> {
|
||||
ctx.accounts.account.my_account = ctx.accounts.my_account.key();
|
||||
ctx.accounts.account.bump = ctx.bumps["account"];
|
||||
ctx.accounts.account.bump = ctx.bumps.account;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
|
@ -33,10 +33,10 @@ pub mod ido_pool {
|
|||
|
||||
ido_account.ido_name = name_data;
|
||||
ido_account.bumps = PoolBumps {
|
||||
ido_account: *ctx.bumps.get("ido_account").unwrap(),
|
||||
redeemable_mint: *ctx.bumps.get("redeemable_mint").unwrap(),
|
||||
pool_watermelon: *ctx.bumps.get("pool_watermelon").unwrap(),
|
||||
pool_usdc: *ctx.bumps.get("pool_usdc").unwrap(),
|
||||
ido_account: ctx.bumps.ido_account,
|
||||
redeemable_mint: ctx.bumps.redeemable_mint,
|
||||
pool_watermelon: ctx.bumps.pool_watermelon,
|
||||
pool_usdc: ctx.bumps.pool_usdc,
|
||||
};
|
||||
ido_account.ido_authority = ctx.accounts.ido_authority.key();
|
||||
|
||||
|
|
|
@ -112,7 +112,7 @@ pub mod misc_optional {
|
|||
pub fn test_pda_init_zero_copy(ctx: Context<TestPdaInitZeroCopy>) -> Result<()> {
|
||||
let mut acc = ctx.accounts.my_pda.as_ref().unwrap().load_init()?;
|
||||
acc.data = 9;
|
||||
acc.bump = *ctx.bumps.get("my_pda").unwrap();
|
||||
acc.bump = ctx.bumps.my_pda;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
|
@ -106,7 +106,7 @@ pub mod misc {
|
|||
pub fn test_pda_init_zero_copy(ctx: Context<TestPdaInitZeroCopy>) -> Result<()> {
|
||||
let mut acc = ctx.accounts.my_pda.load_init()?;
|
||||
acc.data = 9;
|
||||
acc.bump = *ctx.bumps.get("my_pda").unwrap();
|
||||
acc.bump = ctx.bumps.my_pda;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@ pub mod realloc {
|
|||
|
||||
pub fn initialize(ctx: Context<Initialize>) -> Result<()> {
|
||||
ctx.accounts.sample.data = vec![0];
|
||||
ctx.accounts.sample.bump = *ctx.bumps.get("sample").unwrap();
|
||||
ctx.accounts.sample.bump = ctx.bumps.sample;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
|
@ -11,7 +11,7 @@ pub mod relations_derivation {
|
|||
|
||||
pub fn init_base(ctx: Context<InitBase>) -> Result<()> {
|
||||
ctx.accounts.account.my_account = ctx.accounts.my_account.key();
|
||||
ctx.accounts.account.bump = ctx.bumps["account"];
|
||||
ctx.accounts.account.bump = ctx.bumps.account;
|
||||
Ok(())
|
||||
}
|
||||
pub fn test_relation(_ctx: Context<TestRelation>) -> Result<()> {
|
||||
|
@ -32,7 +32,7 @@ pub struct InitBase<'info> {
|
|||
bump,
|
||||
)]
|
||||
account: Account<'info, MyAccount>,
|
||||
system_program: Program<'info, System>
|
||||
system_program: Program<'info, System>,
|
||||
}
|
||||
|
||||
#[derive(Accounts)]
|
||||
|
@ -60,9 +60,8 @@ pub struct TestRelation<'info> {
|
|||
nested: Nested<'info>,
|
||||
}
|
||||
|
||||
|
||||
#[account]
|
||||
pub struct MyAccount {
|
||||
pub my_account: Pubkey,
|
||||
pub bump: u8
|
||||
pub bump: u8,
|
||||
}
|
||||
|
|
|
@ -11,9 +11,7 @@
|
|||
//! 2. Users can call the unwrap function to burn Y and withdraw X unwrapped tokens
|
||||
|
||||
use anchor_lang::prelude::*;
|
||||
use anchor_spl::token_interface::{
|
||||
self, Mint, TokenAccount, TokenInterface,
|
||||
};
|
||||
use anchor_spl::token_interface::{self, Mint, TokenAccount, TokenInterface};
|
||||
|
||||
declare_id!("4ZPcGU8MX8oL2u1EtErHzixAbgNBNeE9yoYq3kKMqnAy");
|
||||
|
||||
|
@ -24,16 +22,16 @@ pub mod token_wrapper {
|
|||
pub const WRAPPER_AUTH_SEED: &[u8] = b"wrapr";
|
||||
pub const WRAPPER_VAULT_SEED: &[u8] = b"vault";
|
||||
|
||||
pub fn initialize(
|
||||
ctx: Context<Initialize>,
|
||||
initializer_amount: u64,
|
||||
) -> Result<()> {
|
||||
pub fn initialize(ctx: Context<Initialize>, initializer_amount: u64) -> Result<()> {
|
||||
// deposit into vault
|
||||
token_interface::transfer_checked(
|
||||
CpiContext::new(
|
||||
ctx.accounts.deposit_token_program.to_account_info(),
|
||||
token_interface::TransferChecked {
|
||||
from: ctx.accounts.initializer_deposit_token_account.to_account_info(),
|
||||
from: ctx
|
||||
.accounts
|
||||
.initializer_deposit_token_account
|
||||
.to_account_info(),
|
||||
mint: ctx.accounts.deposit_mint.to_account_info(),
|
||||
to: ctx.accounts.deposit_token_vault.to_account_info(),
|
||||
authority: ctx.accounts.initializer.to_account_info(),
|
||||
|
@ -48,7 +46,7 @@ pub mod token_wrapper {
|
|||
WRAPPER_AUTH_SEED,
|
||||
ctx.accounts.deposit_mint.to_account_info().key.as_ref(),
|
||||
ctx.accounts.wrapped_mint.to_account_info().key.as_ref(),
|
||||
&[*ctx.bumps.get("wrapper_authority").unwrap()],
|
||||
&[ctx.bumps.wrapper_authority],
|
||||
];
|
||||
let signer_seeds = &[&inner_seeds[..]];
|
||||
token_interface::mint_to(
|
||||
|
@ -56,7 +54,10 @@ pub mod token_wrapper {
|
|||
ctx.accounts.wrapped_token_program.to_account_info(),
|
||||
token_interface::MintTo {
|
||||
mint: ctx.accounts.wrapped_mint.to_account_info(),
|
||||
to: ctx.accounts.initializer_wrapped_token_account.to_account_info(),
|
||||
to: ctx
|
||||
.accounts
|
||||
.initializer_wrapped_token_account
|
||||
.to_account_info(),
|
||||
authority: ctx.accounts.wrapper_authority.to_account_info(),
|
||||
},
|
||||
signer_seeds,
|
||||
|
@ -88,7 +89,7 @@ pub mod token_wrapper {
|
|||
WRAPPER_AUTH_SEED,
|
||||
ctx.accounts.deposit_mint.to_account_info().key.as_ref(),
|
||||
ctx.accounts.wrapped_mint.to_account_info().key.as_ref(),
|
||||
&[*ctx.bumps.get("wrapper_authority").unwrap()],
|
||||
&[ctx.bumps.wrapper_authority],
|
||||
];
|
||||
let signer_seeds = &[&inner_seeds[..]];
|
||||
token_interface::mint_to(
|
||||
|
@ -126,7 +127,7 @@ pub mod token_wrapper {
|
|||
WRAPPER_AUTH_SEED,
|
||||
ctx.accounts.deposit_mint.to_account_info().key.as_ref(),
|
||||
ctx.accounts.wrapped_mint.to_account_info().key.as_ref(),
|
||||
&[*ctx.bumps.get("wrapper_authority").unwrap()],
|
||||
&[ctx.bumps.wrapper_authority],
|
||||
];
|
||||
let signer_seeds = &[&inner_seeds[..]];
|
||||
token_interface::transfer_checked(
|
||||
|
@ -138,7 +139,7 @@ pub mod token_wrapper {
|
|||
to: ctx.accounts.user_deposit_token_account.to_account_info(),
|
||||
authority: ctx.accounts.wrapper_authority.to_account_info(),
|
||||
},
|
||||
signer_seeds
|
||||
signer_seeds,
|
||||
),
|
||||
unwrap_amount,
|
||||
ctx.accounts.deposit_mint.decimals,
|
||||
|
|
Loading…
Reference in New Issue