mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 20:27:58 +00:00
Renaming and documentation for ApplyResult, ApplyOutcome and et al (#4134)
* Remove superflous errors from the system module * Rename and document InclusionOutcome * Rename InclusionError * Remove unused inclusion errors. I left the enumeration though since other elements might be used some day. * Rename and document DispatchOutcome * Apply suggestions from code review Co-Authored-By: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * TransactionValidityError instead of InclusionError * Rename InclusionOutcome to ApplyExtrinsicResult * Update docs. * Update lib.rs should be → is * Bump the block builder API version. * Fix the should_return_runtime_version test * Clean the evidence
This commit is contained in:
@@ -8,12 +8,14 @@ edition = "2018"
|
||||
sr-primitives = { path = "../../sr-primitives", default-features = false }
|
||||
sr-api = { path = "../../sr-api", default-features = false }
|
||||
rstd = { package = "sr-std", path = "../../sr-std", default-features = false }
|
||||
codec = { package = "parity-scale-codec", version = "1.0.6", default-features = false }
|
||||
inherents = { package = "substrate-inherents", path = "../../inherents", default-features = false }
|
||||
|
||||
[features]
|
||||
default = [ "std" ]
|
||||
std = [
|
||||
"sr-primitives/std",
|
||||
"codec/std",
|
||||
"inherents/std",
|
||||
"sr-api/std",
|
||||
"rstd/std",
|
||||
|
||||
@@ -18,16 +18,46 @@
|
||||
|
||||
#![cfg_attr(not(feature = "std"), no_std)]
|
||||
|
||||
use sr_primitives::{traits::Block as BlockT, ApplyResult};
|
||||
use sr_primitives::{traits::Block as BlockT, ApplyExtrinsicResult};
|
||||
|
||||
use inherents::{InherentData, CheckInherentsResult};
|
||||
|
||||
/// Definitions for supporting the older version of API: v3
|
||||
///
|
||||
/// These definitions are taken from the 2c58e30246a029b53d51e5b24c31974ac539ee8b git revision.
|
||||
#[deprecated(note = "These definitions here are only for compatibility reasons")]
|
||||
pub mod compatability_v3 {
|
||||
use sr_primitives::{DispatchOutcome, transaction_validity};
|
||||
use codec::{Encode, Decode};
|
||||
|
||||
#[derive(Eq, PartialEq, Clone, Copy, Decode, Encode, Debug)]
|
||||
pub enum ApplyError {
|
||||
NoPermission,
|
||||
BadState,
|
||||
Validity(transaction_validity::TransactionValidityError),
|
||||
}
|
||||
|
||||
// `ApplyOutcome` was renamed to `DispatchOutcome` with the layout preserved.
|
||||
pub type ApplyResult = Result<DispatchOutcome, ApplyError>;
|
||||
}
|
||||
|
||||
sr_api::decl_runtime_apis! {
|
||||
/// The `BlockBuilder` api trait that provides the required functionality for building a block.
|
||||
#[api_version(3)]
|
||||
#[api_version(4)]
|
||||
pub trait BlockBuilder {
|
||||
/// Apply the given extrinsics.
|
||||
fn apply_extrinsic(extrinsic: <Block as BlockT>::Extrinsic) -> ApplyResult;
|
||||
/// Compatibility version of `apply_extrinsic` for v3.
|
||||
///
|
||||
/// Only the return type is changed.
|
||||
#[changed_in(4)]
|
||||
#[allow(deprecated)]
|
||||
fn apply_extrinsic(extrinsic: <Block as BlockT>::Extrinsic)
|
||||
-> self::compatability_v3::ApplyResult;
|
||||
|
||||
/// Apply the given extrinsic.
|
||||
///
|
||||
/// Returns an inclusion outcome which specifies if this extrinsic is included in
|
||||
/// this block or not.
|
||||
fn apply_extrinsic(extrinsic: <Block as BlockT>::Extrinsic) -> ApplyExtrinsicResult;
|
||||
/// Finish the current block.
|
||||
#[renamed("finalise_block", 3)]
|
||||
fn finalize_block() -> <Block as BlockT>::Header;
|
||||
|
||||
Reference in New Issue
Block a user