mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 12:17:58 +00:00
002d9260f9
**Update:** Pushed additional changes based on the review comments. **This pull request fixes various spelling mistakes in this repository.** Most of the changes are contained in the first **3** commits: - `Fix spelling mistakes in comments and docs` - `Fix spelling mistakes in test names` - `Fix spelling mistakes in error messages, panic messages, logs and tracing` Other source code spelling mistakes are separated into individual commits for easier reviewing: - `Fix the spelling of 'authority'` - `Fix the spelling of 'REASONABLE_HEADERS_IN_JUSTIFICATION_ANCESTRY'` - `Fix the spelling of 'prev_enqueud_messages'` - `Fix the spelling of 'endpoint'` - `Fix the spelling of 'children'` - `Fix the spelling of 'PenpalSiblingSovereignAccount'` - `Fix the spelling of 'PenpalSudoAccount'` - `Fix the spelling of 'insufficient'` - `Fix the spelling of 'PalletXcmExtrinsicsBenchmark'` - `Fix the spelling of 'subtracted'` - `Fix the spelling of 'CandidatePendingAvailability'` - `Fix the spelling of 'exclusive'` - `Fix the spelling of 'until'` - `Fix the spelling of 'discriminator'` - `Fix the spelling of 'nonexistent'` - `Fix the spelling of 'subsystem'` - `Fix the spelling of 'indices'` - `Fix the spelling of 'committed'` - `Fix the spelling of 'topology'` - `Fix the spelling of 'response'` - `Fix the spelling of 'beneficiary'` - `Fix the spelling of 'formatted'` - `Fix the spelling of 'UNKNOWN_PROOF_REQUEST'` - `Fix the spelling of 'succeeded'` - `Fix the spelling of 'reopened'` - `Fix the spelling of 'proposer'` - `Fix the spelling of 'InstantiationNonce'` - `Fix the spelling of 'depositor'` - `Fix the spelling of 'expiration'` - `Fix the spelling of 'phantom'` - `Fix the spelling of 'AggregatedKeyValue'` - `Fix the spelling of 'randomness'` - `Fix the spelling of 'defendant'` - `Fix the spelling of 'AquaticMammal'` - `Fix the spelling of 'transactions'` - `Fix the spelling of 'PassingTracingSubscriber'` - `Fix the spelling of 'TxSignaturePayload'` - `Fix the spelling of 'versioning'` - `Fix the spelling of 'descendant'` - `Fix the spelling of 'overridden'` - `Fix the spelling of 'network'` Let me know if this structure is adequate. **Note:** The usage of the words `Merkle`, `Merkelize`, `Merklization`, `Merkelization`, `Merkleization`, is somewhat inconsistent but I left it as it is. ~~**Note:** In some places the term `Receival` is used to refer to message reception, IMO `Reception` is the correct word here, but I left it as it is.~~ ~~**Note:** In some places the term `Overlayed` is used instead of the more acceptable version `Overlaid` but I also left it as it is.~~ ~~**Note:** In some places the term `Applyable` is used instead of the correct version `Applicable` but I also left it as it is.~~ **Note:** Some usage of British vs American english e.g. `judgement` vs `judgment`, `initialise` vs `initialize`, `optimise` vs `optimize` etc. are both present in different places, but I suppose that's understandable given the number of contributors. ~~**Note:** There is a spelling mistake in `.github/CODEOWNERS` but it triggers errors in CI when I make changes to it, so I left it as it is.~~
205 lines
5.3 KiB
Rust
205 lines
5.3 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0
|
|
|
|
// This program 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.
|
|
|
|
// This program 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 this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
//! Rust executor possible errors.
|
|
|
|
/// Result type alias.
|
|
pub type Result<T> = std::result::Result<T, Error>;
|
|
|
|
/// Error type.
|
|
#[derive(Debug, thiserror::Error)]
|
|
#[allow(missing_docs)]
|
|
pub enum Error {
|
|
#[error("Error calling api function: {0}")]
|
|
ApiError(Box<dyn std::error::Error + Send + Sync>),
|
|
|
|
#[error("Method not found: '{0}'")]
|
|
MethodNotFound(String),
|
|
|
|
#[error("On-chain runtime does not specify version")]
|
|
VersionInvalid,
|
|
|
|
#[error("Externalities error")]
|
|
Externalities,
|
|
|
|
#[error("Invalid index provided")]
|
|
InvalidIndex,
|
|
|
|
#[error("Invalid type returned (should be u64)")]
|
|
InvalidReturn,
|
|
|
|
#[error("Runtime panicked: {0}")]
|
|
RuntimePanicked(String),
|
|
|
|
#[error("Invalid memory reference")]
|
|
InvalidMemoryReference,
|
|
|
|
#[error("The runtime doesn't provide a global named `__heap_base` of type `i32`")]
|
|
HeapBaseNotFoundOrInvalid,
|
|
|
|
#[error("The runtime must not have the `start` function defined")]
|
|
RuntimeHasStartFn,
|
|
|
|
#[error("Other: {0}")]
|
|
Other(String),
|
|
|
|
#[error(transparent)]
|
|
Allocator(#[from] sc_allocator::Error),
|
|
|
|
#[error("Host function {0} execution failed with: {1}")]
|
|
FunctionExecution(String, String),
|
|
|
|
#[error("No table exported by wasm blob")]
|
|
NoTable,
|
|
|
|
#[error("No table entry with index {0} in wasm blob exported table")]
|
|
NoTableEntryWithIndex(u32),
|
|
|
|
#[error("Table element with index {0} is not a function in wasm blob exported table")]
|
|
TableElementIsNotAFunction(u32),
|
|
|
|
#[error("Table entry with index {0} in wasm blob is null")]
|
|
FunctionRefIsNull(u32),
|
|
|
|
#[error(transparent)]
|
|
RuntimeConstruction(#[from] WasmError),
|
|
|
|
#[error("Shared memory is not supported")]
|
|
SharedMemUnsupported,
|
|
|
|
#[error("Imported globals are not supported yet")]
|
|
ImportedGlobalsUnsupported,
|
|
|
|
#[error("initializer expression can have only up to 2 expressions in wasm 1.0")]
|
|
InitializerHasTooManyExpressions,
|
|
|
|
#[error("Invalid initializer expression provided {0}")]
|
|
InvalidInitializerExpression(String),
|
|
|
|
#[error("Execution aborted due to panic: {0}")]
|
|
AbortedDueToPanic(MessageWithBacktrace),
|
|
|
|
#[error("Execution aborted due to trap: {0}")]
|
|
AbortedDueToTrap(MessageWithBacktrace),
|
|
|
|
#[error("Output exceeds bounds of wasm memory")]
|
|
OutputExceedsBounds,
|
|
}
|
|
|
|
impl From<&'static str> for Error {
|
|
fn from(err: &'static str) -> Error {
|
|
Error::Other(err.into())
|
|
}
|
|
}
|
|
|
|
impl From<String> for Error {
|
|
fn from(err: String) -> Error {
|
|
Error::Other(err)
|
|
}
|
|
}
|
|
|
|
/// Type for errors occurring during Wasm runtime construction.
|
|
#[derive(Debug, thiserror::Error)]
|
|
#[allow(missing_docs)]
|
|
pub enum WasmError {
|
|
#[error("Code could not be read from the state.")]
|
|
CodeNotFound,
|
|
|
|
#[error("Failure to reinitialize runtime instance from snapshot.")]
|
|
ApplySnapshotFailed,
|
|
|
|
/// Failure to erase the wasm memory.
|
|
///
|
|
/// Depending on the implementation might mean failure of allocating memory.
|
|
#[error("Failure to erase the wasm memory: {0}")]
|
|
ErasingFailed(String),
|
|
|
|
#[error("Wasm code failed validation.")]
|
|
InvalidModule,
|
|
|
|
#[error("Wasm code could not be deserialized.")]
|
|
CantDeserializeWasm,
|
|
|
|
#[error("The module does not export a linear memory named `memory`.")]
|
|
InvalidMemory,
|
|
|
|
#[error("The number of heap pages requested is disallowed by the module.")]
|
|
InvalidHeapPages,
|
|
|
|
/// Instantiation error.
|
|
#[error("{0}")]
|
|
Instantiation(String),
|
|
|
|
/// Other error happened.
|
|
#[error("Other error happened while constructing the runtime: {0}")]
|
|
Other(String),
|
|
}
|
|
|
|
impl From<polkavm::ProgramParseError> for WasmError {
|
|
fn from(error: polkavm::ProgramParseError) -> Self {
|
|
WasmError::Other(error.to_string())
|
|
}
|
|
}
|
|
|
|
impl From<polkavm::Error> for WasmError {
|
|
fn from(error: polkavm::Error) -> Self {
|
|
WasmError::Other(error.to_string())
|
|
}
|
|
}
|
|
|
|
impl From<polkavm::Error> for Error {
|
|
fn from(error: polkavm::Error) -> Self {
|
|
Error::Other(error.to_string())
|
|
}
|
|
}
|
|
|
|
/// An error message with an attached backtrace.
|
|
#[derive(Debug)]
|
|
pub struct MessageWithBacktrace {
|
|
/// The error message.
|
|
pub message: String,
|
|
|
|
/// The backtrace associated with the error message.
|
|
pub backtrace: Option<Backtrace>,
|
|
}
|
|
|
|
impl std::fmt::Display for MessageWithBacktrace {
|
|
fn fmt(&self, fmt: &mut std::fmt::Formatter) -> std::fmt::Result {
|
|
fmt.write_str(&self.message)?;
|
|
if let Some(ref backtrace) = self.backtrace {
|
|
fmt.write_str("\nWASM backtrace:\n")?;
|
|
backtrace.backtrace_string.fmt(fmt)?;
|
|
}
|
|
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
/// A WASM backtrace.
|
|
#[derive(Debug)]
|
|
pub struct Backtrace {
|
|
/// The string containing the backtrace.
|
|
pub backtrace_string: String,
|
|
}
|
|
|
|
impl std::fmt::Display for Backtrace {
|
|
fn fmt(&self, fmt: &mut std::fmt::Formatter) -> std::fmt::Result {
|
|
fmt.write_str(&self.backtrace_string)
|
|
}
|
|
}
|