mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 00:28:01 +00:00
a0cb14aa4f
* start migrating, broken * first iteration of updating * fmt and clippy * add Composite<u32> decoding via scale value patch * bump scale type gen versions * fix decoding with new scale decode * compiling with changed deps * core utils, condig, client, metadata * core crate compiling * signer crate no once lock * add core to no-std-tests, change imports * broken commit, start pulling everything together in subxt * port more things to subxt * events in core crate, extrinsics sadly much more difficult * almost all examples pass again * dynamic values fix in examples * fix no std issue and fmt * remove unused dependencies * fix lightclient impl * runtime version refactor * formatting and addressing nits * more comments addressed * update wasm example and no-std-signer tests * other nits and error impl on signer errors * fix feature flag * fix runtime version refactor * fix doc links * fix integration tests * fix feature flag gated client state * fix native feature in CI * fix lightclient utils * make imports more lean in subxt-core * integrate changes from subxt-core imports into subxt * other changes in subxt simplify imports more * fix and docs * doc false for cli * fix clippy * remove events block hash in tests * codegen no-std support in generated code * export alloc crate for no-std codegen * fix doc test * implement James comments * remove std traits, use core traits instead * address nits * remove unusued dep in no-std tests * fix Box import in no_std * sp-crypto-hashing instead of sp-core-hashing * bump scale-typegen, add no std codegen tests * fix some things * replace unmaintained derivative with derive_where to remove non-canonical warnings * fmt * remove unused dep * fix deps * update artifacts to fix type ID mismatches * bump to latest scale-typegen --------- Co-authored-by: James Wilson <james@jsdw.me>
53 lines
1.6 KiB
Rust
53 lines
1.6 KiB
Rust
// Copyright 2019-2023 Parity Technologies (UK) Ltd.
|
|
// This file is dual-licensed as Apache-2.0 or GPL-3.0.
|
|
// see LICENSE for license details.
|
|
|
|
use super::Metadata;
|
|
|
|
use alloc::vec::Vec;
|
|
|
|
/// This trait is implemented for all types that also implement [`scale_decode::DecodeAsType`].
|
|
pub trait DecodeWithMetadata: Sized {
|
|
/// Given some metadata and a type ID, attempt to SCALE decode the provided bytes into `Self`.
|
|
fn decode_with_metadata(
|
|
bytes: &mut &[u8],
|
|
type_id: u32,
|
|
metadata: &Metadata,
|
|
) -> Result<Self, scale_decode::Error>;
|
|
}
|
|
|
|
impl<T: scale_decode::DecodeAsType> DecodeWithMetadata for T {
|
|
fn decode_with_metadata(
|
|
bytes: &mut &[u8],
|
|
type_id: u32,
|
|
metadata: &Metadata,
|
|
) -> Result<T, scale_decode::Error> {
|
|
let val = T::decode_as_type(bytes, &type_id, metadata.types())?;
|
|
Ok(val)
|
|
}
|
|
}
|
|
|
|
/// This trait is implemented for all types that also implement [`scale_encode::EncodeAsType`].
|
|
pub trait EncodeWithMetadata {
|
|
/// SCALE encode this type to bytes, possibly with the help of metadata.
|
|
fn encode_with_metadata(
|
|
&self,
|
|
type_id: u32,
|
|
metadata: &Metadata,
|
|
bytes: &mut Vec<u8>,
|
|
) -> Result<(), scale_encode::Error>;
|
|
}
|
|
|
|
impl<T: scale_encode::EncodeAsType> EncodeWithMetadata for T {
|
|
/// SCALE encode this type to bytes, possibly with the help of metadata.
|
|
fn encode_with_metadata(
|
|
&self,
|
|
type_id: u32,
|
|
metadata: &Metadata,
|
|
bytes: &mut Vec<u8>,
|
|
) -> Result<(), scale_encode::Error> {
|
|
self.encode_as_type_to(&type_id, metadata.types(), bytes)?;
|
|
Ok(())
|
|
}
|
|
}
|