multiversx_sc/storage/
storage_key.rsuse unwrap_infallible::UnwrapInfallible;
use crate::{
api::{ErrorApi, ManagedTypeApi},
codec::*,
contract_base::ExitCodecErrorHandler,
types::{heap::BoxedBytes, ManagedBuffer, ManagedByteArray, ManagedType},
*,
};
pub struct StorageKey<A>
where
A: ManagedTypeApi + ErrorApi + 'static,
{
pub(crate) buffer: ManagedBuffer<A>,
}
impl<A> ManagedType<A> for StorageKey<A>
where
A: ManagedTypeApi + ErrorApi + 'static,
{
type OwnHandle = A::ManagedBufferHandle;
#[inline]
unsafe fn from_handle(handle: A::ManagedBufferHandle) -> Self {
StorageKey {
buffer: ManagedBuffer::from_handle(handle),
}
}
fn get_handle(&self) -> A::ManagedBufferHandle {
self.buffer.get_handle()
}
unsafe fn forget_into_handle(self) -> Self::OwnHandle {
self.buffer.forget_into_handle()
}
fn transmute_from_handle_ref(handle_ref: &A::ManagedBufferHandle) -> &Self {
unsafe { core::mem::transmute(handle_ref) }
}
fn transmute_from_handle_ref_mut(handle_ref: &mut A::ManagedBufferHandle) -> &mut Self {
unsafe { core::mem::transmute(handle_ref) }
}
}
impl<A> StorageKey<A>
where
A: ManagedTypeApi + ErrorApi + 'static,
{
#[inline]
pub fn new(base_key: &[u8]) -> Self {
StorageKey {
buffer: ManagedBuffer::new_from_bytes(base_key),
}
}
#[inline]
pub fn append_bytes(&mut self, bytes: &[u8]) {
self.buffer.append_bytes(bytes);
}
#[inline]
pub fn append_managed_buffer(&mut self, buffer: &ManagedBuffer<A>) {
self.buffer.append(buffer);
}
pub fn append_item<T>(&mut self, item: &T)
where
T: NestedEncode,
{
item.dep_encode_or_handle_err(
&mut self.buffer,
ExitCodecErrorHandler::<A>::from(err_msg::STORAGE_KEY_ENCODE_ERROR),
)
.unwrap_infallible()
}
#[inline]
pub fn to_boxed_bytes(&self) -> BoxedBytes {
self.buffer.to_boxed_bytes()
}
}
impl<M: ManagedTypeApi> From<ManagedBuffer<M>> for StorageKey<M> {
#[inline]
fn from(buffer: ManagedBuffer<M>) -> Self {
StorageKey { buffer }
}
}
impl<M: ManagedTypeApi> From<&str> for StorageKey<M> {
#[inline]
fn from(s: &str) -> Self {
StorageKey {
buffer: ManagedBuffer::from(s),
}
}
}
impl<M, const N: usize> From<ManagedByteArray<M, N>> for StorageKey<M>
where
M: ManagedTypeApi + ErrorApi,
{
#[inline]
fn from(mba: ManagedByteArray<M, N>) -> Self {
StorageKey { buffer: mba.buffer }
}
}
impl<M: ManagedTypeApi> Clone for StorageKey<M> {
fn clone(&self) -> Self {
StorageKey {
buffer: self.buffer.clone(),
}
}
}