This repository has been archived by the owner on Nov 15, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Contracts Add deposit for dependencies (#14079)
* wip * fixes * rm comment * join fns * clippy * Fix limits * reduce diff * fix * fix * fix typo * refactor store to use self * refactor run to take self by value * pass tests * rm comment * fixes * fix typo * rm * fix fmt * clippy * ".git/.scripts/commands/bench/bench.sh" pallet dev pallet_contracts * Update frame/contracts/src/lib.rs Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> * Update frame/contracts/src/wasm/mod.rs Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> * Update frame/contracts/src/wasm/mod.rs Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> * PR review, rm duplicate increment_refcount * PR review * Update frame/contracts/src/wasm/prepare.rs Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> * Add test for failing storage_deposit * fix lint * wip * Delegate update take 2 * update * fix migration * fix migration * doc * fix lint * update migration * fix warning * reformat comment * regenerate weightInfo trait * fix merge * PR review #14079 (comment) * PR review https://github.com/paritytech/substrate/pull/14079/files#r1257521373 * PR review remove optimisation https://github.com/paritytech/substrate/pull/14079/files#r1263312237 * PR review fix return type https://github.com/paritytech/substrate/pull/14079/files#r1263315804 * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * PR review pass CodeInfo and update docstring https://github.com/paritytech/substrate/pull/14079/files#r1257522327 * PR review add code_info to the executable https://github.com/paritytech/substrate/pull/14079/files#r1263309049 * rename info -> contract_info * Update frame/contracts/src/exec.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Update frame/contracts/fixtures/add_remove_delegate_dependency.wat Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Update frame/contracts/src/migration/v13.rs * fix tests * Fmt & fix tests * Test Result<(), _> return type * Update frame/contracts/src/migration.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Revert "Test Result<(), _> return type" This reverts commit a876168. * add / update doc comments * fix backticks * Revert "Revert "Test Result<(), _> return type"" This reverts commit 3cbb616. * fix bench * fix bench * fix * Update frame/contracts/src/storage/meter.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * rm stale comments * Apply suggestions from code review Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> * PR suggestion * Add missing doc * fx lint * ".git/.scripts/commands/bench/bench.sh" --subcommand=pallet --runtime=dev --target_dir=substrate --pallet=pallet_contracts * Update frame/contracts/src/lib.rs Co-authored-by: Juan <juangirini@gmail.com> --------- Co-authored-by: command-bot <> Co-authored-by: Sasha Gryaznov <hi@agryaznov.com> Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Juan <juangirini@gmail.com>
- Loading branch information
1 parent
bb0af12
commit 9780579
Showing
14 changed files
with
3,973 additions
and
2,815 deletions.
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
111 changes: 111 additions & 0 deletions
111
frame/contracts/fixtures/add_remove_delegate_dependency.wat
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,111 @@ | ||
;; This contract tests the behavior of adding / removing delegate_dependencies when delegate calling into a contract. | ||
(module | ||
(import "seal0" "add_delegate_dependency" (func $add_delegate_dependency (param i32))) | ||
(import "seal0" "remove_delegate_dependency" (func $remove_delegate_dependency (param i32))) | ||
(import "seal0" "input" (func $input (param i32 i32))) | ||
(import "seal1" "terminate" (func $terminate (param i32))) | ||
(import "seal0" "delegate_call" (func $delegate_call (param i32 i32 i32 i32 i32 i32) (result i32))) | ||
(import "env" "memory" (memory 1 1)) | ||
|
||
;; [100, 132) Address of Alice | ||
(data (i32.const 100) | ||
"\01\01\01\01\01\01\01\01\01\01\01\01\01\01\01\01" | ||
"\01\01\01\01\01\01\01\01\01\01\01\01\01\01\01\01" | ||
) | ||
|
||
(func $assert (param i32) | ||
(block $ok | ||
(br_if $ok | ||
(get_local 0) | ||
) | ||
(unreachable) | ||
) | ||
) | ||
|
||
;; This function loads input data and performs the action specified. | ||
;; The first 4 bytes of the input specify the action to perform. | ||
;; The next 32 bytes specify the code hash to use when calling add_delegate_dependency or remove_delegate_dependency. | ||
;; Actions are: | ||
;; 1: call add_delegate_dependency | ||
;; 2: call remove_delegate_dependency. | ||
;; 3: call terminate. | ||
;; Any other value is a no-op. | ||
(func $load_input | ||
(local $action i32) | ||
(local $code_hash_ptr i32) | ||
|
||
;; Store available input size at offset 0. | ||
(i32.store (i32.const 0) (i32.const 512)) | ||
|
||
;; Read input data. | ||
(call $input (i32.const 4) (i32.const 0)) | ||
|
||
;; Input data layout. | ||
;; [0..4) - size of the call | ||
;; [4..8) - action to perform | ||
;; [8..42) - code hash of the callee | ||
(set_local $action (i32.load (i32.const 4))) | ||
(set_local $code_hash_ptr (i32.const 8)) | ||
|
||
;; Assert input size == 36 (4 for action + 32 for code_hash). | ||
(call $assert | ||
(i32.eq | ||
(i32.load (i32.const 0)) | ||
(i32.const 36) | ||
) | ||
) | ||
|
||
;; Call add_delegate_dependency when action == 1. | ||
(if (i32.eq (get_local $action) (i32.const 1)) | ||
(then | ||
(call $add_delegate_dependency (get_local $code_hash_ptr)) | ||
) | ||
(else) | ||
) | ||
|
||
;; Call remove_delegate_dependency when action == 2. | ||
(if (i32.eq (get_local $action) (i32.const 2)) | ||
(then | ||
(call $remove_delegate_dependency | ||
(get_local $code_hash_ptr) | ||
) | ||
) | ||
(else) | ||
) | ||
|
||
;; Call terminate when action == 3. | ||
(if (i32.eq (get_local $action) (i32.const 3)) | ||
(then | ||
(call $terminate | ||
(i32.const 100) ;; Pointer to beneficiary address | ||
) | ||
(unreachable) ;; terminate never returns | ||
) | ||
(else) | ||
) | ||
) | ||
|
||
(func (export "deploy") | ||
(call $load_input) | ||
) | ||
|
||
(func (export "call") | ||
(call $load_input) | ||
|
||
;; Delegate call into passed code hash. | ||
(call $assert | ||
(i32.eq | ||
(call $delegate_call | ||
(i32.const 0) ;; Set no call flags. | ||
(i32.const 8) ;; Pointer to "callee" code_hash. | ||
(i32.const 0) ;; Input is ignored. | ||
(i32.const 0) ;; Length of the input. | ||
(i32.const 4294967295) ;; u32 max sentinel value: do not copy output. | ||
(i32.const 0) ;; Length is ignored in this case. | ||
) | ||
(i32.const 0) | ||
) | ||
) | ||
) | ||
|
||
) |
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
Oops, something went wrong.