snapshot before rebranding

This commit is contained in:
2025-12-14 07:37:21 +03:00
parent 5520d491a5
commit 09735eb97a
1752 changed files with 58116 additions and 15986 deletions
+208
View File
@@ -0,0 +1,208 @@
// Copyright (C) Parity Technologies (UK) Ltd.
// This file is part of Pezkuwi.
// Pezkuwi 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.
// Pezkuwi 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 Pezkuwi. If not, see <http://www.gnu.org/licenses/>.
//! Errors for the XCM pallet.
use codec::{Decode, DecodeWithMemTracking, Encode};
use pezframe_support::PalletError;
use scale_info::TypeInfo;
use xcm::latest::Error as XcmError;
#[derive(
Copy, Clone, Encode, Decode, DecodeWithMemTracking, Eq, PartialEq, Debug, TypeInfo, PalletError,
)]
pub enum ExecutionError {
// Errors that happen due to instructions being executed. These alone are defined in the
// XCM specification.
/// An arithmetic overflow happened.
#[codec(index = 0)]
Overflow,
/// The instruction is intentionally unsupported.
#[codec(index = 1)]
Unimplemented,
/// Origin Register does not contain a value value for a reserve transfer notification.
#[codec(index = 2)]
UntrustedReserveLocation,
/// Origin Register does not contain a value value for a teleport notification.
#[codec(index = 3)]
UntrustedTeleportLocation,
/// `MultiLocation` value too large to descend further.
#[codec(index = 4)]
LocationFull,
/// `MultiLocation` value ascend more parents than known ancestors of local location.
#[codec(index = 5)]
LocationNotInvertible,
/// The Origin Register does not contain a valid value for instruction.
#[codec(index = 6)]
BadOrigin,
/// The location parameter is not a valid value for the instruction.
#[codec(index = 7)]
InvalidLocation,
/// The given asset is not handled.
#[codec(index = 8)]
AssetNotFound,
/// An asset transaction (like withdraw or deposit) failed (typically due to type conversions).
#[codec(index = 9)]
FailedToTransactAsset,
/// An asset cannot be withdrawn, potentially due to lack of ownership, availability or rights.
#[codec(index = 10)]
NotWithdrawable,
/// An asset cannot be deposited under the ownership of a particular location.
#[codec(index = 11)]
LocationCannotHold,
/// Attempt to send a message greater than the maximum supported by the transport protocol.
#[codec(index = 12)]
ExceedsMaxMessageSize,
/// The given message cannot be translated into a format supported by the destination.
#[codec(index = 13)]
DestinationUnsupported,
/// Destination is routable, but there is some issue with the transport mechanism.
#[codec(index = 14)]
Transport,
/// Destination is known to be unroutable.
#[codec(index = 15)]
Unroutable,
/// Used by `ClaimAsset` when the given claim could not be recognized/found.
#[codec(index = 16)]
UnknownClaim,
/// Used by `Transact` when the functor cannot be decoded.
#[codec(index = 17)]
FailedToDecode,
/// Used by `Transact` to indicate that the given weight limit could be breached by the
/// functor.
#[codec(index = 18)]
MaxWeightInvalid,
/// Used by `BuyExecution` when the Holding Register does not contain payable fees.
#[codec(index = 19)]
NotHoldingFees,
/// Used by `BuyExecution` when the fees declared to purchase weight are insufficient.
#[codec(index = 20)]
TooExpensive,
/// Used by the `Trap` instruction to force an error intentionally. Its code is included.
#[codec(index = 21)]
Trap,
/// Used by `ExpectAsset`, `ExpectError` and `ExpectOrigin` when the expectation was not true.
#[codec(index = 22)]
ExpectationFalse,
/// The provided pallet index was not found.
#[codec(index = 23)]
PalletNotFound,
/// The given pallet's name is different to that expected.
#[codec(index = 24)]
NameMismatch,
/// The given pallet's version has an incompatible version to that expected.
#[codec(index = 25)]
VersionIncompatible,
/// The given operation would lead to an overflow of the Holding Register.
#[codec(index = 26)]
HoldingWouldOverflow,
/// The message was unable to be exported.
#[codec(index = 27)]
ExportError,
/// `MultiLocation` value failed to be reanchored.
#[codec(index = 28)]
ReanchorFailed,
/// No deal is possible under the given constraints.
#[codec(index = 29)]
NoDeal,
/// Fees were required which the origin could not pay.
#[codec(index = 30)]
FeesNotMet,
/// Some other error with locking.
#[codec(index = 31)]
LockError,
/// The state was not in a condition where the operation was valid to make.
#[codec(index = 32)]
NoPermission,
/// The universal location of the local consensus is improper.
#[codec(index = 33)]
Unanchored,
/// An asset cannot be deposited, probably because (too much of) it already exists.
#[codec(index = 34)]
NotDepositable,
/// Too many assets matched the given asset filter.
#[codec(index = 35)]
TooManyAssets,
// Errors that happen prior to instructions being executed. These fall outside of the XCM
// spec.
/// XCM version not able to be handled.
UnhandledXcmVersion,
/// Execution of the XCM would potentially result in a greater weight used than weight limit.
WeightLimitReached,
/// The XCM did not pass the barrier condition for execution.
///
/// The barrier condition differs on different chains and in different circumstances, but
/// generally it means that the conditions surrounding the message were not such that the chain
/// considers the message worth spending time executing. Since most chains lift the barrier to
/// execution on appropriate payment, presentation of an NFT voucher, or based on the message
/// origin, it means that none of those were the case.
Barrier,
/// The weight of an XCM message is not computable ahead of execution.
WeightNotComputable,
/// Recursion stack limit reached
// TODO(https://github.com/pezkuwichain/pezkuwi-sdk/issues/148): This should have a fixed index since
// we use it in `FrameTransactionalProcessor` // which is used in instructions.
// Or we should create a different error for that.
ExceedsStackLimit,
}
impl From<XcmError> for ExecutionError {
fn from(error: XcmError) -> Self {
match error {
XcmError::Overflow => Self::Overflow,
XcmError::Unimplemented => Self::Unimplemented,
XcmError::UntrustedReserveLocation => Self::UntrustedReserveLocation,
XcmError::UntrustedTeleportLocation => Self::UntrustedTeleportLocation,
XcmError::LocationFull => Self::LocationFull,
XcmError::LocationNotInvertible => Self::LocationNotInvertible,
XcmError::BadOrigin => Self::BadOrigin,
XcmError::InvalidLocation => Self::InvalidLocation,
XcmError::AssetNotFound => Self::AssetNotFound,
XcmError::FailedToTransactAsset(_) => Self::FailedToTransactAsset,
XcmError::NotWithdrawable => Self::NotWithdrawable,
XcmError::LocationCannotHold => Self::LocationCannotHold,
XcmError::ExceedsMaxMessageSize => Self::ExceedsMaxMessageSize,
XcmError::DestinationUnsupported => Self::DestinationUnsupported,
XcmError::Transport(_) => Self::Transport,
XcmError::Unroutable => Self::Unroutable,
XcmError::UnknownClaim => Self::UnknownClaim,
XcmError::FailedToDecode => Self::FailedToDecode,
XcmError::MaxWeightInvalid => Self::MaxWeightInvalid,
XcmError::NotHoldingFees => Self::NotHoldingFees,
XcmError::TooExpensive => Self::TooExpensive,
XcmError::Trap(_) => Self::Trap,
XcmError::ExpectationFalse => Self::ExpectationFalse,
XcmError::PalletNotFound => Self::PalletNotFound,
XcmError::NameMismatch => Self::NameMismatch,
XcmError::VersionIncompatible => Self::VersionIncompatible,
XcmError::HoldingWouldOverflow => Self::HoldingWouldOverflow,
XcmError::ExportError => Self::ExportError,
XcmError::ReanchorFailed => Self::ReanchorFailed,
XcmError::NoDeal => Self::NoDeal,
XcmError::FeesNotMet => Self::FeesNotMet,
XcmError::LockError => Self::LockError,
XcmError::NoPermission => Self::NoPermission,
XcmError::Unanchored => Self::Unanchored,
XcmError::NotDepositable => Self::NotDepositable,
XcmError::TooManyAssets => Self::TooManyAssets,
XcmError::UnhandledXcmVersion => Self::UnhandledXcmVersion,
XcmError::WeightLimitReached(_) => Self::WeightLimitReached,
XcmError::Barrier => Self::Barrier,
XcmError::WeightNotComputable => Self::WeightNotComputable,
XcmError::ExceedsStackLimit => Self::ExceedsStackLimit,
}
}
}