mirror of
https://git.citron-emu.org/Citron/Citron.git
synced 2025-01-24 17:47:02 +01:00
renderer_vulkan/wrapper: Add destroy and free overload set
This commit is contained in:
parent
a9e4528d10
commit
60f351084a
2 changed files with 133 additions and 0 deletions
|
@ -234,4 +234,109 @@ const char* ToString(VkResult result) noexcept {
|
||||||
return "Unknown";
|
return "Unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Destroy(VkInstance instance, const InstanceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyInstance(instance, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, const InstanceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyDevice(device, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkBuffer handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyBuffer(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkBufferView handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyBufferView(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkCommandPool handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyCommandPool(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkDescriptorPool handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyDescriptorPool(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkDescriptorSetLayout handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyDescriptorSetLayout(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkDescriptorUpdateTemplateKHR handle,
|
||||||
|
const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyDescriptorUpdateTemplateKHR(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkDeviceMemory handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkFreeMemory(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkFence handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyFence(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkFramebuffer handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyFramebuffer(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkImage handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyImage(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkImageView handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyImageView(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkPipeline handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyPipeline(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkPipelineLayout handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyPipelineLayout(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkQueryPool handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyQueryPool(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkRenderPass handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyRenderPass(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkSampler handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroySampler(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkSwapchainKHR handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroySwapchainKHR(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkSemaphore handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroySemaphore(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkDevice device, VkShaderModule handle, const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyShaderModule(device, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkInstance instance, VkDebugUtilsMessengerEXT handle,
|
||||||
|
const InstanceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroyDebugUtilsMessengerEXT(instance, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Destroy(VkInstance instance, VkSurfaceKHR handle, const InstanceDispatch& dld) noexcept {
|
||||||
|
dld.vkDestroySurfaceKHR(instance, handle, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
VkResult Free(VkDevice device, VkDescriptorPool handle, Span<VkDescriptorSet> sets,
|
||||||
|
const DeviceDispatch& dld) noexcept {
|
||||||
|
return dld.vkFreeDescriptorSets(device, handle, sets.size(), sets.data());
|
||||||
|
}
|
||||||
|
|
||||||
|
VkResult Free(VkDevice device, VkCommandPool handle, Span<VkCommandBuffer> buffers,
|
||||||
|
const DeviceDispatch& dld) noexcept {
|
||||||
|
dld.vkFreeCommandBuffers(device, handle, buffers.size(), buffers.data());
|
||||||
|
return VK_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Vulkan::vk
|
} // namespace Vulkan::vk
|
||||||
|
|
|
@ -250,4 +250,32 @@ bool Load(InstanceDispatch&) noexcept;
|
||||||
/// @return True on success, false on error.
|
/// @return True on success, false on error.
|
||||||
bool Load(VkInstance, InstanceDispatch&) noexcept;
|
bool Load(VkInstance, InstanceDispatch&) noexcept;
|
||||||
|
|
||||||
|
void Destroy(VkInstance, const InstanceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, const InstanceDispatch&) noexcept;
|
||||||
|
|
||||||
|
void Destroy(VkDevice, VkBuffer, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkBufferView, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkCommandPool, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkDescriptorPool, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkDescriptorSetLayout, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkDescriptorUpdateTemplateKHR, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkDeviceMemory, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkFence, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkFramebuffer, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkImage, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkImageView, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkPipeline, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkPipelineLayout, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkQueryPool, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkRenderPass, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkSampler, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkSwapchainKHR, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkSemaphore, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkDevice, VkShaderModule, const DeviceDispatch&) noexcept;
|
||||||
|
void Destroy(VkInstance, VkDebugUtilsMessengerEXT, const InstanceDispatch&) noexcept;
|
||||||
|
void Destroy(VkInstance, VkSurfaceKHR, const InstanceDispatch&) noexcept;
|
||||||
|
|
||||||
|
VkResult Free(VkDevice, VkDescriptorPool, Span<VkDescriptorSet>, const DeviceDispatch&) noexcept;
|
||||||
|
VkResult Free(VkDevice, VkCommandPool, Span<VkCommandBuffer>, const DeviceDispatch&) noexcept;
|
||||||
|
|
||||||
} // namespace Vulkan::vk
|
} // namespace Vulkan::vk
|
||||||
|
|
Loading…
Reference in a new issue