From 53824939af2f7ecb611a445ea773019f7ac8434f Mon Sep 17 00:00:00 2001 From: bjorn3 <17426603+bjorn3@users.noreply.github.com> Date: Wed, 11 Dec 2024 13:17:00 +0100 Subject: [PATCH] Fix the rust allocator when std is not used --- libbz2-rs-sys/src/allocator.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/libbz2-rs-sys/src/allocator.rs b/libbz2-rs-sys/src/allocator.rs index ed165cea2..1347a822d 100644 --- a/libbz2-rs-sys/src/allocator.rs +++ b/libbz2-rs-sys/src/allocator.rs @@ -12,6 +12,10 @@ //! the layout of an allocation to deallocate it, and C interfaces don't usually provide this //! information. Luckily in the library we know in all cases how big the allocation was at the //! point where we deallocate it. + +#[cfg(feature = "rust-allocator")] +extern crate alloc; + use core::ffi::{c_int, c_void}; use crate::bzlib::{BzStream, StreamState}; @@ -148,7 +152,7 @@ impl Allocator { #[cfg(feature = "rust-allocator")] Allocator::Rust => { let layout = core::alloc::Layout::array::(count).unwrap(); - let ptr = unsafe { std::alloc::alloc_zeroed(layout) }; + let ptr = unsafe { alloc::alloc::alloc_zeroed(layout) }; (!ptr.is_null()).then_some(ptr.cast()) } #[cfg(feature = "c-allocator")] @@ -182,7 +186,7 @@ impl Allocator { #[cfg(feature = "rust-allocator")] Allocator::Rust => { let layout = core::alloc::Layout::array::(count).unwrap(); - unsafe { std::alloc::dealloc(ptr.cast(), layout) } + unsafe { alloc::alloc::dealloc(ptr.cast(), layout) } } #[cfg(feature = "c-allocator")] Allocator::C => {