aboutsummaryrefslogtreecommitdiff
path: root/stockton-render/src/texture/block.rs
diff options
context:
space:
mode:
Diffstat (limited to 'stockton-render/src/texture/block.rs')
-rw-r--r--stockton-render/src/texture/block.rs62
1 files changed, 0 insertions, 62 deletions
diff --git a/stockton-render/src/texture/block.rs b/stockton-render/src/texture/block.rs
deleted file mode 100644
index 5ac3a94..0000000
--- a/stockton-render/src/texture/block.rs
+++ /dev/null
@@ -1,62 +0,0 @@
-use super::{loader::BlockRef, repo::BLOCK_SIZE};
-use crate::types::*;
-
-use arrayvec::ArrayVec;
-use rendy_memory::{Allocator, Block};
-use std::{iter::once, mem::ManuallyDrop};
-
-pub struct TexturesBlock<B: Block<back::Backend>> {
- pub id: BlockRef,
- pub descriptor_set: ManuallyDrop<RDescriptorSet>,
- pub imgs: ArrayVec<[LoadedImage<B>; BLOCK_SIZE]>,
-}
-
-impl<B: Block<back::Backend>> TexturesBlock<B> {
- pub fn deactivate<T: Allocator<back::Backend, Block = B>>(
- mut self,
- device: &mut DeviceT,
- tex_alloc: &mut T,
- desc_alloc: &mut DescriptorAllocator,
- ) {
- unsafe {
- use std::ptr::read;
-
- // Descriptor set
- desc_alloc.free(once(read(&*self.descriptor_set)));
-
- // Images
- self.imgs
- .drain(..)
- .map(|x| x.deactivate(device, tex_alloc))
- .for_each(|_| {});
- }
- }
-}
-
-pub struct LoadedImage<B: Block<back::Backend>> {
- pub mem: ManuallyDrop<B>,
- pub img: ManuallyDrop<ImageT>,
- pub img_view: ManuallyDrop<ImageViewT>,
- pub sampler: ManuallyDrop<SamplerT>,
- pub row_size: usize,
- pub height: u32,
- pub width: u32,
-}
-
-impl<B: Block<back::Backend>> LoadedImage<B> {
- pub fn deactivate<T: Allocator<back::Backend, Block = B>>(
- self,
- device: &mut DeviceT,
- alloc: &mut T,
- ) {
- unsafe {
- use std::ptr::read;
-
- device.destroy_image_view(read(&*self.img_view));
- device.destroy_image(read(&*self.img));
- device.destroy_sampler(read(&*self.sampler));
-
- alloc.free(device, read(&*self.mem));
- }
- }
-}