mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 12:07:57 +00:00
78bc5edc14
* Make extrinsics extensible. Also Remove old extrinsic types. * Rest of mockup. Add tips. * Fix some build issues * Runtiem builds :) * Substrate builds. * Fix a doc test * Compact encoding * Extract out the era logic into an extension * Weight Check signed extension. (#3115) * Weight signed extension. * Revert a bit + test for check era. * Update Cargo.toml * Update node/cli/src/factory_impl.rs * Update node/executor/src/lib.rs * Update node/executor/src/lib.rs * Don't use len for weight - use data. * Operational Transaction; second attempt (#3138) * working poc added. * some fixes. * Update doc. * Fix all tests + final logic. * more refactoring. * nits. * System block limit in bytes. * Silent the storage macro warnings. * More logic more tests. * Fix import. * Refactor names. * Fix build. * Update srml/balances/src/lib.rs * Final refactor. * Bump transaction version * Fix weight mult test. * Fix more tests and improve doc. * Bump. * Make some tests work again. * Fix subkey. * Remove todos + bump. * Ignore expensive test. * Bump.
63 lines
1.8 KiB
Rust
63 lines
1.8 KiB
Rust
// Copyright 2017-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Substrate is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// tag::description[]
|
|
//! Generic implementations of Extrinsic/Header/Block.
|
|
// end::description[]
|
|
|
|
mod unchecked_extrinsic;
|
|
mod era;
|
|
mod checked_extrinsic;
|
|
mod header;
|
|
mod block;
|
|
mod digest;
|
|
#[cfg(test)]
|
|
mod tests;
|
|
|
|
pub use self::unchecked_extrinsic::UncheckedExtrinsic;
|
|
pub use self::era::{Era, Phase};
|
|
pub use self::checked_extrinsic::CheckedExtrinsic;
|
|
pub use self::header::Header;
|
|
pub use self::block::{Block, SignedBlock, BlockId};
|
|
pub use self::digest::{
|
|
Digest, DigestItem, DigestItemRef, OpaqueDigestItemId
|
|
};
|
|
|
|
use crate::codec::Encode;
|
|
use rstd::prelude::*;
|
|
|
|
fn encode_with_vec_prefix<T: Encode, F: Fn(&mut Vec<u8>)>(encoder: F) -> Vec<u8> {
|
|
let size = ::rstd::mem::size_of::<T>();
|
|
let reserve = match size {
|
|
0..=0b00111111 => 1,
|
|
0..=0b00111111_11111111 => 2,
|
|
_ => 4,
|
|
};
|
|
let mut v = Vec::with_capacity(reserve + size);
|
|
v.resize(reserve, 0);
|
|
encoder(&mut v);
|
|
|
|
// need to prefix with the total length to ensure it's binary compatible with
|
|
// Vec<u8>.
|
|
let mut length: Vec<()> = Vec::new();
|
|
length.resize(v.len() - reserve, ());
|
|
length.using_encoded(|s| {
|
|
v.splice(0..reserve, s.iter().cloned());
|
|
});
|
|
|
|
v
|
|
}
|