Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bump hashbrown from 0.13.2 to 0.14.0 #38

Closed
wants to merge 685 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
685 commits
Select commit Hold shift + click to select a range
17822fb
Postpone public key creation in the test GenesisStorageBuilder (#14142)
davxy May 15, 2023
7f749ac
Adds integration test for slashed/chilled validator with subsequent v…
gpestana May 15, 2023
6461817
Bump parity-db to 0.4.8 (#14146)
tdimitrov May 15, 2023
cca606f
AccountTouch: deposit_required requires asset id (#14147)
muharem May 15, 2023
9b15dd1
Introduce function into frame System (#14149)
gavofyork May 15, 2023
a053ba5
fully enable `RuntimeDebug` in `feature = try-runtime` (#14136)
kianenigma May 15, 2023
410bd03
Tweak to avoid minor entropy loss (#14152)
gavofyork May 15, 2023
f143544
expose transport, peer_info and discovery in sc-network (#14132)
klbrvik May 15, 2023
563a137
Move node-template Cargo.toml dependencies to workspace (#14058)
kalaninja May 16, 2023
46b8224
Bump tower-http from 0.3.5 to 0.4.0 (#14128)
dependabot[bot] May 16, 2023
16b2eca
Add review rules regarding the owned files (#14122)
juangirini May 16, 2023
a926564
Change unit test upload step (#14124)
mateo-moon May 16, 2023
77c2028
Fix indent for pr-custom-review config (#14161)
alvicsam May 16, 2023
5c2fe95
remove deprecated remove_prefix to clear era_info (#13460)
surajk-m May 16, 2023
9a935b9
frame-system: `uniques` remove one `encode` call (#14154)
bkchr May 16, 2023
9819291
Max class voters for ranked collective vote tally (#13313)
muharem May 17, 2023
9173bae
Add `serde` feature flag to primitives (#13027)
haerdib May 17, 2023
98c3927
chore: move whitelist test to better place and add missing `Inactive …
yjhmelody May 17, 2023
7356ba9
Added serde feature to sp-consensus-aura (#14166)
michalkucharczyk May 18, 2023
0876fd0
Adds ability to use default hasher in `dev_mode` for explicit key bin…
gupnik May 19, 2023
0e704cc
Fix typos (#14177)
piffle-rack May 19, 2023
8f95a3a
Core-Fellowship: fix origin typo (#14179)
muharem May 19, 2023
6291861
remote-externalities: retry for get_keys (#14167)
liamaharon May 19, 2023
f44bcc9
frame: Enable GenesisConfig in no_std (#14108)
michalkucharczyk May 20, 2023
bbc3bc2
Update the nix build configuration. (#13706)
farcaller May 20, 2023
7bf0e7a
FRAME: Allow message ID to be mutated in ProcessMessage (#14183)
gavofyork May 21, 2023
866bb68
RevertCmd: Expose database params via CLI (#14182)
bkchr May 21, 2023
679ebc0
Improve try-state docs (#13967)
Szegoo May 21, 2023
d8dd817
test-runtime: Return hashed call as provides in unsigned validation (…
bkchr May 22, 2023
2a73694
Revert "Optimize merkle proofs for efficient verification in Solidity…
Lederstrumpf May 22, 2023
c01f506
Executor: Add `create_runtime_from_artifact_bytes` (#14184)
mrcnski May 22, 2023
ffbf0bc
WarpSync: Show number of required peers in informant (#14190)
bkchr May 22, 2023
c3f0ac7
BREAKING - Try-runtime: Use proper error types (#13993)
Szegoo May 23, 2023
6eddc0f
NFTs fractionalization (#12565)
lana-shanghai May 23, 2023
4abe643
Actually respect locks of zero (#14144)
gavofyork May 23, 2023
38d491e
Remove the `Copy` bound on `AssetId` (#14158)
koute May 23, 2023
2153a9a
Split `Peerset` into `PeerStore` & `ProtocolController`s (#13611)
dmitry-markin May 23, 2023
b18d89c
Add genesis config to Glutton pallet (#14188)
NachoPal May 23, 2023
975a83d
Bump syn from 2.0.15 to 2.0.16 (#14196)
dependabot[bot] May 23, 2023
e136d0e
TrieCache: Fine tune the size of the local and node cache (#14191)
bkchr May 23, 2023
4760ed8
Easy PR: Fix warnings from latest nightly (#14195)
gilescope May 23, 2023
0e90dec
Remove wasmi backend from sc-executor (#13800)
yjhmelody May 23, 2023
b7af797
Migration hook fixes (#14174)
liamaharon May 23, 2023
3365e3c
wasm: Update from v6.0.2 to v8.0.1 (#14178)
lexnv May 24, 2023
0737c5a
sc-client-db: add test for reverting finalized blocks (#14205)
andresilva May 24, 2023
f91da58
Replace request-response incoming requests queue with `async-channel`…
dmitry-markin May 24, 2023
e9eef9b
pallet-merkle-mountain-range: Remove extra `Hash` type (#14214)
bkchr May 24, 2023
7759913
HoldReason: Improve usage (#13869)
bkchr May 24, 2023
7ae1aaa
Get rid of some pointless pin_project stuff (#14212)
zdave May 25, 2023
74415c3
Support for `cfg` attributes in host functions definitions (#14189)
davxy May 25, 2023
10e95e7
sc-consensus-beefy: graceful support for pallet-beefy reset (#14217)
acatangiu May 25, 2023
54b3429
Don't start evicting peers right after `SyncingEngine` is started (#1…
altonen May 25, 2023
8fa0d79
Asset Conversion pallet (#12984)
gilescope May 25, 2023
e21228a
bump zombienet version (#14227)
pepoviola May 25, 2023
2af0ef2
frame: GenesisBuild::build allowed in no_std (#14107)
michalkucharczyk May 25, 2023
24320e8
Add remove_proxies API for pallet-proxies #7557 (#12714)
vjgaur May 26, 2023
1467d14
Bump platforms from 2.0.0 to 3.0.2 (#13625)
dependabot[bot] May 26, 2023
3810f8a
Soft deprecate GenesisConfig (#14210)
juangirini May 26, 2023
3d7196c
add new documentation guidelines (#14115)
kianenigma May 26, 2023
2d25cbb
test-utils: Fix wait_for_blocks in presence of reorgs (#14215)
alexggh May 26, 2023
4c17347
Improves documentation on `num_slashing_spans` when calling `withdraw…
gpestana May 27, 2023
a98040e
chain_head: Rename `runtimeUpdates` flag to `withRuntime` (#14244)
lexnv May 27, 2023
d3b9ba6
Bump lru from 0.8.1 to 0.10.0 (#14211)
dependabot[bot] May 28, 2023
64fcfff
wasm-builder: Enforce `runtime_version` wasm section (#14228)
bkchr May 28, 2023
c907dce
Bump proc-macro-warning from 0.3.1 to 0.4.1 (#14171)
dependabot[bot] May 29, 2023
d055db2
minor: fix misleading comment in `Notifications` (#14239)
dmitry-markin May 29, 2023
5cc468a
sp-api: Set correct where bound in the generated code (#14252)
bkchr May 29, 2023
b15ddd7
sp-wasm-interface: remove useless wasmi impl (#14208)
koushiro May 29, 2023
78cf0d8
Release: Bump SP crates to release on crates.io (#14237)
lexnv May 29, 2023
5b2fc91
[NFTs] Add minting price to the pre-signed mint object (#14242)
jsidorenko May 29, 2023
af40d7d
`Pay` trait gets `Error` item (#14258)
gavofyork May 29, 2023
6b3ddc1
primitives: added serde feature (#14256)
michalkucharczyk May 29, 2023
706bfec
FRAME: Pay trait benchmark helper should use asset kind (#14259)
gavofyork May 29, 2023
3d50922
bounded-collections bump to 0.1.7 (#14255)
michalkucharczyk May 29, 2023
d079b66
[NFTs] Add mint price to the witness object on mint and confirm it (#…
jsidorenko May 29, 2023
2496c6c
Improve documentation for `fast-unstake` pallet (#14101)
kianenigma May 29, 2023
5da3f71
Incorporate `sc-peerset` into `sc-network` (#14236)
dmitry-markin May 29, 2023
56882be
Bump quote from 1.0.27 to 1.0.28 (#14253)
dependabot[bot] May 29, 2023
fded365
Default Pallet Config Trait / derive_impl (#13454)
kianenigma May 30, 2023
c735939
app_crypto: macro improvements (#14263)
michalkucharczyk May 30, 2023
f3cd1cd
Make offchain tx pool creation reusable (#14230)
bkchr May 31, 2023
2e755a0
Remove `enum-as-inner` pin (#14266)
bkchr May 31, 2023
8b0f217
Bump sp-crates from latest crates.io version + release (#14265)
lexnv May 31, 2023
73c4f38
pallet-beefy-mmr: fix when using custom hashing (#14273)
acatangiu May 31, 2023
06ecbbe
contracts: Multi block migrations (#14045)
pgherveou May 31, 2023
88a5168
Expose `build_system_rpc_future` and `TransactionPoolAdapator` in sc-…
liuchengxu May 31, 2023
fa33f29
Bump serde from 1.0.162 to 1.0.163 (#14271)
dependabot[bot] May 31, 2023
bb3e182
FRAME: Introduce `ConvertToValue` adapter (#14270)
gavofyork Jun 1, 2023
e5ba34d
Reduce logging verbosity when disconnecting an unknown peer (#14274)
dmitry-markin Jun 1, 2023
2f89c67
sp-api: Make the generated code act based on `std` in `sp-api` (#14267)
bkchr Jun 1, 2023
c5fbe1d
frame: support for serde added (#14261)
michalkucharczyk Jun 1, 2023
a9fa48e
frame/support: Link call documentation only in prod-modes (#14283)
lexnv Jun 1, 2023
6f10664
Runtime: Add common morph utility types (#14281)
gavofyork Jun 1, 2023
def7eda
print error info for database error (#14248)
atenjin Jun 1, 2023
eebe0ab
pallet-uniques: remove #[transactional] macro for buy_item (#14277)
cuteolaf Jun 2, 2023
4d4ede8
add test locking removed when amount is zero (#14284)
jpserrat Jun 2, 2023
a2da205
asset-conversion pallet: Generalise integrity test (#14289)
gilescope Jun 2, 2023
5d87b9e
Bump version of `pallet-contracts-primitives` for release (#14288)
ascjones Jun 2, 2023
05d0c69
frame-support Add translate_next (#14043)
pgherveou Jun 2, 2023
578cd5e
sc-transaction-pool: Always use best block to check if we should skip…
bkchr Jun 2, 2023
ff6f26c
sp-api: Remove requirement on `Get*BlockType` (#14299)
bkchr Jun 4, 2023
d55b3d5
Frame: Introduce `TryConvert` and `MaybeConvert` family of traits (#1…
gavofyork Jun 4, 2023
0f6aaa2
frame_system::remark: Allow any kind of origin (#14260)
bkchr Jun 4, 2023
a46eb09
Remove unrequired check (#14298)
gilescope Jun 4, 2023
063231e
migration(tips): unreserve deposits (#14241)
liamaharon Jun 5, 2023
12faec8
upgrade macro_magic to 0.3.5 (#14303)
sam0x17 Jun 5, 2023
6006715
arkworks integration (#13031)
achimcc Jun 6, 2023
a60ecc9
add pallet macro kitchensink example/template (#14052)
kianenigma Jun 6, 2023
2a59c7f
Finalized should be before best (#14308)
davxy Jun 7, 2023
fb2c3d3
Remove native deps: openssl-sys, git2-sys, libssh2-sys (#14302)
gilescope Jun 7, 2023
d87fda5
refactor: define trait `HashOutput` for some Hash associate type (#14…
yjhmelody Jun 8, 2023
ee3eeda
No need for AssetBalanceOf (#14325)
gilescope Jun 8, 2023
f1fafb7
Move `type Migrations` to `Config` (#14309)
juangirini Jun 9, 2023
d182b09
it's always false... (#13330)
gilescope Jun 9, 2023
6affb17
fix gha set-output command (#14312)
sergejparity Jun 9, 2023
c983d4e
Fix RPC error code conflict (#14315)
arkpar Jun 9, 2023
a8a0d50
pallet-aura: Allow multiple blocks per slot (#14024)
rphmeier Jun 9, 2023
fb64062
Frame: Give Referendum `SubmitOrigin` argument (#14326)
gavofyork Jun 12, 2023
6d02a53
build(deps): bump comfy-table from 6.2.0 to 7.0.0 (#14333)
dependabot[bot] Jun 12, 2023
03c3bd0
Update Pallet placeholder struct as per FRAME v2 (#14348)
abhi3700 Jun 12, 2023
c4ff648
fix new warning in nightly (#14334)
gilescope Jun 13, 2023
1dc165e
Reimport `WeightInfo` (#14358)
kalaninja Jun 13, 2023
692ae21
Improvements to node template README (#14181)
Jun 13, 2023
237a6b6
PR template improvements (#14148)
Jun 13, 2023
f4765fc
build(deps): bump expander from 1.0.0 to 2.0.0 (#14361)
dependabot[bot] Jun 13, 2023
ecee408
Bump hyper-rustls from 0.23.2 to 0.24.0 (#14233)
dependabot[bot] Jun 13, 2023
8e8b3fd
Use Incrementable from frame_support::traits (#14367)
jsidorenko Jun 13, 2023
8d5e0df
Take into account proof size for transaction payment and priority (#1…
Ank4n Jun 13, 2023
af4a5fd
`pallet-glutton`: over-unity consumption (#14338)
ggwpez Jun 13, 2023
2be7bb4
migration(democracy): unreserve deposits and clear locks (#14226)
liamaharon Jun 13, 2023
48c5b53
migration(elections-phragmen): unreserve deposits and clear locks (#1…
liamaharon Jun 13, 2023
2fc0cb8
benchmark pallet: Error if files are overwritten twice (#14352)
ggwpez Jun 13, 2023
e612cd7
sc-executor-wasmtime: Do not use absolute path to `Cargo.toml` in tes…
bkchr Jun 13, 2023
80ba1dd
cargo-hfuzz ci: specify manifest patches via cargo --config (#14372)
Jun 14, 2023
993d034
Restructure macro-related exports into private mods for frame (#14375)
gui1117 Jun 14, 2023
5c128ca
Expose ExtraFlags struct (#14376)
kostekIV Jun 14, 2023
f9c1731
`construct_runtime`: support for expanding the macro code (#14379)
michalkucharczyk Jun 14, 2023
0cd8efc
Fix for `pallet_assets::create` benchmark (#14384)
bkontur Jun 14, 2023
08e357c
[frame/im-online] remove network state from heartbeats (#14251)
melekes Jun 15, 2023
a1663ac
fix clippy warnings in node template (#14390)
deepink-mas Jun 15, 2023
c1cae7e
sc-consensus-beefy: fix flaky test beefy_reports_equivocations (#14382)
acatangiu Jun 16, 2023
cac288d
Run all tests with `try-runtime` feature enabled (#14396)
bkchr Jun 16, 2023
40bfa78
Add a deprecation warning to the old runtime GenesisConfig (#14224)
juangirini Jun 16, 2023
0774eae
Fix links (#14371)
Jun 16, 2023
8d0c92b
Delete 1D weight ctors and set explicit deprecation dates (#14397)
ggwpez Jun 16, 2023
2ab7987
[frame/im-online] remove ensure from pre_upgrade (#14401)
melekes Jun 16, 2023
1bf1928
update macro_magic to 0.4.1 (#14356)
sam0x17 Jun 16, 2023
1073417
[network] Extend `Notifications` logs with `SetId` where missing (#14…
dmitry-markin Jun 16, 2023
423e34c
expose the fields of Dust type to public (#14388)
wangjj9219 Jun 18, 2023
48edacc
pallet benchmarking: Bump default steps and repeat (#14408)
ggwpez Jun 18, 2023
03b4924
Society v2 (#11324)
gavofyork Jun 18, 2023
bb67be7
Refactor `BlockBuilder::propose_with` (#14405)
ggwpez Jun 19, 2023
bd716de
".git/.scripts/commands/bench-vm/bench-vm.sh" all (#13933)
mateo-moon Jun 19, 2023
708009d
Update DOCUMENTATION_GUIDELINES.md (#14369)
kianenigma Jun 19, 2023
dbc6a8f
ci: bump ci image for rust 1.70 (#14399)
Jun 20, 2023
ccb4e91
Update contract multi-block migration (#14313)
pgherveou Jun 20, 2023
792d658
ci: move back to paritytech/ci-linux:production image (#14422)
Jun 20, 2023
1568641
Bump `parity-scale-codec` to 3.6.1 (#14428)
koute Jun 21, 2023
3e6ecee
Remove clippy workaround (#14424)
bkchr Jun 21, 2023
c69d0bb
fix(remote-externalities): child trie not loaded (#14365)
liamaharon Jun 21, 2023
2fc7218
suppress unused warning in kitchensink example (#14417)
sam0x17 Jun 21, 2023
f95e4a1
expose setting kademlia replication factor through node CLI (#14391)
klbrvik Jun 21, 2023
e392d66
inspect role for nonfungibles_v2 (#14341)
mutobui Jun 22, 2023
d35c728
[minor] Extend logging with `SetId` in `ProtocolController` where mis…
dmitry-markin Jun 22, 2023
c9c4124
Adds ability to prepare/initialize before running `set_code` benchmar…
bkontur Jun 23, 2023
1ddda32
Pay tx fee with assets by using the asset conversion pallet (#14340)
jsidorenko Jun 23, 2023
de6878d
once_cell in std from 1.70 (#14402)
gilescope Jun 24, 2023
0ba84b8
try-runtime-cli: `execute-block` & `create-snapshot` tests (#14343)
Szegoo Jun 24, 2023
04c1873
Remove k256 crate from frame-support dependencies (#14452)
conr2d Jun 25, 2023
54d795e
`GenesisBuilder` runtime API (#14131)
michalkucharczyk Jun 26, 2023
5aa73df
Added missing BLS feature (#14461)
davxy Jun 26, 2023
fdcb8bb
[FRAME Core] Adds ability to split a pallet across multiple files (#1…
gupnik Jun 27, 2023
21de73d
Remove unused dependencies (#14464)
skunert Jun 27, 2023
d915e7d
fix(test-externalities): include memory db reference counts in snapsh…
liamaharon Jun 27, 2023
8d7d178
`pallet-message-queue`: add queue pausing (#14318)
ggwpez Jun 28, 2023
b979fcd
Metadata V15: Expose types for the overarching Call, Event, Error enu…
lexnv Jun 28, 2023
2e3f956
sc-network: Improve invalid boot node reporting (#14455)
bkchr Jun 28, 2023
8e1bb3c
Metadata V15: Enrich extrinsic type info for decoding (#14123)
lexnv Jun 28, 2023
9afae57
Make triecache generic and work for no-std environments (#14403)
skunert Jun 28, 2023
24c8b84
fix on-runtime-upgrade checks docs (#14467)
liamaharon Jun 28, 2023
56eb32f
Update Reference Hardware Specs (#13317)
ggwpez Jun 28, 2023
20f981f
Unify `SyncMode` data structures under one (#14465)
nazar-pc Jun 29, 2023
7418a61
Inject `FromSwarm::NewListenAddr` to mDNS (#14478)
altonen Jun 29, 2023
b31a485
frame-benchmarking-cli: Remove native dispatch requirement (#14474)
bkchr Jun 29, 2023
421fc2b
sp-api: Support nested transactions (#14447)
bkchr Jun 29, 2023
75fcee7
Stabilize V15 Metadata (#14481)
lexnv Jun 30, 2023
3dd7b75
Pallets: Assets `destroy_accounts` releases the deposit (#14443)
muharem Jul 1, 2023
21dfc2f
migrations: VersionedRuntimeUpgrade (#14311)
liamaharon Jul 2, 2023
5cd3523
Whitelist 'intrablock_entropy' (#14489)
ggwpez Jul 2, 2023
271e557
stabilize instantiation_nonce (#14493)
xermicus Jul 3, 2023
7ae2120
sc-tracing: Only print events for whitelisted targets (#14487)
bkchr Jul 3, 2023
56f4497
sp-api: Put `frame-metadata` behind some feature (#14398)
bkchr Jul 3, 2023
0d6377b
wasm-builder: Make `hash` and `date` optional (#14490)
bkchr Jul 3, 2023
08206a8
Removes `pallet::call_index` from `dev_mode` example (#14492)
gupnik Jul 3, 2023
75c608d
contracts: switch to wasmi gas metering (#14084)
agryaznov Jul 3, 2023
9469554
Fix typo (#14479) (#14480)
Hugo-Trentesaux Jul 3, 2023
b0ccb81
Nomination pools: disallow setting above global max commission (#14496)
Jul 3, 2023
4b9117c
Revert k256 removal (#14499)
bkchr Jul 3, 2023
c468d0b
contracts: switch from `parity-wasm`-based to `wasmi`-based module va…
agryaznov Jul 4, 2023
06ca21e
sc-cli: Remove `SubstrateCli::native_runtime_version` function (#14511)
bkchr Jul 5, 2023
f5a23b0
Improve NFT locking (#14510)
jsidorenko Jul 5, 2023
a897bf2
Use set_balance() instead of write_balance() in benchmark (#14497)
jsidorenko Jul 5, 2023
b159155
emit warn log on bad state (#14513)
liamaharon Jul 5, 2023
58bf294
chore: update some deps to prune duplicated deps (#14515)
koushiro Jul 6, 2023
6d3ae42
run tests with --experimental flag (#14502)
liamaharon Jul 6, 2023
99046a1
Add `try-state` hook to pallet aura (#14363)
pmikolajczyk41 Jul 7, 2023
296f54f
Update lib.rs (#14528)
cuteolaf Jul 7, 2023
2c2f54f
contracts: Refactor instantiate with code (#14503)
pgherveou Jul 7, 2023
dbbcb1b
Fix spellcheck for benchmarking comments (#14535)
ggwpez Jul 7, 2023
988249c
remove `OnStakerSlash` replace with `OnStakingEvents` (#14527)
kianenigma Jul 9, 2023
c488973
replace lru with schnellru (#14539)
koushiro Jul 9, 2023
1317a78
Better handling of error in inherents logic. (#14521)
gui1117 Jul 10, 2023
18b407d
Add missing workspace members (#14537)
ggwpez Jul 10, 2023
cea0182
CI: Do not fail on junit upload failure (#14545)
bkchr Jul 11, 2023
1c0d06f
Removal of execution strategies (#14387)
bkchr Jul 11, 2023
d39f54a
node-template: Remove accidentally added dependency (#14553)
bkchr Jul 11, 2023
9f2a6bd
Contracts rename v9 to v09 (#14533)
pgherveou Jul 12, 2023
39ffcb0
quick updates (#14557)
pgherveou Jul 12, 2023
bb219d6
`GenesisBuild<T,I>` deprecated. `BuildGenesisConfig` added. (#14306)
michalkucharczyk Jul 12, 2023
1aa546c
Update `subkey` README.md (#14552)
nuke-web3 Jul 12, 2023
da1b8d6
Fix refund benchmark for pallet_assets (#14561)
bkontur Jul 12, 2023
c3cfaa1
[pallet_collective] Enforce prime is a valid member of collective in …
ToufeeqP Jul 12, 2023
b8a5c04
update to docify 0.2.0 / crate-relative embed paths (#14570)
sam0x17 Jul 13, 2023
8f51e47
Fix Society v2 migration (#14421)
liamaharon Jul 13, 2023
48d97c8
Moves `Block` to `frame_system` instead of `construct_runtime` and re…
gupnik Jul 13, 2023
58ded3d
Refactor the asset-conversion-tx-payment pallet (#14558)
jsidorenko Jul 13, 2023
cb17c08
Re-add deprecated `--execution` arg on `benchmark pallet` (#14567)
ggwpez Jul 13, 2023
9e106c8
Fixes link to inflation documentation (#14573)
tkisason Jul 13, 2023
00dce17
WasmExecutor flag to ignore onchain heappages value (#14508)
fgamundi Jul 14, 2023
65ed366
Replace system config `Index` for `Nonce` (#14290)
juangirini Jul 14, 2023
0970473
do not filter word `www` in `is_node_name_valid` check (#14575)
atenjin Jul 14, 2023
dbba086
Remove redundant sync primitives for metrics (#14564)
vstakhov Jul 14, 2023
cf8f08b
change $location from tt* to ty and remove unnecessary cb_* versions …
deepink-mas Jul 14, 2023
6d56cae
Contracts add code_len to ContractsInfo (#14523)
pgherveou Jul 14, 2023
470b5b3
fixing return types in crypto module documentation (#14554)
jtfirek Jul 14, 2023
fda0ef3
basic improvements to sp-runtime docs (#14583)
kianenigma Jul 17, 2023
9858181
improve pallet hooks docs (#14578)
kianenigma Jul 17, 2023
c6ab56d
ci-unified:bullseye-1.70.0-2023-05-23 image for ci (#14532)
AndWeHaveAPlan Jul 17, 2023
12b8904
grandpa: avoid importing unnecessary justifications (#14423)
andresilva Jul 17, 2023
30e8cfd
Encryption support for the statement store (#14440)
arkpar Jul 17, 2023
7dca8c5
client: fix invalid node name pattern regex (#14593)
andresilva Jul 18, 2023
e7dc030
Handle the AllowMultiAssetPools=false case in benchmarks (#14590)
jsidorenko Jul 18, 2023
cdcd4c4
Run `integrity_test` in Externalities (#14546)
ggwpez Jul 18, 2023
ee671c2
Improves the EPM/Staking e2e test setup (#14292)
gpestana Jul 18, 2023
ca4bfde
Don't use fixed nominator count for report_equivocation weight calcul…
andresilva Jul 18, 2023
02e7a4c
Move CI_IMAGE to external snippet via !reference #14595
AndWeHaveAPlan Jul 18, 2023
65d7bdc
`WeightMeter`: more consistent naming (#14586)
ggwpez Jul 18, 2023
ab577c7
Make trie-cache resettable from backend (#14516)
skunert Jul 18, 2023
37e9c0c
Staking e2e test - Add case when ledger active balance falls below ED…
gpestana Jul 18, 2023
1dce0b9
Bump hashbrown from 0.13.2 to 0.14.0
dependabot[bot] Jul 19, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
sp-api: Make the generated code act based on std in sp-api (parit…
…ytech#14267)

* sp-api: Make the generated code act based on `std` in `sp-api`

Instead of letting the macro generate code that checks if the `std` feature is enabled, it will now
generate code that checks if the `std` feature is enabled for the `sp-api` crate. The old
implementation basically required that the crate in which the macro was used, had a `std` feature.
Now we don't have this requirement anymore and act accordingly the feature in `sp-api` directly.

* Missing feature!

---------

Co-authored-by: parity-processbot <>
bkchr authored and nathanwhit committed Jul 19, 2023
commit 2f89c67c024bfda49de0d953f7f248b7e9668ab3
1 change: 1 addition & 0 deletions frame/executive/Cargo.toml
Original file line number Diff line number Diff line change
@@ -42,6 +42,7 @@ std = [
"codec/std",
"frame-support/std",
"frame-system/std",
"frame-try-runtime/std",
"scale-info/std",
"sp-core/std",
"sp-io/std",
21 changes: 12 additions & 9 deletions primitives/api/proc-macro/src/decl_runtime_apis.rs
Original file line number Diff line number Diff line change
@@ -539,8 +539,6 @@ impl<'a> Fold for ToClientSideDecl<'a> {
input.supertraits.push(parse_quote!( #crate_::Core<#block_ident> ));
}

// The client side trait is only required when compiling with the feature `std` or `test`.
input.attrs.push(parse_quote!( #[cfg(any(feature = "std", test))] ));
input.items = self.fold_item_trait_items(input.items, input.generics.params.len());

fold::fold_item_trait(self, input)
@@ -584,12 +582,13 @@ fn generate_runtime_info_impl(trait_: &ItemTrait, version: u64) -> TokenStream {
});

quote!(
#[cfg(any(feature = "std", test))]
impl < #( #impl_generics, )* > #crate_::RuntimeApiInfo
for dyn #trait_name < #( #ty_generics, )* >
{
#id
#version
#crate_::std_enabled! {
impl < #( #impl_generics, )* > #crate_::RuntimeApiInfo
for dyn #trait_name < #( #ty_generics, )* >
{
#id
#version
}
}
)
}
@@ -636,7 +635,11 @@ fn generate_client_side_decls(decls: &[ItemTrait]) -> Result<TokenStream> {

let runtime_info = api_version.map(|v| generate_runtime_info_impl(&decl, v))?;

result.push(quote!( #decl #runtime_info #( #errors )* ));
result.push(quote!(
#crate_::std_enabled! { #decl }
#runtime_info
#( #errors )*
));
}

Ok(quote!( #( #result )* ))
344 changes: 172 additions & 172 deletions primitives/api/proc-macro/src/impl_runtime_apis.rs
Original file line number Diff line number Diff line change
@@ -172,11 +172,12 @@ fn generate_dispatch_function(impls: &[ItemImpl]) -> Result<TokenStream> {
});

Ok(quote!(
#[cfg(feature = "std")]
pub fn dispatch(method: &str, mut #data: &[u8]) -> Option<Vec<u8>> {
match method {
#( #impl_calls )*
_ => None,
#c::std_enabled! {
pub fn dispatch(method: &str, mut #data: &[u8]) -> Option<Vec<u8>> {
match method {
#( #impl_calls )*
_ => None,
}
}
}
))
@@ -195,22 +196,23 @@ fn generate_wasm_interface(impls: &[ItemImpl]) -> Result<TokenStream> {
Ident::new(&prefix_function_with_trait(&trait_, &fn_name), Span::call_site());

quote!(
#( #attrs )*
#[cfg(not(feature = "std"))]
#[no_mangle]
pub unsafe fn #fn_name(input_data: *mut u8, input_len: usize) -> u64 {
let mut #input = if input_len == 0 {
&[0u8; 0]
} else {
unsafe {
#c::slice::from_raw_parts(input_data, input_len)
}
};

#c::init_runtime_logger();

let output = (move || { #impl_ })();
#c::to_substrate_wasm_fn_return_value(&output)
#c::std_disabled! {
#( #attrs )*
#[no_mangle]
pub unsafe fn #fn_name(input_data: *mut u8, input_len: usize) -> u64 {
let mut #input = if input_len == 0 {
&[0u8; 0]
} else {
unsafe {
#c::slice::from_raw_parts(input_data, input_len)
}
};

#c::init_runtime_logger();

let output = (move || { #impl_ })();
#c::to_substrate_wasm_fn_return_value(&output)
}
}
)
});
@@ -224,175 +226,173 @@ fn generate_runtime_api_base_structures() -> Result<TokenStream> {
Ok(quote!(
pub struct RuntimeApi {}
/// Implements all runtime apis for the client side.
#[cfg(any(feature = "std", test))]
pub struct RuntimeApiImpl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block> + 'static> {
call: &'static C,
commit_on_success: std::cell::RefCell<bool>,
changes: std::cell::RefCell<#crate_::OverlayedChanges>,
storage_transaction_cache: std::cell::RefCell<
#crate_::StorageTransactionCache<Block, C::StateBackend>
>,
recorder: std::option::Option<#crate_::ProofRecorder<Block>>,
}
#crate_::std_enabled! {
pub struct RuntimeApiImpl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block> + 'static> {
call: &'static C,
commit_on_success: std::cell::RefCell<bool>,
changes: std::cell::RefCell<#crate_::OverlayedChanges>,
storage_transaction_cache: std::cell::RefCell<
#crate_::StorageTransactionCache<Block, C::StateBackend>
>,
recorder: std::option::Option<#crate_::ProofRecorder<Block>>,
}

#[cfg(any(feature = "std", test))]
impl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block>> #crate_::ApiExt<Block> for
RuntimeApiImpl<Block, C>
{
type StateBackend = C::StateBackend;
impl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block>> #crate_::ApiExt<Block> for
RuntimeApiImpl<Block, C>
{
type StateBackend = C::StateBackend;

fn execute_in_transaction<F: FnOnce(&Self) -> #crate_::TransactionOutcome<R>, R>(
&self,
call: F,
) -> R where Self: Sized {
self.start_transaction();
fn execute_in_transaction<F: FnOnce(&Self) -> #crate_::TransactionOutcome<R>, R>(
&self,
call: F,
) -> R where Self: Sized {
self.start_transaction();

*std::cell::RefCell::borrow_mut(&self.commit_on_success) = false;
let res = call(self);
*std::cell::RefCell::borrow_mut(&self.commit_on_success) = true;
*std::cell::RefCell::borrow_mut(&self.commit_on_success) = false;
let res = call(self);
*std::cell::RefCell::borrow_mut(&self.commit_on_success) = true;

self.commit_or_rollback(std::matches!(res, #crate_::TransactionOutcome::Commit(_)));
self.commit_or_rollback(std::matches!(res, #crate_::TransactionOutcome::Commit(_)));

res.into_inner()
}
res.into_inner()
}

fn has_api<A: #crate_::RuntimeApiInfo + ?Sized>(
&self,
at: <Block as #crate_::BlockT>::Hash,
) -> std::result::Result<bool, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
fn has_api<A: #crate_::RuntimeApiInfo + ?Sized>(
&self,
at: <Block as #crate_::BlockT>::Hash,
) -> std::result::Result<bool, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
.map(|v| #crate_::RuntimeVersion::has_api_with(&v, &A::ID, |v| v == A::VERSION))
}
}

fn has_api_with<A: #crate_::RuntimeApiInfo + ?Sized, P: Fn(u32) -> bool>(
&self,
at: <Block as #crate_::BlockT>::Hash,
pred: P,
) -> std::result::Result<bool, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
fn has_api_with<A: #crate_::RuntimeApiInfo + ?Sized, P: Fn(u32) -> bool>(
&self,
at: <Block as #crate_::BlockT>::Hash,
pred: P,
) -> std::result::Result<bool, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
.map(|v| #crate_::RuntimeVersion::has_api_with(&v, &A::ID, pred))
}
}

fn api_version<A: #crate_::RuntimeApiInfo + ?Sized>(
&self,
at: <Block as #crate_::BlockT>::Hash,
) -> std::result::Result<Option<u32>, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
fn api_version<A: #crate_::RuntimeApiInfo + ?Sized>(
&self,
at: <Block as #crate_::BlockT>::Hash,
) -> std::result::Result<Option<u32>, #crate_::ApiError> where Self: Sized {
#crate_::CallApiAt::<Block>::runtime_version_at(self.call, at)
.map(|v| #crate_::RuntimeVersion::api_version(&v, &A::ID))
}
}

fn record_proof(&mut self) {
self.recorder = std::option::Option::Some(std::default::Default::default());
}
fn record_proof(&mut self) {
self.recorder = std::option::Option::Some(std::default::Default::default());
}

fn proof_recorder(&self) -> std::option::Option<#crate_::ProofRecorder<Block>> {
std::clone::Clone::clone(&self.recorder)
}
fn proof_recorder(&self) -> std::option::Option<#crate_::ProofRecorder<Block>> {
std::clone::Clone::clone(&self.recorder)
}

fn extract_proof(
&mut self,
) -> std::option::Option<#crate_::StorageProof> {
let recorder = std::option::Option::take(&mut self.recorder);
std::option::Option::map(recorder, |recorder| {
#crate_::ProofRecorder::<Block>::drain_storage_proof(recorder)
})
}
fn extract_proof(
&mut self,
) -> std::option::Option<#crate_::StorageProof> {
let recorder = std::option::Option::take(&mut self.recorder);
std::option::Option::map(recorder, |recorder| {
#crate_::ProofRecorder::<Block>::drain_storage_proof(recorder)
})
}

fn into_storage_changes(
&self,
backend: &Self::StateBackend,
parent_hash: Block::Hash,
) -> core::result::Result<
#crate_::StorageChanges<C::StateBackend, Block>,
fn into_storage_changes(
&self,
backend: &Self::StateBackend,
parent_hash: Block::Hash,
) -> core::result::Result<
#crate_::StorageChanges<C::StateBackend, Block>,
String
> where Self: Sized {
let state_version = #crate_::CallApiAt::<Block>::runtime_version_at(self.call, std::clone::Clone::clone(&parent_hash))
.map(|v| #crate_::RuntimeVersion::state_version(&v))
.map_err(|e| format!("Failed to get state version: {}", e))?;

#crate_::OverlayedChanges::into_storage_changes(
std::cell::RefCell::take(&self.changes),
backend,
core::cell::RefCell::take(&self.storage_transaction_cache),
state_version,
)
> where Self: Sized {
let state_version = #crate_::CallApiAt::<Block>::runtime_version_at(self.call, std::clone::Clone::clone(&parent_hash))
.map(|v| #crate_::RuntimeVersion::state_version(&v))
.map_err(|e| format!("Failed to get state version: {}", e))?;

#crate_::OverlayedChanges::into_storage_changes(
std::cell::RefCell::take(&self.changes),
backend,
core::cell::RefCell::take(&self.storage_transaction_cache),
state_version,
)
}
}
}

#[cfg(any(feature = "std", test))]
impl<Block: #crate_::BlockT, C> #crate_::ConstructRuntimeApi<Block, C>
for RuntimeApi
where
C: #crate_::CallApiAt<Block> + 'static,
{
type RuntimeApi = RuntimeApiImpl<Block, C>;

fn construct_runtime_api<'a>(
call: &'a C,
) -> #crate_::ApiRef<'a, Self::RuntimeApi> {
RuntimeApiImpl {
call: unsafe { std::mem::transmute(call) },
commit_on_success: true.into(),
changes: std::default::Default::default(),
recorder: std::default::Default::default(),
storage_transaction_cache: std::default::Default::default(),
}.into()
impl<Block: #crate_::BlockT, C> #crate_::ConstructRuntimeApi<Block, C>
for RuntimeApi
where
C: #crate_::CallApiAt<Block> + 'static,
{
type RuntimeApi = RuntimeApiImpl<Block, C>;

fn construct_runtime_api<'a>(
call: &'a C,
) -> #crate_::ApiRef<'a, Self::RuntimeApi> {
RuntimeApiImpl {
call: unsafe { std::mem::transmute(call) },
commit_on_success: true.into(),
changes: std::default::Default::default(),
recorder: std::default::Default::default(),
storage_transaction_cache: std::default::Default::default(),
}.into()
}
}
}

#[cfg(any(feature = "std", test))]
impl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block>> RuntimeApiImpl<Block, C> {
fn commit_or_rollback(&self, commit: bool) {
let proof = "\
impl<Block: #crate_::BlockT, C: #crate_::CallApiAt<Block>> RuntimeApiImpl<Block, C> {
fn commit_or_rollback(&self, commit: bool) {
let proof = "\
We only close a transaction when we opened one ourself.
Other parts of the runtime that make use of transactions (state-machine)
also balance their transactions. The runtime cannot close client initiated
transactions; qed";
if *std::cell::RefCell::borrow(&self.commit_on_success) {
let res = if commit {
let res = if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::commit_transaction(&recorder)
if *std::cell::RefCell::borrow(&self.commit_on_success) {
let res = if commit {
let res = if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::commit_transaction(&recorder)
} else {
Ok(())
};

let res2 = #crate_::OverlayedChanges::commit_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);

// Will panic on an `Err` below, however we should call commit
// on the recorder and the changes together.
std::result::Result::and(res, std::result::Result::map_err(res2, drop))
} else {
Ok(())
let res = if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::rollback_transaction(&recorder)
} else {
Ok(())
};

let res2 = #crate_::OverlayedChanges::rollback_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);

// Will panic on an `Err` below, however we should call commit
// on the recorder and the changes together.
std::result::Result::and(res, std::result::Result::map_err(res2, drop))
};

let res2 = #crate_::OverlayedChanges::commit_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);

// Will panic on an `Err` below, however we should call commit
// on the recorder and the changes together.
std::result::Result::and(res, std::result::Result::map_err(res2, drop))
} else {
let res = if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::rollback_transaction(&recorder)
} else {
Ok(())
};

let res2 = #crate_::OverlayedChanges::rollback_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);

// Will panic on an `Err` below, however we should call commit
// on the recorder and the changes together.
std::result::Result::and(res, std::result::Result::map_err(res2, drop))
};

std::result::Result::expect(res, proof);
std::result::Result::expect(res, proof);
}
}
}

fn start_transaction(&self) {
if !*std::cell::RefCell::borrow(&self.commit_on_success) {
return
}
fn start_transaction(&self) {
if !*std::cell::RefCell::borrow(&self.commit_on_success) {
return
}

#crate_::OverlayedChanges::start_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);
if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::start_transaction(&recorder);
#crate_::OverlayedChanges::start_transaction(
&mut std::cell::RefCell::borrow_mut(&self.changes)
);
if let Some(recorder) = &self.recorder {
#crate_::ProofRecorder::<Block>::start_transaction(&recorder);
}
}
}
}
@@ -571,10 +571,6 @@ impl<'a> Fold for ApiRuntimeImplToApiRuntimeApiImpl<'a> {

input.attrs = filter_cfg_attrs(&input.attrs);

// The implementation for the `RuntimeApiImpl` is only required when compiling with
// the feature `std` or `test`.
input.attrs.push(parse_quote!( #[cfg(any(feature = "std", test))] ));

fold::fold_item_impl(self, input)
}
}
@@ -595,7 +591,10 @@ fn generate_api_impl_for_runtime_api(impls: &[ItemImpl]) -> Result<TokenStream>

result.push(processed_impl);
}
Ok(quote!( #( #result )* ))

let crate_ = generate_crate_access();

Ok(quote!( #crate_::std_enabled! { #( #result )* } ))
}

fn populate_runtime_api_versions(
@@ -612,13 +611,14 @@ fn populate_runtime_api_versions(
));

sections.push(quote!(
#( #attrs )*
const _: () = {
// All sections with the same name are going to be merged by concatenation.
#[cfg(not(feature = "std"))]
#[link_section = "runtime_apis"]
static SECTION_CONTENTS: [u8; 12] = #crate_access::serialize_runtime_api_info(#id, #version);
};
#crate_access::std_disabled! {
#( #attrs )*
const _: () = {
// All sections with the same name are going to be merged by concatenation.
#[link_section = "runtime_apis"]
static SECTION_CONTENTS: [u8; 12] = #crate_access::serialize_runtime_api_info(#id, #version);
};
}
));
}

3 changes: 3 additions & 0 deletions primitives/api/src/lib.rs
Original file line number Diff line number Diff line change
@@ -750,3 +750,6 @@ decl_runtime_apis! {
fn metadata_versions() -> sp_std::vec::Vec<u32>;
}
}

sp_core::generate_feature_enabled_macro!(std_enabled, feature = "std", $);
sp_core::generate_feature_enabled_macro!(std_disabled, not(feature = "std"), $);
5 changes: 0 additions & 5 deletions primitives/api/test/Cargo.toml
Original file line number Diff line number Diff line change
@@ -34,8 +34,3 @@ sp-core = { version = "21.0.0", path = "../../core" }
[[bench]]
name = "bench"
harness = false

# We only need this to generate the correct code.
[features]
default = [ "std" ]
std = []
12 changes: 12 additions & 0 deletions primitives/core/src/lib.rs
Original file line number Diff line number Diff line change
@@ -442,6 +442,18 @@ pub const MAX_POSSIBLE_ALLOCATION: u32 = 33554432; // 2^25 bytes, 32 MiB
///
/// These feature checking macros can be used to conditionally enable/disable code in a dependent
/// crate based on a feature in the crate where the macro is called.
///
/// # Example
///```
/// sp_core::generate_feature_enabled_macro!(check_std_is_enabled, feature = "std", $);
/// sp_core::generate_feature_enabled_macro!(check_std_or_serde_is_enabled, any(feature = "std", feature = "serde"), $);
///
/// // All the code passed to the macro will then conditionally compiled based on the features
/// // activated for the crate where the macro was generated.
/// check_std_is_enabled! {
/// struct StdEnabled;
/// }
///```
#[macro_export]
// We need to skip formatting this macro because of this bug:
// https://github.com/rust-lang/rustfmt/issues/5283