From cf7fc4975dd6f1dde305d4ba3cd7ed9f53154c8f Mon Sep 17 00:00:00 2001 From: SkymanOne Date: Fri, 18 Aug 2023 15:16:29 +0100 Subject: [PATCH 1/4] persist buffer size in the metadata --- crates/ink/codegen/src/generator/metadata.rs | 2 + crates/metadata/src/specs.rs | 75 ++++++++++++++------ crates/metadata/src/tests.rs | 8 +++ 3 files changed, 62 insertions(+), 23 deletions(-) diff --git a/crates/ink/codegen/src/generator/metadata.rs b/crates/ink/codegen/src/generator/metadata.rs index b73b0f55798..909a503448e 100644 --- a/crates/ink/codegen/src/generator/metadata.rs +++ b/crates/ink/codegen/src/generator/metadata.rs @@ -387,6 +387,7 @@ impl Metadata<'_> { let timestamp = Self::generate_type_spec(×tamp); let block_number = Self::generate_type_spec(&block_number); let chain_extension = Self::generate_type_spec(&chain_extension); + let buffer_size_const = quote!(::ink::env::BUFFER_SIZE); quote_spanned!(span=> ::ink::metadata::EnvironmentSpec::new() .account_id(#account_id) @@ -396,6 +397,7 @@ impl Metadata<'_> { .block_number(#block_number) .chain_extension(#chain_extension) .max_event_topics(MAX_EVENT_TOPICS) + .static_buffer_size(#buffer_size_const) .done() ) } diff --git a/crates/metadata/src/specs.rs b/crates/metadata/src/specs.rs index cc9dd37b822..240983993c9 100644 --- a/crates/metadata/src/specs.rs +++ b/crates/metadata/src/specs.rs @@ -661,6 +661,8 @@ mod state { pub struct ChainExtension; /// Type state for the max number of topics specified in the environment. pub struct MaxEventTopics; + /// Type state for the size of the static buffer specified via env var. + pub struct BufferSize; } impl MessageSpec @@ -1551,6 +1553,7 @@ where block_number: TypeSpec, chain_extension: TypeSpec, max_event_topics: usize, + static_buffer_size: usize, } impl Default for EnvironmentSpec @@ -1567,6 +1570,7 @@ where block_number: Default::default(), chain_extension: Default::default(), max_event_topics: Default::default(), + static_buffer_size: Default::default(), } } } @@ -1583,6 +1587,7 @@ impl IntoPortable for EnvironmentSpec { block_number: self.block_number.into_portable(registry), chain_extension: self.chain_extension.into_portable(registry), max_event_topics: self.max_event_topics, + static_buffer_size: self.static_buffer_size, } } } @@ -1638,6 +1643,7 @@ where Missing, Missing, Missing, + Missing, > { EnvironmentSpecBuilder { spec: Default::default(), @@ -1649,18 +1655,18 @@ where /// An environment specification builder. #[allow(clippy::type_complexity)] #[must_use] -pub struct EnvironmentSpecBuilder +pub struct EnvironmentSpecBuilder where F: Form, TypeSpec: Default, EnvironmentSpec: Default, { spec: EnvironmentSpec, - marker: PhantomData (A, B, H, T, BN, C, M)>, + marker: PhantomData (A, B, H, T, BN, C, M, BS)>, } -impl - EnvironmentSpecBuilder, B, H, T, BN, C, M> +impl + EnvironmentSpecBuilder, B, H, T, BN, C, M, BS> where F: Form, TypeSpec: Default, @@ -1670,7 +1676,7 @@ where pub fn account_id( self, account_id: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { account_id, @@ -1681,8 +1687,8 @@ where } } -impl - EnvironmentSpecBuilder, H, T, BN, C, M> +impl + EnvironmentSpecBuilder, H, T, BN, C, M, BS> where F: Form, TypeSpec: Default, @@ -1692,7 +1698,7 @@ where pub fn balance( self, balance: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { balance, @@ -1703,8 +1709,8 @@ where } } -impl - EnvironmentSpecBuilder, T, BN, C, M> +impl + EnvironmentSpecBuilder, T, BN, C, M, BS> where F: Form, TypeSpec: Default, @@ -1714,7 +1720,7 @@ where pub fn hash( self, hash: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { hash, ..self.spec }, marker: PhantomData, @@ -1722,8 +1728,8 @@ where } } -impl - EnvironmentSpecBuilder, BN, C, M> +impl + EnvironmentSpecBuilder, BN, C, M, BS> where F: Form, TypeSpec: Default, @@ -1733,7 +1739,7 @@ where pub fn timestamp( self, timestamp: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { timestamp, @@ -1744,8 +1750,8 @@ where } } -impl - EnvironmentSpecBuilder, C, M> +impl + EnvironmentSpecBuilder, C, M, BS> where F: Form, TypeSpec: Default, @@ -1755,7 +1761,7 @@ where pub fn block_number( self, block_number: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { block_number, @@ -1766,8 +1772,8 @@ where } } -impl - EnvironmentSpecBuilder, M> +impl + EnvironmentSpecBuilder, M, BS> where F: Form, TypeSpec: Default, @@ -1777,7 +1783,7 @@ where pub fn chain_extension( self, chain_extension: TypeSpec, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { chain_extension, @@ -1788,8 +1794,8 @@ where } } -impl - EnvironmentSpecBuilder> +impl + EnvironmentSpecBuilder, BS> where F: Form, TypeSpec: Default, @@ -1799,7 +1805,7 @@ where pub fn max_event_topics( self, max_event_topics: usize, - ) -> EnvironmentSpecBuilder { + ) -> EnvironmentSpecBuilder { EnvironmentSpecBuilder { spec: EnvironmentSpec { max_event_topics, @@ -1810,6 +1816,28 @@ where } } +impl + EnvironmentSpecBuilder> +where + F: Form, + TypeSpec: Default, + EnvironmentSpec: Default, +{ + /// Sets the `MAX_EVENT_TOPICS` value of the environment. + pub fn static_buffer_size( + self, + static_buffer_size: usize, + ) -> EnvironmentSpecBuilder { + EnvironmentSpecBuilder { + spec: EnvironmentSpec { + static_buffer_size, + ..self.spec + }, + marker: PhantomData, + } + } +} + impl EnvironmentSpecBuilder< F, @@ -1820,6 +1848,7 @@ impl state::BlockNumber, state::ChainExtension, state::MaxEventTopics, + state::BufferSize, > where F: Form, diff --git a/crates/metadata/src/tests.rs b/crates/metadata/src/tests.rs index 894c6c22dae..b9b4ae162ef 100644 --- a/crates/metadata/src/tests.rs +++ b/crates/metadata/src/tests.rs @@ -157,6 +157,7 @@ fn spec_contract_only_one_default_constructor_allowed() { )] fn spec_contract_event_definition_exceeds_environment_topics_limit() { const MAX_EVENT_TOPICS: usize = 2; + const BUFFER_SIZE: usize = 1 << 14; ContractSpec::new() .constructors(vec![ConstructorSpec::from_label("new") @@ -238,6 +239,7 @@ fn spec_contract_event_definition_exceeds_environment_topics_limit() { .block_number(TypeSpec::of_type::()) .chain_extension(TypeSpec::of_type::<()>()) .max_event_topics(MAX_EVENT_TOPICS) + .static_buffer_size(BUFFER_SIZE) .done(), ) .done(); @@ -249,6 +251,7 @@ fn spec_contract_event_definition_exceeds_environment_topics_limit() { )] fn spec_contract_event_definition_signature_topic_collision() { const SIGNATURE_TOPIC: Option<[u8; 32]> = Some([42u8; 32]); + const BUFFER_SIZE: usize = 1 << 14; ContractSpec::new() .constructors(vec![ConstructorSpec::from_label("new") @@ -303,6 +306,7 @@ fn spec_contract_event_definition_signature_topic_collision() { .block_number(TypeSpec::of_type::()) .chain_extension(TypeSpec::of_type::<()>()) .max_event_topics(2) + .static_buffer_size(BUFFER_SIZE) .done(), ) .done(); @@ -320,6 +324,7 @@ fn spec_contract_json() { type BlockNumber = u128; type ChainExtension = NoChainExtension; const MAX_EVENT_TOPICS: usize = 4; + const BUFFER_SIZE: usize = 1 << 14; // given let contract: ContractSpec = ContractSpec::new() @@ -424,6 +429,7 @@ fn spec_contract_json() { ), )) .max_event_topics(MAX_EVENT_TOPICS) + .static_buffer_size(BUFFER_SIZE) .done(), ) .done(); @@ -503,6 +509,7 @@ fn spec_contract_json() { ], "type": 9, }, + "staticBufferSize": 16384, "chainExtension": { "displayName": [ "ChainExtension", @@ -714,6 +721,7 @@ fn environment_spec() -> EnvironmentSpec { .block_number(Default::default()) .chain_extension(Default::default()) .max_event_topics(4) + .static_buffer_size(16384) .done() } From c061e4635debcd1c6898a9b75ce15f59c7d94631 Mon Sep 17 00:00:00 2001 From: SkymanOne Date: Fri, 18 Aug 2023 15:19:24 +0100 Subject: [PATCH 2/4] add chanelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index b167d815f1c..dd8f3ac8bd9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Stabilize `call_runtime` ‒ [#1749](/~https://github.com/paritytech/ink/pull/1749) - Make E2E testcases generic over `E2EBackend` trait - [#1867](/~https://github.com/paritytech/ink/pull/1867) - Modify static buffer size via environmental variables - [#1869](/~https://github.com/paritytech/ink/pull/1869) +- Persist static buffer size in metadata - [#1880](/~https://github.com/paritytech/ink/pull/1880) ### Added - Schema generation - [#1765](/~https://github.com/paritytech/ink/pull/1765) From 9c5aa07b13f78b611fea0e3a3699ab5b80a5d93c Mon Sep 17 00:00:00 2001 From: SkymanOne Date: Fri, 18 Aug 2023 15:23:04 +0100 Subject: [PATCH 3/4] fix comment --- crates/metadata/src/specs.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/metadata/src/specs.rs b/crates/metadata/src/specs.rs index 240983993c9..ea027a4068c 100644 --- a/crates/metadata/src/specs.rs +++ b/crates/metadata/src/specs.rs @@ -1823,7 +1823,7 @@ where TypeSpec: Default, EnvironmentSpec: Default, { - /// Sets the `MAX_EVENT_TOPICS` value of the environment. + /// Sets the size of the static buffer configured via environment variable.` pub fn static_buffer_size( self, static_buffer_size: usize, From 7f012edacd8c69465c0def41cdf07fe852284afa Mon Sep 17 00:00:00 2001 From: SkymanOne Date: Fri, 18 Aug 2023 15:24:45 +0100 Subject: [PATCH 4/4] fix another comment --- crates/metadata/src/specs.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/metadata/src/specs.rs b/crates/metadata/src/specs.rs index ea027a4068c..c43c8333a35 100644 --- a/crates/metadata/src/specs.rs +++ b/crates/metadata/src/specs.rs @@ -661,7 +661,7 @@ mod state { pub struct ChainExtension; /// Type state for the max number of topics specified in the environment. pub struct MaxEventTopics; - /// Type state for the size of the static buffer specified via env var. + /// Type state for the size of the static buffer configured via environment variable.` pub struct BufferSize; }